@siemens/ix 0.0.0-v4-next-20251103080000 → 0.0.0-v4-next-20251105155052

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 (809) hide show
  1. package/components/index.js +4 -4
  2. package/components/ix-action-card.js +4 -4
  3. package/components/ix-application-header.js +263 -1
  4. package/components/ix-application-header.js.map +1 -1
  5. package/components/ix-application-sidebar.js +1 -1
  6. package/components/ix-application-switch-modal.js +8 -8
  7. package/components/ix-application.js +5 -7
  8. package/components/ix-application.js.map +1 -1
  9. package/components/ix-avatar.js +1 -1
  10. package/components/ix-blind.js +8 -8
  11. package/components/ix-breadcrumb-item.js +1 -1
  12. package/components/ix-breadcrumb.js +7 -7
  13. package/components/ix-button.js +1 -1
  14. package/components/ix-card-accordion.js +1 -1
  15. package/components/ix-card-content.js +1 -1
  16. package/components/ix-card-list.js +12 -12
  17. package/components/ix-card-title.js +1 -1
  18. package/components/ix-card.js +1 -1
  19. package/components/ix-category-filter.js +10 -10
  20. package/components/ix-checkbox-group.js +8 -8
  21. package/components/ix-checkbox.js +6 -6
  22. package/components/ix-chip.js +10 -10
  23. package/components/ix-col.js +1 -1
  24. package/components/ix-content-header.js +8 -8
  25. package/components/ix-content.js +4 -4
  26. package/components/ix-css-grid-item.js +2 -2
  27. package/components/ix-css-grid.js +2 -2
  28. package/components/ix-custom-field.js +7 -7
  29. package/components/ix-date-dropdown.js +16 -16
  30. package/components/ix-date-input.js +17 -17
  31. package/components/ix-date-picker.js +1 -1
  32. package/components/ix-date-time-card.js +1 -1
  33. package/components/ix-datetime-picker.js +13 -13
  34. package/components/ix-divider.js +1 -1
  35. package/components/ix-drawer.js +9 -9
  36. package/components/ix-dropdown-button.js +9 -9
  37. package/components/ix-dropdown-header.js +3 -3
  38. package/components/ix-dropdown-item.js +1 -1
  39. package/components/ix-dropdown-quick-actions.js +2 -2
  40. package/components/ix-dropdown.js +1 -1
  41. package/components/ix-empty-state.js +5 -5
  42. package/components/ix-event-list-item.js +6 -6
  43. package/components/ix-event-list.js +3 -3
  44. package/components/ix-expanding-search.js +8 -8
  45. package/components/ix-field-label.js +1 -1
  46. package/components/ix-field-wrapper.js +1 -1
  47. package/components/ix-filter-chip.js +1 -1
  48. package/components/ix-flip-tile-content.js +2 -2
  49. package/components/ix-flip-tile.js +7 -7
  50. package/components/ix-group-context-menu.js +1 -1
  51. package/components/ix-group-item.js +1 -1
  52. package/components/ix-group.js +14 -14
  53. package/components/ix-helper-text.js +5 -5
  54. package/components/ix-icon-button.js +1 -1
  55. package/components/ix-icon-toggle-button.js +4 -4
  56. package/components/ix-input-group.js +2 -2
  57. package/components/ix-input.js +14 -14
  58. package/components/ix-key-value-list.js +2 -2
  59. package/components/ix-key-value.js +2 -2
  60. package/components/ix-kpi.js +5 -5
  61. package/components/ix-layout-auto.js +2 -2
  62. package/components/ix-layout-grid.js +1 -1
  63. package/components/ix-link-button.js +5 -5
  64. package/components/ix-menu-about-item.js +2 -2
  65. package/components/ix-menu-about-news.js +10 -10
  66. package/components/ix-menu-about.js +6 -6
  67. package/components/ix-menu-avatar-item.js +1 -1
  68. package/components/ix-menu-avatar.js +12 -12
  69. package/components/ix-menu-category.js +14 -14
  70. package/components/ix-menu-expand-icon.js +1 -1
  71. package/components/ix-menu-item.js +1 -1
  72. package/components/ix-menu-settings-item.js +2 -2
  73. package/components/ix-menu-settings.js +1 -1
  74. package/components/ix-menu.js +22 -32
  75. package/components/ix-menu.js.map +1 -1
  76. package/components/ix-message-bar.js +5 -5
  77. package/components/ix-modal-content.js +1 -1
  78. package/components/ix-modal-footer.js +2 -2
  79. package/components/ix-modal-header.js +1 -1
  80. package/components/ix-modal-loading.js +3 -3
  81. package/components/ix-modal.js +5 -5
  82. package/components/ix-number-input.js +16 -16
  83. package/components/ix-pagination.js +17 -17
  84. package/components/ix-pane-layout.js +2 -2
  85. package/components/ix-pane.js +11 -11
  86. package/components/ix-pill.js +7 -7
  87. package/components/ix-progress-indicator.js +7 -7
  88. package/components/ix-push-card.js +7 -7
  89. package/components/ix-radio-group.js +8 -8
  90. package/components/ix-radio.js +7 -7
  91. package/components/ix-row.js +1 -1
  92. package/components/ix-select-item.js +1 -1
  93. package/components/ix-select.js +1 -1
  94. package/components/ix-slider.js +10 -10
  95. package/components/ix-spinner.js +1 -1
  96. package/components/ix-split-button.js +7 -7
  97. package/components/ix-tab-item.js +1 -1
  98. package/components/ix-tabs.js +1 -1
  99. package/components/ix-textarea.js +9 -9
  100. package/components/ix-tile.js +5 -5
  101. package/components/ix-time-input.js +17 -17
  102. package/components/ix-time-picker.js +1 -1
  103. package/components/ix-toast-container.js +7 -7
  104. package/components/ix-toast.js +1 -1
  105. package/components/ix-toggle-button.js +3 -3
  106. package/components/ix-toggle.js +6 -6
  107. package/components/ix-tooltip.js +1 -1
  108. package/components/ix-tree-item.js +1 -1
  109. package/components/ix-tree.js +3 -3
  110. package/components/ix-typography.js +1 -1
  111. package/components/ix-upload.js +7 -7
  112. package/components/ix-validation-tooltip.js +3 -3
  113. package/components/ix-workflow-step.js +5 -5
  114. package/components/ix-workflow-steps.js +2 -2
  115. package/components/{p-ciUqTzkB.js → p-7EBFmdVz.js} +6 -6
  116. package/components/{p-ciUqTzkB.js.map → p-7EBFmdVz.js.map} +1 -1
  117. package/components/{p-cw5RHost.js → p-B2u6MNTQ.js} +8 -8
  118. package/components/{p-cw5RHost.js.map → p-B2u6MNTQ.js.map} +1 -1
  119. package/components/{p-DOEb0lKA.js → p-B45tl2du.js} +4 -4
  120. package/components/{p-DOEb0lKA.js.map → p-B45tl2du.js.map} +1 -1
  121. package/components/{p-DgfGA7Z3.js → p-BD9N6Sgg.js} +4 -4
  122. package/components/{p-DgfGA7Z3.js.map → p-BD9N6Sgg.js.map} +1 -1
  123. package/components/{p-DsftMeEA.js → p-BGdI6-nv.js} +4 -4
  124. package/components/{p-DsftMeEA.js.map → p-BGdI6-nv.js.map} +1 -1
  125. package/components/{p-XiZWDi7n.js → p-BGjnKa2h.js} +4 -4
  126. package/components/{p-XiZWDi7n.js.map → p-BGjnKa2h.js.map} +1 -1
  127. package/components/{p-BxNzvWr2.js → p-BHcP7TVn.js} +5 -5
  128. package/components/{p-BxNzvWr2.js.map → p-BHcP7TVn.js.map} +1 -1
  129. package/components/{p-BNwXjBuF.js → p-BHkZn2Pd.js} +4 -4
  130. package/components/{p-BNwXjBuF.js.map → p-BHkZn2Pd.js.map} +1 -1
  131. package/components/{p-Qsbo2ls8.js → p-BQPcfjX0.js} +5 -5
  132. package/components/{p-Qsbo2ls8.js.map → p-BQPcfjX0.js.map} +1 -1
  133. package/components/{p-CO2zhw6V.js → p-BQk7HpA-.js} +3 -3
  134. package/components/{p-CO2zhw6V.js.map → p-BQk7HpA-.js.map} +1 -1
  135. package/components/{p-DzscKBhb.js → p-BUFjJUP2.js} +9 -9
  136. package/components/{p-DzscKBhb.js.map → p-BUFjJUP2.js.map} +1 -1
  137. package/components/{p-CJphMgA7.js → p-BVIuLGBo.js} +7 -7
  138. package/components/{p-CJphMgA7.js.map → p-BVIuLGBo.js.map} +1 -1
  139. package/components/{p--2LOMK-5.js → p-BhgW5qDm.js} +2 -3
  140. package/components/p-BhgW5qDm.js.map +1 -0
  141. package/components/{p-DcjRXRwg.js → p-BhmmDvui.js} +7 -7
  142. package/components/{p-DcjRXRwg.js.map → p-BhmmDvui.js.map} +1 -1
  143. package/components/{p-BaWdG-ph.js → p-Bn2uemGV.js} +8 -8
  144. package/components/{p-BaWdG-ph.js.map → p-Bn2uemGV.js.map} +1 -1
  145. package/components/{p-BWTF-D2w.js → p-BtDCIGt3.js} +4 -4
  146. package/components/{p-BWTF-D2w.js.map → p-BtDCIGt3.js.map} +1 -1
  147. package/components/{p-taILGXkr.js → p-BvsadYCu.js} +3 -3
  148. package/components/{p-taILGXkr.js.map → p-BvsadYCu.js.map} +1 -1
  149. package/components/{p-DeBhxnHo.js → p-CJA4iOtm.js} +8 -8
  150. package/components/{p-DeBhxnHo.js.map → p-CJA4iOtm.js.map} +1 -1
  151. package/components/{p-DBsESzrF.js → p-CJD0xZJW.js} +24 -24
  152. package/components/{p-DBsESzrF.js.map → p-CJD0xZJW.js.map} +1 -1
  153. package/components/{p-CFAI8dx_.js → p-CV_EVAOW.js} +3 -3
  154. package/components/{p-CFAI8dx_.js.map → p-CV_EVAOW.js.map} +1 -1
  155. package/components/{p-0MSWDTqB.js → p-ChFNWyCb.js} +4 -4
  156. package/components/{p-0MSWDTqB.js.map → p-ChFNWyCb.js.map} +1 -1
  157. package/components/{p-D_rmJU0n.js → p-CqRVA5i3.js} +15 -15
  158. package/components/{p-D_rmJU0n.js.map → p-CqRVA5i3.js.map} +1 -1
  159. package/components/{p-fahyavc3.js → p-CvF96Z51.js} +8 -8
  160. package/components/{p-fahyavc3.js.map → p-CvF96Z51.js.map} +1 -1
  161. package/components/{p-CtusOOtv.js → p-CwB-Yl7d.js} +6 -6
  162. package/components/{p-CtusOOtv.js.map → p-CwB-Yl7d.js.map} +1 -1
  163. package/components/{p-CKuNFgoe.js → p-D-__gyet.js} +3 -3
  164. package/components/{p-CKuNFgoe.js.map → p-D-__gyet.js.map} +1 -1
  165. package/components/{p-BvKUU6Ta.js → p-D6KzHh-w.js} +4 -4
  166. package/components/{p-BvKUU6Ta.js.map → p-D6KzHh-w.js.map} +1 -1
  167. package/components/{p-BUIOrNGz.js → p-DEgkyi1N.js} +6 -6
  168. package/components/{p-BUIOrNGz.js.map → p-DEgkyi1N.js.map} +1 -1
  169. package/components/{p-VMk3rl5y.js → p-DZHGeQ9B.js} +9 -9
  170. package/components/{p-VMk3rl5y.js.map → p-DZHGeQ9B.js.map} +1 -1
  171. package/components/{p-JUUSQc_M.js → p-D_4Mf9jE.js} +3 -3
  172. package/components/{p-JUUSQc_M.js.map → p-D_4Mf9jE.js.map} +1 -1
  173. package/components/{p-W_8b1-4d.js → p-DdLose3V.js} +3 -3
  174. package/components/{p-W_8b1-4d.js.map → p-DdLose3V.js.map} +1 -1
  175. package/components/{p-By1IU8iL.js → p-De0habf3.js} +5 -5
  176. package/components/{p-By1IU8iL.js.map → p-De0habf3.js.map} +1 -1
  177. package/components/{p-C6MbjoUl.js → p-Dh_lbOuZ.js} +8 -8
  178. package/components/{p-C6MbjoUl.js.map → p-Dh_lbOuZ.js.map} +1 -1
  179. package/components/{p-D1In20Wh.js → p-DkDGUG2W.js} +5 -5
  180. package/components/{p-D1In20Wh.js.map → p-DkDGUG2W.js.map} +1 -1
  181. package/components/{p-CkrLmEP7.js → p-Ds0M0G_e.js} +4 -4
  182. package/components/{p-CkrLmEP7.js.map → p-Ds0M0G_e.js.map} +1 -1
  183. package/components/{p-CCQYIDJK.js → p-DvD1nW88.js} +7 -7
  184. package/components/{p-CCQYIDJK.js.map → p-DvD1nW88.js.map} +1 -1
  185. package/components/{p-FnN74Elm.js → p-MuPiaYr1.js} +3 -3
  186. package/components/{p-FnN74Elm.js.map → p-MuPiaYr1.js.map} +1 -1
  187. package/components/{p-DrH8EeUB.js → p-N-Mgk21S.js} +6 -6
  188. package/components/{p-DrH8EeUB.js.map → p-N-Mgk21S.js.map} +1 -1
  189. package/components/{p-CINrBR9H.js → p-N4h8LKe5.js} +4 -4
  190. package/components/{p-CINrBR9H.js.map → p-N4h8LKe5.js.map} +1 -1
  191. package/components/{p-Bvf7gwPU.js → p-N_4h54Ry.js} +12 -12
  192. package/components/{p-Bvf7gwPU.js.map → p-N_4h54Ry.js.map} +1 -1
  193. package/components/{p-CQhe_rqk.js → p-OLe05BAC.js} +5 -5
  194. package/components/{p-CQhe_rqk.js.map → p-OLe05BAC.js.map} +1 -1
  195. package/components/{p-DLPEB4G8.js → p-S6nC3Yb4.js} +4 -4
  196. package/components/{p-DLPEB4G8.js.map → p-S6nC3Yb4.js.map} +1 -1
  197. package/components/{p-BccEFWg2.js → p-UnkzJgmM.js} +6 -6
  198. package/components/{p-BccEFWg2.js.map → p-UnkzJgmM.js.map} +1 -1
  199. package/components/{p-xZXH2vKm.js → p-hwPzPVf8.js} +5 -5
  200. package/components/{p-xZXH2vKm.js.map → p-hwPzPVf8.js.map} +1 -1
  201. package/components/{p-jbrSDf3o.js → p-ktzNBbfQ.js} +5 -5
  202. package/components/{p-jbrSDf3o.js.map → p-ktzNBbfQ.js.map} +1 -1
  203. package/components/{p-IgT3dgxG.js → p-m0vXewzz.js} +5 -5
  204. package/components/{p-IgT3dgxG.js.map → p-m0vXewzz.js.map} +1 -1
  205. package/components/{p-CHAuj3bi.js → p-p2dtYyiM.js} +10 -10
  206. package/components/{p-CHAuj3bi.js.map → p-p2dtYyiM.js.map} +1 -1
  207. package/components/{p-BEzKnceP.js → p-s425oBQi.js} +9 -9
  208. package/components/{p-BEzKnceP.js.map → p-s425oBQi.js.map} +1 -1
  209. package/components/{p-2fxFa_VL.js → p-xHo-3QVy.js} +3 -3
  210. package/components/{p-2fxFa_VL.js.map → p-xHo-3QVy.js.map} +1 -1
  211. package/dist/cjs/{context-B8bRIFA2.js → context-CmNuiaNz.js} +2 -3
  212. package/dist/{esm/context-CKM5pVsv.js.map → cjs/context-CmNuiaNz.js.map} +1 -1
  213. package/dist/cjs/index-C8Xo8L1k.js +6 -18
  214. package/dist/cjs/ix-application-header.cjs.entry.js +10 -15
  215. package/dist/cjs/ix-application-header.entry.cjs.js.map +1 -1
  216. package/dist/cjs/ix-application.cjs.entry.js +4 -6
  217. package/dist/cjs/ix-application.entry.cjs.js.map +1 -1
  218. package/dist/cjs/ix-avatar_2.cjs.entry.js +1 -1
  219. package/dist/cjs/ix-blind.cjs.entry.js +5 -5
  220. package/dist/cjs/ix-breadcrumb.cjs.entry.js +2 -2
  221. package/dist/cjs/ix-card-accordion_2.cjs.entry.js +5 -5
  222. package/dist/cjs/ix-card-list.cjs.entry.js +4 -4
  223. package/dist/cjs/ix-card_2.cjs.entry.js +3 -3
  224. package/dist/cjs/ix-category-filter.cjs.entry.js +3 -3
  225. package/dist/cjs/ix-checkbox-group.cjs.entry.js +2 -2
  226. package/dist/cjs/ix-checkbox.cjs.entry.js +3 -3
  227. package/dist/cjs/ix-chip.cjs.entry.js +4 -4
  228. package/dist/cjs/ix-col_4.cjs.entry.js +9 -9
  229. package/dist/cjs/ix-content-header.cjs.entry.js +3 -3
  230. package/dist/cjs/ix-content.cjs.entry.js +3 -3
  231. package/dist/cjs/ix-css-grid-item.cjs.entry.js +1 -1
  232. package/dist/cjs/ix-css-grid.cjs.entry.js +1 -1
  233. package/dist/cjs/ix-custom-field.cjs.entry.js +1 -1
  234. package/dist/cjs/ix-date-dropdown.cjs.entry.js +4 -4
  235. package/dist/cjs/ix-date-input.cjs.entry.js +3 -3
  236. package/dist/cjs/ix-date-time-card.cjs.entry.js +2 -2
  237. package/dist/cjs/ix-datetime-picker.cjs.entry.js +1 -1
  238. package/dist/cjs/ix-divider.cjs.entry.js +1 -1
  239. package/dist/cjs/ix-drawer.cjs.entry.js +5 -5
  240. package/dist/cjs/ix-dropdown-button.cjs.entry.js +3 -3
  241. package/dist/cjs/ix-dropdown-header.cjs.entry.js +1 -1
  242. package/dist/cjs/ix-dropdown-item.cjs.entry.js +3 -3
  243. package/dist/cjs/ix-dropdown-quick-actions.cjs.entry.js +1 -1
  244. package/dist/cjs/ix-dropdown.cjs.entry.js +2 -2
  245. package/dist/cjs/ix-empty-state.cjs.entry.js +1 -1
  246. package/dist/cjs/ix-event-list-item.cjs.entry.js +4 -4
  247. package/dist/cjs/ix-event-list.cjs.entry.js +2 -2
  248. package/dist/cjs/ix-expanding-search.cjs.entry.js +4 -4
  249. package/dist/cjs/ix-field-label_2.cjs.entry.js +3 -3
  250. package/dist/cjs/ix-filter-chip_2.cjs.entry.js +2 -2
  251. package/dist/cjs/ix-flip-tile-content.cjs.entry.js +1 -1
  252. package/dist/cjs/ix-flip-tile.cjs.entry.js +3 -3
  253. package/dist/cjs/ix-group-context-menu_2.cjs.entry.js +1 -1
  254. package/dist/cjs/ix-group.cjs.entry.js +8 -8
  255. package/dist/cjs/ix-helper-text.cjs.entry.js +1 -1
  256. package/dist/cjs/ix-icon-button_2.cjs.entry.js +2 -2
  257. package/dist/cjs/ix-icon-toggle-button.cjs.entry.js +1 -1
  258. package/dist/cjs/ix-input-group.cjs.entry.js +1 -1
  259. package/dist/cjs/ix-input.cjs.entry.js +4 -4
  260. package/dist/cjs/ix-key-value-list.cjs.entry.js +1 -1
  261. package/dist/cjs/ix-key-value.cjs.entry.js +1 -1
  262. package/dist/cjs/ix-kpi.cjs.entry.js +3 -3
  263. package/dist/cjs/ix-layout-auto.cjs.entry.js +1 -1
  264. package/dist/cjs/ix-link-button.cjs.entry.js +3 -3
  265. package/dist/cjs/ix-menu-about-item.cjs.entry.js +1 -1
  266. package/dist/cjs/ix-menu-about-news.cjs.entry.js +4 -4
  267. package/dist/cjs/ix-menu-avatar.cjs.entry.js +2 -2
  268. package/dist/cjs/ix-menu-category.cjs.entry.js +6 -6
  269. package/dist/cjs/ix-menu-expand-icon.cjs.entry.js +1 -1
  270. package/dist/cjs/ix-menu-item.cjs.entry.js +4 -4
  271. package/dist/cjs/ix-menu-settings-item.cjs.entry.js +1 -1
  272. package/dist/cjs/ix-menu.cjs.entry.js +13 -23
  273. package/dist/cjs/ix-menu.entry.cjs.js.map +1 -1
  274. package/dist/cjs/ix-message-bar.cjs.entry.js +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 +3 -3
  279. package/dist/cjs/ix-number-input.cjs.entry.js +6 -6
  280. package/dist/cjs/ix-pagination.cjs.entry.js +3 -3
  281. package/dist/cjs/ix-pane-layout.cjs.entry.js +1 -1
  282. package/dist/cjs/ix-pane.cjs.entry.js +6 -6
  283. package/dist/cjs/ix-pill.cjs.entry.js +4 -4
  284. package/dist/cjs/ix-progress-indicator.cjs.entry.js +3 -3
  285. package/dist/cjs/ix-push-card.cjs.entry.js +1 -1
  286. package/dist/cjs/ix-radio-group.cjs.entry.js +2 -2
  287. package/dist/cjs/ix-radio.cjs.entry.js +4 -4
  288. package/dist/cjs/ix-select.cjs.entry.js +8 -8
  289. package/dist/cjs/ix-slider.cjs.entry.js +6 -6
  290. package/dist/cjs/ix-split-button.cjs.entry.js +1 -1
  291. package/dist/cjs/ix-tab-item_2.cjs.entry.js +5 -5
  292. package/dist/cjs/ix-textarea.cjs.entry.js +2 -2
  293. package/dist/cjs/ix-tile.cjs.entry.js +4 -4
  294. package/dist/cjs/ix-time-input.cjs.entry.js +3 -3
  295. package/dist/cjs/ix-time-picker.cjs.entry.js +4 -4
  296. package/dist/cjs/ix-toast-container.cjs.entry.js +2 -2
  297. package/dist/cjs/ix-toast.cjs.entry.js +2 -2
  298. package/dist/cjs/ix-toggle.cjs.entry.js +3 -3
  299. package/dist/cjs/ix-tooltip.cjs.entry.js +1 -1
  300. package/dist/cjs/ix-tree-item.cjs.entry.js +4 -4
  301. package/dist/cjs/ix-tree.cjs.entry.js +1 -1
  302. package/dist/cjs/ix-typography.cjs.entry.js +1 -1
  303. package/dist/cjs/ix-upload.cjs.entry.js +3 -3
  304. package/dist/cjs/ix-validation-tooltip.cjs.entry.js +2 -2
  305. package/dist/cjs/ix-workflow-step.cjs.entry.js +3 -3
  306. package/dist/cjs/ix-workflow-steps.cjs.entry.js +1 -1
  307. package/dist/cjs/loader.cjs.js +1 -1
  308. package/dist/cjs/siemens-ix.cjs.js +1 -1
  309. package/dist/collection/collection-manifest.json +0 -3
  310. package/dist/collection/components/application/application.js +3 -5
  311. package/dist/collection/components/application/application.js.map +1 -1
  312. package/dist/collection/components/application-header/application-header.js +9 -14
  313. package/dist/collection/components/application-header/application-header.js.map +1 -1
  314. package/dist/collection/components/blind/blind.js +5 -5
  315. package/dist/collection/components/breadcrumb/breadcrumb.js +2 -2
  316. package/dist/collection/components/card/card.js +2 -2
  317. package/dist/collection/components/card-accordion/card-accordion.js +4 -4
  318. package/dist/collection/components/card-content/card-content.js +1 -1
  319. package/dist/collection/components/card-list/card-list.js +4 -4
  320. package/dist/collection/components/card-title/card-title.js +1 -1
  321. package/dist/collection/components/category-filter/category-filter.js +3 -3
  322. package/dist/collection/components/checkbox/checkbox.js +3 -3
  323. package/dist/collection/components/checkbox-group/checkbox-group.js +2 -2
  324. package/dist/collection/components/chip/chip.js +4 -4
  325. package/dist/collection/components/col/col.js +1 -1
  326. package/dist/collection/components/content/content.js +3 -3
  327. package/dist/collection/components/content-header/content-header.js +3 -3
  328. package/dist/collection/components/css-grid/css-grid-item.js +1 -1
  329. package/dist/collection/components/css-grid/css-grid.js +1 -1
  330. package/dist/collection/components/custom-field/custom-field.js +1 -1
  331. package/dist/collection/components/date-dropdown/date-dropdown.js +4 -4
  332. package/dist/collection/components/date-input/date-input.js +3 -3
  333. package/dist/collection/components/date-picker/date-picker.js +5 -5
  334. package/dist/collection/components/date-time-card/date-time-card.js +2 -2
  335. package/dist/collection/components/datetime-picker/datetime-picker.js +1 -1
  336. package/dist/collection/components/divider/divider.js +1 -1
  337. package/dist/collection/components/drawer/drawer.js +5 -5
  338. package/dist/collection/components/dropdown/dropdown.js +2 -2
  339. package/dist/collection/components/dropdown-button/dropdown-button.js +3 -3
  340. package/dist/collection/components/dropdown-header/dropdown-header.js +1 -1
  341. package/dist/collection/components/dropdown-item/dropdown-item.js +3 -3
  342. package/dist/collection/components/dropdown-quick-actions/dropdown-quick-actions.js +1 -1
  343. package/dist/collection/components/empty-state/empty-state.js +1 -1
  344. package/dist/collection/components/event-list/event-list.js +2 -2
  345. package/dist/collection/components/event-list-item/event-list-item.js +4 -4
  346. package/dist/collection/components/expanding-search/expanding-search.js +4 -4
  347. package/dist/collection/components/field-label/field-label.js +1 -1
  348. package/dist/collection/components/field-wrapper/field-wrapper.js +2 -2
  349. package/dist/collection/components/filter-chip/filter-chip.js +1 -1
  350. package/dist/collection/components/flip-tile/flip-tile.js +3 -3
  351. package/dist/collection/components/flip-tile-content/flip-tile-content.js +1 -1
  352. package/dist/collection/components/group/group-context-menu.js +1 -1
  353. package/dist/collection/components/group/group.js +8 -8
  354. package/dist/collection/components/helper-text/helper-text.js +1 -1
  355. package/dist/collection/components/icon-button/icon-button.js +1 -1
  356. package/dist/collection/components/icon-toggle-button/icon-toggle-button.js +1 -1
  357. package/dist/collection/components/input/input.js +4 -4
  358. package/dist/collection/components/input/number-input.js +6 -6
  359. package/dist/collection/components/input/textarea.js +2 -2
  360. package/dist/collection/components/input-group/input-group.js +1 -1
  361. package/dist/collection/components/key-value/key-value.js +1 -1
  362. package/dist/collection/components/key-value-list/key-value-list.js +1 -1
  363. package/dist/collection/components/kpi/kpi.js +3 -3
  364. package/dist/collection/components/layout-auto/layout-auto.js +1 -1
  365. package/dist/collection/components/layout-grid/layout-grid.js +2 -2
  366. package/dist/collection/components/link-button/link-button.js +3 -3
  367. package/dist/collection/components/menu/menu-expand-icon.js +1 -1
  368. package/dist/collection/components/menu/menu.js +12 -22
  369. package/dist/collection/components/menu/menu.js.map +1 -1
  370. package/dist/collection/components/menu-about-item/menu-about-item.js +1 -1
  371. package/dist/collection/components/menu-about-news/menu-about-news.js +4 -4
  372. package/dist/collection/components/menu-avatar/menu-avatar.js +2 -2
  373. package/dist/collection/components/menu-avatar-item/menu-avatar-item.js +1 -1
  374. package/dist/collection/components/menu-category/menu-category.js +5 -5
  375. package/dist/collection/components/menu-item/menu-item.js +4 -4
  376. package/dist/collection/components/menu-settings-item/menu-settings-item.js +1 -1
  377. package/dist/collection/components/message-bar/message-bar.js +1 -1
  378. package/dist/collection/components/modal/modal.js +3 -3
  379. package/dist/collection/components/modal-content/modal-content.js +1 -1
  380. package/dist/collection/components/modal-footer/modal-footer.js +1 -1
  381. package/dist/collection/components/modal-header/modal-header.js +1 -1
  382. package/dist/collection/components/modal-loading/modal-loading.js +1 -1
  383. package/dist/collection/components/pagination/pagination.js +3 -3
  384. package/dist/collection/components/pane/pane.js +6 -6
  385. package/dist/collection/components/pane-layout/pane-layout.js +1 -1
  386. package/dist/collection/components/pill/pill.js +4 -4
  387. package/dist/collection/components/progress-indicator/progress-indicator.js +3 -3
  388. package/dist/collection/components/push-card/push-card.js +1 -1
  389. package/dist/collection/components/radio/radio.js +4 -4
  390. package/dist/collection/components/radio-group/radio-group.js +2 -2
  391. package/dist/collection/components/row/row.js +1 -1
  392. package/dist/collection/components/select/select.js +8 -8
  393. package/dist/collection/components/select-item/select-item.js +1 -1
  394. package/dist/collection/components/slider/slider.js +6 -6
  395. package/dist/collection/components/spinner/spinner.js +1 -1
  396. package/dist/collection/components/split-button/split-button.js +1 -1
  397. package/dist/collection/components/tab-item/tab-item.js +3 -3
  398. package/dist/collection/components/tabs/tabs.js +2 -2
  399. package/dist/collection/components/tile/tile.js +4 -4
  400. package/dist/collection/components/time-input/time-input.js +3 -3
  401. package/dist/collection/components/time-picker/time-picker.js +4 -4
  402. package/dist/collection/components/toast/toast-container.js +2 -2
  403. package/dist/collection/components/toast/toast.js +2 -2
  404. package/dist/collection/components/toggle/toggle.js +3 -3
  405. package/dist/collection/components/tooltip/tooltip.js +1 -1
  406. package/dist/collection/components/tree/tree.js +1 -1
  407. package/dist/collection/components/tree-item/tree-item.js +4 -4
  408. package/dist/collection/components/typography/typography.js +1 -1
  409. package/dist/collection/components/upload/upload.js +3 -3
  410. package/dist/collection/components/utils/application-layout/context.js +0 -1
  411. package/dist/collection/components/utils/application-layout/context.js.map +1 -1
  412. package/dist/collection/components/validation-tooltip/validation-tooltip.js +2 -2
  413. package/dist/collection/components/workflow-step/workflow-step.js +3 -3
  414. package/dist/collection/components/workflow-steps/workflow-steps.js +1 -1
  415. package/dist/esm/{context-CKM5pVsv.js → context-BniHpAE1.js} +2 -3
  416. package/dist/{cjs/context-B8bRIFA2.js.map → esm/context-BniHpAE1.js.map} +1 -1
  417. package/dist/esm/{helper-text-util-rnbkuaac.js → helper-text-util-BurV4TiQ.js} +3 -3
  418. package/dist/esm/{helper-text-util-rnbkuaac.js.map → helper-text-util-BurV4TiQ.js.map} +1 -1
  419. package/dist/esm/{index-Cz75KU1f.js → index-8HpPmDK_.js} +3 -3
  420. package/dist/esm/{index-Cz75KU1f.js.map → index-8HpPmDK_.js.map} +1 -1
  421. package/dist/esm/index-CtoreFVF.js +6 -18
  422. package/dist/esm/{index--ZIr3Aqz.js → index-Kp5Wf9wr.js} +3 -3
  423. package/dist/esm/{index--ZIr3Aqz.js.map → index-Kp5Wf9wr.js.map} +1 -1
  424. package/dist/esm/index.js +3 -3
  425. package/dist/esm/ix-application-header.entry.js +13 -18
  426. package/dist/esm/ix-application-header.entry.js.map +1 -1
  427. package/dist/esm/ix-application-switch-modal.entry.js +2 -2
  428. package/dist/esm/ix-application.entry.js +4 -6
  429. package/dist/esm/ix-application.entry.js.map +1 -1
  430. package/dist/esm/ix-avatar_2.entry.js +1 -1
  431. package/dist/esm/ix-blind.entry.js +6 -6
  432. package/dist/esm/ix-breadcrumb-item.entry.js +1 -1
  433. package/dist/esm/ix-breadcrumb.entry.js +2 -2
  434. package/dist/esm/ix-card-accordion_2.entry.js +6 -6
  435. package/dist/esm/ix-card-list.entry.js +5 -5
  436. package/dist/esm/ix-card_2.entry.js +3 -3
  437. package/dist/esm/ix-category-filter.entry.js +4 -4
  438. package/dist/esm/ix-checkbox-group.entry.js +2 -2
  439. package/dist/esm/ix-checkbox.entry.js +3 -3
  440. package/dist/esm/ix-chip.entry.js +5 -5
  441. package/dist/esm/ix-col_4.entry.js +10 -10
  442. package/dist/esm/ix-content-header.entry.js +4 -4
  443. package/dist/esm/ix-content.entry.js +3 -3
  444. package/dist/esm/ix-css-grid-item.entry.js +1 -1
  445. package/dist/esm/ix-css-grid.entry.js +1 -1
  446. package/dist/esm/ix-custom-field.entry.js +1 -1
  447. package/dist/esm/ix-date-dropdown.entry.js +5 -5
  448. package/dist/esm/ix-date-input.entry.js +4 -4
  449. package/dist/esm/ix-date-time-card.entry.js +2 -2
  450. package/dist/esm/ix-datetime-picker.entry.js +1 -1
  451. package/dist/esm/ix-divider.entry.js +1 -1
  452. package/dist/esm/ix-drawer.entry.js +6 -6
  453. package/dist/esm/ix-dropdown-button.entry.js +4 -4
  454. package/dist/esm/ix-dropdown-header.entry.js +1 -1
  455. package/dist/esm/ix-dropdown-item.entry.js +4 -4
  456. package/dist/esm/ix-dropdown-quick-actions.entry.js +1 -1
  457. package/dist/esm/ix-dropdown.entry.js +2 -2
  458. package/dist/esm/ix-empty-state.entry.js +1 -1
  459. package/dist/esm/ix-event-list-item.entry.js +5 -5
  460. package/dist/esm/ix-event-list.entry.js +2 -2
  461. package/dist/esm/ix-expanding-search.entry.js +5 -5
  462. package/dist/esm/ix-field-label_2.entry.js +5 -5
  463. package/dist/esm/ix-filter-chip_2.entry.js +3 -3
  464. package/dist/esm/ix-flip-tile-content.entry.js +1 -1
  465. package/dist/esm/ix-flip-tile.entry.js +4 -4
  466. package/dist/esm/ix-group-context-menu_2.entry.js +2 -2
  467. package/dist/esm/ix-group.entry.js +9 -9
  468. package/dist/esm/ix-helper-text.entry.js +3 -3
  469. package/dist/esm/ix-icon-button_2.entry.js +2 -2
  470. package/dist/esm/ix-icon-toggle-button.entry.js +1 -1
  471. package/dist/esm/ix-input-group.entry.js +1 -1
  472. package/dist/esm/ix-input.entry.js +5 -5
  473. package/dist/esm/ix-key-value-list.entry.js +1 -1
  474. package/dist/esm/ix-key-value.entry.js +1 -1
  475. package/dist/esm/ix-kpi.entry.js +4 -4
  476. package/dist/esm/ix-layout-auto.entry.js +1 -1
  477. package/dist/esm/ix-link-button.entry.js +4 -4
  478. package/dist/esm/ix-menu-about-item.entry.js +1 -1
  479. package/dist/esm/ix-menu-about-news.entry.js +5 -5
  480. package/dist/esm/ix-menu-about.entry.js +2 -2
  481. package/dist/esm/ix-menu-avatar.entry.js +3 -3
  482. package/dist/esm/ix-menu-category.entry.js +7 -7
  483. package/dist/esm/ix-menu-expand-icon.entry.js +2 -2
  484. package/dist/esm/ix-menu-item.entry.js +5 -5
  485. package/dist/esm/{ix-menu-settings-DRSkDgox.js → ix-menu-settings-Bif4wByb.js} +3 -3
  486. package/dist/esm/{ix-menu-settings-DRSkDgox.js.map → ix-menu-settings-Bif4wByb.js.map} +1 -1
  487. package/dist/esm/ix-menu-settings-item.entry.js +1 -1
  488. package/dist/esm/ix-menu-settings.entry.js +2 -2
  489. package/dist/esm/ix-menu.entry.js +16 -26
  490. package/dist/esm/ix-menu.entry.js.map +1 -1
  491. package/dist/esm/ix-message-bar.entry.js +2 -2
  492. package/dist/esm/ix-modal-content_2.entry.js +3 -3
  493. package/dist/esm/ix-modal-footer.entry.js +1 -1
  494. package/dist/esm/ix-modal-loading.entry.js +1 -1
  495. package/dist/esm/ix-modal.entry.js +3 -3
  496. package/dist/esm/ix-number-input.entry.js +7 -7
  497. package/dist/esm/ix-pagination.entry.js +4 -4
  498. package/dist/esm/ix-pane-layout.entry.js +1 -1
  499. package/dist/esm/ix-pane.entry.js +7 -7
  500. package/dist/esm/ix-pill.entry.js +4 -4
  501. package/dist/esm/ix-progress-indicator.entry.js +4 -4
  502. package/dist/esm/ix-push-card.entry.js +1 -1
  503. package/dist/esm/ix-radio-group.entry.js +2 -2
  504. package/dist/esm/ix-radio.entry.js +4 -4
  505. package/dist/esm/ix-select.entry.js +9 -9
  506. package/dist/esm/ix-slider.entry.js +6 -6
  507. package/dist/esm/ix-split-button.entry.js +2 -2
  508. package/dist/esm/ix-tab-item_2.entry.js +6 -6
  509. package/dist/esm/ix-textarea.entry.js +2 -2
  510. package/dist/esm/ix-tile.entry.js +4 -4
  511. package/dist/esm/ix-time-input.entry.js +4 -4
  512. package/dist/esm/ix-time-picker.entry.js +4 -4
  513. package/dist/esm/ix-toast-container.entry.js +2 -2
  514. package/dist/esm/ix-toast.entry.js +3 -3
  515. package/dist/esm/ix-toggle.entry.js +3 -3
  516. package/dist/esm/ix-tooltip.entry.js +1 -1
  517. package/dist/esm/ix-tree-item.entry.js +5 -5
  518. package/dist/esm/ix-tree.entry.js +1 -1
  519. package/dist/esm/ix-typography.entry.js +1 -1
  520. package/dist/esm/ix-upload.entry.js +4 -4
  521. package/dist/esm/ix-validation-tooltip.entry.js +2 -2
  522. package/dist/esm/ix-workflow-step.entry.js +4 -4
  523. package/dist/esm/ix-workflow-steps.entry.js +1 -1
  524. package/dist/esm/loader.js +1 -1
  525. package/dist/esm/{modal-D9BaTrTa.js → modal-BTxff2hq.js} +3 -3
  526. package/dist/esm/{modal-D9BaTrTa.js.map → modal-BTxff2hq.js.map} +1 -1
  527. package/dist/esm/siemens-ix.js +1 -1
  528. package/dist/siemens-ix/index.esm.js +1 -1
  529. package/dist/siemens-ix/ix-application-header.entry.esm.js.map +1 -1
  530. package/dist/siemens-ix/ix-application.entry.esm.js.map +1 -1
  531. package/dist/siemens-ix/ix-menu.entry.esm.js.map +1 -1
  532. package/dist/siemens-ix/{p-7cf61ff6.entry.js → p-011fe058.entry.js} +2 -2
  533. package/dist/siemens-ix/{p-6f152ed2.entry.js → p-06a2c69b.entry.js} +2 -2
  534. package/dist/siemens-ix/p-07c079fd.entry.js +2 -0
  535. package/dist/siemens-ix/{p-f29f280b.entry.js.map → p-07c079fd.entry.js.map} +1 -1
  536. package/dist/siemens-ix/p-091295e8.entry.js +2 -0
  537. package/dist/siemens-ix/{p-5e86944d.entry.js.map → p-091295e8.entry.js.map} +1 -1
  538. package/dist/siemens-ix/{p-0e2b89f2.entry.js → p-0fd006b9.entry.js} +2 -2
  539. package/dist/siemens-ix/{p-a4d6ee80.entry.js → p-11b1eaa3.entry.js} +2 -2
  540. package/dist/siemens-ix/p-1550973a.entry.js +2 -0
  541. package/dist/siemens-ix/{p-f9b4e5f1.entry.js → p-162a4cc0.entry.js} +2 -2
  542. package/dist/siemens-ix/{p-4448252f.entry.js → p-18d4645d.entry.js} +2 -2
  543. package/dist/siemens-ix/{p-20ad8d1e.entry.js → p-1c83cb5f.entry.js} +2 -2
  544. package/dist/siemens-ix/{p-01030dfb.entry.js → p-1de6e736.entry.js} +2 -2
  545. package/dist/siemens-ix/{p-3b314194.entry.js → p-213f28c0.entry.js} +2 -2
  546. package/dist/siemens-ix/{p-e25aa385.entry.js → p-23e4f5f3.entry.js} +2 -2
  547. package/dist/siemens-ix/{p-34e530b9.entry.js → p-249f87ff.entry.js} +2 -2
  548. package/dist/siemens-ix/{p-f3b485de.entry.js → p-277f6718.entry.js} +2 -2
  549. package/dist/siemens-ix/p-28695184.entry.js +2 -0
  550. package/dist/siemens-ix/{p-f82e4e0f.entry.js.map → p-28695184.entry.js.map} +1 -1
  551. package/dist/siemens-ix/{p-347fcf94.entry.js → p-2b2f339e.entry.js} +2 -2
  552. package/dist/siemens-ix/{p-d49f7ae4.entry.js → p-2d96a4a1.entry.js} +2 -2
  553. package/dist/siemens-ix/{p-80f55403.entry.js → p-305b3333.entry.js} +2 -2
  554. package/dist/siemens-ix/{p-db9d5872.entry.js → p-306c889e.entry.js} +2 -2
  555. package/dist/siemens-ix/{p-2db36aa6.entry.js → p-3099c12a.entry.js} +2 -2
  556. package/dist/siemens-ix/p-35d6b656.entry.js +2 -0
  557. package/dist/siemens-ix/p-35d6b656.entry.js.map +1 -0
  558. package/dist/siemens-ix/{p-75d8b192.entry.js → p-39c321c1.entry.js} +2 -2
  559. package/dist/siemens-ix/{p-608b3631.entry.js → p-418671c7.entry.js} +2 -2
  560. package/dist/siemens-ix/{p-f753f1f5.entry.js → p-4288bd66.entry.js} +2 -2
  561. package/dist/siemens-ix/{p-730a6161.entry.js → p-439d7ab7.entry.js} +2 -2
  562. package/dist/siemens-ix/{p-b7c5ab43.entry.js → p-43ecc5c3.entry.js} +2 -2
  563. package/dist/siemens-ix/p-43ecc5c3.entry.js.map +1 -0
  564. package/dist/siemens-ix/p-453aa17a.entry.js +2 -0
  565. package/dist/siemens-ix/{p-4b65234d.entry.js.map → p-453aa17a.entry.js.map} +1 -1
  566. package/dist/siemens-ix/p-45b53c34.entry.js +2 -0
  567. package/dist/siemens-ix/{p-710af987.entry.js.map → p-45b53c34.entry.js.map} +1 -1
  568. package/dist/siemens-ix/{p-4b1745dc.entry.js → p-49843cce.entry.js} +2 -2
  569. package/dist/siemens-ix/{p-48cbacaf.entry.js → p-4d0e900c.entry.js} +2 -2
  570. package/dist/siemens-ix/{p-b6736ce7.entry.js → p-4f6dee54.entry.js} +2 -2
  571. package/dist/siemens-ix/{p-9c862819.entry.js → p-51bd3222.entry.js} +2 -2
  572. package/dist/siemens-ix/{p-2f54ce99.entry.js → p-531f9746.entry.js} +2 -2
  573. package/dist/siemens-ix/{p-337a3457.entry.js → p-53cc0fda.entry.js} +2 -2
  574. package/dist/siemens-ix/p-53df921a.entry.js +2 -0
  575. package/dist/siemens-ix/{p-556417c6.entry.js.map → p-53df921a.entry.js.map} +1 -1
  576. package/dist/siemens-ix/p-598ece5a.entry.js +2 -0
  577. package/dist/siemens-ix/{p-81120f11.entry.js → p-5bb86bf7.entry.js} +2 -2
  578. package/dist/siemens-ix/{p-67766c28.entry.js → p-5c22d3e5.entry.js} +2 -2
  579. package/dist/siemens-ix/{p-9d8fb7dd.entry.js → p-6045dce9.entry.js} +2 -2
  580. package/dist/siemens-ix/{p-17a74a48.entry.js → p-60d2f3db.entry.js} +2 -2
  581. package/dist/siemens-ix/{p-fc3071d0.entry.js → p-619a3dc8.entry.js} +2 -2
  582. package/dist/siemens-ix/p-620158aa.entry.js +2 -0
  583. package/dist/siemens-ix/{p-9d135d59.entry.js → p-6880e267.entry.js} +2 -2
  584. package/dist/siemens-ix/{p-ecff1e2f.entry.js → p-6fd7d11a.entry.js} +2 -2
  585. package/dist/siemens-ix/p-70af7f44.entry.js +2 -0
  586. package/dist/siemens-ix/{p-d4ba3f9f.entry.js → p-713df610.entry.js} +2 -2
  587. package/dist/siemens-ix/{p-467c0fff.entry.js → p-7364534a.entry.js} +2 -2
  588. package/dist/siemens-ix/{p-fea12773.entry.js → p-75a10c1e.entry.js} +2 -2
  589. package/dist/siemens-ix/{p-67e4f814.entry.js → p-76bd4cf9.entry.js} +2 -2
  590. package/dist/siemens-ix/{p-0d4f0223.entry.js → p-7827c263.entry.js} +2 -2
  591. package/dist/siemens-ix/{p-65842e35.entry.js → p-79181aa7.entry.js} +2 -2
  592. package/dist/siemens-ix/{p-e562ffb2.entry.js → p-7c474c82.entry.js} +2 -2
  593. package/dist/siemens-ix/{p-548a2231.entry.js → p-7f0b0fa3.entry.js} +2 -2
  594. package/dist/siemens-ix/{p-d8fb5a86.entry.js → p-80981f03.entry.js} +2 -2
  595. package/dist/siemens-ix/p-8418f756.entry.js +2 -0
  596. package/dist/siemens-ix/p-8418f756.entry.js.map +1 -0
  597. package/dist/siemens-ix/{p-7388d2ee.entry.js → p-8532a932.entry.js} +2 -2
  598. package/dist/siemens-ix/{p-Cz75KU1f.js → p-8HpPmDK_.js} +2 -2
  599. package/dist/siemens-ix/{p-Cz75KU1f.js.map → p-8HpPmDK_.js.map} +1 -1
  600. package/dist/siemens-ix/{p-04f1b89a.entry.js → p-8cb3d70c.entry.js} +2 -2
  601. package/dist/siemens-ix/{p-784c6dd6.entry.js → p-8ce61408.entry.js} +2 -2
  602. package/dist/siemens-ix/{p-c0064123.entry.js → p-8f17f6ec.entry.js} +2 -2
  603. package/dist/siemens-ix/{p-3472fc1a.entry.js → p-8fc2bea6.entry.js} +2 -2
  604. package/dist/siemens-ix/{p-9e7223f6.entry.js → p-905d4977.entry.js} +2 -2
  605. package/dist/siemens-ix/{p-538843d4.entry.js → p-92e0ebf1.entry.js} +2 -2
  606. package/dist/siemens-ix/{p-3acbbe01.entry.js → p-94596bff.entry.js} +2 -2
  607. package/dist/siemens-ix/{p-e825a921.entry.js → p-97c3d27e.entry.js} +2 -2
  608. package/dist/siemens-ix/{p-957d0d0b.entry.js → p-9a4db5e9.entry.js} +2 -2
  609. package/dist/siemens-ix/{p-7e6beda5.entry.js → p-9f7f5cd3.entry.js} +2 -2
  610. package/dist/siemens-ix/{p-CpVbQsUI.js → p-BC0Exw_O.js} +2 -2
  611. package/dist/siemens-ix/{p-CpVbQsUI.js.map → p-BC0Exw_O.js.map} +1 -1
  612. package/dist/siemens-ix/{p--2LOMK-5.js → p-BhgW5qDm.js} +2 -2
  613. package/dist/siemens-ix/{p--2LOMK-5.js.map → p-BhgW5qDm.js.map} +1 -1
  614. package/dist/siemens-ix/{p-DRnSC9aV.js → p-CObJ-t0Z.js} +2 -2
  615. package/dist/siemens-ix/{p-DRnSC9aV.js.map → p-CObJ-t0Z.js.map} +1 -1
  616. package/dist/siemens-ix/{p-sxLz5AVO.js → p-DBsKyLIP.js} +2 -2
  617. package/dist/siemens-ix/{p-sxLz5AVO.js.map → p-DBsKyLIP.js.map} +1 -1
  618. package/dist/siemens-ix/{p-CX3n_rRh.js → p-DXAZefAa.js} +2 -2
  619. package/dist/siemens-ix/{p-CX3n_rRh.js.map → p-DXAZefAa.js.map} +1 -1
  620. package/dist/siemens-ix/p-a0ffeea7.entry.js +2 -0
  621. package/dist/siemens-ix/{p-58219b7e.entry.js → p-a2829e55.entry.js} +2 -2
  622. package/dist/siemens-ix/{p-4f2fb1c5.entry.js → p-a4c8457e.entry.js} +2 -2
  623. package/dist/siemens-ix/p-a61972c5.entry.js +2 -0
  624. package/dist/siemens-ix/{p-2180ddb8.entry.js.map → p-a61972c5.entry.js.map} +1 -1
  625. package/dist/siemens-ix/p-a6e398d2.entry.js +2 -0
  626. package/dist/siemens-ix/{p-aa6368b4.entry.js → p-acb7c236.entry.js} +2 -2
  627. package/dist/siemens-ix/{p-788e1ef8.entry.js → p-b2aa549b.entry.js} +2 -2
  628. package/dist/siemens-ix/{p-89449e22.entry.js → p-b7c64537.entry.js} +2 -2
  629. package/dist/siemens-ix/{p-d1941577.entry.js → p-bb744e91.entry.js} +2 -2
  630. package/dist/siemens-ix/{p-94fa5d00.entry.js → p-be78352f.entry.js} +2 -2
  631. package/dist/siemens-ix/{p-845054ca.entry.js → p-c6536a88.entry.js} +2 -2
  632. package/dist/siemens-ix/p-ca43aa61.entry.js +2 -0
  633. package/dist/siemens-ix/{p-8aa0fda7.entry.js → p-cc7f7788.entry.js} +2 -2
  634. package/dist/siemens-ix/p-d18df859.entry.js +2 -0
  635. package/dist/siemens-ix/{p-a02e0685.entry.js → p-d2831f7b.entry.js} +2 -2
  636. package/dist/siemens-ix/{p-dff78943.entry.js → p-d90d1310.entry.js} +2 -2
  637. package/dist/siemens-ix/{p-fabcc5f5.entry.js → p-d997238b.entry.js} +2 -2
  638. package/dist/siemens-ix/{p-41b9392e.entry.js → p-da3a9845.entry.js} +2 -2
  639. package/dist/siemens-ix/{p-51786593.entry.js → p-df5494ff.entry.js} +2 -2
  640. package/dist/siemens-ix/{p-79798af1.entry.js → p-e3dca831.entry.js} +2 -2
  641. package/dist/siemens-ix/{p-eebe632b.entry.js → p-e5180acd.entry.js} +2 -2
  642. package/dist/siemens-ix/{p-b5e0ddb3.entry.js → p-ea410634.entry.js} +2 -2
  643. package/dist/siemens-ix/{p-39950a1c.entry.js → p-f253d38c.entry.js} +2 -2
  644. package/dist/siemens-ix/{p-da6a27c1.entry.js → p-fb02d7fd.entry.js} +2 -2
  645. package/dist/siemens-ix/p-fdb802ac.entry.js +2 -0
  646. package/dist/siemens-ix/{p-7e612a3b.entry.js → p-fe5bf44b.entry.js} +2 -2
  647. package/dist/siemens-ix/{p-1f5befb2.entry.js → p-ff6f13e1.entry.js} +2 -2
  648. package/dist/siemens-ix/siemens-ix-core.css +1 -1
  649. package/dist/siemens-ix/siemens-ix.css +0 -17
  650. package/dist/siemens-ix/siemens-ix.esm.js +1 -1
  651. package/dist/types/components/utils/application-layout/context.d.ts +0 -1
  652. package/dist/types/components.d.ts +0 -229
  653. package/hydrate/index.js +259 -616
  654. package/hydrate/index.mjs +259 -616
  655. package/package.json +1 -1
  656. package/scss/theme/core/_components.scss +0 -2
  657. package/components/ix-basic-navigation.d.ts +0 -11
  658. package/components/ix-basic-navigation.js +0 -156
  659. package/components/ix-basic-navigation.js.map +0 -1
  660. package/components/ix-map-navigation-overlay.d.ts +0 -11
  661. package/components/ix-map-navigation-overlay.js +0 -9
  662. package/components/ix-map-navigation-overlay.js.map +0 -1
  663. package/components/ix-map-navigation.d.ts +0 -11
  664. package/components/ix-map-navigation.js +0 -240
  665. package/components/ix-map-navigation.js.map +0 -1
  666. package/components/p--2LOMK-5.js.map +0 -1
  667. package/components/p-UEMLzDk6.js +0 -92
  668. package/components/p-UEMLzDk6.js.map +0 -1
  669. package/components/p-yuZO1O90.js +0 -273
  670. package/components/p-yuZO1O90.js.map +0 -1
  671. package/dist/cjs/ix-basic-navigation.cjs.entry.js +0 -93
  672. package/dist/cjs/ix-basic-navigation.entry.cjs.js.map +0 -1
  673. package/dist/cjs/ix-map-navigation-overlay.cjs.entry.js +0 -56
  674. package/dist/cjs/ix-map-navigation-overlay.entry.cjs.js.map +0 -1
  675. package/dist/cjs/ix-map-navigation.cjs.entry.js +0 -169
  676. package/dist/cjs/ix-map-navigation.entry.cjs.js.map +0 -1
  677. package/dist/collection/components/basic-navigation/basic-navigation.css +0 -113
  678. package/dist/collection/components/basic-navigation/basic-navigation.js +0 -209
  679. package/dist/collection/components/basic-navigation/basic-navigation.js.map +0 -1
  680. package/dist/collection/components/map-navigation/map-navigation.css +0 -212
  681. package/dist/collection/components/map-navigation/map-navigation.js +0 -401
  682. package/dist/collection/components/map-navigation/map-navigation.js.map +0 -1
  683. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.css +0 -156
  684. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.js +0 -209
  685. package/dist/collection/components/map-navigation-overlay/map-navigation-overlay.js.map +0 -1
  686. package/dist/esm/ix-basic-navigation.entry.js +0 -91
  687. package/dist/esm/ix-basic-navigation.entry.js.map +0 -1
  688. package/dist/esm/ix-map-navigation-overlay.entry.js +0 -54
  689. package/dist/esm/ix-map-navigation-overlay.entry.js.map +0 -1
  690. package/dist/esm/ix-map-navigation.entry.js +0 -167
  691. package/dist/esm/ix-map-navigation.entry.js.map +0 -1
  692. package/dist/siemens-ix/ix-basic-navigation.entry.esm.js.map +0 -1
  693. package/dist/siemens-ix/ix-map-navigation-overlay.entry.esm.js.map +0 -1
  694. package/dist/siemens-ix/ix-map-navigation.entry.esm.js.map +0 -1
  695. package/dist/siemens-ix/p-08f4c3f0.entry.js +0 -2
  696. package/dist/siemens-ix/p-2055daf3.entry.js +0 -2
  697. package/dist/siemens-ix/p-2055daf3.entry.js.map +0 -1
  698. package/dist/siemens-ix/p-2180ddb8.entry.js +0 -2
  699. package/dist/siemens-ix/p-4b65234d.entry.js +0 -2
  700. package/dist/siemens-ix/p-52d377d1.entry.js +0 -2
  701. package/dist/siemens-ix/p-52d377d1.entry.js.map +0 -1
  702. package/dist/siemens-ix/p-556417c6.entry.js +0 -2
  703. package/dist/siemens-ix/p-5e86944d.entry.js +0 -2
  704. package/dist/siemens-ix/p-710af987.entry.js +0 -2
  705. package/dist/siemens-ix/p-759ba03d.entry.js +0 -2
  706. package/dist/siemens-ix/p-85f3aa13.entry.js +0 -2
  707. package/dist/siemens-ix/p-879a0cc5.entry.js +0 -2
  708. package/dist/siemens-ix/p-879a0cc5.entry.js.map +0 -1
  709. package/dist/siemens-ix/p-92a6324b.entry.js +0 -2
  710. package/dist/siemens-ix/p-ad20efd0.entry.js +0 -2
  711. package/dist/siemens-ix/p-b7c5ab43.entry.js.map +0 -1
  712. package/dist/siemens-ix/p-c4b26603.entry.js +0 -2
  713. package/dist/siemens-ix/p-cc80918d.entry.js +0 -2
  714. package/dist/siemens-ix/p-d120adf6.entry.js +0 -2
  715. package/dist/siemens-ix/p-d120adf6.entry.js.map +0 -1
  716. package/dist/siemens-ix/p-dd89a190.entry.js +0 -2
  717. package/dist/siemens-ix/p-e3c57208.entry.js +0 -2
  718. package/dist/siemens-ix/p-eef311b1.entry.js +0 -2
  719. package/dist/siemens-ix/p-eef311b1.entry.js.map +0 -1
  720. package/dist/siemens-ix/p-f29f280b.entry.js +0 -2
  721. package/dist/siemens-ix/p-f82e4e0f.entry.js +0 -2
  722. package/dist/types/components/basic-navigation/basic-navigation.d.ts +0 -33
  723. package/dist/types/components/map-navigation/map-navigation.d.ts +0 -68
  724. package/dist/types/components/map-navigation-overlay/map-navigation-overlay.d.ts +0 -43
  725. package/scss/theme/core/components/map-navigation.scss +0 -20
  726. /package/dist/siemens-ix/{p-7cf61ff6.entry.js.map → p-011fe058.entry.js.map} +0 -0
  727. /package/dist/siemens-ix/{p-6f152ed2.entry.js.map → p-06a2c69b.entry.js.map} +0 -0
  728. /package/dist/siemens-ix/{p-0e2b89f2.entry.js.map → p-0fd006b9.entry.js.map} +0 -0
  729. /package/dist/siemens-ix/{p-a4d6ee80.entry.js.map → p-11b1eaa3.entry.js.map} +0 -0
  730. /package/dist/siemens-ix/{p-ad20efd0.entry.js.map → p-1550973a.entry.js.map} +0 -0
  731. /package/dist/siemens-ix/{p-f9b4e5f1.entry.js.map → p-162a4cc0.entry.js.map} +0 -0
  732. /package/dist/siemens-ix/{p-4448252f.entry.js.map → p-18d4645d.entry.js.map} +0 -0
  733. /package/dist/siemens-ix/{p-20ad8d1e.entry.js.map → p-1c83cb5f.entry.js.map} +0 -0
  734. /package/dist/siemens-ix/{p-01030dfb.entry.js.map → p-1de6e736.entry.js.map} +0 -0
  735. /package/dist/siemens-ix/{p-3b314194.entry.js.map → p-213f28c0.entry.js.map} +0 -0
  736. /package/dist/siemens-ix/{p-e25aa385.entry.js.map → p-23e4f5f3.entry.js.map} +0 -0
  737. /package/dist/siemens-ix/{p-34e530b9.entry.js.map → p-249f87ff.entry.js.map} +0 -0
  738. /package/dist/siemens-ix/{p-f3b485de.entry.js.map → p-277f6718.entry.js.map} +0 -0
  739. /package/dist/siemens-ix/{p-347fcf94.entry.js.map → p-2b2f339e.entry.js.map} +0 -0
  740. /package/dist/siemens-ix/{p-d49f7ae4.entry.js.map → p-2d96a4a1.entry.js.map} +0 -0
  741. /package/dist/siemens-ix/{p-80f55403.entry.js.map → p-305b3333.entry.js.map} +0 -0
  742. /package/dist/siemens-ix/{p-db9d5872.entry.js.map → p-306c889e.entry.js.map} +0 -0
  743. /package/dist/siemens-ix/{p-2db36aa6.entry.js.map → p-3099c12a.entry.js.map} +0 -0
  744. /package/dist/siemens-ix/{p-75d8b192.entry.js.map → p-39c321c1.entry.js.map} +0 -0
  745. /package/dist/siemens-ix/{p-608b3631.entry.js.map → p-418671c7.entry.js.map} +0 -0
  746. /package/dist/siemens-ix/{p-f753f1f5.entry.js.map → p-4288bd66.entry.js.map} +0 -0
  747. /package/dist/siemens-ix/{p-730a6161.entry.js.map → p-439d7ab7.entry.js.map} +0 -0
  748. /package/dist/siemens-ix/{p-4b1745dc.entry.js.map → p-49843cce.entry.js.map} +0 -0
  749. /package/dist/siemens-ix/{p-48cbacaf.entry.js.map → p-4d0e900c.entry.js.map} +0 -0
  750. /package/dist/siemens-ix/{p-b6736ce7.entry.js.map → p-4f6dee54.entry.js.map} +0 -0
  751. /package/dist/siemens-ix/{p-9c862819.entry.js.map → p-51bd3222.entry.js.map} +0 -0
  752. /package/dist/siemens-ix/{p-2f54ce99.entry.js.map → p-531f9746.entry.js.map} +0 -0
  753. /package/dist/siemens-ix/{p-337a3457.entry.js.map → p-53cc0fda.entry.js.map} +0 -0
  754. /package/dist/siemens-ix/{p-759ba03d.entry.js.map → p-598ece5a.entry.js.map} +0 -0
  755. /package/dist/siemens-ix/{p-81120f11.entry.js.map → p-5bb86bf7.entry.js.map} +0 -0
  756. /package/dist/siemens-ix/{p-67766c28.entry.js.map → p-5c22d3e5.entry.js.map} +0 -0
  757. /package/dist/siemens-ix/{p-9d8fb7dd.entry.js.map → p-6045dce9.entry.js.map} +0 -0
  758. /package/dist/siemens-ix/{p-17a74a48.entry.js.map → p-60d2f3db.entry.js.map} +0 -0
  759. /package/dist/siemens-ix/{p-fc3071d0.entry.js.map → p-619a3dc8.entry.js.map} +0 -0
  760. /package/dist/siemens-ix/{p-dd89a190.entry.js.map → p-620158aa.entry.js.map} +0 -0
  761. /package/dist/siemens-ix/{p-9d135d59.entry.js.map → p-6880e267.entry.js.map} +0 -0
  762. /package/dist/siemens-ix/{p-ecff1e2f.entry.js.map → p-6fd7d11a.entry.js.map} +0 -0
  763. /package/dist/siemens-ix/{p-e3c57208.entry.js.map → p-70af7f44.entry.js.map} +0 -0
  764. /package/dist/siemens-ix/{p-d4ba3f9f.entry.js.map → p-713df610.entry.js.map} +0 -0
  765. /package/dist/siemens-ix/{p-467c0fff.entry.js.map → p-7364534a.entry.js.map} +0 -0
  766. /package/dist/siemens-ix/{p-fea12773.entry.js.map → p-75a10c1e.entry.js.map} +0 -0
  767. /package/dist/siemens-ix/{p-67e4f814.entry.js.map → p-76bd4cf9.entry.js.map} +0 -0
  768. /package/dist/siemens-ix/{p-0d4f0223.entry.js.map → p-7827c263.entry.js.map} +0 -0
  769. /package/dist/siemens-ix/{p-65842e35.entry.js.map → p-79181aa7.entry.js.map} +0 -0
  770. /package/dist/siemens-ix/{p-e562ffb2.entry.js.map → p-7c474c82.entry.js.map} +0 -0
  771. /package/dist/siemens-ix/{p-548a2231.entry.js.map → p-7f0b0fa3.entry.js.map} +0 -0
  772. /package/dist/siemens-ix/{p-d8fb5a86.entry.js.map → p-80981f03.entry.js.map} +0 -0
  773. /package/dist/siemens-ix/{p-7388d2ee.entry.js.map → p-8532a932.entry.js.map} +0 -0
  774. /package/dist/siemens-ix/{p-04f1b89a.entry.js.map → p-8cb3d70c.entry.js.map} +0 -0
  775. /package/dist/siemens-ix/{p-784c6dd6.entry.js.map → p-8ce61408.entry.js.map} +0 -0
  776. /package/dist/siemens-ix/{p-c0064123.entry.js.map → p-8f17f6ec.entry.js.map} +0 -0
  777. /package/dist/siemens-ix/{p-3472fc1a.entry.js.map → p-8fc2bea6.entry.js.map} +0 -0
  778. /package/dist/siemens-ix/{p-9e7223f6.entry.js.map → p-905d4977.entry.js.map} +0 -0
  779. /package/dist/siemens-ix/{p-538843d4.entry.js.map → p-92e0ebf1.entry.js.map} +0 -0
  780. /package/dist/siemens-ix/{p-3acbbe01.entry.js.map → p-94596bff.entry.js.map} +0 -0
  781. /package/dist/siemens-ix/{p-e825a921.entry.js.map → p-97c3d27e.entry.js.map} +0 -0
  782. /package/dist/siemens-ix/{p-957d0d0b.entry.js.map → p-9a4db5e9.entry.js.map} +0 -0
  783. /package/dist/siemens-ix/{p-7e6beda5.entry.js.map → p-9f7f5cd3.entry.js.map} +0 -0
  784. /package/dist/siemens-ix/{p-85f3aa13.entry.js.map → p-a0ffeea7.entry.js.map} +0 -0
  785. /package/dist/siemens-ix/{p-58219b7e.entry.js.map → p-a2829e55.entry.js.map} +0 -0
  786. /package/dist/siemens-ix/{p-4f2fb1c5.entry.js.map → p-a4c8457e.entry.js.map} +0 -0
  787. /package/dist/siemens-ix/{p-c4b26603.entry.js.map → p-a6e398d2.entry.js.map} +0 -0
  788. /package/dist/siemens-ix/{p-aa6368b4.entry.js.map → p-acb7c236.entry.js.map} +0 -0
  789. /package/dist/siemens-ix/{p-788e1ef8.entry.js.map → p-b2aa549b.entry.js.map} +0 -0
  790. /package/dist/siemens-ix/{p-89449e22.entry.js.map → p-b7c64537.entry.js.map} +0 -0
  791. /package/dist/siemens-ix/{p-d1941577.entry.js.map → p-bb744e91.entry.js.map} +0 -0
  792. /package/dist/siemens-ix/{p-94fa5d00.entry.js.map → p-be78352f.entry.js.map} +0 -0
  793. /package/dist/siemens-ix/{p-845054ca.entry.js.map → p-c6536a88.entry.js.map} +0 -0
  794. /package/dist/siemens-ix/{p-cc80918d.entry.js.map → p-ca43aa61.entry.js.map} +0 -0
  795. /package/dist/siemens-ix/{p-8aa0fda7.entry.js.map → p-cc7f7788.entry.js.map} +0 -0
  796. /package/dist/siemens-ix/{p-92a6324b.entry.js.map → p-d18df859.entry.js.map} +0 -0
  797. /package/dist/siemens-ix/{p-a02e0685.entry.js.map → p-d2831f7b.entry.js.map} +0 -0
  798. /package/dist/siemens-ix/{p-dff78943.entry.js.map → p-d90d1310.entry.js.map} +0 -0
  799. /package/dist/siemens-ix/{p-fabcc5f5.entry.js.map → p-d997238b.entry.js.map} +0 -0
  800. /package/dist/siemens-ix/{p-41b9392e.entry.js.map → p-da3a9845.entry.js.map} +0 -0
  801. /package/dist/siemens-ix/{p-51786593.entry.js.map → p-df5494ff.entry.js.map} +0 -0
  802. /package/dist/siemens-ix/{p-79798af1.entry.js.map → p-e3dca831.entry.js.map} +0 -0
  803. /package/dist/siemens-ix/{p-eebe632b.entry.js.map → p-e5180acd.entry.js.map} +0 -0
  804. /package/dist/siemens-ix/{p-b5e0ddb3.entry.js.map → p-ea410634.entry.js.map} +0 -0
  805. /package/dist/siemens-ix/{p-39950a1c.entry.js.map → p-f253d38c.entry.js.map} +0 -0
  806. /package/dist/siemens-ix/{p-da6a27c1.entry.js.map → p-fb02d7fd.entry.js.map} +0 -0
  807. /package/dist/siemens-ix/{p-08f4c3f0.entry.js.map → p-fdb802ac.entry.js.map} +0 -0
  808. /package/dist/siemens-ix/{p-7e612a3b.entry.js.map → p-fe5bf44b.entry.js.map} +0 -0
  809. /package/dist/siemens-ix/{p-1f5befb2.entry.js.map → p-ff6f13e1.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"file":"p-BEzKnceP.js","mappings":"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","names":["__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/avatar/avatar.scss?tag=ix-avatar&encapsulation=shadow","src/components/avatar/avatar.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 './../button/button-mixin';\n@use 'mixins/text-truncation';\n@use 'mixins/hover';\n@use 'mixins/scrollbar';\n\n:host {\n display: flex;\n position: relative;\n width: fit-content;\n\n @include scrollbar.scrollbar();\n\n .avatar {\n display: flex;\n align-items: center;\n\n > .avatar-image {\n height: 2rem;\n width: 2rem;\n min-height: 2rem;\n min-width: 2rem;\n border-radius: 100px;\n }\n\n > .avatar-initials {\n display: flex;\n align-items: center;\n justify-content: center;\n height: 2rem;\n width: 2rem;\n min-height: 2rem;\n min-width: 2rem;\n border-radius: 100px;\n background-color: var(--theme-avatar--background);\n color: var(--theme-avatar--color);\n\n > ix-typography {\n // Fix to get the text vertically centered\n margin-top: 1px;\n }\n }\n\n #avatar-path-background {\n fill: var(--theme-avatar--background);\n }\n\n #avatar-path-person {\n fill: var(--theme-avatar--color);\n }\n }\n}\n\n:host {\n .user-info {\n display: flex;\n flex-direction: row;\n position: relative;\n height: 2.5rem;\n padding: 1rem;\n width: 12.75rem;\n min-width: 12.75rem;\n max-width: 12.75rem;\n\n gap: 1rem;\n\n .avatar {\n width: 2rem;\n pointer-events: none;\n }\n\n .user {\n display: flex;\n position: relative;\n flex-direction: column;\n justify-content: center;\n max-width: 10rem;\n width: 100%;\n overflow: hidden;\n }\n\n .username {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .extra {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n}\n\n:host(.avatar-button) {\n button {\n border-radius: 100px !important;\n\n @include button-mixin.btn-base;\n\n & {\n padding: 0px;\n }\n }\n\n @include button-mixin.btn-base-variant('tertiary');\n\n .avatar {\n transform: scale(0.8);\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 Fragment,\n h,\n Host,\n Prop,\n readTask,\n State,\n} from '@stencil/core';\nimport { BaseButton } from '../button/base-button';\nimport { a11yBoolean, a11yHostAttributes } from '../utils/a11y';\nimport { makeRef } from '../utils/make-ref';\nimport { closestElement, hasSlottedElements } from '../utils/shadow-dom';\n\nfunction DefaultAvatar(\n props: Readonly<{ initials?: string; a11yLabel?: string }>\n) {\n const { initials } = props;\n\n if (initials) {\n return (\n <div class={'avatar-initials'}>\n <ix-typography format=\"label-lg\">{initials}</ix-typography>\n </div>\n );\n }\n\n return (\n <svg\n class={'avatar-image'}\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"32\"\n height=\"32\"\n viewBox=\"0 0 32 32\"\n aria-label={props.a11yLabel}\n >\n <g fill=\"none\" fill-rule=\"evenodd\">\n <path\n id=\"avatar-path-background\"\n d=\"M16 0C7.163 0 0 7.163 0 16s7.163 16 16 16 16-7.163\n 16-16c0-4.243-1.686-8.313-4.686-11.314C24.314 1.686 20.244 0 16 0z\"\n />\n <path\n id=\"avatar-path-person\"\n d=\"M17.897 17.91c3.8-.018 7.358 1.875 9.485 5.046-2.417 3.999-6.734 6.434-11.382\n 6.42-4.648.014-8.965-2.421-11.382-6.42 2.127-3.171 5.685-5.064\n 9.485-5.045h3.794zM15.821 2.129c3.682 0 6.667 2.984 6.667 6.666 0 3.682-2.985\n 6.667-6.667 6.667s-6.667-2.985-6.667-6.667 2.985-6.666 6.667-6.666z\"\n />\n </g>\n </svg>\n );\n}\n\nfunction AvatarImage(\n props: Readonly<{\n image?: string;\n initials?: string;\n a11yLabel?: string;\n }>\n) {\n return (\n <div class=\"avatar\">\n {props.image ? (\n <img\n src={props.image}\n class=\"avatar-image\"\n aria-label={props.a11yLabel}\n ></img>\n ) : (\n <DefaultAvatar initials={props.initials} a11yLabel={props.a11yLabel} />\n )}\n </div>\n );\n}\n\nfunction UserInfo(\n props: Readonly<{\n image?: string;\n initials?: string;\n userName: string;\n extra?: string;\n a11yLabel?: string;\n }>\n) {\n return (\n <Fragment>\n <div class=\"user-info\" onClick={(event) => event.preventDefault()}>\n <AvatarImage\n image={props.image}\n initials={props.initials}\n a11yLabel={props.a11yLabel}\n />\n <div class=\"user\">\n <div class=\"username\">{props.userName}</div>\n {props.extra && (\n <ix-typography class=\"extra\" text-color={'soft'}>\n {props.extra}\n </ix-typography>\n )}\n </div>\n </div>\n </Fragment>\n );\n}\n\n@Component({\n tag: 'ix-avatar',\n styleUrl: 'avatar.scss',\n shadow: true,\n})\nexport class Avatar {\n @Element() hostElement!: HTMLIxAvatarElement;\n\n /**\n * Accessibility label for the image\n * Will be set as aria-label on the nested HTML img element\n *\n * @deprecated Set the native `aria-label` on the ix-avatar host element. Will be removed in 5.0.0\n */\n @Prop({ attribute: 'a11y-label' }) a11yLabel?: string;\n\n /**\n * Display an avatar image\n *\n */\n @Prop() image?: string;\n\n /**\n * Display the initials of the user. Will be overwritten by image\n *\n */\n @Prop() initials?: string;\n\n /**\n * If set an info card displaying the username will be placed inside the dropdown.\n * Note: Only working if avatar is part of the ix-application-header\n */\n @Prop() username?: string;\n\n /**\n * Optional description text that will be displayed underneath the username.\n * Note: Only working if avatar is part of the ix-application-header\n */\n @Prop() extra?: string;\n\n /**\n * Text to display in a tooltip when hovering over the avatar\n *\n * @since 4.0.0\n */\n @Prop() tooltipText?: string;\n\n /**\n * aria-label for the tooltip\n *\n * @since 4.0.0\n */\n @Prop() ariaLabelTooltip?: string;\n\n @State() isClosestApplicationHeader = false;\n @State() hasSlottedElements = false;\n\n private slotElement?: HTMLSlotElement;\n private dropdownElement?: HTMLIxDropdownElement;\n\n private readonly tooltipRef = makeRef<HTMLIxTooltipElement>();\n\n componentWillLoad() {\n const closest = closestElement('ix-application-header', this.hostElement);\n this.isClosestApplicationHeader = closest !== null;\n }\n\n private async slottedChanged() {\n this.hasSlottedElements = hasSlottedElements(this.slotElement);\n }\n\n private resolveAvatarTrigger() {\n return new Promise<HTMLElement>((resolve, reject) => {\n readTask(() => {\n const button = this.hostElement.shadowRoot!.querySelector('button');\n if (button) {\n resolve(button);\n } else {\n reject(new Error('ix-avatar - trigger element not found'));\n }\n });\n });\n }\n\n private onDropdownClick(event: MouseEvent) {\n if (event.target === this.dropdownElement) {\n event.preventDefault();\n }\n }\n\n render() {\n const a11y = a11yHostAttributes(this.hostElement);\n const a11yLabel = a11y['aria-label'];\n\n const tooltipText = this.tooltipText || this.username;\n const ariaHidden = tooltipText === this.username;\n\n const Avatar = (\n <Fragment>\n <AvatarImage\n image={this.image}\n initials={this.initials}\n a11yLabel={a11yLabel ?? this.a11yLabel}\n />\n {!!tooltipText && (\n <ix-tooltip\n ref={this.tooltipRef}\n for={this.hostElement}\n aria-hidden={a11yBoolean(ariaHidden)}\n aria-label={this.ariaLabelTooltip}\n >\n {tooltipText}\n </ix-tooltip>\n )}\n </Fragment>\n );\n\n if (this.isClosestApplicationHeader) {\n return (\n <Host slot=\"ix-application-header-avatar\" class={'avatar-button'}>\n <BaseButton\n disabled={false}\n iconOval={false}\n icon={undefined}\n iconOnly={false}\n loading={false}\n selected={false}\n type=\"button\"\n variant=\"tertiary\"\n >\n {Avatar}\n </BaseButton>\n <ix-dropdown\n ref={(ref) => (this.dropdownElement = ref as HTMLIxDropdownElement)}\n trigger={this.resolveAvatarTrigger()}\n class=\"avatar-dropdown\"\n onClick={(e) => this.onDropdownClick(e)}\n onShowChanged={(event) => {\n if (event.detail && this.tooltipRef.current) {\n this.tooltipRef.current.hideTooltip(0);\n }\n }}\n >\n {this.username && (\n <Fragment>\n <UserInfo\n extra={this.extra}\n image={this.image}\n initials={this.initials}\n userName={this.username}\n a11yLabel={a11yLabel ?? this.a11yLabel}\n />\n {this.hasSlottedElements && (\n <ix-divider onClick={(e) => e.preventDefault()}></ix-divider>\n )}\n </Fragment>\n )}\n <slot\n onSlotchange={() => this.slottedChanged()}\n ref={(ref) => (this.slotElement = ref as HTMLSlotElement)}\n ></slot>\n </ix-dropdown>\n </Host>\n );\n }\n\n return <Host>{Avatar}</Host>;\n }\n}\n"],"version":3}
1
+ {"file":"p-s425oBQi.js","mappings":"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","names":["__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/avatar/avatar.scss?tag=ix-avatar&encapsulation=shadow","src/components/avatar/avatar.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 './../button/button-mixin';\n@use 'mixins/text-truncation';\n@use 'mixins/hover';\n@use 'mixins/scrollbar';\n\n:host {\n display: flex;\n position: relative;\n width: fit-content;\n\n @include scrollbar.scrollbar();\n\n .avatar {\n display: flex;\n align-items: center;\n\n > .avatar-image {\n height: 2rem;\n width: 2rem;\n min-height: 2rem;\n min-width: 2rem;\n border-radius: 100px;\n }\n\n > .avatar-initials {\n display: flex;\n align-items: center;\n justify-content: center;\n height: 2rem;\n width: 2rem;\n min-height: 2rem;\n min-width: 2rem;\n border-radius: 100px;\n background-color: var(--theme-avatar--background);\n color: var(--theme-avatar--color);\n\n > ix-typography {\n // Fix to get the text vertically centered\n margin-top: 1px;\n }\n }\n\n #avatar-path-background {\n fill: var(--theme-avatar--background);\n }\n\n #avatar-path-person {\n fill: var(--theme-avatar--color);\n }\n }\n}\n\n:host {\n .user-info {\n display: flex;\n flex-direction: row;\n position: relative;\n height: 2.5rem;\n padding: 1rem;\n width: 12.75rem;\n min-width: 12.75rem;\n max-width: 12.75rem;\n\n gap: 1rem;\n\n .avatar {\n width: 2rem;\n pointer-events: none;\n }\n\n .user {\n display: flex;\n position: relative;\n flex-direction: column;\n justify-content: center;\n max-width: 10rem;\n width: 100%;\n overflow: hidden;\n }\n\n .username {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .extra {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n}\n\n:host(.avatar-button) {\n button {\n border-radius: 100px !important;\n\n @include button-mixin.btn-base;\n\n & {\n padding: 0px;\n }\n }\n\n @include button-mixin.btn-base-variant('tertiary');\n\n .avatar {\n transform: scale(0.8);\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 Fragment,\n h,\n Host,\n Prop,\n readTask,\n State,\n} from '@stencil/core';\nimport { BaseButton } from '../button/base-button';\nimport { a11yBoolean, a11yHostAttributes } from '../utils/a11y';\nimport { makeRef } from '../utils/make-ref';\nimport { closestElement, hasSlottedElements } from '../utils/shadow-dom';\n\nfunction DefaultAvatar(\n props: Readonly<{ initials?: string; a11yLabel?: string }>\n) {\n const { initials } = props;\n\n if (initials) {\n return (\n <div class={'avatar-initials'}>\n <ix-typography format=\"label-lg\">{initials}</ix-typography>\n </div>\n );\n }\n\n return (\n <svg\n class={'avatar-image'}\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"32\"\n height=\"32\"\n viewBox=\"0 0 32 32\"\n aria-label={props.a11yLabel}\n >\n <g fill=\"none\" fill-rule=\"evenodd\">\n <path\n id=\"avatar-path-background\"\n d=\"M16 0C7.163 0 0 7.163 0 16s7.163 16 16 16 16-7.163\n 16-16c0-4.243-1.686-8.313-4.686-11.314C24.314 1.686 20.244 0 16 0z\"\n />\n <path\n id=\"avatar-path-person\"\n d=\"M17.897 17.91c3.8-.018 7.358 1.875 9.485 5.046-2.417 3.999-6.734 6.434-11.382\n 6.42-4.648.014-8.965-2.421-11.382-6.42 2.127-3.171 5.685-5.064\n 9.485-5.045h3.794zM15.821 2.129c3.682 0 6.667 2.984 6.667 6.666 0 3.682-2.985\n 6.667-6.667 6.667s-6.667-2.985-6.667-6.667 2.985-6.666 6.667-6.666z\"\n />\n </g>\n </svg>\n );\n}\n\nfunction AvatarImage(\n props: Readonly<{\n image?: string;\n initials?: string;\n a11yLabel?: string;\n }>\n) {\n return (\n <div class=\"avatar\">\n {props.image ? (\n <img\n src={props.image}\n class=\"avatar-image\"\n aria-label={props.a11yLabel}\n ></img>\n ) : (\n <DefaultAvatar initials={props.initials} a11yLabel={props.a11yLabel} />\n )}\n </div>\n );\n}\n\nfunction UserInfo(\n props: Readonly<{\n image?: string;\n initials?: string;\n userName: string;\n extra?: string;\n a11yLabel?: string;\n }>\n) {\n return (\n <Fragment>\n <div class=\"user-info\" onClick={(event) => event.preventDefault()}>\n <AvatarImage\n image={props.image}\n initials={props.initials}\n a11yLabel={props.a11yLabel}\n />\n <div class=\"user\">\n <div class=\"username\">{props.userName}</div>\n {props.extra && (\n <ix-typography class=\"extra\" text-color={'soft'}>\n {props.extra}\n </ix-typography>\n )}\n </div>\n </div>\n </Fragment>\n );\n}\n\n@Component({\n tag: 'ix-avatar',\n styleUrl: 'avatar.scss',\n shadow: true,\n})\nexport class Avatar {\n @Element() hostElement!: HTMLIxAvatarElement;\n\n /**\n * Accessibility label for the image\n * Will be set as aria-label on the nested HTML img element\n *\n * @deprecated Set the native `aria-label` on the ix-avatar host element. Will be removed in 5.0.0\n */\n @Prop({ attribute: 'a11y-label' }) a11yLabel?: string;\n\n /**\n * Display an avatar image\n *\n */\n @Prop() image?: string;\n\n /**\n * Display the initials of the user. Will be overwritten by image\n *\n */\n @Prop() initials?: string;\n\n /**\n * If set an info card displaying the username will be placed inside the dropdown.\n * Note: Only working if avatar is part of the ix-application-header\n */\n @Prop() username?: string;\n\n /**\n * Optional description text that will be displayed underneath the username.\n * Note: Only working if avatar is part of the ix-application-header\n */\n @Prop() extra?: string;\n\n /**\n * Text to display in a tooltip when hovering over the avatar\n *\n * @since 4.0.0\n */\n @Prop() tooltipText?: string;\n\n /**\n * aria-label for the tooltip\n *\n * @since 4.0.0\n */\n @Prop() ariaLabelTooltip?: string;\n\n @State() isClosestApplicationHeader = false;\n @State() hasSlottedElements = false;\n\n private slotElement?: HTMLSlotElement;\n private dropdownElement?: HTMLIxDropdownElement;\n\n private readonly tooltipRef = makeRef<HTMLIxTooltipElement>();\n\n componentWillLoad() {\n const closest = closestElement('ix-application-header', this.hostElement);\n this.isClosestApplicationHeader = closest !== null;\n }\n\n private async slottedChanged() {\n this.hasSlottedElements = hasSlottedElements(this.slotElement);\n }\n\n private resolveAvatarTrigger() {\n return new Promise<HTMLElement>((resolve, reject) => {\n readTask(() => {\n const button = this.hostElement.shadowRoot!.querySelector('button');\n if (button) {\n resolve(button);\n } else {\n reject(new Error('ix-avatar - trigger element not found'));\n }\n });\n });\n }\n\n private onDropdownClick(event: MouseEvent) {\n if (event.target === this.dropdownElement) {\n event.preventDefault();\n }\n }\n\n render() {\n const a11y = a11yHostAttributes(this.hostElement);\n const a11yLabel = a11y['aria-label'];\n\n const tooltipText = this.tooltipText || this.username;\n const ariaHidden = tooltipText === this.username;\n\n const Avatar = (\n <Fragment>\n <AvatarImage\n image={this.image}\n initials={this.initials}\n a11yLabel={a11yLabel ?? this.a11yLabel}\n />\n {!!tooltipText && (\n <ix-tooltip\n ref={this.tooltipRef}\n for={this.hostElement}\n aria-hidden={a11yBoolean(ariaHidden)}\n aria-label={this.ariaLabelTooltip}\n >\n {tooltipText}\n </ix-tooltip>\n )}\n </Fragment>\n );\n\n if (this.isClosestApplicationHeader) {\n return (\n <Host slot=\"ix-application-header-avatar\" class={'avatar-button'}>\n <BaseButton\n disabled={false}\n iconOval={false}\n icon={undefined}\n iconOnly={false}\n loading={false}\n selected={false}\n type=\"button\"\n variant=\"tertiary\"\n >\n {Avatar}\n </BaseButton>\n <ix-dropdown\n ref={(ref) => (this.dropdownElement = ref as HTMLIxDropdownElement)}\n trigger={this.resolveAvatarTrigger()}\n class=\"avatar-dropdown\"\n onClick={(e) => this.onDropdownClick(e)}\n onShowChanged={(event) => {\n if (event.detail && this.tooltipRef.current) {\n this.tooltipRef.current.hideTooltip(0);\n }\n }}\n >\n {this.username && (\n <Fragment>\n <UserInfo\n extra={this.extra}\n image={this.image}\n initials={this.initials}\n userName={this.username}\n a11yLabel={a11yLabel ?? this.a11yLabel}\n />\n {this.hasSlottedElements && (\n <ix-divider onClick={(e) => e.preventDefault()}></ix-divider>\n )}\n </Fragment>\n )}\n <slot\n onSlotchange={() => this.slottedChanged()}\n ref={(ref) => (this.slotElement = ref as HTMLSlotElement)}\n ></slot>\n </ix-dropdown>\n </Host>\n );\n }\n\n return <Host>{Avatar}</Host>;\n }\n}\n"],"version":3}
@@ -1,4 +1,4 @@
1
- import { j as getElement } from './p-CKuNFgoe.js';
1
+ import { j as getElement } from './p-D-__gyet.js';
2
2
 
3
3
  /*
4
4
  * SPDX-FileCopyrightText: 2024 Siemens AG
@@ -114,6 +114,6 @@ function HookValidationLifecycle(options) {
114
114
  }
115
115
 
116
116
  export { HookValidationLifecycle as H, checkFieldClasses as a, createClassMutationObserver as c, shouldSuppressInternalValidation as s };
117
- //# sourceMappingURL=p-2fxFa_VL.js.map
117
+ //# sourceMappingURL=p-xHo-3QVy.js.map
118
118
 
119
- //# sourceMappingURL=p-2fxFa_VL.js.map
119
+ //# sourceMappingURL=p-xHo-3QVy.js.map
@@ -1 +1 @@
1
- {"file":"p-2fxFa_VL.js","mappings":"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","names":[],"sources":["src/components/utils/input/validation.ts"],"sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { getElement } from '@stencil/core';\nimport { HTMLIxFormComponentElement, IxFormComponent } from '.';\nimport { IxComponent } from '../internal';\n\nexport type ClassMutationObserver = {\n destroy: () => void;\n};\n\nexport async function isTouched<T>(host: IxFormComponent<T>) {\n if (typeof host.isTouched === 'function') {\n return host.isTouched();\n }\n}\n\nexport async function shouldSuppressInternalValidation<T>(\n host: IxFormComponent<T>\n) {\n if (\n host.getAssociatedFormElement &&\n typeof host.getAssociatedFormElement === 'function'\n ) {\n const form = await host.getAssociatedFormElement();\n\n if (!form) {\n return false;\n }\n\n return form.noValidate;\n }\n\n return false;\n}\n\nexport function createClassMutationObserver(\n element: HTMLElement,\n callback: () => void,\n options?: {\n includeChildren?: boolean;\n }\n): ClassMutationObserver {\n const observer = new MutationObserver(callback);\n observer.observe(element, {\n subtree: options?.includeChildren,\n childList: options?.includeChildren,\n attributes: true,\n attributeFilter: ['class'],\n });\n\n return {\n destroy() {\n observer.disconnect();\n },\n };\n}\n\nexport type ValidationResultProperty =\n | 'isInvalid'\n | 'isInvalidByRequired'\n | 'isValid'\n | 'isInfo'\n | 'isWarning';\nexport type ValidationResults = Record<ValidationResultProperty, boolean>;\n\nfunction classListContains(\n hostElement: HTMLIxFormComponentElement<unknown>,\n className: string,\n includeChildren: boolean\n) {\n return (\n hostElement.classList.contains(`${className}`) ||\n (includeChildren ? !!hostElement.querySelector(`.${className}`) : false)\n );\n}\n\nexport function checkFieldClasses(\n hostElement: HTMLIxFormComponentElement<unknown>,\n includeChildren = false\n): ValidationResults {\n return {\n isInvalid:\n classListContains(hostElement, 'ix-invalid', includeChildren) ||\n classListContains(\n hostElement,\n 'ix-invalid--validity-invalid',\n includeChildren\n ),\n isInvalidByRequired: classListContains(\n hostElement,\n 'ix-invalid--required',\n includeChildren\n ),\n isValid: classListContains(hostElement, 'ix-valid', includeChildren),\n isInfo: classListContains(hostElement, 'ix-info', includeChildren),\n isWarning: classListContains(hostElement, 'ix-warning', includeChildren),\n };\n}\n\nexport function HookValidationLifecycle(options?: {\n includeChildren?: boolean;\n}) {\n return (proto: IxComponent, methodName: string) => {\n let checkIfRequiredFunction: (() => Promise<void>) | null;\n let classMutationObserver: ClassMutationObserver | null;\n const { componentWillLoad, disconnectedCallback, connectedCallback } =\n proto;\n\n proto.connectedCallback = function () {\n const host = getElement(\n this\n ) as unknown as HTMLIxFormComponentElement<unknown>;\n\n checkIfRequiredFunction = async () => {\n const skipValidation = await shouldSuppressInternalValidation(host);\n if (skipValidation) {\n return;\n }\n\n if (host.hasValidValue && typeof host.hasValidValue === 'function') {\n const hasValue = await host.hasValidValue();\n const touched = await isTouched(host);\n\n if (host.required) {\n host.classList.toggle('ix-invalid--required', !hasValue && touched);\n } else {\n host.classList.remove('ix-invalid--required');\n }\n }\n\n if (\n host.getValidityState &&\n typeof host.getValidityState === 'function'\n ) {\n const validityState = await host.getValidityState();\n\n host.classList.toggle(\n `ix-invalid--validity-patternMismatch`,\n validityState.patternMismatch\n );\n }\n };\n\n host.addEventListener('checkedChange', checkIfRequiredFunction);\n host.addEventListener('valueChange', checkIfRequiredFunction);\n host.addEventListener('ixBlur', checkIfRequiredFunction);\n setTimeout(checkIfRequiredFunction);\n return connectedCallback?.call(this);\n };\n\n proto.componentWillLoad = function () {\n const host = getElement(\n this\n ) as unknown as HTMLIxFormComponentElement<unknown>;\n classMutationObserver = createClassMutationObserver(\n host,\n () => {\n const result = checkFieldClasses(host, options?.includeChildren);\n proto[methodName].call(this, result);\n },\n options\n );\n const result = checkFieldClasses(host, options?.includeChildren);\n proto[methodName].call(this, result);\n return componentWillLoad?.call(this);\n };\n\n proto.disconnectedCallback = function () {\n const host = getElement(this);\n\n if (host && classMutationObserver) {\n classMutationObserver.destroy();\n classMutationObserver = null;\n }\n\n if (host && checkIfRequiredFunction) {\n host.removeEventListener('checkedChange', checkIfRequiredFunction);\n host.removeEventListener('valueChange', checkIfRequiredFunction);\n host.removeEventListener('ixBlur', checkIfRequiredFunction);\n checkIfRequiredFunction = null;\n }\n\n return disconnectedCallback?.call(this);\n };\n };\n}\n"],"version":3}
1
+ {"file":"p-xHo-3QVy.js","mappings":"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","names":[],"sources":["src/components/utils/input/validation.ts"],"sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { getElement } from '@stencil/core';\nimport { HTMLIxFormComponentElement, IxFormComponent } from '.';\nimport { IxComponent } from '../internal';\n\nexport type ClassMutationObserver = {\n destroy: () => void;\n};\n\nexport async function isTouched<T>(host: IxFormComponent<T>) {\n if (typeof host.isTouched === 'function') {\n return host.isTouched();\n }\n}\n\nexport async function shouldSuppressInternalValidation<T>(\n host: IxFormComponent<T>\n) {\n if (\n host.getAssociatedFormElement &&\n typeof host.getAssociatedFormElement === 'function'\n ) {\n const form = await host.getAssociatedFormElement();\n\n if (!form) {\n return false;\n }\n\n return form.noValidate;\n }\n\n return false;\n}\n\nexport function createClassMutationObserver(\n element: HTMLElement,\n callback: () => void,\n options?: {\n includeChildren?: boolean;\n }\n): ClassMutationObserver {\n const observer = new MutationObserver(callback);\n observer.observe(element, {\n subtree: options?.includeChildren,\n childList: options?.includeChildren,\n attributes: true,\n attributeFilter: ['class'],\n });\n\n return {\n destroy() {\n observer.disconnect();\n },\n };\n}\n\nexport type ValidationResultProperty =\n | 'isInvalid'\n | 'isInvalidByRequired'\n | 'isValid'\n | 'isInfo'\n | 'isWarning';\nexport type ValidationResults = Record<ValidationResultProperty, boolean>;\n\nfunction classListContains(\n hostElement: HTMLIxFormComponentElement<unknown>,\n className: string,\n includeChildren: boolean\n) {\n return (\n hostElement.classList.contains(`${className}`) ||\n (includeChildren ? !!hostElement.querySelector(`.${className}`) : false)\n );\n}\n\nexport function checkFieldClasses(\n hostElement: HTMLIxFormComponentElement<unknown>,\n includeChildren = false\n): ValidationResults {\n return {\n isInvalid:\n classListContains(hostElement, 'ix-invalid', includeChildren) ||\n classListContains(\n hostElement,\n 'ix-invalid--validity-invalid',\n includeChildren\n ),\n isInvalidByRequired: classListContains(\n hostElement,\n 'ix-invalid--required',\n includeChildren\n ),\n isValid: classListContains(hostElement, 'ix-valid', includeChildren),\n isInfo: classListContains(hostElement, 'ix-info', includeChildren),\n isWarning: classListContains(hostElement, 'ix-warning', includeChildren),\n };\n}\n\nexport function HookValidationLifecycle(options?: {\n includeChildren?: boolean;\n}) {\n return (proto: IxComponent, methodName: string) => {\n let checkIfRequiredFunction: (() => Promise<void>) | null;\n let classMutationObserver: ClassMutationObserver | null;\n const { componentWillLoad, disconnectedCallback, connectedCallback } =\n proto;\n\n proto.connectedCallback = function () {\n const host = getElement(\n this\n ) as unknown as HTMLIxFormComponentElement<unknown>;\n\n checkIfRequiredFunction = async () => {\n const skipValidation = await shouldSuppressInternalValidation(host);\n if (skipValidation) {\n return;\n }\n\n if (host.hasValidValue && typeof host.hasValidValue === 'function') {\n const hasValue = await host.hasValidValue();\n const touched = await isTouched(host);\n\n if (host.required) {\n host.classList.toggle('ix-invalid--required', !hasValue && touched);\n } else {\n host.classList.remove('ix-invalid--required');\n }\n }\n\n if (\n host.getValidityState &&\n typeof host.getValidityState === 'function'\n ) {\n const validityState = await host.getValidityState();\n\n host.classList.toggle(\n `ix-invalid--validity-patternMismatch`,\n validityState.patternMismatch\n );\n }\n };\n\n host.addEventListener('checkedChange', checkIfRequiredFunction);\n host.addEventListener('valueChange', checkIfRequiredFunction);\n host.addEventListener('ixBlur', checkIfRequiredFunction);\n setTimeout(checkIfRequiredFunction);\n return connectedCallback?.call(this);\n };\n\n proto.componentWillLoad = function () {\n const host = getElement(\n this\n ) as unknown as HTMLIxFormComponentElement<unknown>;\n classMutationObserver = createClassMutationObserver(\n host,\n () => {\n const result = checkFieldClasses(host, options?.includeChildren);\n proto[methodName].call(this, result);\n },\n options\n );\n const result = checkFieldClasses(host, options?.includeChildren);\n proto[methodName].call(this, result);\n return componentWillLoad?.call(this);\n };\n\n proto.disconnectedCallback = function () {\n const host = getElement(this);\n\n if (host && classMutationObserver) {\n classMutationObserver.destroy();\n classMutationObserver = null;\n }\n\n if (host && checkIfRequiredFunction) {\n host.removeEventListener('checkedChange', checkIfRequiredFunction);\n host.removeEventListener('valueChange', checkIfRequiredFunction);\n host.removeEventListener('ixBlur', checkIfRequiredFunction);\n checkIfRequiredFunction = null;\n }\n\n return disconnectedCallback?.call(this);\n };\n };\n}\n"],"version":3}
@@ -97,7 +97,6 @@ const closestIxMenu = (element) => {
97
97
  };
98
98
  const ApplicationLayoutContext = createContext('application-layout-context', {
99
99
  hideHeader: false,
100
- host: null,
101
100
  sidebar: false,
102
101
  });
103
102
 
@@ -105,6 +104,6 @@ exports.ApplicationLayoutContext = ApplicationLayoutContext;
105
104
  exports.closestIxMenu = closestIxMenu;
106
105
  exports.useContextConsumer = useContextConsumer;
107
106
  exports.useContextProvider = useContextProvider;
108
- //# sourceMappingURL=context-B8bRIFA2.js.map
107
+ //# sourceMappingURL=context-CmNuiaNz.js.map
109
108
 
110
- //# sourceMappingURL=context-B8bRIFA2.js.map
109
+ //# sourceMappingURL=context-CmNuiaNz.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"context-CKM5pVsv.js","sources":["src/components/utils/context.ts","src/components/utils/application-layout/context.ts"],"sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { TypedEvent } from './typed-event';\n\n/**\n * A Context object defines an optional initial value for a Context, as well as a name identifier for debugging purposes.\n */\nexport type Context<T> = {\n name: string;\n initialValue?: T;\n};\n\n/**\n * An unknown context type\n */\nexport type UnknownContext = Context<unknown>;\n\n/**\n * A helper type which can extract a Context value type from a Context type\n */\nexport type ContextType<T extends UnknownContext> =\n T extends Context<infer Y> ? Y : never;\n\n/**\n * A function which creates a Context value object\n */\nexport function createContext<T>(\n name: string,\n initialValue?: T\n): Readonly<Context<T>> {\n return {\n name,\n initialValue,\n };\n}\n\n/**\n * A callback which is provided by a context requester and is called with the value satisfying the request.\n * This callback can be called multiple times by context providers as the requested value is changed.\n */\nexport type ContextCallback<ValueType> = (\n value: ValueType,\n unsubscribe?: () => void\n) => void;\n\n/**\n * An event fired by a context requester to signal it desires a named context.\n *\n * A provider should inspect the `context` property of the event to determine if it has a value that can\n * satisfy the request, calling the `callback` with the requested value if so.\n *\n * If the requested context event contains a truthy `subscribe` value, then a provider can call the callback\n * multiple times if the value is changed, if this is the case the provider should pass an `unsubscribe`\n * function to the callback which requesters can invoke to indicate they no longer wish to receive these updates.\n */\nexport class ContextEvent<T extends UnknownContext> extends Event {\n public constructor(\n public readonly context: T,\n public readonly callback: ContextCallback<ContextType<T>>,\n public readonly subscribe?: boolean\n ) {\n super('context-request', { bubbles: true, composed: true });\n }\n}\n\ndeclare global {\n interface HTMLElementEventMap {\n /**\n * A 'context-request' event can be emitted by any element which desires\n * a context value to be injected by an external provider.\n */\n 'context-request': ContextEvent<UnknownContext>;\n }\n}\n\nexport type ContextConsumerSubscription = {\n unsubscribe: () => void;\n};\n\nexport function useContextConsumer<\n T extends HTMLElement,\n C extends UnknownContext,\n>(\n hostElement: T,\n context: C,\n onContextReceived: (\n context: ContextType<C>,\n unsubscribe?: () => void\n ) => void,\n subscribe?: boolean\n): ContextConsumerSubscription {\n let _unsubscribe: (() => void) | undefined;\n hostElement.dispatchEvent(\n new ContextEvent(\n context,\n (ctx, unSub) => {\n onContextReceived(ctx, unSub);\n _unsubscribe = unSub;\n },\n subscribe\n )\n );\n\n return {\n unsubscribe: () => {\n if (_unsubscribe) {\n _unsubscribe();\n }\n },\n };\n}\nexport type ContextProvider<C extends Context<{}> = Context<any>> = {\n emit: (context: ContextType<C>) => void;\n};\n\nexport function useContextProvider<\n X extends {},\n C extends Context<X>,\n T extends HTMLElement = HTMLElement,\n>(\n hostElement: T,\n context: C,\n contextPayload?: ContextType<C>\n): ContextProvider<C> {\n const requestContext = new TypedEvent<ContextEvent<C>>();\n const updateContext = new TypedEvent<ContextType<C>>();\n\n const requests = new Set<ContextEvent<UnknownContext>>();\n\n hostElement.addEventListener('context-request', (event: Event) => {\n const requestContextEvent = event as ContextEvent<C>;\n if (requestContextEvent?.context.name !== context.name) {\n return;\n }\n\n requestContextEvent.stopPropagation();\n\n if (requestContextEvent.subscribe) {\n requests.add(requestContextEvent);\n }\n requestContext.emit(requestContextEvent);\n\n if (contextPayload) {\n requestContextEvent.callback(contextPayload, () => {\n requests.delete(requestContextEvent);\n });\n }\n });\n\n updateContext.on((context: ContextType<C>) => {\n requests.forEach((r) =>\n r.callback(context, () => {\n requests.delete(r);\n })\n );\n });\n\n return {\n emit: (context: ContextType<C>) => {\n updateContext.emit(context);\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\nimport { createContext } from '../context';\nimport { type LiteralStringUnion } from '../type-helper';\n\nexport const closestIxMenu = (element: Element) => {\n const menuElement = element.closest('ix-menu');\n return menuElement;\n};\n\nexport type AppSwitchConfigurationTarget = LiteralStringUnion<\n '_self' | '_blank' | '_parent' | '_top'\n>;\n\nexport type AppSwitchConfiguration = {\n currentAppId: string;\n apps: {\n id: string;\n name: string;\n description: string;\n url: string;\n target: AppSwitchConfigurationTarget;\n iconSrc: string;\n }[];\n i18nAppSwitch?: string;\n i18nLoadingApps?: string;\n};\n\nexport const ApplicationLayoutContext = createContext<{\n hideHeader: boolean;\n host: 'basic-navigation' | 'map-navigation' | null;\n appSwitchConfig?: AppSwitchConfiguration;\n sidebar?: boolean;\n}>('application-layout-context', {\n hideHeader: false,\n host: null,\n sidebar: false,\n});\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"context-CmNuiaNz.js","sources":["src/components/utils/context.ts","src/components/utils/application-layout/context.ts"],"sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport { TypedEvent } from './typed-event';\n\n/**\n * A Context object defines an optional initial value for a Context, as well as a name identifier for debugging purposes.\n */\nexport type Context<T> = {\n name: string;\n initialValue?: T;\n};\n\n/**\n * An unknown context type\n */\nexport type UnknownContext = Context<unknown>;\n\n/**\n * A helper type which can extract a Context value type from a Context type\n */\nexport type ContextType<T extends UnknownContext> =\n T extends Context<infer Y> ? Y : never;\n\n/**\n * A function which creates a Context value object\n */\nexport function createContext<T>(\n name: string,\n initialValue?: T\n): Readonly<Context<T>> {\n return {\n name,\n initialValue,\n };\n}\n\n/**\n * A callback which is provided by a context requester and is called with the value satisfying the request.\n * This callback can be called multiple times by context providers as the requested value is changed.\n */\nexport type ContextCallback<ValueType> = (\n value: ValueType,\n unsubscribe?: () => void\n) => void;\n\n/**\n * An event fired by a context requester to signal it desires a named context.\n *\n * A provider should inspect the `context` property of the event to determine if it has a value that can\n * satisfy the request, calling the `callback` with the requested value if so.\n *\n * If the requested context event contains a truthy `subscribe` value, then a provider can call the callback\n * multiple times if the value is changed, if this is the case the provider should pass an `unsubscribe`\n * function to the callback which requesters can invoke to indicate they no longer wish to receive these updates.\n */\nexport class ContextEvent<T extends UnknownContext> extends Event {\n public constructor(\n public readonly context: T,\n public readonly callback: ContextCallback<ContextType<T>>,\n public readonly subscribe?: boolean\n ) {\n super('context-request', { bubbles: true, composed: true });\n }\n}\n\ndeclare global {\n interface HTMLElementEventMap {\n /**\n * A 'context-request' event can be emitted by any element which desires\n * a context value to be injected by an external provider.\n */\n 'context-request': ContextEvent<UnknownContext>;\n }\n}\n\nexport type ContextConsumerSubscription = {\n unsubscribe: () => void;\n};\n\nexport function useContextConsumer<\n T extends HTMLElement,\n C extends UnknownContext,\n>(\n hostElement: T,\n context: C,\n onContextReceived: (\n context: ContextType<C>,\n unsubscribe?: () => void\n ) => void,\n subscribe?: boolean\n): ContextConsumerSubscription {\n let _unsubscribe: (() => void) | undefined;\n hostElement.dispatchEvent(\n new ContextEvent(\n context,\n (ctx, unSub) => {\n onContextReceived(ctx, unSub);\n _unsubscribe = unSub;\n },\n subscribe\n )\n );\n\n return {\n unsubscribe: () => {\n if (_unsubscribe) {\n _unsubscribe();\n }\n },\n };\n}\nexport type ContextProvider<C extends Context<{}> = Context<any>> = {\n emit: (context: ContextType<C>) => void;\n};\n\nexport function useContextProvider<\n X extends {},\n C extends Context<X>,\n T extends HTMLElement = HTMLElement,\n>(\n hostElement: T,\n context: C,\n contextPayload?: ContextType<C>\n): ContextProvider<C> {\n const requestContext = new TypedEvent<ContextEvent<C>>();\n const updateContext = new TypedEvent<ContextType<C>>();\n\n const requests = new Set<ContextEvent<UnknownContext>>();\n\n hostElement.addEventListener('context-request', (event: Event) => {\n const requestContextEvent = event as ContextEvent<C>;\n if (requestContextEvent?.context.name !== context.name) {\n return;\n }\n\n requestContextEvent.stopPropagation();\n\n if (requestContextEvent.subscribe) {\n requests.add(requestContextEvent);\n }\n requestContext.emit(requestContextEvent);\n\n if (contextPayload) {\n requestContextEvent.callback(contextPayload, () => {\n requests.delete(requestContextEvent);\n });\n }\n });\n\n updateContext.on((context: ContextType<C>) => {\n requests.forEach((r) =>\n r.callback(context, () => {\n requests.delete(r);\n })\n );\n });\n\n return {\n emit: (context: ContextType<C>) => {\n updateContext.emit(context);\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\nimport { createContext } from '../context';\nimport { type LiteralStringUnion } from '../type-helper';\n\nexport const closestIxMenu = (element: Element) => {\n const menuElement = element.closest('ix-menu');\n return menuElement;\n};\n\nexport type AppSwitchConfigurationTarget = LiteralStringUnion<\n '_self' | '_blank' | '_parent' | '_top'\n>;\n\nexport type AppSwitchConfiguration = {\n currentAppId: string;\n apps: {\n id: string;\n name: string;\n description: string;\n url: string;\n target: AppSwitchConfigurationTarget;\n iconSrc: string;\n }[];\n i18nAppSwitch?: string;\n i18nLoadingApps?: string;\n};\n\nexport const ApplicationLayoutContext = createContext<{\n hideHeader: boolean;\n appSwitchConfig?: AppSwitchConfiguration;\n sidebar?: boolean;\n}>('application-layout-context', {\n hideHeader: false,\n sidebar: false,\n});\n"],"names":["TypedEvent"],"mappings":";;;;AAAA;;;;;;;AAOG;AAuBH;;AAEG;AACa,SAAA,aAAa,CAC3B,IAAY,EACZ,YAAgB,EAAA;IAEhB,OAAO;QACL,IAAI;QACJ,YAAY;KACb;AACH;AAWA;;;;;;;;;AASG;AACG,MAAO,YAAuC,SAAQ,KAAK,CAAA;AAC/D,IAAA,WAAA,CACkB,OAAU,EACV,QAAyC,EACzC,SAAmB,EAAA;AAEnC,QAAA,KAAK,CAAC,iBAAiB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;AAJ3C,QAAA,IAAO,CAAA,OAAA,GAAP,OAAO;AACP,QAAA,IAAQ,CAAA,QAAA,GAAR,QAAQ;AACR,QAAA,IAAS,CAAA,SAAA,GAAT,SAAS;;AAI5B;AAgBK,SAAU,kBAAkB,CAIhC,WAAc,EACd,OAAU,EACV,iBAGS,EACT,SAAmB,EAAA;AAEnB,IAAA,IAAI,YAAsC;AAC1C,IAAA,WAAW,CAAC,aAAa,CACvB,IAAI,YAAY,CACd,OAAO,EACP,CAAC,GAAG,EAAE,KAAK,KAAI;AACb,QAAA,iBAAiB,CAAC,GAAG,EAAE,KAAK,CAAC;QAC7B,YAAY,GAAG,KAAK;AACtB,KAAC,EACD,SAAS,CACV,CACF;IAED,OAAO;QACL,WAAW,EAAE,MAAK;YAChB,IAAI,YAAY,EAAE;AAChB,gBAAA,YAAY,EAAE;;SAEjB;KACF;AACH;SAKgB,kBAAkB,CAKhC,WAAc,EACd,OAAU,EACV,cAA+B,EAAA;AAE/B,IAAA,MAAM,cAAc,GAAG,IAAIA,qBAAU,EAAmB;AACxD,IAAA,MAAM,aAAa,GAAG,IAAIA,qBAAU,EAAkB;AAEtD,IAAA,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAgC;IAExD,WAAW,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC,KAAY,KAAI;QAC/D,MAAM,mBAAmB,GAAG,KAAwB;AACpD,QAAA,IAAI,CAAA,mBAAmB,KAAnB,IAAA,IAAA,mBAAmB,uBAAnB,mBAAmB,CAAE,OAAO,CAAC,IAAI,MAAK,OAAO,CAAC,IAAI,EAAE;YACtD;;QAGF,mBAAmB,CAAC,eAAe,EAAE;AAErC,QAAA,IAAI,mBAAmB,CAAC,SAAS,EAAE;AACjC,YAAA,QAAQ,CAAC,GAAG,CAAC,mBAAmB,CAAC;;AAEnC,QAAA,cAAc,CAAC,IAAI,CAAC,mBAAmB,CAAC;QAExC,IAAI,cAAc,EAAE;AAClB,YAAA,mBAAmB,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAK;AAChD,gBAAA,QAAQ,CAAC,MAAM,CAAC,mBAAmB,CAAC;AACtC,aAAC,CAAC;;AAEN,KAAC,CAAC;AAEF,IAAA,aAAa,CAAC,EAAE,CAAC,CAAC,OAAuB,KAAI;AAC3C,QAAA,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,KACjB,CAAC,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAK;AACvB,YAAA,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;SACnB,CAAC,CACH;AACH,KAAC,CAAC;IAEF,OAAO;AACL,QAAA,IAAI,EAAE,CAAC,OAAuB,KAAI;AAChC,YAAA,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC;SAC5B;KACF;AACH;;ACzKA;;;;;;;AAOG;AAKU,MAAA,aAAa,GAAG,CAAC,OAAgB,KAAI;IAChD,MAAM,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC;AAC9C,IAAA,OAAO,WAAW;AACpB;AAoBa,MAAA,wBAAwB,GAAG,aAAa,CAIlD,4BAA4B,EAAE;AAC/B,IAAA,UAAU,EAAE,KAAK;AACjB,IAAA,OAAO,EAAE,KAAK;AACf,CAAA;;;;;;;"}
@@ -120,6 +120,10 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
120
120
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
121
121
  /* webpackMode: "lazy" */
122
122
  './ix-application.cjs.entry.js')); }).then(processMod, consoleError);
123
+ case 'ix-application-header.cjs':
124
+ return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
125
+ /* webpackMode: "lazy" */
126
+ './ix-application-header.cjs.entry.js')); }).then(processMod, consoleError);
123
127
  case 'ix-application-sidebar.cjs':
124
128
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
125
129
  /* webpackMode: "lazy" */
@@ -128,10 +132,6 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
128
132
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
129
133
  /* webpackMode: "lazy" */
130
134
  './ix-application-switch-modal.cjs.entry.js')); }).then(processMod, consoleError);
131
- case 'ix-basic-navigation.cjs':
132
- return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
133
- /* webpackMode: "lazy" */
134
- './ix-basic-navigation.cjs.entry.js')); }).then(processMod, consoleError);
135
135
  case 'ix-blind.cjs':
136
136
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
137
137
  /* webpackMode: "lazy" */
@@ -268,10 +268,6 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
268
268
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
269
269
  /* webpackMode: "lazy" */
270
270
  './ix-link-button.cjs.entry.js')); }).then(processMod, consoleError);
271
- case 'ix-map-navigation.cjs':
272
- return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
273
- /* webpackMode: "lazy" */
274
- './ix-map-navigation.cjs.entry.js')); }).then(processMod, consoleError);
275
271
  case 'ix-menu-about.cjs':
276
272
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
277
273
  /* webpackMode: "lazy" */
@@ -388,10 +384,6 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
388
384
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
389
385
  /* webpackMode: "lazy" */
390
386
  './ix-breadcrumb-item.cjs.entry.js')); }).then(processMod, consoleError);
391
- case 'ix-map-navigation-overlay.cjs':
392
- return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
393
- /* webpackMode: "lazy" */
394
- './ix-map-navigation-overlay.cjs.entry.js')); }).then(processMod, consoleError);
395
387
  case 'ix-select.cjs':
396
388
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
397
389
  /* webpackMode: "lazy" */
@@ -404,10 +396,10 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
404
396
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
405
397
  /* webpackMode: "lazy" */
406
398
  './ix-tree-item.cjs.entry.js')); }).then(processMod, consoleError);
407
- case 'ix-application-header.cjs':
399
+ case 'ix-menu-expand-icon.cjs':
408
400
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
409
401
  /* webpackMode: "lazy" */
410
- './ix-application-header.cjs.entry.js')); }).then(processMod, consoleError);
402
+ './ix-menu-expand-icon.cjs.entry.js')); }).then(processMod, consoleError);
411
403
  case 'ix-time-picker.cjs':
412
404
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
413
405
  /* webpackMode: "lazy" */
@@ -416,10 +408,6 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
416
408
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
417
409
  /* webpackMode: "lazy" */
418
410
  './ix-divider.cjs.entry.js')); }).then(processMod, consoleError);
419
- case 'ix-menu-expand-icon.cjs':
420
- return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
421
- /* webpackMode: "lazy" */
422
- './ix-menu-expand-icon.cjs.entry.js')); }).then(processMod, consoleError);
423
411
  case 'ix-date-time-card.cjs':
424
412
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
425
413
  /* webpackMode: "lazy" */
@@ -4,7 +4,7 @@ var index = require('./index-C8Xo8L1k.js');
4
4
  var index$2 = require('./index-Dyz3z1FD.js');
5
5
  var index$1 = require('./index-B7AMgiIZ.js');
6
6
  var service = require('./service-DuiJmf7R.js');
7
- var context = require('./context-B8bRIFA2.js');
7
+ var context = require('./context-CmNuiaNz.js');
8
8
  var breakpoints = require('./breakpoints-C5ZrUCbZ.js');
9
9
  var menuService = require('./menu-service-CW0vT80Q.js');
10
10
  var shadowDom = require('./shadow-dom-DT01VwcB.js');
@@ -54,11 +54,6 @@ const ApplicationHeader = class {
54
54
  componentWillLoad() {
55
55
  this.breakpoint = breakpoints.getCurrentBreakpoint();
56
56
  context.useContextConsumer(this.hostElement, context.ApplicationLayoutContext, (ctx) => {
57
- if ((ctx === null || ctx === void 0 ? void 0 : ctx.host) === 'map-navigation') {
58
- this.suppressResponsive = true;
59
- this.breakpoint = 'md';
60
- return;
61
- }
62
57
  this.breakpoint = service.applicationLayoutService.breakpoint;
63
58
  this.applicationLayoutContext = ctx;
64
59
  this.tryUpdateAppSwitch();
@@ -166,31 +161,31 @@ const ApplicationHeader = class {
166
161
  this.breakpoint !== 'sm' &&
167
162
  this.suppressResponsive === false;
168
163
  const showCompanyLogoByProperty = this.breakpoint !== 'sm' && !!this.companyLogo;
169
- return (index.h(index.Host, { key: 'ef0ab6f2a81031458e8ed28d37498fc8b1446bac', class: {
164
+ return (index.h(index.Host, { key: '0568c65fa9cfe4f1250a5f7704cc19f7e38a5d19', class: {
170
165
  [`breakpoint-${this.breakpoint}`]: true,
171
166
  'hide-bottom-border': this.hideBottomBorder,
172
- }, slot: "application-header" }, index.h("div", { key: 'efe93ad72d12055c809bba772b705d20fed00ee7', class: "left-side" }, this.appIcon && this.breakpoint !== 'sm' && (index.h("div", { key: 'ef86725dc6c5d99b629115e1142f11d513a76f52', class: {
167
+ }, slot: "application-header" }, index.h("div", { key: 'a5c4fa84d92bd9ce8e236f117605652bfc92e60d', class: "left-side" }, this.appIcon && this.breakpoint !== 'sm' && (index.h("div", { key: '0f790883c295875ef6b3f023cd9daa34980c5c96', class: {
173
168
  'app-icon': true,
174
169
  'app-icon-outline': this.appIconOutline,
175
- } }, index.h("img", { key: 'aaca1d8a674774635a0f0774aaf1c6cb8c63ca3e', src: this.appIcon, alt: this.appIconAlt }))), (this.showMenu || showMenuByApplicationFrame) && (index.h("ix-menu-expand-icon", { key: '6cd981d9c4398e0c72ba5096694e30855f970bec', onClick: () => this.onMenuClick(), expanded: this.menuExpanded, ixAriaLabel: this.ariaLabelMenuExpandIconButton })), showApplicationSwitch && (index.h("ix-icon-button", { key: '933e394225b9239f10b18962c40f8021a5e4b059', onClick: () => this.showAppSwitch(), icon: index$2.iconApps, variant: "subtle-tertiary", class: {
170
+ } }, index.h("img", { key: '3e20234523c716d04e123706912eef1023eb884f', src: this.appIcon, alt: this.appIconAlt }))), (this.showMenu || showMenuByApplicationFrame) && (index.h("ix-menu-expand-icon", { key: 'b46e806adadc12a7a355691bdb14bb2a3ee0f98f', onClick: () => this.onMenuClick(), expanded: this.menuExpanded, ixAriaLabel: this.ariaLabelMenuExpandIconButton })), showApplicationSwitch && (index.h("ix-icon-button", { key: '57112cb328fc5231871e18496863ebc3a38f978b', onClick: () => this.showAppSwitch(), icon: index$2.iconApps, variant: "subtle-tertiary", class: {
176
171
  'app-switch': true,
177
172
  'without-app-icon': !this.appIcon,
178
- }, "aria-label": this.ariaLabelAppSwitchIconButton })), showCompanyLogoByProperty && (index.h("div", { key: 'df4c4e5db00d5f7b7680ea05c9da06250c769308', class: "logo" }, index.h("img", { key: '2187d02dedbb48e5b27ea431b90a1a33a4b1e9e6', src: this.companyLogo, alt: this.companyLogoAlt }))), index.h("div", { key: '0abdbb9bf1b3fc81c14d46ea826ee73336c560b5', class: {
173
+ }, "aria-label": this.ariaLabelAppSwitchIconButton })), showCompanyLogoByProperty && (index.h("div", { key: 'b622ece9a3c1645141c1cb54d9cb88f0b2b12646', class: "logo" }, index.h("img", { key: '854a9696190d015ce052c745f9ed7acc206f16d5', src: this.companyLogo, alt: this.companyLogoAlt }))), index.h("div", { key: '0d5ff7f62bb55cb15d2e15e41279ca671716224c', class: {
179
174
  logo: true,
180
175
  'hide-logo': !this.hasSlottedLogo,
181
- } }, index.h("slot", { key: '468f56a361d387af9b46dddabbece87e03f1692b', name: "logo", onSlotchange: () => (this.hasSlottedLogo = this.checkLogoSlot()) })), index.h("div", { key: '84265b38ce425386a4df25a52e2334b760d28067', class: "name" }, index.h("ix-typography", { key: 'c2cb4a0e91d28ccdb07dd8a68a6b6989b3faab14', format: "body-lg", class: "application-name" }, this.name), this.nameSuffix && this.breakpoint !== 'sm' && (index.h("ix-typography", { key: 'f34d596a5071ee964fecfc1021a420b0cc5fad32', format: "body-xs", class: "application-name-suffix" }, this.nameSuffix)))), index.h("div", { key: 'e4f60f5f9fb727385eb180ea91f5c75b7a207993', class: { 'right-side': true, sm: this.breakpoint === 'sm' } }, this.breakpoint !== 'sm' && (index.h("div", { key: 'b78fcf9127124d7c57d2ebf15f65fb271efd30fc', class: "secondary" }, index.h("slot", { key: '0c82211f37d6cb285047f97ee222f22aa424bfad', name: "secondary" }))), index.h("div", { key: 'acb023efd34eeba9730ad5a60dd933240bb09b80', class: "content" }, this.breakpoint !== 'sm' && index.h("slot", { key: '05fcf4ca0ee08e392ebba65ef7f671e5822cc9c5' }), index.h("ix-icon-button", { key: '196aa553bc0ed8f7ac43586c8bd065c3c4990535', class: {
176
+ } }, index.h("slot", { key: '42d42aab0493036c165f1d7d969288bc2dc339c8', name: "logo", onSlotchange: () => (this.hasSlottedLogo = this.checkLogoSlot()) })), index.h("div", { key: 'a388e25471839639f82f2e3d8798d041cdab1f78', class: "name" }, index.h("ix-typography", { key: 'f7d197105b6609597fa742ca8b85aa2c80b2c25d', format: "body-lg", class: "application-name" }, this.name), this.nameSuffix && this.breakpoint !== 'sm' && (index.h("ix-typography", { key: '5a78095814f0d39666bbe26bb968d4df72233016', format: "body-xs", class: "application-name-suffix" }, this.nameSuffix)))), index.h("div", { key: 'e4a01fd2bf06bd9ae064c5f336e7ef2fe2880e1c', class: { 'right-side': true, sm: this.breakpoint === 'sm' } }, this.breakpoint !== 'sm' && (index.h("div", { key: 'f3c3221c2dbcccf19d23502ff05984815fc8ea1e', class: "secondary" }, index.h("slot", { key: '9392845b82451cb62b886ab1bafa7ba7ddf21d13', name: "secondary" }))), index.h("div", { key: 'a288be02d9ee23480339d8de284c186fbc9bfd26', class: "content" }, this.breakpoint !== 'sm' && index.h("slot", { key: '34dfa9b114c85e3e59183fce1b5a977eabe02d6a' }), index.h("ix-icon-button", { key: 'c884b249320deb5f105538dd0fd7e47efd6207c0', class: {
182
177
  'context-menu': true,
183
178
  'context-menu-visible': this.hasOverflowContextMenu || this.hasOverflowSlotElements,
184
- }, "data-context-menu": true, "data-testid": "show-more", icon: index$2.iconMoreMenu, variant: "subtle-tertiary", "aria-label": this.ariaLabelMoreMenuIconButton, "aria-hidden": a11y.a11yBoolean(!(this.hasOverflowContextMenu || this.hasOverflowSlotElements)) }), index.h("ix-dropdown", { key: '7657364247c4964e0cbe2380fffedcd22f6513d9', "data-overflow-dropdown": true, class: "dropdown", discoverAllSubmenus: true, trigger: this.resolveContextMenuButton(), "aria-hidden": a11y.a11yBoolean(!(this.hasOverflowContextMenu || this.hasOverflowSlotElements)) }, index.h("div", { key: '06f57598668ae32ef6fc377ae9ccf180ffbd5361', class: "dropdown-content", onClick: (e) => this.onContentBgClick(e) }, this.breakpoint === 'sm' && (index.h("div", { key: 'f59b62075ac364ccc86791e6dda77a155135dc91', class: {
179
+ }, "data-context-menu": true, "data-testid": "show-more", icon: index$2.iconMoreMenu, variant: "subtle-tertiary", "aria-label": this.ariaLabelMoreMenuIconButton, "aria-hidden": a11y.a11yBoolean(!(this.hasOverflowContextMenu || this.hasOverflowSlotElements)) }), index.h("ix-dropdown", { key: '42ea43e1f28ecdd7651a2f652edb6eb2462a0df3', "data-overflow-dropdown": true, class: "dropdown", discoverAllSubmenus: true, trigger: this.resolveContextMenuButton(), "aria-hidden": a11y.a11yBoolean(!(this.hasOverflowContextMenu || this.hasOverflowSlotElements)) }, index.h("div", { key: 'b57645df48b14862e17510560386dffdc7f918f2', class: "dropdown-content", onClick: (e) => this.onContentBgClick(e) }, this.breakpoint === 'sm' && (index.h("div", { key: 'd27a3ab3dcccb24deea6452aab078975d7657c1f', class: {
185
180
  'slot-content': true,
186
181
  'slot-content-active': this.hasSecondarySlotElements,
187
- } }, index.h("slot", { key: '25a1cbf08436b248cb892cabcc4b6377abcdda4f', name: "secondary", onSlotchange: () => this.updateHasSlotAssignedElementsStates() }))), this.breakpoint === 'sm' && (index.h("div", { key: '903e47dc9fe7906bc94650d9617031a9ec8ecbd3', class: {
182
+ } }, index.h("slot", { key: '8236935ea329c8650b08c0fbb2be11a4233b54a5', name: "secondary", onSlotchange: () => this.updateHasSlotAssignedElementsStates() }))), this.breakpoint === 'sm' && (index.h("div", { key: 'd947b3da7b1c2683f319604698550e6deede8bb5', class: {
188
183
  'slot-content': true,
189
184
  'slot-content-active': this.hasDefaultSlotElements,
190
- } }, index.h("slot", { key: 'dd848b5a87034692f1b0c518ec694cc9e3197787', onSlotchange: () => this.updateHasSlotAssignedElementsStates() }))), index.h("div", { key: '0fe4250f4a64d239ca6db9eea89d1cc4869492e6', class: {
185
+ } }, index.h("slot", { key: '5e60684fe9b2d19e67a4b8c56225be76a2aff668', onSlotchange: () => this.updateHasSlotAssignedElementsStates() }))), index.h("div", { key: 'c072ab98aa238e71087064f9ffcbc46a8b43cacd', class: {
191
186
  'slot-content': true,
192
187
  'slot-content-active': this.hasOverflowSlotElements,
193
- } }, index.h("slot", { key: '10862703e3e6701ff5bb110039242b826914e8af', name: "overflow", onSlotchange: () => this.updateHasSlotAssignedElementsStates() })))), index.h("slot", { key: 'eb5fbef4f3783afba128d57fdc3924e4957af6b1', name: "ix-application-header-avatar" })))));
188
+ } }, index.h("slot", { key: '99752eacbebd15e6b9dda9b9dc96c919ed8ebcf6', name: "overflow", onSlotchange: () => this.updateHasSlotAssignedElementsStates() })))), index.h("slot", { key: 'c6c071f3ee91c6f0aa709ba59e979e644f22f22d', name: "ix-application-header-avatar" })))));
194
189
  }
195
190
  get hostElement() { return index.getElement(this); }
196
191
  static get watchers() { return {
@@ -1 +1 @@
1
- {"version":3,"file":"ix-application-header.entry.cjs.js","sources":["src/components/application-header/application-header.scss?tag=ix-application-header&encapsulation=shadow","src/components/application-header/application-header.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 'mixins/break-points';\n\n:host {\n display: flex;\n flex-wrap: nowrap;\n align-items: end;\n justify-content: space-between;\n position: relative;\n width: 100%;\n min-height: 3rem;\n padding-top: var(--ix-safe-area-inset-top, 0rem);\n padding-right: calc(0.625rem + var(--ix-safe-area-inset-right, 0rem));\n padding-left: calc(0.625rem + var(--ix-safe-area-inset-left, 0rem));\n\n color: var(--theme-app-header--color);\n background-color: var(--theme-app-header--background);\n\n border-bottom: var(--theme-app-header--border-width) solid\n var(--theme-app-header--border-color);\n\n z-index: var(--theme-z-index-fixed);\n\n @include component.ix-component;\n\n .left-side,\n .right-side {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n position: relative;\n align-items: center;\n min-width: 0;\n min-height: 3rem;\n height: 100%;\n }\n\n .left-side {\n flex: 0 1 auto;\n\n .app-icon {\n display: block;\n position: relative;\n width: 2rem;\n min-width: 2rem;\n max-width: 2rem;\n height: 2rem;\n min-height: 2rem;\n max-height: 2rem;\n }\n\n .app-icon.app-icon-outline {\n outline: 1px solid var(--theme-app-header-app-icon--outline-color);\n border-radius: 0.125rem;\n }\n\n .app-icon img {\n position: relative;\n display: block;\n width: 100%;\n height: 100%;\n border-radius: 0.125rem;\n }\n\n .app-switch {\n margin: 0 0.625rem;\n }\n\n .app-switch.without-app-icon {\n margin-left: 0px;\n }\n\n .name {\n display: flex;\n position: relative;\n flex-direction: row;\n flex-wrap: nowrap;\n\n margin-left: 0.75rem;\n margin-right: 0.75rem;\n color: var(--theme-app-header--color);\n min-width: 0;\n\n gap: 0.75rem;\n overflow: hidden;\n }\n\n .application-name,\n .application-name-suffix {\n overflow: hidden;\n overflow-wrap: anywhere;\n text-overflow: ellipsis;\n text-wrap: nowrap;\n }\n\n .application-name {\n flex: 0 1 auto;\n min-width: 0;\n flex-shrink: 0;\n max-width: 100%;\n }\n\n .application-name-suffix {\n flex: 1 1 auto;\n margin-top: 0.4rem;\n min-width: 0;\n flex-shrink: 1;\n color: var(--theme-app-header-name-suffix--color);\n }\n\n .logo {\n display: inline-flex;\n align-items: center;\n position: relative;\n height: 32px;\n overflow: hidden;\n line-height: 0rem;\n color: var(--theme-app-header-logo--color);\n margin-right: 1rem;\n margin-left: 1rem;\n min-width: fit-content;\n }\n\n .logo.hide-logo {\n display: none;\n }\n }\n\n .right-side {\n flex: 1 1 auto;\n overflow: hidden;\n justify-content: space-between;\n\n .content,\n .secondary {\n display: flex;\n position: relative;\n align-items: center;\n justify-content: space-between;\n flex-direction: row;\n flex-wrap: nowrap;\n height: 100%;\n }\n\n .content {\n min-width: max-content;\n }\n\n .secondary {\n overflow: hidden;\n }\n\n .dropdown {\n overflow: visible;\n }\n\n .dropdown-content > .slot-content-active {\n padding: 0.5rem 1.5rem 0.5rem 1.5rem;\n border-top: none;\n }\n\n .dropdown-content .slot-content-active ~ .slot-content-active {\n border-top: 1px solid var(--theme-color-x-weak-bdr);\n }\n\n .context-menu {\n display: none;\n }\n\n .context-menu.context-menu-visible {\n display: block;\n margin-left: 0.5rem;\n }\n\n ::slotted(ix-avatar) {\n margin-left: 0.5rem;\n }\n\n .primary-navigation {\n align-self: end;\n }\n }\n\n .right-side.sm {\n justify-content: end;\n }\n\n @include break-points.media-breakpoint-match('sm') {\n .logo {\n margin-left: 0.5rem;\n display: none !important;\n }\n\n .content,\n .secondary,\n .app-icon {\n display: none;\n }\n }\n}\n\n:host(.hide-bottom-border) {\n border-bottom: none;\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { iconApps, iconMoreMenu } from '@siemens/ix-icons/icons';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Prop,\n readTask,\n State,\n Watch,\n} from '@stencil/core';\nimport { showAppSwitch } from '../utils/app-switch';\nimport { applicationLayoutService } from '../utils/application-layout';\nimport {\n ApplicationLayoutContext,\n AppSwitchConfiguration,\n} from '../utils/application-layout/context';\nimport { Breakpoint, getCurrentBreakpoint } from '../utils/breakpoints';\nimport { ContextType, useContextConsumer } from '../utils/context';\nimport { menuController } from '../utils/menu-service/menu-service';\nimport { hasSlottedElements } from '../utils/shadow-dom';\nimport { Disposable } from '../utils/typed-event';\nimport { a11yBoolean } from '../utils/a11y';\n\n/**\n * @slot default - Place items on the right side of the header. If the screen size is small, the items will be shown inside a dropdown.\n * @slot secondary - Place additional items inside the header. They will appear after logo and name. If the screen size is small, the items will be shown inside a dropdown.\n * @slot overflow - Use this slot to display additional items that do not fit in the default or secondary slot.\n * @slot logo - Place a company logo inside the header. Alternatively the companyLogo property can be set.\n */\n@Component({\n tag: 'ix-application-header',\n styleUrl: 'application-header.scss',\n shadow: true,\n})\nexport class ApplicationHeader {\n @Element() hostElement!: HTMLIxApplicationHeaderElement;\n\n /**\n * Application name\n */\n @Prop() name?: string;\n\n /**\n * Define a suffix which will be displayed next to the application name\n *\n * @since 4.0.0\n */\n @Prop() nameSuffix?: string;\n\n /**\n * Company logo will be show on the left side of the application name.\n * It will be hidden on smaller screens.\n *\n * @since 4.0.0\n */\n @Prop() companyLogo?: string;\n\n /**\n * Alt text for the company logo\n *\n * @since 4.0.0\n */\n @Prop() companyLogoAlt?: string;\n\n /**\n * The app icon will be shown as the first element inside the header.\n * It will be hidden on smaller screens.\n *\n * @since 4.0.0\n */\n @Prop() appIcon?: string;\n\n /**\n * Alt text for the app icon\n *\n * @since 4.0.0\n */\n @Prop() appIconAlt?: string;\n\n /**\n * Render subtle outline around app icon to ensure proper contrast.\n *\n * @since 4.0.0\n */\n @Prop() appIconOutline = false;\n\n /**\n * Hides the bottom border of the header\n *\n * @since 4.0.0\n */\n @Prop() hideBottomBorder = false;\n\n /**\n * Controls the visibility of the menu toggle button based on the context of the application header.\n *\n * When the application header is utilized outside the application frame, the menu toggle button is displayed.\n * Conversely, if the header is within the application frame, this property is ineffective.\n */\n @Prop({ mutable: true }) showMenu?: boolean = false;\n\n /**\n * ARIA label for the menu expand icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelMenuExpandIconButton?: string;\n\n /**\n * ARIA label for the app switch icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelAppSwitchIconButton?: string;\n\n /**\n * ARIA label for the more menu icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelMoreMenuIconButton?: string;\n\n /**\n * Event emitted when the menu toggle button is clicked\n */\n @Event() menuToggle!: EventEmitter<boolean>;\n\n /**\n * Event emitted when the app switch button is clicked\n *\n * @since 3.0.0\n */\n @Event() openAppSwitch!: EventEmitter<void>;\n\n @State() breakpoint: Breakpoint = 'lg';\n @State() menuExpanded = false;\n @State() suppressResponsive = false;\n\n @State() hasSlottedLogo = false;\n @State() hasOverflowContextMenu = false;\n @State() hasSecondarySlotElements = false;\n @State() hasDefaultSlotElements = false;\n @State() hasOverflowSlotElements = false;\n @State() applicationLayoutContext?: ContextType<\n typeof ApplicationLayoutContext\n >;\n private menuDisposable?: Disposable;\n private modeDisposable?: Disposable;\n private callbackUpdateAppSwitchModal?: (\n config: AppSwitchConfiguration\n ) => void;\n\n get contentBackground() {\n return this.hostElement.shadowRoot!.querySelector('.dropdown-content');\n }\n\n componentWillLoad() {\n this.breakpoint = getCurrentBreakpoint();\n\n useContextConsumer(\n this.hostElement,\n ApplicationLayoutContext,\n (ctx) => {\n if (ctx?.host === 'map-navigation') {\n this.suppressResponsive = true;\n this.breakpoint = 'md';\n return;\n }\n\n this.breakpoint = applicationLayoutService.breakpoint;\n this.applicationLayoutContext = ctx;\n\n this.tryUpdateAppSwitch();\n },\n true\n );\n\n this.menuDisposable = menuController.expandChange.on((show) => {\n this.menuExpanded = show;\n });\n\n this.modeDisposable = applicationLayoutService.onChange.on((mode) => {\n if (this.suppressResponsive) {\n return;\n }\n\n this.breakpoint = mode;\n });\n\n this.updateHasSlotAssignedElementsStates();\n }\n\n componentDidLoad() {\n this.attachSiemensLogoIfLoaded();\n }\n\n disconnectedCallback() {\n this.menuDisposable?.dispose();\n this.modeDisposable?.dispose();\n }\n\n @Watch('applicationLayoutContext')\n watchApplicationLayoutContext() {\n if (this.applicationLayoutContext) {\n this.showMenu = false;\n }\n }\n @Watch('suppressResponsive')\n watchSuppressResponsive() {\n this.breakpoint = 'md';\n }\n\n private checkLogoSlot() {\n const slotElement = this.hostElement.shadowRoot!.querySelector(\n 'slot[name=\"logo\"]'\n ) as HTMLSlotElement;\n\n const isSiemensLogoDefined =\n window.customElements.get('ix-siemens-logo') !== undefined;\n\n if (isSiemensLogoDefined) {\n return hasSlottedElements(slotElement);\n }\n\n let assignedElements = slotElement?.assignedElements({ flatten: true });\n\n assignedElements = assignedElements?.filter(\n (element) => element.tagName !== 'IX-SIEMENS-LOGO'\n );\n\n return assignedElements?.length !== 0;\n }\n\n private attachSiemensLogoIfLoaded() {\n if (this.companyLogo) {\n return;\n }\n\n if (!this.checkLogoSlot()) {\n const logoElement = document.createElement('ix-siemens-logo');\n logoElement.slot = 'logo';\n this.hostElement.appendChild(logoElement);\n }\n }\n\n private async onMenuClick() {\n if (this.applicationLayoutContext) {\n menuController.toggle();\n } else {\n this.menuExpanded = !this.menuExpanded;\n }\n\n this.menuToggle.emit(this.menuExpanded);\n }\n\n private resolveContextMenuButton() {\n return new Promise<HTMLElement>((resolve) =>\n readTask(() =>\n resolve(\n this.hostElement.shadowRoot!.querySelector(\n '[data-context-menu]'\n ) as HTMLElement\n )\n )\n );\n }\n\n private tryUpdateAppSwitch() {\n if (\n !this.callbackUpdateAppSwitchModal ||\n !this.applicationLayoutContext?.appSwitchConfig\n ) {\n return;\n }\n\n this.callbackUpdateAppSwitchModal(\n this.applicationLayoutContext?.appSwitchConfig\n );\n }\n\n private async showAppSwitch() {\n const { defaultPrevented } = this.openAppSwitch.emit();\n\n if (defaultPrevented) {\n return;\n }\n\n if (!this.applicationLayoutContext?.appSwitchConfig) {\n return;\n }\n\n this.callbackUpdateAppSwitchModal = await showAppSwitch(\n this.applicationLayoutContext?.appSwitchConfig\n );\n }\n\n private updateHasSlotAssignedElementsStates() {\n const defaultSlot = this.hostElement.shadowRoot!.querySelector(\n '.content slot:not([name])'\n );\n\n const secondarySlot = this.hostElement.shadowRoot!.querySelector(\n '.content slot[name=\"secondary\"]'\n );\n\n const overflowSlot = this.hostElement.shadowRoot!.querySelector(\n '.content slot[name=\"overflow\"]'\n );\n\n this.hasDefaultSlotElements = hasSlottedElements(defaultSlot);\n this.hasSecondarySlotElements = hasSlottedElements(secondarySlot);\n this.hasOverflowSlotElements = hasSlottedElements(overflowSlot);\n\n this.hasOverflowContextMenu =\n this.hasDefaultSlotElements || this.hasSecondarySlotElements;\n }\n\n private onContentBgClick(e: MouseEvent) {\n if (e.target === this.contentBackground) {\n e.preventDefault();\n }\n }\n\n render() {\n const hasApplicationContextAvailable = !!this.applicationLayoutContext;\n\n const showMenuByApplicationFrame =\n this.breakpoint === 'sm' &&\n this.suppressResponsive === false &&\n hasApplicationContextAvailable;\n\n const showApplicationSwitch =\n this.applicationLayoutContext?.appSwitchConfig &&\n this.breakpoint !== 'sm' &&\n this.suppressResponsive === false;\n\n const showCompanyLogoByProperty =\n this.breakpoint !== 'sm' && !!this.companyLogo;\n\n return (\n <Host\n class={{\n [`breakpoint-${this.breakpoint}`]: true,\n 'hide-bottom-border': this.hideBottomBorder,\n }}\n slot=\"application-header\"\n >\n <div class=\"left-side\">\n {this.appIcon && this.breakpoint !== 'sm' && (\n <div\n class={{\n 'app-icon': true,\n 'app-icon-outline': this.appIconOutline,\n }}\n >\n <img src={this.appIcon} alt={this.appIconAlt} />\n </div>\n )}\n {(this.showMenu || showMenuByApplicationFrame) && (\n <ix-menu-expand-icon\n onClick={() => this.onMenuClick()}\n expanded={this.menuExpanded}\n ixAriaLabel={this.ariaLabelMenuExpandIconButton}\n ></ix-menu-expand-icon>\n )}\n {showApplicationSwitch && (\n <ix-icon-button\n onClick={() => this.showAppSwitch()}\n icon={iconApps}\n variant=\"subtle-tertiary\"\n class={{\n 'app-switch': true,\n 'without-app-icon': !this.appIcon,\n }}\n aria-label={this.ariaLabelAppSwitchIconButton}\n ></ix-icon-button>\n )}\n {showCompanyLogoByProperty && (\n <div class=\"logo\">\n <img src={this.companyLogo} alt={this.companyLogoAlt} />\n </div>\n )}\n <div\n class={{\n logo: true,\n 'hide-logo': !this.hasSlottedLogo,\n }}\n >\n <slot\n name=\"logo\"\n onSlotchange={() => (this.hasSlottedLogo = this.checkLogoSlot())}\n ></slot>\n </div>\n <div class=\"name\">\n <ix-typography format=\"body-lg\" class=\"application-name\">\n {this.name}\n </ix-typography>\n {this.nameSuffix && this.breakpoint !== 'sm' && (\n <ix-typography format=\"body-xs\" class=\"application-name-suffix\">\n {this.nameSuffix}\n </ix-typography>\n )}\n </div>\n </div>\n <div class={{ 'right-side': true, sm: this.breakpoint === 'sm' }}>\n {this.breakpoint !== 'sm' && (\n <div class=\"secondary\">\n <slot name=\"secondary\"></slot>\n </div>\n )}\n <div class=\"content\">\n {this.breakpoint !== 'sm' && <slot></slot>}\n <ix-icon-button\n class={{\n 'context-menu': true,\n 'context-menu-visible':\n this.hasOverflowContextMenu || this.hasOverflowSlotElements,\n }}\n data-context-menu\n data-testid=\"show-more\"\n icon={iconMoreMenu}\n variant=\"subtle-tertiary\"\n aria-label={this.ariaLabelMoreMenuIconButton}\n aria-hidden={a11yBoolean(\n !(this.hasOverflowContextMenu || this.hasOverflowSlotElements)\n )}\n ></ix-icon-button>\n <ix-dropdown\n data-overflow-dropdown\n class=\"dropdown\"\n discoverAllSubmenus\n trigger={this.resolveContextMenuButton()}\n aria-hidden={a11yBoolean(\n !(this.hasOverflowContextMenu || this.hasOverflowSlotElements)\n )}\n >\n <div\n class=\"dropdown-content\"\n onClick={(e) => this.onContentBgClick(e)}\n >\n {this.breakpoint === 'sm' && (\n <div\n class={{\n 'slot-content': true,\n 'slot-content-active': this.hasSecondarySlotElements,\n }}\n >\n <slot\n name=\"secondary\"\n onSlotchange={() =>\n this.updateHasSlotAssignedElementsStates()\n }\n ></slot>\n </div>\n )}\n {this.breakpoint === 'sm' && (\n <div\n class={{\n 'slot-content': true,\n 'slot-content-active': this.hasDefaultSlotElements,\n }}\n >\n <slot\n onSlotchange={() =>\n this.updateHasSlotAssignedElementsStates()\n }\n ></slot>\n </div>\n )}\n <div\n class={{\n 'slot-content': true,\n 'slot-content-active': this.hasOverflowSlotElements,\n }}\n >\n <slot\n name=\"overflow\"\n onSlotchange={() =>\n this.updateHasSlotAssignedElementsStates()\n }\n ></slot>\n </div>\n </div>\n </ix-dropdown>\n <slot name=\"ix-application-header-avatar\"></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":["getCurrentBreakpoint","useContextConsumer","ApplicationLayoutContext","applicationLayoutService","menuController","hasSlottedElements","readTask","showAppSwitch","h","Host","iconApps","iconMoreMenu","a11yBoolean"],"mappings":"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"}
1
+ {"version":3,"file":"ix-application-header.entry.cjs.js","sources":["src/components/application-header/application-header.scss?tag=ix-application-header&encapsulation=shadow","src/components/application-header/application-header.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 'mixins/break-points';\n\n:host {\n display: flex;\n flex-wrap: nowrap;\n align-items: end;\n justify-content: space-between;\n position: relative;\n width: 100%;\n min-height: 3rem;\n padding-top: var(--ix-safe-area-inset-top, 0rem);\n padding-right: calc(0.625rem + var(--ix-safe-area-inset-right, 0rem));\n padding-left: calc(0.625rem + var(--ix-safe-area-inset-left, 0rem));\n\n color: var(--theme-app-header--color);\n background-color: var(--theme-app-header--background);\n\n border-bottom: var(--theme-app-header--border-width) solid\n var(--theme-app-header--border-color);\n\n z-index: var(--theme-z-index-fixed);\n\n @include component.ix-component;\n\n .left-side,\n .right-side {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n position: relative;\n align-items: center;\n min-width: 0;\n min-height: 3rem;\n height: 100%;\n }\n\n .left-side {\n flex: 0 1 auto;\n\n .app-icon {\n display: block;\n position: relative;\n width: 2rem;\n min-width: 2rem;\n max-width: 2rem;\n height: 2rem;\n min-height: 2rem;\n max-height: 2rem;\n }\n\n .app-icon.app-icon-outline {\n outline: 1px solid var(--theme-app-header-app-icon--outline-color);\n border-radius: 0.125rem;\n }\n\n .app-icon img {\n position: relative;\n display: block;\n width: 100%;\n height: 100%;\n border-radius: 0.125rem;\n }\n\n .app-switch {\n margin: 0 0.625rem;\n }\n\n .app-switch.without-app-icon {\n margin-left: 0px;\n }\n\n .name {\n display: flex;\n position: relative;\n flex-direction: row;\n flex-wrap: nowrap;\n\n margin-left: 0.75rem;\n margin-right: 0.75rem;\n color: var(--theme-app-header--color);\n min-width: 0;\n\n gap: 0.75rem;\n overflow: hidden;\n }\n\n .application-name,\n .application-name-suffix {\n overflow: hidden;\n overflow-wrap: anywhere;\n text-overflow: ellipsis;\n text-wrap: nowrap;\n }\n\n .application-name {\n flex: 0 1 auto;\n min-width: 0;\n flex-shrink: 0;\n max-width: 100%;\n }\n\n .application-name-suffix {\n flex: 1 1 auto;\n margin-top: 0.4rem;\n min-width: 0;\n flex-shrink: 1;\n color: var(--theme-app-header-name-suffix--color);\n }\n\n .logo {\n display: inline-flex;\n align-items: center;\n position: relative;\n height: 32px;\n overflow: hidden;\n line-height: 0rem;\n color: var(--theme-app-header-logo--color);\n margin-right: 1rem;\n margin-left: 1rem;\n min-width: fit-content;\n }\n\n .logo.hide-logo {\n display: none;\n }\n }\n\n .right-side {\n flex: 1 1 auto;\n overflow: hidden;\n justify-content: space-between;\n\n .content,\n .secondary {\n display: flex;\n position: relative;\n align-items: center;\n justify-content: space-between;\n flex-direction: row;\n flex-wrap: nowrap;\n height: 100%;\n }\n\n .content {\n min-width: max-content;\n }\n\n .secondary {\n overflow: hidden;\n }\n\n .dropdown {\n overflow: visible;\n }\n\n .dropdown-content > .slot-content-active {\n padding: 0.5rem 1.5rem 0.5rem 1.5rem;\n border-top: none;\n }\n\n .dropdown-content .slot-content-active ~ .slot-content-active {\n border-top: 1px solid var(--theme-color-x-weak-bdr);\n }\n\n .context-menu {\n display: none;\n }\n\n .context-menu.context-menu-visible {\n display: block;\n margin-left: 0.5rem;\n }\n\n ::slotted(ix-avatar) {\n margin-left: 0.5rem;\n }\n\n .primary-navigation {\n align-self: end;\n }\n }\n\n .right-side.sm {\n justify-content: end;\n }\n\n @include break-points.media-breakpoint-match('sm') {\n .logo {\n margin-left: 0.5rem;\n display: none !important;\n }\n\n .content,\n .secondary,\n .app-icon {\n display: none;\n }\n }\n}\n\n:host(.hide-bottom-border) {\n border-bottom: none;\n}\n","/*\n * SPDX-FileCopyrightText: 2023 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { iconApps, iconMoreMenu } from '@siemens/ix-icons/icons';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Host,\n Prop,\n readTask,\n State,\n Watch,\n} from '@stencil/core';\nimport { showAppSwitch } from '../utils/app-switch';\nimport { applicationLayoutService } from '../utils/application-layout';\nimport {\n ApplicationLayoutContext,\n AppSwitchConfiguration,\n} from '../utils/application-layout/context';\nimport { Breakpoint, getCurrentBreakpoint } from '../utils/breakpoints';\nimport { ContextType, useContextConsumer } from '../utils/context';\nimport { menuController } from '../utils/menu-service/menu-service';\nimport { hasSlottedElements } from '../utils/shadow-dom';\nimport { Disposable } from '../utils/typed-event';\nimport { a11yBoolean } from '../utils/a11y';\n\n/**\n * @slot default - Place items on the right side of the header. If the screen size is small, the items will be shown inside a dropdown.\n * @slot secondary - Place additional items inside the header. They will appear after logo and name. If the screen size is small, the items will be shown inside a dropdown.\n * @slot overflow - Use this slot to display additional items that do not fit in the default or secondary slot.\n * @slot logo - Place a company logo inside the header. Alternatively the companyLogo property can be set.\n */\n@Component({\n tag: 'ix-application-header',\n styleUrl: 'application-header.scss',\n shadow: true,\n})\nexport class ApplicationHeader {\n @Element() hostElement!: HTMLIxApplicationHeaderElement;\n\n /**\n * Application name\n */\n @Prop() name?: string;\n\n /**\n * Define a suffix which will be displayed next to the application name\n *\n * @since 4.0.0\n */\n @Prop() nameSuffix?: string;\n\n /**\n * Company logo will be show on the left side of the application name.\n * It will be hidden on smaller screens.\n *\n * @since 4.0.0\n */\n @Prop() companyLogo?: string;\n\n /**\n * Alt text for the company logo\n *\n * @since 4.0.0\n */\n @Prop() companyLogoAlt?: string;\n\n /**\n * The app icon will be shown as the first element inside the header.\n * It will be hidden on smaller screens.\n *\n * @since 4.0.0\n */\n @Prop() appIcon?: string;\n\n /**\n * Alt text for the app icon\n *\n * @since 4.0.0\n */\n @Prop() appIconAlt?: string;\n\n /**\n * Render subtle outline around app icon to ensure proper contrast.\n *\n * @since 4.0.0\n */\n @Prop() appIconOutline = false;\n\n /**\n * Hides the bottom border of the header\n *\n * @since 4.0.0\n */\n @Prop() hideBottomBorder = false;\n\n /**\n * Controls the visibility of the menu toggle button based on the context of the application header.\n *\n * When the application header is utilized outside the application frame, the menu toggle button is displayed.\n * Conversely, if the header is within the application frame, this property is ineffective.\n */\n @Prop({ mutable: true }) showMenu?: boolean = false;\n\n /**\n * ARIA label for the menu expand icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelMenuExpandIconButton?: string;\n\n /**\n * ARIA label for the app switch icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelAppSwitchIconButton?: string;\n\n /**\n * ARIA label for the more menu icon button\n *\n * @since 3.2.0\n */\n @Prop() ariaLabelMoreMenuIconButton?: string;\n\n /**\n * Event emitted when the menu toggle button is clicked\n */\n @Event() menuToggle!: EventEmitter<boolean>;\n\n /**\n * Event emitted when the app switch button is clicked\n *\n * @since 3.0.0\n */\n @Event() openAppSwitch!: EventEmitter<void>;\n\n @State() breakpoint: Breakpoint = 'lg';\n @State() menuExpanded = false;\n @State() suppressResponsive = false;\n\n @State() hasSlottedLogo = false;\n @State() hasOverflowContextMenu = false;\n @State() hasSecondarySlotElements = false;\n @State() hasDefaultSlotElements = false;\n @State() hasOverflowSlotElements = false;\n @State() applicationLayoutContext?: ContextType<\n typeof ApplicationLayoutContext\n >;\n private menuDisposable?: Disposable;\n private modeDisposable?: Disposable;\n private callbackUpdateAppSwitchModal?: (\n config: AppSwitchConfiguration\n ) => void;\n\n get contentBackground() {\n return this.hostElement.shadowRoot!.querySelector('.dropdown-content');\n }\n\n componentWillLoad() {\n this.breakpoint = getCurrentBreakpoint();\n\n useContextConsumer(\n this.hostElement,\n ApplicationLayoutContext,\n (ctx) => {\n this.breakpoint = applicationLayoutService.breakpoint;\n this.applicationLayoutContext = ctx;\n\n this.tryUpdateAppSwitch();\n },\n true\n );\n\n this.menuDisposable = menuController.expandChange.on((show) => {\n this.menuExpanded = show;\n });\n\n this.modeDisposable = applicationLayoutService.onChange.on((mode) => {\n if (this.suppressResponsive) {\n return;\n }\n\n this.breakpoint = mode;\n });\n\n this.updateHasSlotAssignedElementsStates();\n }\n\n componentDidLoad() {\n this.attachSiemensLogoIfLoaded();\n }\n\n disconnectedCallback() {\n this.menuDisposable?.dispose();\n this.modeDisposable?.dispose();\n }\n\n @Watch('applicationLayoutContext')\n watchApplicationLayoutContext() {\n if (this.applicationLayoutContext) {\n this.showMenu = false;\n }\n }\n @Watch('suppressResponsive')\n watchSuppressResponsive() {\n this.breakpoint = 'md';\n }\n\n private checkLogoSlot() {\n const slotElement = this.hostElement.shadowRoot!.querySelector(\n 'slot[name=\"logo\"]'\n ) as HTMLSlotElement;\n\n const isSiemensLogoDefined =\n window.customElements.get('ix-siemens-logo') !== undefined;\n\n if (isSiemensLogoDefined) {\n return hasSlottedElements(slotElement);\n }\n\n let assignedElements = slotElement?.assignedElements({ flatten: true });\n\n assignedElements = assignedElements?.filter(\n (element) => element.tagName !== 'IX-SIEMENS-LOGO'\n );\n\n return assignedElements?.length !== 0;\n }\n\n private attachSiemensLogoIfLoaded() {\n if (this.companyLogo) {\n return;\n }\n\n if (!this.checkLogoSlot()) {\n const logoElement = document.createElement('ix-siemens-logo');\n logoElement.slot = 'logo';\n this.hostElement.appendChild(logoElement);\n }\n }\n\n private async onMenuClick() {\n if (this.applicationLayoutContext) {\n menuController.toggle();\n } else {\n this.menuExpanded = !this.menuExpanded;\n }\n\n this.menuToggle.emit(this.menuExpanded);\n }\n\n private resolveContextMenuButton() {\n return new Promise<HTMLElement>((resolve) =>\n readTask(() =>\n resolve(\n this.hostElement.shadowRoot!.querySelector(\n '[data-context-menu]'\n ) as HTMLElement\n )\n )\n );\n }\n\n private tryUpdateAppSwitch() {\n if (\n !this.callbackUpdateAppSwitchModal ||\n !this.applicationLayoutContext?.appSwitchConfig\n ) {\n return;\n }\n\n this.callbackUpdateAppSwitchModal(\n this.applicationLayoutContext?.appSwitchConfig\n );\n }\n\n private async showAppSwitch() {\n const { defaultPrevented } = this.openAppSwitch.emit();\n\n if (defaultPrevented) {\n return;\n }\n\n if (!this.applicationLayoutContext?.appSwitchConfig) {\n return;\n }\n\n this.callbackUpdateAppSwitchModal = await showAppSwitch(\n this.applicationLayoutContext?.appSwitchConfig\n );\n }\n\n private updateHasSlotAssignedElementsStates() {\n const defaultSlot = this.hostElement.shadowRoot!.querySelector(\n '.content slot:not([name])'\n );\n\n const secondarySlot = this.hostElement.shadowRoot!.querySelector(\n '.content slot[name=\"secondary\"]'\n );\n\n const overflowSlot = this.hostElement.shadowRoot!.querySelector(\n '.content slot[name=\"overflow\"]'\n );\n\n this.hasDefaultSlotElements = hasSlottedElements(defaultSlot);\n this.hasSecondarySlotElements = hasSlottedElements(secondarySlot);\n this.hasOverflowSlotElements = hasSlottedElements(overflowSlot);\n\n this.hasOverflowContextMenu =\n this.hasDefaultSlotElements || this.hasSecondarySlotElements;\n }\n\n private onContentBgClick(e: MouseEvent) {\n if (e.target === this.contentBackground) {\n e.preventDefault();\n }\n }\n\n render() {\n const hasApplicationContextAvailable = !!this.applicationLayoutContext;\n\n const showMenuByApplicationFrame =\n this.breakpoint === 'sm' &&\n this.suppressResponsive === false &&\n hasApplicationContextAvailable;\n\n const showApplicationSwitch =\n this.applicationLayoutContext?.appSwitchConfig &&\n this.breakpoint !== 'sm' &&\n this.suppressResponsive === false;\n\n const showCompanyLogoByProperty =\n this.breakpoint !== 'sm' && !!this.companyLogo;\n\n return (\n <Host\n class={{\n [`breakpoint-${this.breakpoint}`]: true,\n 'hide-bottom-border': this.hideBottomBorder,\n }}\n slot=\"application-header\"\n >\n <div class=\"left-side\">\n {this.appIcon && this.breakpoint !== 'sm' && (\n <div\n class={{\n 'app-icon': true,\n 'app-icon-outline': this.appIconOutline,\n }}\n >\n <img src={this.appIcon} alt={this.appIconAlt} />\n </div>\n )}\n {(this.showMenu || showMenuByApplicationFrame) && (\n <ix-menu-expand-icon\n onClick={() => this.onMenuClick()}\n expanded={this.menuExpanded}\n ixAriaLabel={this.ariaLabelMenuExpandIconButton}\n ></ix-menu-expand-icon>\n )}\n {showApplicationSwitch && (\n <ix-icon-button\n onClick={() => this.showAppSwitch()}\n icon={iconApps}\n variant=\"subtle-tertiary\"\n class={{\n 'app-switch': true,\n 'without-app-icon': !this.appIcon,\n }}\n aria-label={this.ariaLabelAppSwitchIconButton}\n ></ix-icon-button>\n )}\n {showCompanyLogoByProperty && (\n <div class=\"logo\">\n <img src={this.companyLogo} alt={this.companyLogoAlt} />\n </div>\n )}\n <div\n class={{\n logo: true,\n 'hide-logo': !this.hasSlottedLogo,\n }}\n >\n <slot\n name=\"logo\"\n onSlotchange={() => (this.hasSlottedLogo = this.checkLogoSlot())}\n ></slot>\n </div>\n <div class=\"name\">\n <ix-typography format=\"body-lg\" class=\"application-name\">\n {this.name}\n </ix-typography>\n {this.nameSuffix && this.breakpoint !== 'sm' && (\n <ix-typography format=\"body-xs\" class=\"application-name-suffix\">\n {this.nameSuffix}\n </ix-typography>\n )}\n </div>\n </div>\n <div class={{ 'right-side': true, sm: this.breakpoint === 'sm' }}>\n {this.breakpoint !== 'sm' && (\n <div class=\"secondary\">\n <slot name=\"secondary\"></slot>\n </div>\n )}\n <div class=\"content\">\n {this.breakpoint !== 'sm' && <slot></slot>}\n <ix-icon-button\n class={{\n 'context-menu': true,\n 'context-menu-visible':\n this.hasOverflowContextMenu || this.hasOverflowSlotElements,\n }}\n data-context-menu\n data-testid=\"show-more\"\n icon={iconMoreMenu}\n variant=\"subtle-tertiary\"\n aria-label={this.ariaLabelMoreMenuIconButton}\n aria-hidden={a11yBoolean(\n !(this.hasOverflowContextMenu || this.hasOverflowSlotElements)\n )}\n ></ix-icon-button>\n <ix-dropdown\n data-overflow-dropdown\n class=\"dropdown\"\n discoverAllSubmenus\n trigger={this.resolveContextMenuButton()}\n aria-hidden={a11yBoolean(\n !(this.hasOverflowContextMenu || this.hasOverflowSlotElements)\n )}\n >\n <div\n class=\"dropdown-content\"\n onClick={(e) => this.onContentBgClick(e)}\n >\n {this.breakpoint === 'sm' && (\n <div\n class={{\n 'slot-content': true,\n 'slot-content-active': this.hasSecondarySlotElements,\n }}\n >\n <slot\n name=\"secondary\"\n onSlotchange={() =>\n this.updateHasSlotAssignedElementsStates()\n }\n ></slot>\n </div>\n )}\n {this.breakpoint === 'sm' && (\n <div\n class={{\n 'slot-content': true,\n 'slot-content-active': this.hasDefaultSlotElements,\n }}\n >\n <slot\n onSlotchange={() =>\n this.updateHasSlotAssignedElementsStates()\n }\n ></slot>\n </div>\n )}\n <div\n class={{\n 'slot-content': true,\n 'slot-content-active': this.hasOverflowSlotElements,\n }}\n >\n <slot\n name=\"overflow\"\n onSlotchange={() =>\n this.updateHasSlotAssignedElementsStates()\n }\n ></slot>\n </div>\n </div>\n </ix-dropdown>\n <slot name=\"ix-application-header-avatar\"></slot>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":["getCurrentBreakpoint","useContextConsumer","ApplicationLayoutContext","applicationLayoutService","menuController","hasSlottedElements","readTask","showAppSwitch","h","Host","iconApps","iconMoreMenu","a11yBoolean"],"mappings":";;;;;;;;;;;;;;;AAAA,MAAM,oBAAoB,GAAG,89HAA89H;;MC6C9+H,iBAAiB,GAAA,MAAA;AAL9B,IAAA,WAAA,CAAA,OAAA,EAAA;;;;AAkDE;;;;AAIG;AACK,QAAA,IAAc,CAAA,cAAA,GAAG,KAAK;AAE9B;;;;AAIG;AACK,QAAA,IAAgB,CAAA,gBAAA,GAAG,KAAK;AAEhC;;;;;AAKG;AACsB,QAAA,IAAQ,CAAA,QAAA,GAAa,KAAK;AAmC1C,QAAA,IAAU,CAAA,UAAA,GAAe,IAAI;AAC7B,QAAA,IAAY,CAAA,YAAA,GAAG,KAAK;AACpB,QAAA,IAAkB,CAAA,kBAAA,GAAG,KAAK;AAE1B,QAAA,IAAc,CAAA,cAAA,GAAG,KAAK;AACtB,QAAA,IAAsB,CAAA,sBAAA,GAAG,KAAK;AAC9B,QAAA,IAAwB,CAAA,wBAAA,GAAG,KAAK;AAChC,QAAA,IAAsB,CAAA,sBAAA,GAAG,KAAK;AAC9B,QAAA,IAAuB,CAAA,uBAAA,GAAG,KAAK;AAsVzC;AA5UC,IAAA,IAAI,iBAAiB,GAAA;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,UAAW,CAAC,aAAa,CAAC,mBAAmB,CAAC;;IAGxE,iBAAiB,GAAA;AACf,QAAA,IAAI,CAAC,UAAU,GAAGA,gCAAoB,EAAE;QAExCC,0BAAkB,CAChB,IAAI,CAAC,WAAW,EAChBC,gCAAwB,EACxB,CAAC,GAAG,KAAI;AACN,YAAA,IAAI,CAAC,UAAU,GAAGC,gCAAwB,CAAC,UAAU;AACrD,YAAA,IAAI,CAAC,wBAAwB,GAAG,GAAG;YAEnC,IAAI,CAAC,kBAAkB,EAAE;SAC1B,EACD,IAAI,CACL;AAED,QAAA,IAAI,CAAC,cAAc,GAAGC,0BAAc,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,IAAI,KAAI;AAC5D,YAAA,IAAI,CAAC,YAAY,GAAG,IAAI;AAC1B,SAAC,CAAC;AAEF,QAAA,IAAI,CAAC,cAAc,GAAGD,gCAAwB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,IAAI,KAAI;AAClE,YAAA,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAC3B;;AAGF,YAAA,IAAI,CAAC,UAAU,GAAG,IAAI;AACxB,SAAC,CAAC;QAEF,IAAI,CAAC,mCAAmC,EAAE;;IAG5C,gBAAgB,GAAA;QACd,IAAI,CAAC,yBAAyB,EAAE;;IAGlC,oBAAoB,GAAA;;QAClB,CAAA,EAAA,GAAA,IAAI,CAAC,cAAc,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,OAAO,EAAE;QAC9B,CAAA,EAAA,GAAA,IAAI,CAAC,cAAc,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,OAAO,EAAE;;IAIhC,6BAA6B,GAAA;AAC3B,QAAA,IAAI,IAAI,CAAC,wBAAwB,EAAE;AACjC,YAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;;;IAIzB,uBAAuB,GAAA;AACrB,QAAA,IAAI,CAAC,UAAU,GAAG,IAAI;;IAGhB,aAAa,GAAA;AACnB,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,UAAW,CAAC,aAAa,CAC5D,mBAAmB,CACD;AAEpB,QAAA,MAAM,oBAAoB,GACxB,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,iBAAiB,CAAC,KAAK,SAAS;QAE5D,IAAI,oBAAoB,EAAE;AACxB,YAAA,OAAOE,4BAAkB,CAAC,WAAW,CAAC;;AAGxC,QAAA,IAAI,gBAAgB,GAAG,WAAW,KAAX,IAAA,IAAA,WAAW,uBAAX,WAAW,CAAE,gBAAgB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AAEvE,QAAA,gBAAgB,GAAG,gBAAgB,KAAhB,IAAA,IAAA,gBAAgB,uBAAhB,gBAAgB,CAAE,MAAM,CACzC,CAAC,OAAO,KAAK,OAAO,CAAC,OAAO,KAAK,iBAAiB,CACnD;QAED,OAAO,CAAA,gBAAgB,KAAA,IAAA,IAAhB,gBAAgB,KAAA,MAAA,GAAA,MAAA,GAAhB,gBAAgB,CAAE,MAAM,MAAK,CAAC;;IAG/B,yBAAyB,GAAA;AAC/B,QAAA,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB;;AAGF,QAAA,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE;YACzB,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,iBAAiB,CAAC;AAC7D,YAAA,WAAW,CAAC,IAAI,GAAG,MAAM;AACzB,YAAA,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,WAAW,CAAC;;;AAIrC,IAAA,MAAM,WAAW,GAAA;AACvB,QAAA,IAAI,IAAI,CAAC,wBAAwB,EAAE;YACjCD,0BAAc,CAAC,MAAM,EAAE;;aAClB;AACL,YAAA,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY;;QAGxC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC;;IAGjC,wBAAwB,GAAA;AAC9B,QAAA,OAAO,IAAI,OAAO,CAAc,CAAC,OAAO,KACtCE,cAAQ,CAAC,MACP,OAAO,CACL,IAAI,CAAC,WAAW,CAAC,UAAW,CAAC,aAAa,CACxC,qBAAqB,CACP,CACjB,CACF,CACF;;IAGK,kBAAkB,GAAA;;QACxB,IACE,CAAC,IAAI,CAAC,4BAA4B;AAClC,YAAA,EAAC,MAAA,IAAI,CAAC,wBAAwB,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,eAAe,CAAA,EAC/C;YACA;;AAGF,QAAA,IAAI,CAAC,4BAA4B,CAC/B,CAAA,EAAA,GAAA,IAAI,CAAC,wBAAwB,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,eAAe,CAC/C;;AAGK,IAAA,MAAM,aAAa,GAAA;;QACzB,MAAM,EAAE,gBAAgB,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE;QAEtD,IAAI,gBAAgB,EAAE;YACpB;;AAGF,QAAA,IAAI,EAAC,CAAA,EAAA,GAAA,IAAI,CAAC,wBAAwB,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,eAAe,CAAA,EAAE;YACnD;;AAGF,QAAA,IAAI,CAAC,4BAA4B,GAAG,MAAMC,qBAAa,CACrD,CAAA,EAAA,GAAA,IAAI,CAAC,wBAAwB,MAAE,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,eAAe,CAC/C;;IAGK,mCAAmC,GAAA;AACzC,QAAA,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,UAAW,CAAC,aAAa,CAC5D,2BAA2B,CAC5B;AAED,QAAA,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,UAAW,CAAC,aAAa,CAC9D,iCAAiC,CAClC;AAED,QAAA,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,UAAW,CAAC,aAAa,CAC7D,gCAAgC,CACjC;AAED,QAAA,IAAI,CAAC,sBAAsB,GAAGF,4BAAkB,CAAC,WAAW,CAAC;AAC7D,QAAA,IAAI,CAAC,wBAAwB,GAAGA,4BAAkB,CAAC,aAAa,CAAC;AACjE,QAAA,IAAI,CAAC,uBAAuB,GAAGA,4BAAkB,CAAC,YAAY,CAAC;AAE/D,QAAA,IAAI,CAAC,sBAAsB;AACzB,YAAA,IAAI,CAAC,sBAAsB,IAAI,IAAI,CAAC,wBAAwB;;AAGxD,IAAA,gBAAgB,CAAC,CAAa,EAAA;QACpC,IAAI,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,iBAAiB,EAAE;YACvC,CAAC,CAAC,cAAc,EAAE;;;IAItB,MAAM,GAAA;;AACJ,QAAA,MAAM,8BAA8B,GAAG,CAAC,CAAC,IAAI,CAAC,wBAAwB;AAEtE,QAAA,MAAM,0BAA0B,GAC9B,IAAI,CAAC,UAAU,KAAK,IAAI;YACxB,IAAI,CAAC,kBAAkB,KAAK,KAAK;AACjC,YAAA,8BAA8B;AAEhC,QAAA,MAAM,qBAAqB,GACzB,CAAA,CAAA,EAAA,GAAA,IAAI,CAAC,wBAAwB,0CAAE,eAAe;YAC9C,IAAI,CAAC,UAAU,KAAK,IAAI;AACxB,YAAA,IAAI,CAAC,kBAAkB,KAAK,KAAK;AAEnC,QAAA,MAAM,yBAAyB,GAC7B,IAAI,CAAC,UAAU,KAAK,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW;QAEhD,QACEG,OAAA,CAACC,UAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EACH,KAAK,EAAE;AACL,gBAAA,CAAC,cAAc,IAAI,CAAC,UAAU,CAAE,CAAA,GAAG,IAAI;gBACvC,oBAAoB,EAAE,IAAI,CAAC,gBAAgB;AAC5C,aAAA,EACD,IAAI,EAAC,oBAAoB,EAAA,EAEzBD,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,WAAW,EAAA,EACnB,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,KACvCA,OACE,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE;AACL,gBAAA,UAAU,EAAE,IAAI;gBAChB,kBAAkB,EAAE,IAAI,CAAC,cAAc;aACxC,EAAA,EAEDA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,GAAG,EAAE,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,UAAU,EAAA,CAAI,CAC5C,CACP,EACA,CAAC,IAAI,CAAC,QAAQ,IAAI,0BAA0B,MAC3CA,OACE,CAAA,qBAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,OAAO,EAAE,MAAM,IAAI,CAAC,WAAW,EAAE,EACjC,QAAQ,EAAE,IAAI,CAAC,YAAY,EAC3B,WAAW,EAAE,IAAI,CAAC,6BAA6B,GAC1B,CACxB,EACA,qBAAqB,KACpBA,OACE,CAAA,gBAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,OAAO,EAAE,MAAM,IAAI,CAAC,aAAa,EAAE,EACnC,IAAI,EAAEE,gBAAQ,EACd,OAAO,EAAC,iBAAiB,EACzB,KAAK,EAAE;AACL,gBAAA,YAAY,EAAE,IAAI;AAClB,gBAAA,kBAAkB,EAAE,CAAC,IAAI,CAAC,OAAO;AAClC,aAAA,EAAA,YAAA,EACW,IAAI,CAAC,4BAA4B,EAAA,CAC7B,CACnB,EACA,yBAAyB,KACxBF,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,MAAM,EAAA,EACfA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,GAAG,EAAE,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,IAAI,CAAC,cAAc,EAAA,CAAI,CACpD,CACP,EACDA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,IAAI,EAAE,IAAI;AACV,gBAAA,WAAW,EAAE,CAAC,IAAI,CAAC,cAAc;aAClC,EAAA,EAEDA,OACE,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAC,MAAM,EACX,YAAY,EAAE,OAAO,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,GAC1D,CACJ,EACNA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,MAAM,EAAA,EACfA,OAAe,CAAA,eAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,MAAM,EAAC,SAAS,EAAC,KAAK,EAAC,kBAAkB,EACrD,EAAA,IAAI,CAAC,IAAI,CACI,EACf,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,KAAK,IAAI,KAC1CA,OAAe,CAAA,eAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,MAAM,EAAC,SAAS,EAAC,KAAK,EAAC,yBAAyB,EAAA,EAC5D,IAAI,CAAC,UAAU,CACF,CACjB,CACG,CACF,EACNA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,KAAK,IAAI,EAAE,EAAA,EAC7D,IAAI,CAAC,UAAU,KAAK,IAAI,KACvBA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,KAAK,EAAC,WAAW,EAAA,EACpBA,OAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAM,IAAI,EAAC,WAAW,EAAA,CAAQ,CAC1B,CACP,EACDA,OAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,SAAS,EAAA,EACjB,IAAI,CAAC,UAAU,KAAK,IAAI,IAAIA,OAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,EAC1CA,OAAA,CAAA,gBAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,cAAc,EAAE,IAAI;AACpB,gBAAA,sBAAsB,EACpB,IAAI,CAAC,sBAAsB,IAAI,IAAI,CAAC,uBAAuB;AAC9D,aAAA,EAEW,mBAAA,EAAA,IAAA,EAAA,aAAA,EAAA,WAAW,EACvB,IAAI,EAAEG,oBAAY,EAClB,OAAO,EAAC,iBAAiB,EACb,YAAA,EAAA,IAAI,CAAC,2BAA2B,EAC/B,aAAA,EAAAC,gBAAW,CACtB,EAAE,IAAI,CAAC,sBAAsB,IAAI,IAAI,CAAC,uBAAuB,CAAC,CAC/D,EACe,CAAA,EAClBJ,OAEE,CAAA,aAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,wBAAA,EAAA,IAAA,EAAA,KAAK,EAAC,UAAU,EAChB,mBAAmB,QACnB,OAAO,EAAE,IAAI,CAAC,wBAAwB,EAAE,iBAC3BI,gBAAW,CACtB,EAAE,IAAI,CAAC,sBAAsB,IAAI,IAAI,CAAC,uBAAuB,CAAC,CAC/D,EAAA,EAEDJ,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAC,kBAAkB,EACxB,OAAO,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAA,EAEvC,IAAI,CAAC,UAAU,KAAK,IAAI,KACvBA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,cAAc,EAAE,IAAI;gBACpB,qBAAqB,EAAE,IAAI,CAAC,wBAAwB;aACrD,EAAA,EAEDA,OAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,IAAI,EAAC,WAAW,EAChB,YAAY,EAAE,MACZ,IAAI,CAAC,mCAAmC,EAAE,EAAA,CAEtC,CACJ,CACP,EACA,IAAI,CAAC,UAAU,KAAK,IAAI,KACvBA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,cAAc,EAAE,IAAI;gBACpB,qBAAqB,EAAE,IAAI,CAAC,sBAAsB;AACnD,aAAA,EAAA,EAEDA,OACE,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,YAAY,EAAE,MACZ,IAAI,CAAC,mCAAmC,EAAE,EAEtC,CAAA,CACJ,CACP,EACDA,OAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,KAAK,EAAE;AACL,gBAAA,cAAc,EAAE,IAAI;gBACpB,qBAAqB,EAAE,IAAI,CAAC,uBAAuB;aACpD,EAAA,EAEDA,OAAA,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACE,IAAI,EAAC,UAAU,EACf,YAAY,EAAE,MACZ,IAAI,CAAC,mCAAmC,EAAE,EAEtC,CAAA,CACJ,CACF,CACM,EACdA,OAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,IAAI,EAAC,8BAA8B,EAAA,CAAQ,CAC7C,CACF,CACD;;;;;;;;;;;;"}
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var index = require('./index-C8Xo8L1k.js');
4
- var context = require('./context-B8bRIFA2.js');
4
+ var context = require('./context-CmNuiaNz.js');
5
5
  var service = require('./service-DuiJmf7R.js');
6
6
  var menuService = require('./menu-service-CW0vT80Q.js');
7
7
  var shadowDom = require('./shadow-dom-DT01VwcB.js');
@@ -53,7 +53,6 @@ const Application = class {
53
53
  service.applicationLayoutService.setBreakpoints(this.breakpoints);
54
54
  this.contextProvider = context.useContextProvider(this.hostElement, context.ApplicationLayoutContext, {
55
55
  hideHeader: false,
56
- host: 'basic-navigation',
57
56
  sidebar: this.applicationSidebarSlotted,
58
57
  appSwitchConfig: this.appSwitchConfig,
59
58
  });
@@ -90,18 +89,17 @@ const Application = class {
90
89
  }
91
90
  this.contextProvider.emit({
92
91
  hideHeader: false,
93
- host: 'basic-navigation',
94
92
  sidebar: this.applicationSidebarSlotted,
95
93
  appSwitchConfig: this.appSwitchConfig,
96
94
  });
97
95
  }
98
96
  render() {
99
- return (index.h(index.Host, { key: '8ec10f51dff7f068d6d9ecc3482f57f7eee372e1', "data-role": "", class: {
97
+ return (index.h(index.Host, { key: '80437ae705c381c0167b8d7c5ce429e611b03f91', "data-role": "", class: {
100
98
  [`breakpoint-${this.breakpoint}`]: true,
101
- } }, index.h("slot", { key: '0907c0a93f6baa2bec75388748c5b380ac57ba9f', name: "application-header" }), index.h("div", { key: '20dbe63e526f7842680f6c4abc6d4295892ae7f6', class: "application" }, index.h("slot", { key: 'd47121e13a25c0738cba759b53fac4e33ec05dc6', name: "menu" }), index.h("aside", { key: '61e0b686faca2fb562651b67286b837d94053b99', class: {
99
+ } }, index.h("slot", { key: '865d2e5a9252459f62ff8ab5dce1413d11c04379', name: "application-header" }), index.h("div", { key: 'ae1960437e8721fbc4afab659d149265660e4164', class: "application" }, index.h("slot", { key: 'a2a9a835af35e30d2ebe52347903f1838e75ac8d', name: "menu" }), index.h("aside", { key: '6141152471ac7dc7310247b23278dc594e025fa3', class: {
102
100
  'application-sidebar': true,
103
101
  slotted: this.applicationSidebarSlotted,
104
- }, onClick: () => this.onContentClick() }, index.h("slot", { key: '2e84b0947f7f8f663ea18211e8cd2112e2702048', name: "application-sidebar", onSlotchange: () => (this.applicationSidebarSlotted = shadowDom.hasSlottedElements(this.applicationSidebarSlot)) })), index.h("div", { key: '89cc5e6a029a43cedb58865984d0e46b6b14c4d3', class: "content-area" }, index.h("main", { key: 'dfc4b2e1842a43ca077d0b87168ac7119c7bb80d', class: "content", onClick: () => this.onContentClick() }, index.h("slot", { key: '6af3c3a4f10005a8d3d10d86e3388c41ffce7204' })), index.h("footer", { key: '44c8fdcf8f6fe6c6c03e2c03214c5acbb8e9d7bf', class: "footer" }, index.h("slot", { key: 'c066f4dcc1948952fa8218b70fb697470385f4d8', name: "bottom" }))))));
102
+ }, onClick: () => this.onContentClick() }, index.h("slot", { key: '3285cc16452a7a6936a542dd26758beebb515972', name: "application-sidebar", onSlotchange: () => (this.applicationSidebarSlotted = shadowDom.hasSlottedElements(this.applicationSidebarSlot)) })), index.h("div", { key: 'c6d022a1a5c220ed088adeba49ab5daa27ff8c77', class: "content-area" }, index.h("main", { key: '8ab781e17318078290a6ce4e1e64dfea43d5ae00', class: "content", onClick: () => this.onContentClick() }, index.h("slot", { key: '24e83882ab5746f4e00a0c16c797ddf4111aa1e8' })), index.h("footer", { key: '3ce838daa8f8f4b4e56cb2626476223d9575177c', class: "footer" }, index.h("slot", { key: 'e49d1cd476554dfddca3b538194040ca29394967', name: "bottom" }))))));
105
103
  }
106
104
  get hostElement() { return index.getElement(this); }
107
105
  static get watchers() { return {
@@ -1 +1 @@
1
- {"version":3,"file":"ix-application.entry.cjs.js","sources":["src/components/application/application.scss?tag=ix-application&encapsulation=shadow","src/components/application/application.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 'mixins/shadow-dom/component';\n\n:host {\n display: flex;\n position: relative;\n width: 100vw;\n height: 100vh;\n\n flex-direction: column;\n\n @include component.ix-component;\n\n ix-application-header {\n z-index: calc(var(--theme-z-index-sticky) + 1);\n }\n\n .logo-wrapper {\n display: contents;\n }\n\n .application {\n display: flex;\n position: relative;\n flex-direction: row;\n height: 100%;\n width: 100%;\n overflow: hidden;\n }\n\n .content-area {\n display: flex;\n position: relative;\n flex-direction: column;\n flex-wrap: nowrap;\n height: calc(100% - var(--ix-safe-area-inset-bottom, 0px));\n width: 100%;\n margin-left: var(--ix-application-menu-margin-left);\n min-width: 0;\n }\n\n main {\n display: block;\n position: relative;\n flex-grow: 1;\n\n width: 100%;\n padding-bottom: var(--ix-safe-area-inset-bottom);\n overflow: auto;\n }\n\n footer {\n display: block;\n position: relative;\n width: 100%;\n }\n}\n\n:host(.breakpoint-md) {\n --ix-application-menu-margin-left: calc(\n 3.25rem + var(--ix-application-menu-safe-area-left, 0rem)\n );\n\n aside.slotted {\n margin-left: var(--ix-application-menu-margin-left);\n }\n\n aside.slotted + .content-area {\n margin-left: 0;\n }\n\n aside:not(.slotted) + .content-area {\n margin-left: var(--ix-application-menu-margin-left);\n }\n}\n\n:host(.breakpoint-lg) {\n --ix-application-menu-margin-left: 0;\n}\n\n:host(.breakpoint-sm) {\n --ix-application-menu-margin-left: var(\n --ix-application-menu-safe-area-left,\n 0rem\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 { Component, Element, h, Host, Prop, State, Watch } from '@stencil/core';\nimport {\n ApplicationLayoutContext,\n AppSwitchConfiguration,\n} from '../utils/application-layout/context';\nimport { applicationLayoutService } from '../utils/application-layout/service';\nimport { Breakpoint } from '../utils/breakpoints';\nimport { ContextProvider, useContextProvider } from '../utils/context';\nimport { menuController } from '../utils/menu-service/menu-service';\nimport { hasSlottedElements } from '../utils/shadow-dom';\nimport { IxTheme, themeSwitcher } from '../utils/theme-switcher';\nimport { Disposable } from '../utils/typed-event';\n\n@Component({\n tag: 'ix-application',\n styleUrl: 'application.scss',\n shadow: true,\n})\nexport class Application {\n @Element() hostElement!: HTMLIxApplicationElement;\n\n /**\n * Application theme\n */\n @Prop() theme?: IxTheme;\n\n /**\n * Use the system appearance dark or light\n */\n @Prop() themeSystemAppearance = false;\n\n /**\n * Change the responsive layout of the menu structure\n */\n @Prop() forceBreakpoint: Breakpoint | undefined;\n forceLayoutChange(newMode: Breakpoint | undefined) {\n if (!newMode) {\n applicationLayoutService.enableBreakpointDetection();\n return;\n }\n\n applicationLayoutService.disableBreakpointDetection();\n applicationLayoutService.setBreakpoint(newMode);\n }\n\n /**\n * Supported layouts\n */\n @Prop() breakpoints: Breakpoint[] = ['sm', 'md', 'lg'];\n @Watch('breakpoints')\n onBreakpointsChange(breakpoints: Breakpoint[]) {\n applicationLayoutService.setBreakpoints(breakpoints);\n }\n\n /**\n * Define application switch configuration\n */\n @Prop() appSwitchConfig?: AppSwitchConfiguration;\n\n @State() breakpoint: Breakpoint = 'lg';\n @State() applicationSidebarSlotted = false;\n\n private contextProvider?: ContextProvider<typeof ApplicationLayoutContext>;\n\n get menu(): HTMLIxMenuElement | null {\n return this.hostElement.querySelector('ix-menu');\n }\n\n get applicationSidebarSlot() {\n return this.hostElement.shadowRoot!.querySelector(\n '.application-sidebar slot'\n ) as HTMLSlotElement;\n }\n\n private modeDisposable?: Disposable;\n\n private onContentClick() {\n if (menuController.isPinned) {\n return;\n }\n this.menu?.toggleMenu(false);\n }\n\n componentWillLoad() {\n applicationLayoutService.setBreakpoints(this.breakpoints);\n\n this.contextProvider = useContextProvider(\n this.hostElement,\n ApplicationLayoutContext,\n {\n hideHeader: false,\n host: 'basic-navigation',\n sidebar: this.applicationSidebarSlotted,\n appSwitchConfig: this.appSwitchConfig,\n }\n );\n\n this.modeDisposable = applicationLayoutService.onChange.on((mode) => {\n this.breakpoint = mode;\n });\n this.breakpoint = applicationLayoutService.breakpoint;\n\n if (this.forceBreakpoint) {\n this.forceLayoutChange(this.forceBreakpoint);\n }\n\n this.changeTheme();\n }\n\n disconnectedCallback() {\n this.modeDisposable?.dispose();\n }\n\n @Watch('theme')\n @Watch('themeSystemAppearance')\n private changeTheme() {\n if (!this.theme) {\n if (this.themeSystemAppearance) {\n themeSwitcher.setVariant();\n }\n\n return;\n }\n\n if (themeSwitcher.hasVariantSuffix(this.theme)) {\n themeSwitcher.setTheme(`theme-${this.theme}`);\n return;\n }\n\n themeSwitcher.setTheme(\n `theme-${this.theme}-dark`,\n this.themeSystemAppearance\n );\n }\n\n @Watch('appSwitchConfig')\n @Watch('applicationSidebarSlotted')\n onApplicationSidebarChange() {\n if (!this.contextProvider) {\n console.error('Context provider not available');\n return;\n }\n this.contextProvider.emit({\n hideHeader: false,\n host: 'basic-navigation',\n sidebar: this.applicationSidebarSlotted,\n appSwitchConfig: this.appSwitchConfig,\n });\n }\n\n render() {\n return (\n <Host\n data-role=\"\"\n class={{\n [`breakpoint-${this.breakpoint}`]: true,\n }}\n >\n <slot name=\"application-header\"></slot>\n <div class=\"application\">\n <slot name=\"menu\"></slot>\n <aside\n class={{\n 'application-sidebar': true,\n slotted: this.applicationSidebarSlotted,\n }}\n onClick={() => this.onContentClick()}\n >\n <slot\n name=\"application-sidebar\"\n onSlotchange={() =>\n (this.applicationSidebarSlotted = hasSlottedElements(\n this.applicationSidebarSlot\n ))\n }\n ></slot>\n </aside>\n <div class=\"content-area\">\n <main class=\"content\" onClick={() => this.onContentClick()}>\n <slot></slot>\n </main>\n <footer class=\"footer\">\n <slot name=\"bottom\"></slot>\n </footer>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":["applicationLayoutService","menuController","useContextProvider","ApplicationLayoutContext","themeSwitcher","h","Host","hasSlottedElements"],"mappings":"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"}
1
+ {"version":3,"file":"ix-application.entry.cjs.js","sources":["src/components/application/application.scss?tag=ix-application&encapsulation=shadow","src/components/application/application.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 'mixins/shadow-dom/component';\n\n:host {\n display: flex;\n position: relative;\n width: 100vw;\n height: 100vh;\n\n flex-direction: column;\n\n @include component.ix-component;\n\n ix-application-header {\n z-index: calc(var(--theme-z-index-sticky) + 1);\n }\n\n .logo-wrapper {\n display: contents;\n }\n\n .application {\n display: flex;\n position: relative;\n flex-direction: row;\n height: 100%;\n width: 100%;\n overflow: hidden;\n }\n\n .content-area {\n display: flex;\n position: relative;\n flex-direction: column;\n flex-wrap: nowrap;\n height: calc(100% - var(--ix-safe-area-inset-bottom, 0px));\n width: 100%;\n margin-left: var(--ix-application-menu-margin-left);\n min-width: 0;\n }\n\n main {\n display: block;\n position: relative;\n flex-grow: 1;\n\n width: 100%;\n padding-bottom: var(--ix-safe-area-inset-bottom);\n overflow: auto;\n }\n\n footer {\n display: block;\n position: relative;\n width: 100%;\n }\n}\n\n:host(.breakpoint-md) {\n --ix-application-menu-margin-left: calc(\n 3.25rem + var(--ix-application-menu-safe-area-left, 0rem)\n );\n\n aside.slotted {\n margin-left: var(--ix-application-menu-margin-left);\n }\n\n aside.slotted + .content-area {\n margin-left: 0;\n }\n\n aside:not(.slotted) + .content-area {\n margin-left: var(--ix-application-menu-margin-left);\n }\n}\n\n:host(.breakpoint-lg) {\n --ix-application-menu-margin-left: 0;\n}\n\n:host(.breakpoint-sm) {\n --ix-application-menu-margin-left: var(\n --ix-application-menu-safe-area-left,\n 0rem\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 { Component, Element, h, Host, Prop, State, Watch } from '@stencil/core';\nimport {\n ApplicationLayoutContext,\n AppSwitchConfiguration,\n} from '../utils/application-layout/context';\nimport { applicationLayoutService } from '../utils/application-layout/service';\nimport { Breakpoint } from '../utils/breakpoints';\nimport { ContextProvider, useContextProvider } from '../utils/context';\nimport { menuController } from '../utils/menu-service/menu-service';\nimport { hasSlottedElements } from '../utils/shadow-dom';\nimport { IxTheme, themeSwitcher } from '../utils/theme-switcher';\nimport { Disposable } from '../utils/typed-event';\n\n@Component({\n tag: 'ix-application',\n styleUrl: 'application.scss',\n shadow: true,\n})\nexport class Application {\n @Element() hostElement!: HTMLIxApplicationElement;\n\n /**\n * Application theme\n */\n @Prop() theme?: IxTheme;\n\n /**\n * Use the system appearance dark or light\n */\n @Prop() themeSystemAppearance = false;\n\n /**\n * Change the responsive layout of the menu structure\n */\n @Prop() forceBreakpoint: Breakpoint | undefined;\n forceLayoutChange(newMode: Breakpoint | undefined) {\n if (!newMode) {\n applicationLayoutService.enableBreakpointDetection();\n return;\n }\n\n applicationLayoutService.disableBreakpointDetection();\n applicationLayoutService.setBreakpoint(newMode);\n }\n\n /**\n * Supported layouts\n */\n @Prop() breakpoints: Breakpoint[] = ['sm', 'md', 'lg'];\n @Watch('breakpoints')\n onBreakpointsChange(breakpoints: Breakpoint[]) {\n applicationLayoutService.setBreakpoints(breakpoints);\n }\n\n /**\n * Define application switch configuration\n */\n @Prop() appSwitchConfig?: AppSwitchConfiguration;\n\n @State() breakpoint: Breakpoint = 'lg';\n @State() applicationSidebarSlotted = false;\n\n private contextProvider?: ContextProvider<typeof ApplicationLayoutContext>;\n\n get menu(): HTMLIxMenuElement | null {\n return this.hostElement.querySelector('ix-menu');\n }\n\n get applicationSidebarSlot() {\n return this.hostElement.shadowRoot!.querySelector(\n '.application-sidebar slot'\n ) as HTMLSlotElement;\n }\n\n private modeDisposable?: Disposable;\n\n private onContentClick() {\n if (menuController.isPinned) {\n return;\n }\n this.menu?.toggleMenu(false);\n }\n\n componentWillLoad() {\n applicationLayoutService.setBreakpoints(this.breakpoints);\n\n this.contextProvider = useContextProvider(\n this.hostElement,\n ApplicationLayoutContext,\n {\n hideHeader: false,\n sidebar: this.applicationSidebarSlotted,\n appSwitchConfig: this.appSwitchConfig,\n }\n );\n\n this.modeDisposable = applicationLayoutService.onChange.on((mode) => {\n this.breakpoint = mode;\n });\n this.breakpoint = applicationLayoutService.breakpoint;\n\n if (this.forceBreakpoint) {\n this.forceLayoutChange(this.forceBreakpoint);\n }\n\n this.changeTheme();\n }\n\n disconnectedCallback() {\n this.modeDisposable?.dispose();\n }\n\n @Watch('theme')\n @Watch('themeSystemAppearance')\n private changeTheme() {\n if (!this.theme) {\n if (this.themeSystemAppearance) {\n themeSwitcher.setVariant();\n }\n\n return;\n }\n\n if (themeSwitcher.hasVariantSuffix(this.theme)) {\n themeSwitcher.setTheme(`theme-${this.theme}`);\n return;\n }\n\n themeSwitcher.setTheme(\n `theme-${this.theme}-dark`,\n this.themeSystemAppearance\n );\n }\n\n @Watch('appSwitchConfig')\n @Watch('applicationSidebarSlotted')\n onApplicationSidebarChange() {\n if (!this.contextProvider) {\n console.error('Context provider not available');\n return;\n }\n this.contextProvider.emit({\n hideHeader: false,\n sidebar: this.applicationSidebarSlotted,\n appSwitchConfig: this.appSwitchConfig,\n });\n }\n\n render() {\n return (\n <Host\n data-role=\"\"\n class={{\n [`breakpoint-${this.breakpoint}`]: true,\n }}\n >\n <slot name=\"application-header\"></slot>\n <div class=\"application\">\n <slot name=\"menu\"></slot>\n <aside\n class={{\n 'application-sidebar': true,\n slotted: this.applicationSidebarSlotted,\n }}\n onClick={() => this.onContentClick()}\n >\n <slot\n name=\"application-sidebar\"\n onSlotchange={() =>\n (this.applicationSidebarSlotted = hasSlottedElements(\n this.applicationSidebarSlot\n ))\n }\n ></slot>\n </aside>\n <div class=\"content-area\">\n <main class=\"content\" onClick={() => this.onContentClick()}>\n <slot></slot>\n </main>\n <footer class=\"footer\">\n <slot name=\"bottom\"></slot>\n </footer>\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"names":["applicationLayoutService","menuController","useContextProvider","ApplicationLayoutContext","themeSwitcher","h","Host","hasSlottedElements"],"mappings":"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"}