@infineon/infineon-design-system-stencil 35.5.0--canary.1904.c3cb7254ae476891ebdb18f1579f66379ad24854.0 → 36.0.0--canary.1926.3b76d5defe8b9a743d9ec0dd5e6879c04e8055c0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (731) hide show
  1. package/dist/cjs/ifx-accordion_2.cjs.entry.js +26 -33
  2. package/dist/cjs/ifx-accordion_2.cjs.entry.js.map +1 -1
  3. package/dist/cjs/ifx-alert_2.cjs.entry.js +1 -7
  4. package/dist/cjs/ifx-alert_2.cjs.entry.js.map +1 -1
  5. package/dist/cjs/ifx-badge.cjs.entry.js +1 -9
  6. package/dist/cjs/ifx-badge.cjs.entry.js.map +1 -1
  7. package/dist/cjs/ifx-basic-table.cjs.entry.js +4 -9
  8. package/dist/cjs/ifx-basic-table.cjs.entry.js.map +1 -1
  9. package/dist/cjs/ifx-breadcrumb.cjs.entry.js +1 -8
  10. package/dist/cjs/ifx-breadcrumb.cjs.entry.js.map +1 -1
  11. package/dist/cjs/ifx-button.cjs.entry.js +1 -6
  12. package/dist/cjs/ifx-button.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ifx-card.cjs.entry.js +3 -8
  14. package/dist/cjs/ifx-card.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ifx-checkbox-group.cjs.entry.js +1 -6
  16. package/dist/cjs/ifx-checkbox-group.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ifx-checkbox.cjs.entry.js +3 -8
  18. package/dist/cjs/ifx-checkbox.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ifx-chip_3.cjs.entry.js +9 -17
  20. package/dist/cjs/ifx-chip_3.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ifx-content-switcher.cjs.entry.js +1 -6
  22. package/dist/cjs/ifx-content-switcher.cjs.entry.js.map +1 -1
  23. package/dist/cjs/ifx-date-picker.cjs.entry.js +2 -9
  24. package/dist/cjs/ifx-date-picker.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ifx-dropdown.cjs.entry.js +1 -6
  26. package/dist/cjs/ifx-dropdown.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ifx-faq.cjs.entry.js +1 -1
  28. package/dist/cjs/ifx-file-upload.cjs.entry.js +2 -9
  29. package/dist/cjs/ifx-file-upload.cjs.entry.js.map +1 -1
  30. package/dist/cjs/ifx-filter-accordion.cjs.entry.js +2 -2
  31. package/dist/cjs/ifx-filter-bar.cjs.entry.js +1 -1
  32. package/dist/cjs/ifx-filter-search.cjs.entry.js +1 -1
  33. package/dist/cjs/ifx-filter-type-group.cjs.entry.js +1 -1
  34. package/dist/cjs/ifx-footer.cjs.entry.js +4 -9
  35. package/dist/cjs/ifx-footer.cjs.entry.js.map +1 -1
  36. package/dist/cjs/ifx-icon-button.cjs.entry.js +1 -6
  37. package/dist/cjs/ifx-icon-button.cjs.entry.js.map +1 -1
  38. package/dist/cjs/ifx-icon.cjs.entry.js +3 -36
  39. package/dist/cjs/ifx-icon.cjs.entry.js.map +1 -1
  40. package/dist/cjs/ifx-indicator.cjs.entry.js +2 -7
  41. package/dist/cjs/ifx-indicator.cjs.entry.js.map +1 -1
  42. package/dist/cjs/ifx-link.cjs.entry.js +1 -9
  43. package/dist/cjs/ifx-link.cjs.entry.js.map +1 -1
  44. package/dist/cjs/ifx-list-entry.cjs.entry.js +1 -1
  45. package/dist/cjs/ifx-modal.cjs.entry.js +2 -9
  46. package/dist/cjs/ifx-modal.cjs.entry.js.map +1 -1
  47. package/dist/cjs/ifx-multiselect_2.cjs.entry.js +932 -0
  48. package/dist/cjs/ifx-multiselect_2.cjs.entry.js.map +1 -0
  49. package/dist/cjs/ifx-navbar.cjs.entry.js +3 -5
  50. package/dist/cjs/ifx-navbar.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ifx-notification.cjs.entry.js +2 -10
  52. package/dist/cjs/ifx-notification.cjs.entry.js.map +1 -1
  53. package/dist/cjs/ifx-progress-bar.cjs.entry.js +1 -7
  54. package/dist/cjs/ifx-progress-bar.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ifx-radio-button-group.cjs.entry.js +1 -6
  56. package/dist/cjs/ifx-radio-button-group.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ifx-radio-button.cjs.entry.js +2 -7
  58. package/dist/cjs/ifx-radio-button.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ifx-search-bar.cjs.entry.js +1 -6
  60. package/dist/cjs/ifx-search-bar.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ifx-search-field.cjs.entry.js +1 -9
  62. package/dist/cjs/ifx-search-field.cjs.entry.js.map +1 -1
  63. package/dist/cjs/ifx-segmented-control.cjs.entry.js +2 -9
  64. package/dist/cjs/ifx-segmented-control.cjs.entry.js.map +1 -1
  65. package/dist/cjs/ifx-select.cjs.entry.js +2 -7
  66. package/dist/cjs/ifx-select.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ifx-set-filter.cjs.entry.js +19 -2
  68. package/dist/cjs/ifx-set-filter.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ifx-sidebar.cjs.entry.js +5 -7
  70. package/dist/cjs/ifx-sidebar.cjs.entry.js.map +1 -1
  71. package/dist/cjs/ifx-slider.cjs.entry.js +3 -8
  72. package/dist/cjs/ifx-slider.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ifx-spinner_2.cjs.entry.js +6 -17
  74. package/dist/cjs/ifx-spinner_2.cjs.entry.js.map +1 -1
  75. package/dist/cjs/ifx-status.cjs.entry.js +1 -9
  76. package/dist/cjs/ifx-status.cjs.entry.js.map +1 -1
  77. package/dist/cjs/ifx-step.cjs.entry.js +4 -4
  78. package/dist/cjs/ifx-step.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ifx-stepper.cjs.entry.js +2 -7
  80. package/dist/cjs/ifx-stepper.cjs.entry.js.map +1 -1
  81. package/dist/cjs/ifx-switch.cjs.entry.js +1 -6
  82. package/dist/cjs/ifx-switch.cjs.entry.js.map +1 -1
  83. package/dist/cjs/ifx-tab.cjs.entry.js +1 -1
  84. package/dist/cjs/ifx-table.cjs.entry.js +5 -10
  85. package/dist/cjs/ifx-table.cjs.entry.js.map +1 -1
  86. package/dist/cjs/ifx-tabs.cjs.entry.js +2 -7
  87. package/dist/cjs/ifx-tabs.cjs.entry.js.map +1 -1
  88. package/dist/cjs/ifx-tag.cjs.entry.js +1 -9
  89. package/dist/cjs/ifx-tag.cjs.entry.js.map +1 -1
  90. package/dist/cjs/ifx-templates-ui.cjs.entry.js +1 -1
  91. package/dist/cjs/ifx-textarea.cjs.entry.js +1 -6
  92. package/dist/cjs/ifx-textarea.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ifx-tooltip.cjs.entry.js +4 -9
  94. package/dist/cjs/ifx-tooltip.cjs.entry.js.map +1 -1
  95. package/dist/cjs/ifx-tree-view-item.cjs.entry.js +2 -2
  96. package/dist/cjs/ifx-tree-view.cjs.entry.js +1 -9
  97. package/dist/cjs/ifx-tree-view.cjs.entry.js.map +1 -1
  98. package/dist/cjs/index-7f4df11a.js +14 -14
  99. package/dist/cjs/infineon-design-system-stencil.cjs.js +1 -1
  100. package/dist/cjs/loader.cjs.js +1 -1
  101. package/dist/collection/collection-manifest.json +1 -0
  102. package/dist/collection/components/accordion/accordion.js +2 -8
  103. package/dist/collection/components/accordion/accordion.js.map +1 -1
  104. package/dist/collection/components/accordion/accordionItem.css +4 -0
  105. package/dist/collection/components/accordion/accordionItem.js +24 -24
  106. package/dist/collection/components/accordion/accordionItem.js.map +1 -1
  107. package/dist/collection/components/alert/alert.js +0 -6
  108. package/dist/collection/components/alert/alert.js.map +1 -1
  109. package/dist/collection/components/badge/badge.js +1 -9
  110. package/dist/collection/components/badge/badge.js.map +1 -1
  111. package/dist/collection/components/breadcrumb/breadcrumb.js +1 -8
  112. package/dist/collection/components/breadcrumb/breadcrumb.js.map +1 -1
  113. package/dist/collection/components/button/button.js +1 -6
  114. package/dist/collection/components/button/button.js.map +1 -1
  115. package/dist/collection/components/card/card.js +3 -8
  116. package/dist/collection/components/card/card.js.map +1 -1
  117. package/dist/collection/components/checkbox/checkbox.js +3 -8
  118. package/dist/collection/components/checkbox/checkbox.js.map +1 -1
  119. package/dist/collection/components/checkbox-group/checkbox-group.js +1 -6
  120. package/dist/collection/components/checkbox-group/checkbox-group.js.map +1 -1
  121. package/dist/collection/components/chip/chip.js +8 -13
  122. package/dist/collection/components/chip/chip.js.map +1 -1
  123. package/dist/collection/components/content-switcher/content-switcher.js +1 -6
  124. package/dist/collection/components/content-switcher/content-switcher.js.map +1 -1
  125. package/dist/collection/components/date-picker/date-picker.js +2 -9
  126. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  127. package/dist/collection/components/dropdown/dropdown.js +1 -6
  128. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  129. package/dist/collection/components/file-upload/file-upload.js +2 -9
  130. package/dist/collection/components/file-upload/file-upload.js.map +1 -1
  131. package/dist/collection/components/footer/footer.js +4 -9
  132. package/dist/collection/components/footer/footer.js.map +1 -1
  133. package/dist/collection/components/footer/footer.stories.js +4 -4
  134. package/dist/collection/components/footer/footer.stories.js.map +1 -1
  135. package/dist/collection/components/icon/infineonIconStencil.js +3 -36
  136. package/dist/collection/components/icon/infineonIconStencil.js.map +1 -1
  137. package/dist/collection/components/icon-button/icon-button.js +1 -6
  138. package/dist/collection/components/icon-button/icon-button.js.map +1 -1
  139. package/dist/collection/components/indicator/indicator.js +2 -7
  140. package/dist/collection/components/indicator/indicator.js.map +1 -1
  141. package/dist/collection/components/link/link.js +1 -9
  142. package/dist/collection/components/link/link.js.map +1 -1
  143. package/dist/collection/components/modal/modal.js +2 -9
  144. package/dist/collection/components/modal/modal.js.map +1 -1
  145. package/dist/collection/components/navigation/navbar/navbar.js +3 -5
  146. package/dist/collection/components/navigation/navbar/navbar.js.map +1 -1
  147. package/dist/collection/components/navigation/sidebar/sidebar.js +5 -7
  148. package/dist/collection/components/navigation/sidebar/sidebar.js.map +1 -1
  149. package/dist/collection/components/notification/notification.js +2 -10
  150. package/dist/collection/components/notification/notification.js.map +1 -1
  151. package/dist/collection/components/pagination/pagination.js +1 -6
  152. package/dist/collection/components/pagination/pagination.js.map +1 -1
  153. package/dist/collection/components/progress-bar/progress-bar.js +1 -7
  154. package/dist/collection/components/progress-bar/progress-bar.js.map +1 -1
  155. package/dist/collection/components/radio-button/radio-button.js +2 -7
  156. package/dist/collection/components/radio-button/radio-button.js.map +1 -1
  157. package/dist/collection/components/radio-button-group/radio-button-group.js +1 -6
  158. package/dist/collection/components/radio-button-group/radio-button-group.js.map +1 -1
  159. package/dist/collection/components/search-bar/search-bar.js +1 -6
  160. package/dist/collection/components/search-bar/search-bar.js.map +1 -1
  161. package/dist/collection/components/search-field/search-field.js +1 -9
  162. package/dist/collection/components/search-field/search-field.js.map +1 -1
  163. package/dist/collection/components/segmented-control/segmented-control.js +2 -9
  164. package/dist/collection/components/segmented-control/segmented-control.js.map +1 -1
  165. package/dist/collection/components/select/multi-select/interfaces.js.map +1 -1
  166. package/dist/collection/components/select/multi-select/multiselect-option.css +112 -0
  167. package/dist/collection/components/select/multi-select/multiselect-option.js +505 -0
  168. package/dist/collection/components/select/multi-select/multiselect-option.js.map +1 -0
  169. package/dist/collection/components/select/multi-select/multiselect.css +56 -67
  170. package/dist/collection/components/select/multi-select/multiselect.js +678 -432
  171. package/dist/collection/components/select/multi-select/multiselect.js.map +1 -1
  172. package/dist/collection/components/select/multi-select/multiselect.stories.js +439 -135
  173. package/dist/collection/components/select/multi-select/multiselect.stories.js.map +1 -1
  174. package/dist/collection/components/select/single-select/select.js +2 -7
  175. package/dist/collection/components/select/single-select/select.js.map +1 -1
  176. package/dist/collection/components/slider/slider.css +2 -2
  177. package/dist/collection/components/slider/slider.js +2 -7
  178. package/dist/collection/components/slider/slider.js.map +1 -1
  179. package/dist/collection/components/spinner/spinner.js +2 -10
  180. package/dist/collection/components/spinner/spinner.js.map +1 -1
  181. package/dist/collection/components/status/status.js +1 -9
  182. package/dist/collection/components/status/status.js.map +1 -1
  183. package/dist/collection/components/stepper/step/step.js +4 -4
  184. package/dist/collection/components/stepper/step/step.js.map +1 -1
  185. package/dist/collection/components/stepper/stepper.js +2 -7
  186. package/dist/collection/components/stepper/stepper.js.map +1 -1
  187. package/dist/collection/components/switch/switch.js +1 -6
  188. package/dist/collection/components/switch/switch.js.map +1 -1
  189. package/dist/collection/components/table-advanced-version/filter-bar/filter-bar.js +1 -1
  190. package/dist/collection/components/table-advanced-version/filter-type-group/filter-accordion/filter-accordion.js +2 -2
  191. package/dist/collection/components/table-advanced-version/filter-type-group/filter-search/filter-search.js +1 -1
  192. package/dist/collection/components/table-advanced-version/filter-type-group/filter-type-group.js +1 -1
  193. package/dist/collection/components/table-advanced-version/list/list-entry/list-entry.js +1 -1
  194. package/dist/collection/components/table-advanced-version/set-filter/setFilter.js +19 -2
  195. package/dist/collection/components/table-advanced-version/set-filter/setFilter.js.map +1 -1
  196. package/dist/collection/components/table-advanced-version/table.js +5 -10
  197. package/dist/collection/components/table-advanced-version/table.js.map +1 -1
  198. package/dist/collection/components/table-advanced-version/table.stories.js +2 -3
  199. package/dist/collection/components/table-advanced-version/table.stories.js.map +1 -1
  200. package/dist/collection/components/table-basic-version/table.js +4 -9
  201. package/dist/collection/components/table-basic-version/table.js.map +1 -1
  202. package/dist/collection/components/tabs/tab.js +1 -1
  203. package/dist/collection/components/tabs/tabs.js +3 -7
  204. package/dist/collection/components/tabs/tabs.js.map +1 -1
  205. package/dist/collection/components/tag/tag.js +1 -9
  206. package/dist/collection/components/tag/tag.js.map +1 -1
  207. package/dist/collection/components/templates/template/template.js +1 -1
  208. package/dist/collection/components/templates/templates-ui/templates-ui.js +1 -1
  209. package/dist/collection/components/text-field/text-field.js +4 -9
  210. package/dist/collection/components/text-field/text-field.js.map +1 -1
  211. package/dist/collection/components/textarea/textarea.js +1 -6
  212. package/dist/collection/components/textarea/textarea.js.map +1 -1
  213. package/dist/collection/components/tooltip/tooltip.js +4 -9
  214. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  215. package/dist/collection/components/tree-view/tree-view-item.js +2 -2
  216. package/dist/collection/components/tree-view/tree-view.js +1 -9
  217. package/dist/collection/components/tree-view/tree-view.js.map +1 -1
  218. package/dist/collection/stories/setup-and-installation/faq/faq.js +1 -1
  219. package/dist/components/ifx-accordion-item.js +1 -1
  220. package/dist/components/ifx-accordion.js +1 -1
  221. package/dist/components/ifx-alert.js +1 -1
  222. package/dist/components/ifx-badge.js +1 -9
  223. package/dist/components/ifx-badge.js.map +1 -1
  224. package/dist/components/ifx-basic-table.js +4 -9
  225. package/dist/components/ifx-basic-table.js.map +1 -1
  226. package/dist/components/ifx-breadcrumb-item-label.js +1 -1
  227. package/dist/components/ifx-breadcrumb.js +1 -8
  228. package/dist/components/ifx-breadcrumb.js.map +1 -1
  229. package/dist/components/ifx-button.js +1 -1
  230. package/dist/components/ifx-card.js +3 -8
  231. package/dist/components/ifx-card.js.map +1 -1
  232. package/dist/components/ifx-checkbox-group.js +2 -7
  233. package/dist/components/ifx-checkbox-group.js.map +1 -1
  234. package/dist/components/ifx-checkbox.js +1 -1
  235. package/dist/components/ifx-chip-item.js +1 -1
  236. package/dist/components/ifx-chip.js +1 -1
  237. package/dist/components/ifx-content-switcher.js +1 -6
  238. package/dist/components/ifx-content-switcher.js.map +1 -1
  239. package/dist/components/ifx-date-picker.js +3 -10
  240. package/dist/components/ifx-date-picker.js.map +1 -1
  241. package/dist/components/ifx-download.js +1 -1
  242. package/dist/components/ifx-dropdown-item.js +1 -1
  243. package/dist/components/ifx-dropdown-separator.js +29 -1
  244. package/dist/components/ifx-dropdown-separator.js.map +1 -1
  245. package/dist/components/ifx-dropdown-trigger-button.js +2 -2
  246. package/dist/components/ifx-dropdown.js +1 -6
  247. package/dist/components/ifx-dropdown.js.map +1 -1
  248. package/dist/components/ifx-faq.js +4 -4
  249. package/dist/components/ifx-file-upload.js +6 -13
  250. package/dist/components/ifx-file-upload.js.map +1 -1
  251. package/dist/components/ifx-filter-accordion.js +4 -4
  252. package/dist/components/ifx-filter-bar.js +3 -3
  253. package/dist/components/ifx-filter-search.js +3 -3
  254. package/dist/components/ifx-filter-type-group.js +1 -1
  255. package/dist/components/ifx-footer.js +4 -9
  256. package/dist/components/ifx-footer.js.map +1 -1
  257. package/dist/components/ifx-icon-button.js +1 -1
  258. package/dist/components/ifx-icon.js +1 -1
  259. package/dist/components/ifx-icons-preview.js +4 -4
  260. package/dist/components/ifx-indicator.js +1 -1
  261. package/dist/components/ifx-link.js +1 -1
  262. package/dist/components/ifx-list-entry.js +4 -4
  263. package/dist/components/ifx-list.js +2 -2
  264. package/dist/components/ifx-modal.js +4 -11
  265. package/dist/components/ifx-modal.js.map +1 -1
  266. package/dist/components/ifx-multiselect-option.d.ts +11 -0
  267. package/dist/components/ifx-multiselect-option.js +8 -0
  268. package/dist/components/ifx-multiselect-option.js.map +1 -0
  269. package/dist/components/ifx-multiselect.js +1 -1
  270. package/dist/components/ifx-navbar-item.js +2 -2
  271. package/dist/components/ifx-navbar.js +4 -6
  272. package/dist/components/ifx-navbar.js.map +1 -1
  273. package/dist/components/ifx-notification.js +1 -1
  274. package/dist/components/ifx-overview-table.js +3 -3
  275. package/dist/components/ifx-pagination.js +1 -1
  276. package/dist/components/ifx-progress-bar.js +1 -1
  277. package/dist/components/ifx-radio-button-group.js +2 -7
  278. package/dist/components/ifx-radio-button-group.js.map +1 -1
  279. package/dist/components/ifx-radio-button.js +1 -1
  280. package/dist/components/ifx-search-bar.js +3 -8
  281. package/dist/components/ifx-search-bar.js.map +1 -1
  282. package/dist/components/ifx-search-field.js +1 -1
  283. package/dist/components/ifx-segment.js +1 -1
  284. package/dist/components/ifx-segmented-control.js +3 -10
  285. package/dist/components/ifx-segmented-control.js.map +1 -1
  286. package/dist/components/ifx-select.js +1 -1
  287. package/dist/components/ifx-set-filter.js +35 -12
  288. package/dist/components/ifx-set-filter.js.map +1 -1
  289. package/dist/components/ifx-sidebar-item.js +2 -2
  290. package/dist/components/ifx-sidebar.js +5 -7
  291. package/dist/components/ifx-sidebar.js.map +1 -1
  292. package/dist/components/ifx-slider.js +4 -9
  293. package/dist/components/ifx-slider.js.map +1 -1
  294. package/dist/components/ifx-spinner.js +1 -1
  295. package/dist/components/ifx-status.js +1 -9
  296. package/dist/components/ifx-status.js.map +1 -1
  297. package/dist/components/ifx-step.js +5 -5
  298. package/dist/components/ifx-step.js.map +1 -1
  299. package/dist/components/ifx-stepper.js +2 -7
  300. package/dist/components/ifx-stepper.js.map +1 -1
  301. package/dist/components/ifx-switch.js +1 -6
  302. package/dist/components/ifx-switch.js.map +1 -1
  303. package/dist/components/ifx-tab.js +1 -1
  304. package/dist/components/ifx-table.js +14 -19
  305. package/dist/components/ifx-table.js.map +1 -1
  306. package/dist/components/ifx-tabs.js +3 -8
  307. package/dist/components/ifx-tabs.js.map +1 -1
  308. package/dist/components/ifx-tag.js +2 -10
  309. package/dist/components/ifx-tag.js.map +1 -1
  310. package/dist/components/ifx-template.js +1 -1
  311. package/dist/components/ifx-templates-ui.js +9 -9
  312. package/dist/components/ifx-text-field.js +1 -1
  313. package/dist/components/ifx-textarea.js +1 -6
  314. package/dist/components/ifx-textarea.js.map +1 -1
  315. package/dist/components/ifx-tooltip.js +5 -10
  316. package/dist/components/ifx-tooltip.js.map +1 -1
  317. package/dist/components/ifx-tree-view-item.js +4 -4
  318. package/dist/components/ifx-tree-view.js +1 -9
  319. package/dist/components/ifx-tree-view.js.map +1 -1
  320. package/dist/components/p-09673a59.js +119 -0
  321. package/dist/components/p-09673a59.js.map +1 -0
  322. package/dist/components/{p-816b2612.js → p-17df0350.js} +2 -7
  323. package/dist/components/p-17df0350.js.map +1 -0
  324. package/dist/components/p-1bb40944.js +602 -0
  325. package/dist/components/p-1bb40944.js.map +1 -0
  326. package/dist/components/{p-e126ea6f.js → p-351949f1.js} +3 -11
  327. package/dist/components/p-351949f1.js.map +1 -0
  328. package/dist/components/{p-54b39a91.js → p-357107c5.js} +3 -8
  329. package/dist/components/p-357107c5.js.map +1 -0
  330. package/dist/components/p-3f51d740.js +432 -0
  331. package/dist/components/p-3f51d740.js.map +1 -0
  332. package/dist/components/{p-9ea9e274.js → p-53d4339c.js} +2 -10
  333. package/dist/components/p-53d4339c.js.map +1 -0
  334. package/dist/components/{p-6d95b3c1.js → p-5e9d3450.js} +2 -8
  335. package/dist/components/p-5e9d3450.js.map +1 -0
  336. package/dist/components/{p-465d3172.js → p-8a645052.js} +3 -11
  337. package/dist/components/p-8a645052.js.map +1 -0
  338. package/dist/components/{p-94da6823.js → p-9142f93b.js} +3 -8
  339. package/dist/components/p-9142f93b.js.map +1 -0
  340. package/dist/components/{p-4fc475c9.js → p-9a258534.js} +4 -37
  341. package/dist/components/p-9a258534.js.map +1 -0
  342. package/dist/components/{p-1ad917f9.js → p-9bdb8233.js} +4 -9
  343. package/dist/components/p-9bdb8233.js.map +1 -0
  344. package/dist/components/{p-830057b3.js → p-ba627b54.js} +2 -8
  345. package/dist/components/p-ba627b54.js.map +1 -0
  346. package/dist/components/{p-24382260.js → p-c90a8438.js} +6 -11
  347. package/dist/components/p-c90a8438.js.map +1 -0
  348. package/dist/components/{p-cf109552.js → p-cdac7da6.js} +5 -10
  349. package/dist/components/p-cdac7da6.js.map +1 -0
  350. package/dist/components/{p-8cb991f4.js → p-cf9adb93.js} +5 -13
  351. package/dist/components/p-cf9adb93.js.map +1 -0
  352. package/dist/components/{p-13578a85.js → p-dda8b55f.js} +7 -7
  353. package/dist/components/{p-13578a85.js.map → p-dda8b55f.js.map} +1 -1
  354. package/dist/components/{p-0905733d.js → p-e4c0ba88.js} +11 -16
  355. package/dist/components/p-e4c0ba88.js.map +1 -0
  356. package/dist/components/{p-cca71d97.js → p-ed739e86.js} +2 -9
  357. package/dist/components/p-ed739e86.js.map +1 -0
  358. package/dist/components/{p-0d6ca0f6.js → p-eebb75a8.js} +3 -8
  359. package/dist/components/p-eebb75a8.js.map +1 -0
  360. package/dist/components/{p-ee0f87ac.js → p-f38c3009.js} +3 -3
  361. package/dist/components/{p-ee0f87ac.js.map → p-f38c3009.js.map} +1 -1
  362. package/dist/components/{p-13126216.js → p-f5675de2.js} +5 -10
  363. package/dist/components/p-f5675de2.js.map +1 -0
  364. package/dist/esm/ifx-accordion_2.entry.js +26 -33
  365. package/dist/esm/ifx-accordion_2.entry.js.map +1 -1
  366. package/dist/esm/ifx-alert_2.entry.js +1 -7
  367. package/dist/esm/ifx-alert_2.entry.js.map +1 -1
  368. package/dist/esm/ifx-badge.entry.js +2 -10
  369. package/dist/esm/ifx-badge.entry.js.map +1 -1
  370. package/dist/esm/ifx-basic-table.entry.js +4 -9
  371. package/dist/esm/ifx-basic-table.entry.js.map +1 -1
  372. package/dist/esm/ifx-breadcrumb.entry.js +1 -8
  373. package/dist/esm/ifx-breadcrumb.entry.js.map +1 -1
  374. package/dist/esm/ifx-button.entry.js +1 -6
  375. package/dist/esm/ifx-button.entry.js.map +1 -1
  376. package/dist/esm/ifx-card.entry.js +3 -8
  377. package/dist/esm/ifx-card.entry.js.map +1 -1
  378. package/dist/esm/ifx-checkbox-group.entry.js +1 -6
  379. package/dist/esm/ifx-checkbox-group.entry.js.map +1 -1
  380. package/dist/esm/ifx-checkbox.entry.js +3 -8
  381. package/dist/esm/ifx-checkbox.entry.js.map +1 -1
  382. package/dist/esm/ifx-chip_3.entry.js +9 -17
  383. package/dist/esm/ifx-chip_3.entry.js.map +1 -1
  384. package/dist/esm/ifx-content-switcher.entry.js +1 -6
  385. package/dist/esm/ifx-content-switcher.entry.js.map +1 -1
  386. package/dist/esm/ifx-date-picker.entry.js +2 -9
  387. package/dist/esm/ifx-date-picker.entry.js.map +1 -1
  388. package/dist/esm/ifx-dropdown.entry.js +1 -6
  389. package/dist/esm/ifx-dropdown.entry.js.map +1 -1
  390. package/dist/esm/ifx-faq.entry.js +1 -1
  391. package/dist/esm/ifx-file-upload.entry.js +2 -9
  392. package/dist/esm/ifx-file-upload.entry.js.map +1 -1
  393. package/dist/esm/ifx-filter-accordion.entry.js +2 -2
  394. package/dist/esm/ifx-filter-bar.entry.js +1 -1
  395. package/dist/esm/ifx-filter-search.entry.js +1 -1
  396. package/dist/esm/ifx-filter-type-group.entry.js +1 -1
  397. package/dist/esm/ifx-footer.entry.js +4 -9
  398. package/dist/esm/ifx-footer.entry.js.map +1 -1
  399. package/dist/esm/ifx-icon-button.entry.js +1 -6
  400. package/dist/esm/ifx-icon-button.entry.js.map +1 -1
  401. package/dist/esm/ifx-icon.entry.js +4 -37
  402. package/dist/esm/ifx-icon.entry.js.map +1 -1
  403. package/dist/esm/ifx-indicator.entry.js +2 -7
  404. package/dist/esm/ifx-indicator.entry.js.map +1 -1
  405. package/dist/esm/ifx-link.entry.js +2 -10
  406. package/dist/esm/ifx-link.entry.js.map +1 -1
  407. package/dist/esm/ifx-list-entry.entry.js +1 -1
  408. package/dist/esm/ifx-modal.entry.js +2 -9
  409. package/dist/esm/ifx-modal.entry.js.map +1 -1
  410. package/dist/esm/ifx-multiselect_2.entry.js +927 -0
  411. package/dist/esm/ifx-multiselect_2.entry.js.map +1 -0
  412. package/dist/esm/ifx-navbar.entry.js +3 -5
  413. package/dist/esm/ifx-navbar.entry.js.map +1 -1
  414. package/dist/esm/ifx-notification.entry.js +3 -11
  415. package/dist/esm/ifx-notification.entry.js.map +1 -1
  416. package/dist/esm/ifx-progress-bar.entry.js +2 -8
  417. package/dist/esm/ifx-progress-bar.entry.js.map +1 -1
  418. package/dist/esm/ifx-radio-button-group.entry.js +1 -6
  419. package/dist/esm/ifx-radio-button-group.entry.js.map +1 -1
  420. package/dist/esm/ifx-radio-button.entry.js +2 -7
  421. package/dist/esm/ifx-radio-button.entry.js.map +1 -1
  422. package/dist/esm/ifx-search-bar.entry.js +1 -6
  423. package/dist/esm/ifx-search-bar.entry.js.map +1 -1
  424. package/dist/esm/ifx-search-field.entry.js +2 -10
  425. package/dist/esm/ifx-search-field.entry.js.map +1 -1
  426. package/dist/esm/ifx-segmented-control.entry.js +2 -9
  427. package/dist/esm/ifx-segmented-control.entry.js.map +1 -1
  428. package/dist/esm/ifx-select.entry.js +2 -7
  429. package/dist/esm/ifx-select.entry.js.map +1 -1
  430. package/dist/esm/ifx-set-filter.entry.js +19 -2
  431. package/dist/esm/ifx-set-filter.entry.js.map +1 -1
  432. package/dist/esm/ifx-sidebar.entry.js +5 -7
  433. package/dist/esm/ifx-sidebar.entry.js.map +1 -1
  434. package/dist/esm/ifx-slider.entry.js +3 -8
  435. package/dist/esm/ifx-slider.entry.js.map +1 -1
  436. package/dist/esm/ifx-spinner_2.entry.js +7 -18
  437. package/dist/esm/ifx-spinner_2.entry.js.map +1 -1
  438. package/dist/esm/ifx-status.entry.js +2 -10
  439. package/dist/esm/ifx-status.entry.js.map +1 -1
  440. package/dist/esm/ifx-step.entry.js +4 -4
  441. package/dist/esm/ifx-step.entry.js.map +1 -1
  442. package/dist/esm/ifx-stepper.entry.js +2 -7
  443. package/dist/esm/ifx-stepper.entry.js.map +1 -1
  444. package/dist/esm/ifx-switch.entry.js +1 -6
  445. package/dist/esm/ifx-switch.entry.js.map +1 -1
  446. package/dist/esm/ifx-tab.entry.js +1 -1
  447. package/dist/esm/ifx-table.entry.js +5 -10
  448. package/dist/esm/ifx-table.entry.js.map +1 -1
  449. package/dist/esm/ifx-tabs.entry.js +2 -7
  450. package/dist/esm/ifx-tabs.entry.js.map +1 -1
  451. package/dist/esm/ifx-tag.entry.js +2 -10
  452. package/dist/esm/ifx-tag.entry.js.map +1 -1
  453. package/dist/esm/ifx-templates-ui.entry.js +1 -1
  454. package/dist/esm/ifx-textarea.entry.js +1 -6
  455. package/dist/esm/ifx-textarea.entry.js.map +1 -1
  456. package/dist/esm/ifx-tooltip.entry.js +4 -9
  457. package/dist/esm/ifx-tooltip.entry.js.map +1 -1
  458. package/dist/esm/ifx-tree-view-item.entry.js +2 -2
  459. package/dist/esm/ifx-tree-view.entry.js +2 -10
  460. package/dist/esm/ifx-tree-view.entry.js.map +1 -1
  461. package/dist/esm/index-6c9eba32.js +14 -14
  462. package/dist/esm/infineon-design-system-stencil.js +1 -1
  463. package/dist/esm/loader.js +1 -1
  464. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js +1 -1
  465. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js.map +1 -1
  466. package/dist/infineon-design-system-stencil/p-02496917.entry.js +2 -0
  467. package/dist/infineon-design-system-stencil/p-02496917.entry.js.map +1 -0
  468. package/dist/infineon-design-system-stencil/{p-f2bea855.entry.js → p-04d8ea38.entry.js} +2 -2
  469. package/dist/infineon-design-system-stencil/p-061bfdb1.entry.js +2 -0
  470. package/dist/infineon-design-system-stencil/p-061bfdb1.entry.js.map +1 -0
  471. package/dist/infineon-design-system-stencil/{p-87fbd617.entry.js → p-0c1c831c.entry.js} +2 -2
  472. package/dist/infineon-design-system-stencil/p-135110b2.entry.js +2 -0
  473. package/dist/infineon-design-system-stencil/p-135110b2.entry.js.map +1 -0
  474. package/dist/infineon-design-system-stencil/p-13c107bf.entry.js +2 -0
  475. package/dist/infineon-design-system-stencil/p-13c107bf.entry.js.map +1 -0
  476. package/dist/infineon-design-system-stencil/p-17f3f2f5.entry.js +2 -0
  477. package/dist/infineon-design-system-stencil/p-17f3f2f5.entry.js.map +1 -0
  478. package/dist/infineon-design-system-stencil/p-1bf2d4f8.entry.js +2 -0
  479. package/dist/infineon-design-system-stencil/p-1bf2d4f8.entry.js.map +1 -0
  480. package/dist/infineon-design-system-stencil/p-2006c7a0.entry.js +2 -0
  481. package/dist/infineon-design-system-stencil/p-2006c7a0.entry.js.map +1 -0
  482. package/dist/infineon-design-system-stencil/p-292cff35.entry.js +2 -0
  483. package/dist/infineon-design-system-stencil/p-292cff35.entry.js.map +1 -0
  484. package/dist/infineon-design-system-stencil/p-2d89c5e0.entry.js +2 -0
  485. package/dist/infineon-design-system-stencil/p-2d89c5e0.entry.js.map +1 -0
  486. package/dist/infineon-design-system-stencil/p-33a4fd0a.entry.js +2 -0
  487. package/dist/infineon-design-system-stencil/p-33a4fd0a.entry.js.map +1 -0
  488. package/dist/infineon-design-system-stencil/{p-a9cfb70d.entry.js → p-36dcebde.entry.js} +2 -2
  489. package/dist/infineon-design-system-stencil/p-37d6c639.entry.js +2 -0
  490. package/dist/infineon-design-system-stencil/p-37d6c639.entry.js.map +1 -0
  491. package/dist/infineon-design-system-stencil/{p-0f096cf1.entry.js → p-3d037fa4.entry.js} +2 -2
  492. package/dist/infineon-design-system-stencil/p-3d23deba.entry.js +2 -0
  493. package/dist/infineon-design-system-stencil/p-3d23deba.entry.js.map +1 -0
  494. package/dist/infineon-design-system-stencil/p-3ff96710.entry.js +2 -0
  495. package/dist/infineon-design-system-stencil/p-3ff96710.entry.js.map +1 -0
  496. package/dist/infineon-design-system-stencil/p-4764665d.entry.js +2 -0
  497. package/dist/infineon-design-system-stencil/p-4764665d.entry.js.map +1 -0
  498. package/dist/infineon-design-system-stencil/p-47a3e831.entry.js +2 -0
  499. package/dist/infineon-design-system-stencil/p-47a3e831.entry.js.map +1 -0
  500. package/dist/infineon-design-system-stencil/p-487d2155.entry.js +2 -0
  501. package/dist/infineon-design-system-stencil/p-487d2155.entry.js.map +1 -0
  502. package/dist/infineon-design-system-stencil/p-4f82fcfd.entry.js +2 -0
  503. package/dist/infineon-design-system-stencil/p-4f82fcfd.entry.js.map +1 -0
  504. package/dist/infineon-design-system-stencil/p-5e376887.entry.js +2 -0
  505. package/dist/infineon-design-system-stencil/p-5e376887.entry.js.map +1 -0
  506. package/dist/infineon-design-system-stencil/p-5f38cace.entry.js +2 -0
  507. package/dist/infineon-design-system-stencil/p-5f38cace.entry.js.map +1 -0
  508. package/dist/infineon-design-system-stencil/p-6250b9f6.entry.js +2 -0
  509. package/dist/infineon-design-system-stencil/p-6250b9f6.entry.js.map +1 -0
  510. package/dist/infineon-design-system-stencil/p-6790d912.entry.js +2 -0
  511. package/dist/infineon-design-system-stencil/p-6790d912.entry.js.map +1 -0
  512. package/dist/infineon-design-system-stencil/p-6bdca580.entry.js +2 -0
  513. package/dist/infineon-design-system-stencil/p-6bdca580.entry.js.map +1 -0
  514. package/dist/infineon-design-system-stencil/{p-babf3f2d.entry.js → p-6c2698a3.entry.js} +2 -2
  515. package/dist/infineon-design-system-stencil/p-6c999b11.entry.js +2 -0
  516. package/dist/infineon-design-system-stencil/p-6c999b11.entry.js.map +1 -0
  517. package/dist/infineon-design-system-stencil/{p-9c28f35f.entry.js → p-6e7b0250.entry.js} +3 -3
  518. package/dist/infineon-design-system-stencil/p-6e7b0250.entry.js.map +1 -0
  519. package/dist/infineon-design-system-stencil/p-70f4fd1b.entry.js +2 -0
  520. package/dist/infineon-design-system-stencil/p-70f4fd1b.entry.js.map +1 -0
  521. package/dist/infineon-design-system-stencil/p-741ee6fd.entry.js +2 -0
  522. package/dist/infineon-design-system-stencil/p-741ee6fd.entry.js.map +1 -0
  523. package/dist/infineon-design-system-stencil/p-7619bd75.entry.js +2 -0
  524. package/dist/infineon-design-system-stencil/p-7619bd75.entry.js.map +1 -0
  525. package/dist/infineon-design-system-stencil/p-76e0c34f.entry.js +2 -0
  526. package/dist/infineon-design-system-stencil/p-76e0c34f.entry.js.map +1 -0
  527. package/dist/infineon-design-system-stencil/{p-6d99d01d.entry.js → p-7adee2dd.entry.js} +2 -2
  528. package/dist/infineon-design-system-stencil/p-99faadcf.entry.js +2 -0
  529. package/dist/infineon-design-system-stencil/p-99faadcf.entry.js.map +1 -0
  530. package/dist/infineon-design-system-stencil/p-9fc0f50d.entry.js +2 -0
  531. package/dist/infineon-design-system-stencil/p-9fc0f50d.entry.js.map +1 -0
  532. package/dist/infineon-design-system-stencil/p-a2a44fbe.entry.js +2 -0
  533. package/dist/infineon-design-system-stencil/p-a356a82d.entry.js +2 -0
  534. package/dist/infineon-design-system-stencil/p-a356a82d.entry.js.map +1 -0
  535. package/dist/infineon-design-system-stencil/p-a80e321b.entry.js +2 -0
  536. package/dist/infineon-design-system-stencil/p-a80e321b.entry.js.map +1 -0
  537. package/dist/infineon-design-system-stencil/p-aadd1a9d.entry.js +2 -0
  538. package/dist/infineon-design-system-stencil/p-aadd1a9d.entry.js.map +1 -0
  539. package/dist/infineon-design-system-stencil/p-ad1ec9d6.entry.js +2 -0
  540. package/dist/infineon-design-system-stencil/p-ad1ec9d6.entry.js.map +1 -0
  541. package/dist/infineon-design-system-stencil/p-b73a5f18.entry.js +2 -0
  542. package/dist/infineon-design-system-stencil/p-b73a5f18.entry.js.map +1 -0
  543. package/dist/infineon-design-system-stencil/{p-2b38c405.entry.js → p-b7cb706f.entry.js} +2 -2
  544. package/dist/infineon-design-system-stencil/{p-2b38c405.entry.js.map → p-b7cb706f.entry.js.map} +1 -1
  545. package/dist/infineon-design-system-stencil/p-b9c761d3.entry.js +2 -0
  546. package/dist/infineon-design-system-stencil/p-b9c761d3.entry.js.map +1 -0
  547. package/dist/infineon-design-system-stencil/{p-7b7ac7fa.entry.js → p-c7e86c7c.entry.js} +2 -2
  548. package/dist/infineon-design-system-stencil/p-c84ef603.entry.js +2 -0
  549. package/dist/infineon-design-system-stencil/p-c84ef603.entry.js.map +1 -0
  550. package/dist/infineon-design-system-stencil/p-d890b0de.entry.js +2 -0
  551. package/dist/infineon-design-system-stencil/p-d890b0de.entry.js.map +1 -0
  552. package/dist/infineon-design-system-stencil/p-dd28f3a1.entry.js +2 -0
  553. package/dist/infineon-design-system-stencil/p-dd28f3a1.entry.js.map +1 -0
  554. package/dist/infineon-design-system-stencil/p-e571c002.entry.js +2 -0
  555. package/dist/infineon-design-system-stencil/p-e72e5fb2.entry.js +2 -0
  556. package/dist/infineon-design-system-stencil/p-e72e5fb2.entry.js.map +1 -0
  557. package/dist/infineon-design-system-stencil/p-ef6d0dc6.entry.js +2 -0
  558. package/dist/infineon-design-system-stencil/p-ef6d0dc6.entry.js.map +1 -0
  559. package/dist/infineon-design-system-stencil/p-f338fb85.entry.js +2 -0
  560. package/dist/infineon-design-system-stencil/p-f338fb85.entry.js.map +1 -0
  561. package/dist/infineon-design-system-stencil/p-f9a7ae20.entry.js +2 -0
  562. package/dist/infineon-design-system-stencil/p-f9a7ae20.entry.js.map +1 -0
  563. package/dist/types/components/accordion/accordion.d.ts +0 -1
  564. package/dist/types/components/accordion/accordionItem.d.ts +1 -2
  565. package/dist/types/components/alert/alert.d.ts +0 -1
  566. package/dist/types/components/badge/badge.d.ts +0 -2
  567. package/dist/types/components/breadcrumb/breadcrumb.d.ts +0 -1
  568. package/dist/types/components/date-picker/date-picker.d.ts +0 -1
  569. package/dist/types/components/file-upload/file-upload.d.ts +0 -1
  570. package/dist/types/components/icon/infineonIconStencil.d.ts +0 -3
  571. package/dist/types/components/link/link.d.ts +0 -2
  572. package/dist/types/components/modal/modal.d.ts +0 -1
  573. package/dist/types/components/notification/notification.d.ts +0 -2
  574. package/dist/types/components/progress-bar/progress-bar.d.ts +0 -1
  575. package/dist/types/components/search-field/search-field.d.ts +0 -2
  576. package/dist/types/components/segmented-control/segmented-control.d.ts +0 -1
  577. package/dist/types/components/select/multi-select/interfaces.d.ts +1 -1
  578. package/dist/types/components/select/multi-select/multiselect-option.d.ts +36 -0
  579. package/dist/types/components/select/multi-select/multiselect.d.ts +38 -61
  580. package/dist/types/components/select/multi-select/multiselect.stories.d.ts +219 -30
  581. package/dist/types/components/spinner/spinner.d.ts +0 -2
  582. package/dist/types/components/status/status.d.ts +0 -2
  583. package/dist/types/components/tag/tag.d.ts +0 -2
  584. package/dist/types/components/tree-view/tree-view.d.ts +0 -2
  585. package/dist/types/components.d.ts +54 -8
  586. package/package.json +2 -2
  587. package/dist/cjs/dom-utils-2c4573c2.js +0 -20
  588. package/dist/cjs/dom-utils-2c4573c2.js.map +0 -1
  589. package/dist/cjs/ifx-multiselect.cjs.entry.js +0 -550
  590. package/dist/cjs/ifx-multiselect.cjs.entry.js.map +0 -1
  591. package/dist/cjs/tracking-f00364dc.js +0 -41
  592. package/dist/cjs/tracking-f00364dc.js.map +0 -1
  593. package/dist/collection/global/utils/dom-utils.js +0 -15
  594. package/dist/collection/global/utils/dom-utils.js.map +0 -1
  595. package/dist/collection/global/utils/tracking.js +0 -37
  596. package/dist/collection/global/utils/tracking.js.map +0 -1
  597. package/dist/components/p-0905733d.js.map +0 -1
  598. package/dist/components/p-0d6ca0f6.js.map +0 -1
  599. package/dist/components/p-13126216.js.map +0 -1
  600. package/dist/components/p-1ad917f9.js.map +0 -1
  601. package/dist/components/p-1ecafb97.js +0 -18
  602. package/dist/components/p-1ecafb97.js.map +0 -1
  603. package/dist/components/p-24382260.js.map +0 -1
  604. package/dist/components/p-347a1b14.js +0 -603
  605. package/dist/components/p-347a1b14.js.map +0 -1
  606. package/dist/components/p-465d3172.js.map +0 -1
  607. package/dist/components/p-4fc475c9.js.map +0 -1
  608. package/dist/components/p-54b39a91.js.map +0 -1
  609. package/dist/components/p-68016aea.js +0 -33
  610. package/dist/components/p-68016aea.js.map +0 -1
  611. package/dist/components/p-6d95b3c1.js.map +0 -1
  612. package/dist/components/p-6ecb6a6f.js +0 -39
  613. package/dist/components/p-6ecb6a6f.js.map +0 -1
  614. package/dist/components/p-816b2612.js.map +0 -1
  615. package/dist/components/p-830057b3.js.map +0 -1
  616. package/dist/components/p-8cb991f4.js.map +0 -1
  617. package/dist/components/p-94da6823.js.map +0 -1
  618. package/dist/components/p-9ea9e274.js.map +0 -1
  619. package/dist/components/p-cca71d97.js.map +0 -1
  620. package/dist/components/p-cf109552.js.map +0 -1
  621. package/dist/components/p-e126ea6f.js.map +0 -1
  622. package/dist/components/p-fe90e932.js +0 -119
  623. package/dist/components/p-fe90e932.js.map +0 -1
  624. package/dist/esm/dom-utils-1988cdf1.js +0 -18
  625. package/dist/esm/dom-utils-1988cdf1.js.map +0 -1
  626. package/dist/esm/ifx-multiselect.entry.js +0 -546
  627. package/dist/esm/ifx-multiselect.entry.js.map +0 -1
  628. package/dist/esm/tracking-a7efdbcd.js +0 -39
  629. package/dist/esm/tracking-a7efdbcd.js.map +0 -1
  630. package/dist/infineon-design-system-stencil/p-0c60ce87.entry.js +0 -2
  631. package/dist/infineon-design-system-stencil/p-0c60ce87.entry.js.map +0 -1
  632. package/dist/infineon-design-system-stencil/p-14842bbb.entry.js +0 -2
  633. package/dist/infineon-design-system-stencil/p-14842bbb.entry.js.map +0 -1
  634. package/dist/infineon-design-system-stencil/p-19fcf1db.entry.js +0 -2
  635. package/dist/infineon-design-system-stencil/p-19fcf1db.entry.js.map +0 -1
  636. package/dist/infineon-design-system-stencil/p-1ecafb97.js +0 -2
  637. package/dist/infineon-design-system-stencil/p-1ecafb97.js.map +0 -1
  638. package/dist/infineon-design-system-stencil/p-1fd80576.entry.js +0 -2
  639. package/dist/infineon-design-system-stencil/p-1fd80576.entry.js.map +0 -1
  640. package/dist/infineon-design-system-stencil/p-227fa186.entry.js +0 -2
  641. package/dist/infineon-design-system-stencil/p-227fa186.entry.js.map +0 -1
  642. package/dist/infineon-design-system-stencil/p-26c73456.entry.js +0 -2
  643. package/dist/infineon-design-system-stencil/p-26c73456.entry.js.map +0 -1
  644. package/dist/infineon-design-system-stencil/p-296f215f.entry.js +0 -2
  645. package/dist/infineon-design-system-stencil/p-296f215f.entry.js.map +0 -1
  646. package/dist/infineon-design-system-stencil/p-32b0dfda.entry.js +0 -2
  647. package/dist/infineon-design-system-stencil/p-32b0dfda.entry.js.map +0 -1
  648. package/dist/infineon-design-system-stencil/p-34738a10.entry.js +0 -2
  649. package/dist/infineon-design-system-stencil/p-45ac2698.entry.js +0 -2
  650. package/dist/infineon-design-system-stencil/p-45ac2698.entry.js.map +0 -1
  651. package/dist/infineon-design-system-stencil/p-4eda4ef3.entry.js +0 -2
  652. package/dist/infineon-design-system-stencil/p-4eda4ef3.entry.js.map +0 -1
  653. package/dist/infineon-design-system-stencil/p-52420868.entry.js +0 -2
  654. package/dist/infineon-design-system-stencil/p-52420868.entry.js.map +0 -1
  655. package/dist/infineon-design-system-stencil/p-5493e6f5.entry.js +0 -2
  656. package/dist/infineon-design-system-stencil/p-5493e6f5.entry.js.map +0 -1
  657. package/dist/infineon-design-system-stencil/p-5a12d20a.entry.js +0 -2
  658. package/dist/infineon-design-system-stencil/p-5a12d20a.entry.js.map +0 -1
  659. package/dist/infineon-design-system-stencil/p-65255c40.entry.js +0 -2
  660. package/dist/infineon-design-system-stencil/p-65255c40.entry.js.map +0 -1
  661. package/dist/infineon-design-system-stencil/p-65e57b85.entry.js +0 -2
  662. package/dist/infineon-design-system-stencil/p-68423787.entry.js +0 -2
  663. package/dist/infineon-design-system-stencil/p-68423787.entry.js.map +0 -1
  664. package/dist/infineon-design-system-stencil/p-6d72ad32.entry.js +0 -2
  665. package/dist/infineon-design-system-stencil/p-6d72ad32.entry.js.map +0 -1
  666. package/dist/infineon-design-system-stencil/p-6ecb6a6f.js +0 -2
  667. package/dist/infineon-design-system-stencil/p-6ecb6a6f.js.map +0 -1
  668. package/dist/infineon-design-system-stencil/p-73d39ed6.entry.js +0 -2
  669. package/dist/infineon-design-system-stencil/p-73d39ed6.entry.js.map +0 -1
  670. package/dist/infineon-design-system-stencil/p-76914839.entry.js +0 -2
  671. package/dist/infineon-design-system-stencil/p-76914839.entry.js.map +0 -1
  672. package/dist/infineon-design-system-stencil/p-796675ed.entry.js +0 -2
  673. package/dist/infineon-design-system-stencil/p-796675ed.entry.js.map +0 -1
  674. package/dist/infineon-design-system-stencil/p-79b7d7a2.entry.js +0 -2
  675. package/dist/infineon-design-system-stencil/p-79b7d7a2.entry.js.map +0 -1
  676. package/dist/infineon-design-system-stencil/p-82c59e6b.entry.js +0 -2
  677. package/dist/infineon-design-system-stencil/p-82c59e6b.entry.js.map +0 -1
  678. package/dist/infineon-design-system-stencil/p-82dd7e7d.entry.js +0 -2
  679. package/dist/infineon-design-system-stencil/p-82dd7e7d.entry.js.map +0 -1
  680. package/dist/infineon-design-system-stencil/p-877e1d37.entry.js +0 -2
  681. package/dist/infineon-design-system-stencil/p-877e1d37.entry.js.map +0 -1
  682. package/dist/infineon-design-system-stencil/p-8a7bfe65.entry.js +0 -2
  683. package/dist/infineon-design-system-stencil/p-8a7bfe65.entry.js.map +0 -1
  684. package/dist/infineon-design-system-stencil/p-98532a0e.entry.js +0 -2
  685. package/dist/infineon-design-system-stencil/p-98532a0e.entry.js.map +0 -1
  686. package/dist/infineon-design-system-stencil/p-9c28f35f.entry.js.map +0 -1
  687. package/dist/infineon-design-system-stencil/p-a0006775.entry.js +0 -2
  688. package/dist/infineon-design-system-stencil/p-a0006775.entry.js.map +0 -1
  689. package/dist/infineon-design-system-stencil/p-ac7db8d1.entry.js +0 -2
  690. package/dist/infineon-design-system-stencil/p-ac7db8d1.entry.js.map +0 -1
  691. package/dist/infineon-design-system-stencil/p-ae8110b7.entry.js +0 -2
  692. package/dist/infineon-design-system-stencil/p-ae8110b7.entry.js.map +0 -1
  693. package/dist/infineon-design-system-stencil/p-aeaa6d0b.entry.js +0 -2
  694. package/dist/infineon-design-system-stencil/p-aeaa6d0b.entry.js.map +0 -1
  695. package/dist/infineon-design-system-stencil/p-b110d5d4.entry.js +0 -2
  696. package/dist/infineon-design-system-stencil/p-b110d5d4.entry.js.map +0 -1
  697. package/dist/infineon-design-system-stencil/p-b17a0e8c.entry.js +0 -2
  698. package/dist/infineon-design-system-stencil/p-b17a0e8c.entry.js.map +0 -1
  699. package/dist/infineon-design-system-stencil/p-bb7b2a3c.entry.js +0 -2
  700. package/dist/infineon-design-system-stencil/p-bb7b2a3c.entry.js.map +0 -1
  701. package/dist/infineon-design-system-stencil/p-c164c83b.entry.js +0 -2
  702. package/dist/infineon-design-system-stencil/p-c164c83b.entry.js.map +0 -1
  703. package/dist/infineon-design-system-stencil/p-c220733b.entry.js +0 -2
  704. package/dist/infineon-design-system-stencil/p-c220733b.entry.js.map +0 -1
  705. package/dist/infineon-design-system-stencil/p-c88876dc.entry.js +0 -2
  706. package/dist/infineon-design-system-stencil/p-c88876dc.entry.js.map +0 -1
  707. package/dist/infineon-design-system-stencil/p-e0978af0.entry.js +0 -2
  708. package/dist/infineon-design-system-stencil/p-e0978af0.entry.js.map +0 -1
  709. package/dist/infineon-design-system-stencil/p-e5018880.entry.js +0 -2
  710. package/dist/infineon-design-system-stencil/p-e5018880.entry.js.map +0 -1
  711. package/dist/infineon-design-system-stencil/p-ed869b07.entry.js +0 -2
  712. package/dist/infineon-design-system-stencil/p-ed869b07.entry.js.map +0 -1
  713. package/dist/infineon-design-system-stencil/p-eeb59f76.entry.js +0 -2
  714. package/dist/infineon-design-system-stencil/p-eeb59f76.entry.js.map +0 -1
  715. package/dist/infineon-design-system-stencil/p-f3f8d603.entry.js +0 -2
  716. package/dist/infineon-design-system-stencil/p-f3f8d603.entry.js.map +0 -1
  717. package/dist/infineon-design-system-stencil/p-fb6a813b.entry.js +0 -2
  718. package/dist/infineon-design-system-stencil/p-fb6a813b.entry.js.map +0 -1
  719. package/dist/infineon-design-system-stencil/p-fe22fc31.entry.js +0 -2
  720. package/dist/infineon-design-system-stencil/p-fe22fc31.entry.js.map +0 -1
  721. package/dist/types/global/utils/dom-utils.d.ts +0 -1
  722. package/dist/types/global/utils/tracking.d.ts +0 -9
  723. /package/dist/infineon-design-system-stencil/{p-f2bea855.entry.js.map → p-04d8ea38.entry.js.map} +0 -0
  724. /package/dist/infineon-design-system-stencil/{p-87fbd617.entry.js.map → p-0c1c831c.entry.js.map} +0 -0
  725. /package/dist/infineon-design-system-stencil/{p-a9cfb70d.entry.js.map → p-36dcebde.entry.js.map} +0 -0
  726. /package/dist/infineon-design-system-stencil/{p-0f096cf1.entry.js.map → p-3d037fa4.entry.js.map} +0 -0
  727. /package/dist/infineon-design-system-stencil/{p-babf3f2d.entry.js.map → p-6c2698a3.entry.js.map} +0 -0
  728. /package/dist/infineon-design-system-stencil/{p-6d99d01d.entry.js.map → p-7adee2dd.entry.js.map} +0 -0
  729. /package/dist/infineon-design-system-stencil/{p-65e57b85.entry.js.map → p-a2a44fbe.entry.js.map} +0 -0
  730. /package/dist/infineon-design-system-stencil/{p-7b7ac7fa.entry.js.map → p-c7e86c7c.entry.js.map} +0 -0
  731. /package/dist/infineon-design-system-stencil/{p-34738a10.entry.js.map → p-e571c002.entry.js.map} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"names":["multiselectCss","IfxMultiselectStyle0","debounce","func","wait","timeout","executedFunction","args","later","clearTimeout","setTimeout","Multiselect","constructor","hostRef","this","disabled","error","errorMessage","label","placeholder","showSearch","showSelectAll","showClearButton","showExpandCollapse","noResultsMessage","showNoResultsMessage","searchPlaceholder","selectAllLabel","expandLabel","collapseLabel","ariaLabel","ariaLabelledBy","ariaDescribedBy","ariaSearchLabel","ariaClearLabel","ariaToggleLabel","ariaSelectAllLabel","ariaExpandAllLabel","ariaCollapseAllLabel","internalError","persistentSelectedOptions","dropdownOpen","searchTerm","handleSearch","targetElement","value","toLowerCase","isSearchActive","wrapper","el","shadowRoot","querySelector","classList","remove","searchField","searchFieldHasFocus","matches","add","optionsContainer","requestAnimationFrame","allOptions","querySelectorAll","forEach","option","searchEvent","CustomEvent","detail","isActive","dispatchEvent","visibleCount","style","window","getComputedStyle","rect","getBoundingClientRect","display","visibility","opacity","height","handleDocumentClick","event","path","composedPath","includes","dropdownElement","document","removeEventListener","resetSearch","ifxOpen","emit","parseChildOptions","options","childElements","Array","from","children","child","index","tagName","parseOptionElement","push","element","getAttribute","selected","hasAttribute","indeterminate","nestedOptions","filter","map","childIndex","opt","length","loadInitialOptions","internalErrorMessage","initiallySelected","collectSelectedOptions","initiallySelectedNotInState","init","some","selectedOptions","concat","collectLeafOptions","existingOption","leafOptions","handleSearchFocus","hasFocus","positionDropdown","wrapperRect","_a","spaceBelow","innerHeight","bottom","spaceAbove","top","dropdownFlipped","updateSlotBasedSelections","emitEvent","allOptionElements","selectedLeafOptions","optionEl","instance","hasChildren","ifxSelect","updateInitialParentStates","optionsByDepth","depth","parseInt","item","sort","a","b","updateParentState","parentInstance","directChildren","selectedCount","indeterminateCount","totalCount","componentDidLoad","addEventListener","componentWillLoad","updateInternalError","updateInternalErrorMessage","onSelectionChange","newValue","_","formData","FormData","append","name","internals","setFormValue","collapseAll","isExpanded","expandAll","selectAll","clearSelection","toggleDropdown","handleWrapperClick","currentTarget","target","handleKeyDown","code","preventDefault","closest","focusFirstOption","firstOption","labelElement","focus","renderSelectAll","allSelected","toggleSelectAll","stopPropagation","h","class","id","checked","size","onClick","onKeyDown","e","key","renderNoResultsMessage","render","selectedOptionsLabels","optionElement","textContent","trim","join","hasSelections","isFlatMultiselect","every","ref","role","undefined","tabindex","onIfxInput","onFocus","onBlur","tabIndex","icon","multiselectOptionCss","IfxMultiselectOptionStyle0","MultiselectOption","isSearchDisabled","handleSearchFilter","updateSearchClasses","handleCheckboxClick","newSelectedState","selectAllChildren","expandAllChildren","updateParentStates","notifyMultiselect","handleHeaderClick","handleClick","calculateDepth","setAttribute","toString","hasSelectedChildren","hasAnySelectedChildren","disconnectedCallback","optionDiv","removeHighlighting","getTextContent","matchesSearch","hasMatchingParent","hasMatchingChildren","highlightSearchTerm","slotElement","originalText","searchTermLower","originalTextLower","searchIndex","indexOf","beforeMatch","substring","matchText","afterMatch","highlightedContent","createElement","className","appendChild","createTextNode","boldElement","highlightedElement","removeChild","removeAttribute","text","childNodes","node","nodeType","Node","TEXT_NODE","childOptions","childInstance","childText","childMatches","grandChildrenMatch","parent","parentElement","parentText","type","toggleExpansion","updateEvent","bubbles","call","expanded","siblings","sibling","hasSelected","hasSelectedDescendants","checkForSelectedDescendants","nestedChild","isSelected","hasSelectedNested","parentMultiselect","basePadding","additionalPadding","totalPadding","optionItemStyle","paddingLeft","Host"],"sources":["src/components/select/multi-select/multiselect.scss?tag=ifx-multiselect&encapsulation=shadow","src/components/select/multi-select/multiselect.tsx","src/components/select/multi-select/multiselect-option.scss?tag=ifx-multiselect-option&encapsulation=shadow","src/components/select/multi-select/multiselect-option.tsx"],"sourcesContent":["// @import '~choices.js/public/assets/styles/choices.css';\n@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../../global/font.scss\";\n\n.ifx-multiselect-container {\n position: relative;\n box-sizing: border-box;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n\n &:hover {\n cursor: pointer;\n }\n\n .ifx-label-wrapper {\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n white-space: pre-wrap;\n word-wrap: break-word;\n overflow-wrap: anywhere;\n max-width: 100%;\n }\n\n .ifx-error-message-wrapper {\n color: #CD002F;\n font-size: tokens.$ifxFontSizeXs;\n line-height: tokens.$ifxLineHeightXs;\n white-space: pre-wrap;\n word-wrap: break-word;\n overflow-wrap: anywhere;\n max-width: 100%;\n }\n\n .ifx-multiselect-wrapper {\n background-color: tokens.$ifxColorBaseWhite;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n border: 1px solid tokens.$ifxColorEngineering400;\n border-radius: tokens.$ifxBorderRadius12;\n width: 100%;\n font-weight: 400;\n font-style: normal;\n height: 40px;\n line-height: 24px;\n padding: 8px 16px;\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n\n &:focus-visible {\n outline: none;\n }\n\n &:focus-visible:not(.active):not(:active) {\n outline: none;\n\n &::before {\n content: '';\n position: absolute;\n width: calc(100% + 4px);\n height: calc(100% + 4px);\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n border: 2px solid tokens.$ifxColorOcean500;\n border-radius: 2px;\n\n }\n }\n\n &.disabled {\n background: tokens.$ifxColorEngineering200;\n color: #575352;\n border-color: #575352;\n cursor: default;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none;\n }\n\n &.error {\n border-color: #CD002F;\n }\n\n &:hover:not(.focus, :focus) {\n border-color: tokens.$ifxColorEngineering500;\n }\n\n &.active {\n border-color: tokens.$ifxColorOcean500 !important; // Active border color\n\n & .icon-wrapper-up {\n display: flex;\n align-items: center;\n justify-content: center;\n padding-left: tokens.$ifxSpace100;\n }\n\n & .icon-wrapper-down {\n display: none\n }\n }\n\n\n & .icon-wrapper-up {\n display: none;\n }\n\n & .icon-wrapper-down {\n display: flex;\n align-items: center;\n justify-content: center;\n padding-left: tokens.$ifxSpace100;\n }\n\n &.is-flipped {\n .ifx-multiselect-dropdown-menu {\n top: auto;\n bottom: 100%;\n }\n }\n }\n\n .ifx-multiselect-input {\n flex-grow: 1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n\n &.placeholder {\n opacity: 0.5;\n }\n\n }\n\n\n .ifx-multiselect-icon-container {\n margin-left: auto;\n display: flex;\n align-items: center;\n gap: tokens.$ifxSpace100;\n\n .ifx-multiselect-icon-container {\n display: flex;\n }\n\n .icon-wrapper {\n display: flex;\n align-items: center;\n transition: transform 0.2s ease-in-out;\n }\n\n .icon-wrapper--open {\n transform: rotate(180deg);\n }\n }\n\n .ifx-clear-button {\n display: flex;\n align-items: center;\n\n &.hide {\n display: none;\n }\n }\n\n .ifx-multiselect-dropdown-menu {\n box-sizing: border-box;\n position: absolute;\n top: 100%;\n left: 0;\n width: 100%;\n margin-top: tokens.$ifxSpace50;\n border: 1px solid tokens.$ifxColorEngineering200;\n background-color: #fff;\n box-shadow: 0px 6px 9px 0px rgba(29, 29, 29, 0.10);\n max-height: 300px;\n z-index: 1000;\n display: flex;\n flex-direction: column;\n }\n}\n\n.ifx-multiselect-dropdown-functions {\n padding: tokens.$ifxSpace150 tokens.$ifxSpace200;\n border-bottom: 1px solid tokens.$ifxColorEngineering200;\n flex-shrink: 0;\n}\n\n.ifx-multiselect-dropdown-search {\n margin-bottom: tokens.$ifxSpace150;\n}\n\n.ifx-multiselect-dropdown-controls {\n display: flex;\n flex-wrap: wrap;\n justify-content: space-between;\n gap: tokens.$ifxSpace100;\n\n .select-all-wrapper {\n display: flex;\n }\n\n .expand-collapse-controls {\n display: flex;\n gap: tokens.$ifxSpace150;\n }\n\n .control-item {\n font-size: tokens.$ifxFontSizeS;\n line-height: tokens.$ifxLineHeightS;\n\n &:focus {\n outline: none;\n }\n\n &:focus-visible {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n border-radius: tokens.$ifxBorderRadius12;\n }\n }\n}\n\n.ifx-multiselect-options {\n flex: 1;\n overflow-y: auto;\n padding-top: tokens.$ifxSpace150;\n padding-bottom: tokens.$ifxSpace150;\n\n &.show-no-results {\n .ifx-multiselect-no-results {\n display: block;\n }\n }\n}\n\n.ifx-multiselect-no-results {\n padding-left: tokens.$ifxSpace200;\n padding-right: tokens.$ifxSpace200;\n display: none;\n\n .no-results-content {\n\n .no-results-text {\n\n }\n }\n}\n\n","import { Component, Prop, State, Event, EventEmitter, Element, AttachInternals, h, Watch, Method } from '@stencil/core';\nimport { Option } from './interfaces';\n\nfunction debounce(func, wait) {\n let timeout;\n return function executedFunction(...args) {\n const later = () => {\n clearTimeout(timeout);\n func(...args);\n };\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n };\n}\n\n@Component({\n tag: 'ifx-multiselect',\n styleUrl: 'multiselect.scss',\n shadow: true,\n formAssociated: true\n})\n\nexport class Multiselect {\n @Prop() name: string;\n @Prop() disabled: boolean = false;\n @Prop() error: boolean = false;\n @Prop() errorMessage: string = \"Error\";\n @Prop() label: string = \"\";\n @Prop() placeholder: string = \"\";\n @Prop() showSearch: boolean = true;\n @Prop() showSelectAll: boolean = true;\n @Prop() showClearButton: boolean = true;\n @Prop() showExpandCollapse: boolean = true;\n @Prop() noResultsMessage: string = \"No results found.\";\n @Prop() showNoResultsMessage: boolean = true;\n @Prop() searchPlaceholder: string = \"Search\";\n @Prop() selectAllLabel: string = \"Select all\";\n @Prop() expandLabel: string = \"Expand\";\n @Prop() collapseLabel: string = \"Collapse\";\n @Prop() ariaLabel: string = \"Multi-select dropdown\";\n @Prop() ariaLabelledBy: string = \"\";\n @Prop() ariaDescribedBy: string = \"\";\n @Prop() ariaSearchLabel: string = \"Search options\";\n @Prop() ariaClearLabel: string = \"Clear all selections\";\n @Prop() ariaToggleLabel: string = \"Toggle dropdown\";\n @Prop() ariaSelectAllLabel: string = \"Select all options\";\n @Prop() ariaExpandAllLabel: string = \"Expand all categories\";\n @Prop() ariaCollapseAllLabel: string = \"Collapse all categories\";\n\n @State() internalError: boolean = false;\n @State() internalErrorMessage: string;\n @State() persistentSelectedOptions: Option[] = [];\n @State() dropdownOpen = false;\n @State() dropdownFlipped: boolean;\n @State() searchTerm: string = '';\n\n @Event() ifxSelect: EventEmitter;\n @Event() ifxOpen: EventEmitter;\n\n @Element() el: HTMLElement;\n dropdownElement!: HTMLElement;\n\n @AttachInternals() internals: ElementInternals;\n private parseChildOptions(): Option[] {\n const options: Option[] = [];\n const childElements = Array.from(this.el.children);\n\n childElements.forEach((child, index) => {\n if (child.tagName === 'IFX-MULTISELECT-OPTION') {\n const option = this.parseOptionElement(child as HTMLElement, index);\n if (option) {\n options.push(option);\n }\n }\n });\n\n return options;\n }\n\n private parseOptionElement(element: HTMLElement, index: number): Option | null {\n const value = element.getAttribute('value') || `option-${index}`;\n const selected = element.hasAttribute('selected');\n const disabled = element.hasAttribute('disabled');\n const indeterminate = element.hasAttribute('indeterminate');\n\n const option: Option = {\n value,\n selected,\n disabled,\n indeterminate\n };\n\n const nestedOptions = Array.from(element.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION')\n .map((child, childIndex) => this.parseOptionElement(child as HTMLElement, childIndex))\n .filter(opt => opt !== null) as Option[];\n\n if (nestedOptions.length > 0) {\n option.children = nestedOptions;\n }\n\n return option;\n }\n\n loadInitialOptions() {\n this.internalError = this.error;\n this.internalErrorMessage = this.errorMessage;\n\n const allOptions = this.parseChildOptions();\n const initiallySelected = this.collectSelectedOptions(allOptions);\n const initiallySelectedNotInState = initiallySelected.filter(init =>\n !this.persistentSelectedOptions.some(opt => opt.value == init.value)\n );\n this.persistentSelectedOptions = [...this.persistentSelectedOptions, ...initiallySelectedNotInState];\n }\n\n private collectSelectedOptions(options: Option[]): Option[] {\n let selectedOptions: Option[] = [];\n\n for (const option of options) {\n if (option.selected) {\n if (option.children && option.children.length > 0) {\n selectedOptions = selectedOptions.concat(this.collectLeafOptions(option.children));\n } else {\n if (!selectedOptions.some(existingOption => existingOption.value === option.value)) {\n selectedOptions.push(option);\n }\n }\n } else {\n if (option.children && option.children.length > 0) {\n selectedOptions = selectedOptions.concat(this.collectSelectedOptions(option.children));\n }\n }\n }\n\n return selectedOptions;\n }\n\n private collectLeafOptions(children: Option[]): Option[] {\n let leafOptions = [];\n\n for (const child of children) {\n if (child.children && child.children.length > 0) {\n leafOptions = leafOptions.concat(this.collectLeafOptions(child.children));\n } else {\n leafOptions.push(child);\n }\n }\n return leafOptions;\n }\n\n handleSearch = debounce((targetElement: HTMLInputElement) => {\n const searchTerm = targetElement.value.toLowerCase();\n const isSearchActive = searchTerm !== '';\n\n this.searchTerm = searchTerm;\n\n const wrapper = this.el.shadowRoot.querySelector('.ifx-multiselect-wrapper');\n if (wrapper) {\n if (isSearchActive) {\n wrapper.classList.remove('active');\n } else {\n const searchField = this.el.shadowRoot.querySelector('ifx-search-field');\n const searchFieldHasFocus = searchField && searchField.matches(':focus-within');\n if (!searchFieldHasFocus) {\n wrapper.classList.add('active');\n }\n }\n }\n\n const optionsContainer = this.el.shadowRoot.querySelector('.ifx-multiselect-options');\n if (optionsContainer) {\n if (isSearchActive) {\n optionsContainer.classList.add('has-search-filter');\n } else {\n optionsContainer.classList.remove('has-search-filter');\n }\n }\n\n requestAnimationFrame(() => {\n const allOptions = this.el.querySelectorAll('ifx-multiselect-option');\n allOptions.forEach(option => {\n const searchEvent = new CustomEvent('ifx-search-filter', {\n detail: { searchTerm, isActive: isSearchActive }\n });\n option.dispatchEvent(searchEvent);\n });\n\n if (isSearchActive) {\n setTimeout(() => {\n const allOptions = this.el.querySelectorAll('ifx-multiselect-option');\n let visibleCount = 0;\n\n allOptions.forEach(option => {\n const style = window.getComputedStyle(option);\n const rect = option.getBoundingClientRect();\n\n if (style.display !== 'none' &&\n style.visibility !== 'hidden' &&\n style.opacity !== '0' &&\n rect.height > 0) {\n visibleCount++;\n }\n });\n\n const optionsContainer = this.el.shadowRoot.querySelector('.ifx-multiselect-options');\n if (optionsContainer) {\n if (visibleCount === 0) {\n optionsContainer.classList.add('show-no-results');\n } else {\n optionsContainer.classList.remove('show-no-results');\n }\n }\n }, 200);\n } else {\n const optionsContainer = this.el.shadowRoot.querySelector('.ifx-multiselect-options');\n if (optionsContainer) {\n optionsContainer.classList.remove('show-no-results');\n }\n }\n });\n }, 150);\n\n private handleSearchFocus(hasFocus: boolean) {\n const wrapper = this.el.shadowRoot.querySelector('.ifx-multiselect-wrapper');\n if (wrapper) {\n if (hasFocus || this.searchTerm !== '') {\n wrapper.classList.remove('active');\n } else {\n wrapper.classList.add('active');\n }\n }\n }\n\n positionDropdown() {\n const wrapperRect = this.el.shadowRoot.querySelector('.ifx-multiselect-wrapper')?.getBoundingClientRect();\n const spaceBelow = window.innerHeight - wrapperRect.bottom;\n const spaceAbove = wrapperRect.top;\n\n if ((spaceAbove > spaceBelow && wrapperRect.height > spaceBelow) || (wrapperRect.bottom > window.innerHeight)) {\n this.dropdownFlipped = true;\n } else {\n this.dropdownFlipped = false;\n }\n }\n\n public updateSlotBasedSelections(emitEvent: boolean = false) {\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n const selectedLeafOptions: Option[] = [];\n\n allOptionElements.forEach((optionEl: any) => {\n const instance = optionEl['__stencil_instance'];\n if (instance && instance.selected && !instance.hasChildren) {\n selectedLeafOptions.push({\n value: instance.value,\n selected: true,\n disabled: instance.disabled\n });\n }\n });\n\n this.persistentSelectedOptions = selectedLeafOptions;\n\n if (emitEvent) {\n this.ifxSelect.emit(this.persistentSelectedOptions);\n }\n }\n\n private updateInitialParentStates() {\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n const optionsByDepth = Array.from(allOptionElements)\n .map(el => ({\n element: el,\n instance: (el as any)['__stencil_instance'],\n depth: parseInt(el.getAttribute('data-level') || '0')\n }))\n .filter(item => item.instance)\n .sort((a, b) => b.depth - a.depth);\n\n optionsByDepth.forEach(({ instance }) => {\n if (instance.hasChildren) {\n this.updateParentState(instance);\n }\n });\n }\n\n private updateParentState(parentInstance: any) {\n const directChildren = Array.from(parentInstance.el.children as HTMLCollection)\n .filter((child: Element) => child.tagName === 'IFX-MULTISELECT-OPTION')\n .map(child => (child as any)['__stencil_instance'])\n .filter(instance => instance !== null);\n\n const selectedCount = directChildren.filter(child => child.selected).length;\n const indeterminateCount = directChildren.filter(child => child.indeterminate).length;\n const totalCount = directChildren.length;\n\n if (selectedCount === totalCount && indeterminateCount === 0) {\n parentInstance.selected = true;\n parentInstance.indeterminate = false;\n } else if (selectedCount === 0 && indeterminateCount === 0) {\n parentInstance.selected = false;\n parentInstance.indeterminate = false;\n } else {\n parentInstance.selected = false;\n parentInstance.indeterminate = true;\n }\n }\n\n componentDidLoad() {\n setTimeout(() => {\n this.positionDropdown();\n }, 500);\n\n this.el.addEventListener('ifx-option-changed', () => {\n requestAnimationFrame(() => {\n this.updateSlotBasedSelections(true);\n });\n });\n\n setTimeout(() => {\n this.updateSlotBasedSelections(false);\n this.updateInitialParentStates();\n }, 100);\n }\n\n componentWillLoad() {\n this.loadInitialOptions();\n }\n\n @Watch('error')\n updateInternalError() {\n this.internalError = this.error;\n }\n\n @Watch('errorMessage')\n updateInternalErrorMessage() {\n this.internalErrorMessage = this.errorMessage;\n }\n\n @Watch('persistentSelectedOptions')\n onSelectionChange(newValue: Option[], _: Option[]) {\n const formData = new FormData();\n newValue.forEach(option => formData.append(this.name, option.value));\n this.internals.setFormValue(formData);\n }\n collapseAll() {\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n allOptionElements.forEach((optionEl: any) => {\n const instance = optionEl['__stencil_instance'];\n if (instance && instance.hasChildren) {\n instance.isExpanded = false;\n }\n });\n }\n\n expandAll() {\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n allOptionElements.forEach((optionEl: any) => {\n const instance = optionEl['__stencil_instance'];\n if (instance && instance.hasChildren) {\n instance.isExpanded = true;\n }\n });\n }\n\n selectAll() {\n this.resetSearch();\n\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n\n allOptionElements.forEach((optionEl: any) => {\n const instance = optionEl['__stencil_instance'];\n if (instance) {\n if (instance.hasChildren) {\n instance.isExpanded = true;\n } else {\n instance.selected = true;\n }\n }\n });\n\n setTimeout(() => {\n this.updateInitialParentStates();\n this.updateSlotBasedSelections(false);\n this.ifxSelect.emit(this.persistentSelectedOptions);\n }, 0);\n }\n\n @Method()\n async clearSelection() {\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n allOptionElements.forEach((optionEl: any) => {\n const instance = optionEl['__stencil_instance'];\n if (instance) {\n instance.selected = false;\n instance.indeterminate = false;\n if (instance.hasChildren) {\n instance.isExpanded = false;\n }\n }\n });\n\n this.persistentSelectedOptions = [];\n\n setTimeout(() => {\n this.updateSlotBasedSelections(false);\n this.ifxSelect.emit(this.persistentSelectedOptions);\n }, 0);\n }\n\n handleDocumentClick = (event: Event) => {\n const path = event.composedPath();\n if (!path.includes(this.dropdownElement)) {\n this.dropdownOpen = false;\n document.removeEventListener('click', this.handleDocumentClick);\n this.resetSearch();\n this.ifxOpen.emit(this.dropdownOpen);\n }\n }\n\n toggleDropdown() {\n this.dropdownOpen = !this.dropdownOpen;\n setTimeout(() => {\n if (this.dropdownOpen) {\n document.addEventListener('click', this.handleDocumentClick);\n } else {\n this.resetSearch();\n }\n this.ifxOpen.emit(this.dropdownOpen);\n }, 0);\n }\n\n private resetSearch() {\n this.searchTerm = '';\n\n const searchField = this.el.shadowRoot.querySelector('ifx-search-field') as any;\n if (searchField) {\n searchField.value = '';\n }\n\n const optionsContainer = this.el.shadowRoot.querySelector('.ifx-multiselect-options');\n if (optionsContainer) {\n optionsContainer.classList.remove('has-search-filter');\n }\n\n const allOptions = this.el.querySelectorAll('ifx-multiselect-option');\n allOptions.forEach(option => {\n const searchEvent = new CustomEvent('ifx-search-filter', {\n detail: { searchTerm: '', isActive: false }\n });\n option.dispatchEvent(searchEvent);\n });\n }\n\n handleWrapperClick(event: MouseEvent) {\n this.positionDropdown();\n\n if (event.currentTarget === event.target) {\n this.toggleDropdown();\n }\n }\n\n handleKeyDown(event: KeyboardEvent) {\n if (this.disabled) return;\n\n // If dropdown is closed, only allow opening\n if (!this.dropdownOpen) {\n switch (event.code) {\n case 'Enter':\n case 'Space':\n case 'ArrowDown':\n event.preventDefault();\n this.toggleDropdown();\n break;\n }\n return;\n }\n\n // Dropdown is open - handle navigation and controls\n switch (event.code) {\n case 'Escape':\n event.preventDefault();\n this.toggleDropdown();\n break;\n case 'Enter':\n case 'Space':\n // Don't close dropdown when pressing space/enter in controls area\n const target = event.target as HTMLElement;\n if (!target.closest('.ifx-multiselect-dropdown-functions')) {\n event.preventDefault();\n this.toggleDropdown();\n }\n break;\n case 'ArrowDown':\n case 'ArrowUp':\n // Focus first/last option for navigation\n event.preventDefault();\n this.focusFirstOption();\n break;\n }\n }\n\n private focusFirstOption() {\n const firstOption = this.el.querySelector('ifx-multiselect-option:not(.search-hidden)');\n if (firstOption) {\n const labelElement = firstOption.shadowRoot?.querySelector('.option-label') as HTMLElement;\n labelElement?.focus();\n }\n }\n\n private renderSelectAll() {\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n const leafOptions = Array.from(allOptionElements).filter((el: any) => !el.hasChildren);\n const selectedLeafOptions = Array.from(allOptionElements).filter((el: any) => !el.hasChildren && el.selected);\n\n const allSelected = leafOptions.length > 0 && selectedLeafOptions.length === leafOptions.length;\n\n const toggleSelectAll = (event?: Event) => {\n if (event) {\n event.preventDefault();\n event.stopPropagation();\n }\n\n if (allSelected) {\n this.clearSelection();\n } else {\n this.selectAll();\n }\n };\n\n return (\n <div class=\"select-all-wrapper\">\n <ifx-checkbox\n id='selectAll'\n checked={allSelected}\n size=\"s\"\n aria-label={this.ariaSelectAllLabel}\n onClick={toggleSelectAll}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n toggleSelectAll(e);\n }\n }}\n >\n {this.selectAllLabel}\n </ifx-checkbox>\n </div>\n );\n }\n\n private renderNoResultsMessage() {\n return (\n <div class=\"ifx-multiselect-no-results\">\n <div class=\"no-results-content\">\n <span class=\"no-results-text\">{this.noResultsMessage}</span>\n </div>\n </div>\n );\n }\n\n render() {\n const selectedOptionsLabels = this.persistentSelectedOptions\n .map((option) => {\n const optionElement = this.el.querySelector(`ifx-multiselect-option[value=\"${option.value}\"]`);\n return optionElement?.textContent?.trim() || option.value;\n })\n .join(', ');\n\n const hasSelections = this.persistentSelectedOptions.length > 0;\n\n let isFlatMultiselect = false;\n const allOptionElements = this.el.querySelectorAll('ifx-multiselect-option');\n if (allOptionElements.length > 0) {\n isFlatMultiselect = Array.from(allOptionElements).every(option => option.children.length === 0);\n }\n\n return (\n <div class={`ifx-multiselect-container`} ref={el => this.dropdownElement = el as HTMLElement}>\n {\n this.label ?\n <div class=\"ifx-label-wrapper\">\n <span>{this.label}</span>\n </div> : null\n }\n <div class={`ifx-multiselect-wrapper\n ${this.dropdownOpen ? 'active' : ''}\n ${this.dropdownFlipped ? 'is-flipped' : ''}\n ${this.internalError ? 'error' : \"\"}\n ${this.disabled ? 'disabled' : \"\"}`}\n role=\"combobox\"\n aria-label={this.ariaLabel}\n aria-labelledby={this.ariaLabelledBy || undefined}\n aria-describedby={this.ariaDescribedBy || undefined}\n aria-expanded={this.dropdownOpen}\n aria-haspopup=\"listbox\"\n aria-disabled={this.disabled}\n tabindex=\"0\"\n onClick={this.disabled ? undefined : (event) => this.handleWrapperClick(event)}\n onKeyDown={this.disabled ? undefined : (event) => this.handleKeyDown(event)} >\n <div class={`ifx-multiselect-input\n ${hasSelections ? '' : 'placeholder'}\n `}\n onClick={this.disabled ? undefined : () => this.toggleDropdown()}\n >\n {hasSelections ? selectedOptionsLabels : this.placeholder}\n </div>\n {this.dropdownOpen && (\n <div class=\"ifx-multiselect-dropdown-menu\">\n\n {(this.showSearch || this.showSelectAll || (this.showExpandCollapse && !isFlatMultiselect)) && (\n <div class=\"ifx-multiselect-dropdown-functions\" onClick={(e) => e.stopPropagation()}>\n {this.showSearch && (\n <div class=\"ifx-multiselect-dropdown-search\">\n <ifx-search-field\n class=\"search-input\"\n placeholder={this.searchPlaceholder}\n size=\"s\"\n show-delete-icon=\"true\"\n aria-label={this.ariaSearchLabel}\n onKeyDown={(e) => { e.stopPropagation() }}\n onIfxInput={(event) => this.handleSearch(event.target)}\n onFocus={() => this.handleSearchFocus(true)}\n onBlur={() => this.handleSearchFocus(false)}\n ></ifx-search-field>\n </div>\n )}\n\n <div class=\"ifx-multiselect-dropdown-controls\">\n {this.showSelectAll && this.renderSelectAll()}\n {this.showExpandCollapse && !isFlatMultiselect && (\n <div class=\"expand-collapse-controls\">\n <span\n class=\"control-item\"\n role=\"button\"\n tabIndex={0}\n aria-label={this.ariaExpandAllLabel}\n onClick={(e) => { e.stopPropagation(); this.expandAll(); }}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n this.expandAll();\n }\n }}\n >\n {this.expandLabel}\n </span>\n <span\n class=\"control-item\"\n role=\"button\"\n tabIndex={0}\n aria-label={this.ariaCollapseAllLabel}\n onClick={(e) => { e.stopPropagation(); this.collapseAll(); }}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n this.collapseAll();\n }\n }}\n >\n {this.collapseLabel}\n </span>\n </div>\n )}\n </div>\n </div>\n )}\n\n <div class=\"ifx-multiselect-options\" role=\"listbox\" aria-multiselectable=\"true\">\n <slot />\n {this.searchTerm && this.showNoResultsMessage && this.renderNoResultsMessage()}\n </div>\n </div>\n )}\n <div class='ifx-multiselect-icon-container'>\n\n {/* Clear Button - will show only if there's a selection */}\n {hasSelections && (\n <div class={`ifx-clear-button ${!this.showClearButton ? 'hide' : ''}`}\n aria-label={this.ariaClearLabel}\n role=\"button\"\n tabIndex={0}\n onClick={this.disabled ? undefined : (e) => { e.stopPropagation(); this.clearSelection(); }}\n onKeyDown={this.disabled ? undefined : (e) => { if (e.key === 'Enter' || e.key === ' ') { e.stopPropagation(); this.clearSelection(); } }}>\n <ifx-icon icon=\"c-remove-16\" key=\"clear-icon\"></ifx-icon>\n </div>\n )}\n <div class={`icon-wrapper ${this.dropdownOpen ? 'icon-wrapper--open' : 'icon-wrapper--closed'}`}\n aria-label={this.ariaToggleLabel}\n role=\"button\"\n tabIndex={0}\n onClick={this.disabled ? undefined : (e) => { e.stopPropagation(); this.toggleDropdown(); }}\n onKeyDown={this.disabled ? undefined : (e) => { if (e.key === 'Enter' || e.key === ' ') { e.stopPropagation(); this.toggleDropdown(); } }}>\n <ifx-icon icon='chevron-down-16' key=\"chevron-icon\"></ifx-icon>\n </div>\n </div>\n\n </div>\n {\n this.internalError ?\n <div class=\"ifx-error-message-wrapper\">\n <span>{this.internalErrorMessage}</span>\n </div> : null\n }\n </div>\n );\n }\n}\n","@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n:host {\n display: block;\n width: 100%;\n}\n\n.option {\n display: flex;\n flex-direction: column;\n position: relative;\n cursor: pointer;\n list-style: none;\n\n &.option--expanded {\n position: relative;\n }\n\n &.option--has-children {\n position: relative;\n\n .option-item > .chevron-wrapper {\n display: flex;\n }\n }\n\n &--disabled {\n cursor: not-allowed;\n pointer-events: none;\n color: tokens.$ifxColorEngineering300;\n }\n\n &--selected {\n // Additional styles for selected state if needed\n // .option-item {\n // background: red;\n // }\n }\n\n &.search-hidden {\n display: none !important;\n }\n\n &.search-match {\n .option-item {\n .option-label {\n .search-highlight {\n font-weight: bold;\n // color: tokens.$ifxColorOcean400;\n }\n }\n }\n }\n}\n\n.option-item {\n display: flex;\n flex-direction: row;\n align-items: center;\n white-space: nowrap;\n min-height: tokens.$ifxSize250;\n padding: tokens.$ifxSize50 tokens.$ifxSpace200;\n background-color: tokens.$ifxColorBaseWhite;\n transition: background-color 0.2s ease-in-out;\n\n &:hover {\n background-color: tokens.$ifxColorEngineering100;\n }\n\n .option--disabled & {\n &:hover {\n background-color: transparent;\n }\n }\n}\n\n.option-children {\n display: block;\n}\n\n.chevron-wrapper {\n display: none;\n align-items: center;\n justify-content: center;\n margin-right: tokens.$ifxSpace100;\n width: tokens.$ifxSize250;\n height: tokens.$ifxSize250;\n flex-shrink: 0;\n\n &:focus {\n outline: none;\n }\n\n &:focus-visible {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n border-radius: tokens.$ifxBorderRadius12;\n }\n\n .option--has-children & {\n display: flex;\n }\n\n .chevron {\n transition: transform 0.2s ease-in-out;\n color: tokens.$ifxColorEngineering600;\n\n &.chevron--expanded {\n transform: rotate(90deg);\n }\n\n &.chevron--collapsed {\n transform: rotate(0deg);\n }\n }\n}\n\n.checkbox-wrapper {\n display: flex;\n align-items: center;\n margin-right: tokens.$ifxSpace100;\n flex-shrink: 0;\n}\n\n.option-label {\n flex-grow: 1;\n display: flex;\n align-items: center;\n cursor: pointer;\n padding: tokens.$ifxSpace25 0;\n font-size: tokens.$ifxFontSizeS;\n\n &:focus {\n outline: none;\n }\n\n &:focus-visible {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n border-radius: tokens.$ifxBorderRadius12;\n }\n\n .option--disabled & {\n cursor: not-allowed;\n color: tokens.$ifxColorEngineering300;\n }\n}\n","import { Component, Prop, Element, h, Host, State, Listen } from '@stencil/core';\n\n@Component({\n tag: 'ifx-multiselect-option',\n styleUrl: 'multiselect-option.scss',\n shadow: true,\n})\nexport class MultiselectOption {\n @Element() el: HTMLElement;\n\n @Prop() value: string;\n @Prop({ reflect: true, mutable: true }) selected: boolean = false;\n @Prop({ reflect: true, mutable: true }) disabled: boolean = false;\n @Prop({ reflect: true, mutable: true }) indeterminate: boolean = false;\n\n @State() private isExpanded: boolean = false;\n @State() private hasChildren: boolean = false;\n @State() private depth: number = 0;\n @State() private searchTerm: string = '';\n @State() private isSearchActive: boolean = false;\n @State() private isSearchDisabled: boolean = false;\n\n componentWillLoad() {\n this.hasChildren = this.el.children.length > 0;\n this.depth = this.calculateDepth();\n\n this.el.setAttribute('data-level', this.depth.toString());\n }\n\n componentDidLoad() {\n if (this.hasChildren) {\n const hasSelectedChildren = this.hasAnySelectedChildren();\n if (hasSelectedChildren) {\n this.isExpanded = true;\n }\n }\n\n (this.el as any)['__stencil_instance'] = this;\n this.notifyMultiselect();\n this.el.addEventListener('ifx-search-filter', this.handleSearchFilter);\n }\n\n disconnectedCallback() {\n this.el.removeEventListener('ifx-search-filter', this.handleSearchFilter);\n }\n\n private handleSearchFilter = (event: CustomEvent) => {\n const { searchTerm, isActive } = event.detail;\n this.searchTerm = searchTerm.toLowerCase();\n this.isSearchActive = isActive;\n\n requestAnimationFrame(() => {\n this.updateSearchClasses();\n });\n }\n\n private updateSearchClasses() {\n const optionDiv = this.el.shadowRoot?.querySelector('.option');\n if (!optionDiv) return;\n\n if (!this.isSearchActive) {\n optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');\n this.removeHighlighting();\n this.isSearchDisabled = false;\n return;\n }\n\n const textContent = this.getTextContent().toLowerCase();\n const matchesSearch = textContent.includes(this.searchTerm);\n const hasMatchingParent = this.hasMatchingParent();\n\n requestAnimationFrame(() => {\n const hasMatchingChildren = this.hasMatchingChildren();\n\n optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');\n this.isSearchDisabled = false;\n\n if (matchesSearch && !this.hasChildren) {\n optionDiv.classList.add('search-match');\n this.highlightSearchTerm();\n } else if (matchesSearch && this.hasChildren) {\n optionDiv.classList.add('search-match');\n this.highlightSearchTerm();\n this.isExpanded = true;\n } else if (!matchesSearch && this.hasChildren && hasMatchingChildren) {\n optionDiv.classList.add('search-parent');\n this.removeHighlighting();\n this.isExpanded = true;\n this.isSearchDisabled = true;\n } else if (hasMatchingParent) {\n optionDiv.classList.add('search-match');\n this.removeHighlighting();\n } else {\n optionDiv.classList.add('search-hidden');\n this.removeHighlighting();\n }\n });\n }\n\n private highlightSearchTerm() {\n if (!this.searchTerm) return;\n\n const labelElement = this.el.shadowRoot?.querySelector('.option-label');\n if (!labelElement) return;\n\n const slotElement = labelElement.querySelector('slot');\n if (!slotElement) return;\n\n this.removeHighlighting();\n\n const originalText = this.getTextContent();\n const searchTermLower = this.searchTerm.toLowerCase();\n const originalTextLower = originalText.toLowerCase();\n\n if (!originalTextLower.includes(searchTermLower)) return;\n\n const searchIndex = originalTextLower.indexOf(searchTermLower);\n\n if (searchIndex === -1) return;\n\n const beforeMatch = originalText.substring(0, searchIndex);\n const matchText = originalText.substring(searchIndex, searchIndex + searchTermLower.length);\n const afterMatch = originalText.substring(searchIndex + searchTermLower.length);\n\n const highlightedContent = document.createElement('span');\n highlightedContent.className = 'highlighted-text';\n\n if (beforeMatch) {\n highlightedContent.appendChild(document.createTextNode(beforeMatch));\n }\n\n const boldElement = document.createElement('strong');\n boldElement.className = 'search-highlight';\n boldElement.textContent = matchText;\n highlightedContent.appendChild(boldElement);\n\n if (afterMatch) {\n highlightedContent.appendChild(document.createTextNode(afterMatch));\n }\n\n labelElement.setAttribute('data-original-content', 'true');\n slotElement.style.display = 'none';\n labelElement.appendChild(highlightedContent);\n }\n\n private removeHighlighting() {\n const labelElement = this.el.shadowRoot?.querySelector('.option-label');\n if (!labelElement) return;\n\n const slotElement = labelElement.querySelector('slot');\n const highlightedElement = labelElement.querySelector('.highlighted-text');\n\n if (highlightedElement) {\n labelElement.removeChild(highlightedElement);\n }\n\n if (slotElement) {\n slotElement.style.display = '';\n }\n\n labelElement.removeAttribute('data-original-content');\n }\n\n private getTextContent(): string {\n let text = '';\n Array.from(this.el.childNodes).forEach(node => {\n if (node.nodeType === Node.TEXT_NODE) {\n text += node.textContent?.trim() || '';\n }\n });\n return text || this.value || '';\n }\n\n private hasMatchingChildren(): boolean {\n if (!this.hasChildren) return false;\n\n const childOptions = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as HTMLElement[];\n\n return childOptions.some(child => {\n const childInstance = (child as any)['__stencil_instance'];\n if (!childInstance) return false;\n\n const childText = childInstance.getTextContent().toLowerCase();\n const childMatches = childText.includes(this.searchTerm);\n const grandChildrenMatch = childInstance.hasMatchingChildren();\n\n return childMatches || grandChildrenMatch;\n });\n }\n\n private hasMatchingParent(): boolean {\n let parent = this.el.parentElement;\n while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {\n const parentInstance = (parent as any)['__stencil_instance'];\n if (parentInstance) {\n const parentText = parentInstance.getTextContent().toLowerCase();\n if (parentText.includes(this.searchTerm)) {\n return true;\n }\n }\n parent = parent.parentElement;\n }\n return false;\n }\n\n private calculateDepth(): number {\n let depth = 0;\n let parent = this.el.parentElement;\n while (parent && parent.tagName !== 'IFX-MULTISELECT') {\n if (parent.tagName === 'IFX-MULTISELECT-OPTION') {\n depth++;\n }\n parent = parent.parentElement;\n }\n return depth;\n }\n\n @Listen('click')\n handleClick(event: Event) {\n if (this.disabled || (this.isSearchActive && this.isSearchDisabled)) return;\n\n event.stopPropagation();\n\n if (event.type === 'click' && (event.target as HTMLElement).closest('.chevron-wrapper')) {\n this.toggleExpansion();\n return;\n }\n\n let newSelectedState: boolean;\n\n if (this.indeterminate) {\n newSelectedState = true;\n } else {\n newSelectedState = !this.selected;\n }\n\n this.selected = newSelectedState;\n this.indeterminate = false;\n\n if (this.hasChildren) {\n this.isExpanded = newSelectedState;\n\n requestAnimationFrame(() => {\n this.selectAllChildren(newSelectedState);\n this.expandAllChildren(newSelectedState);\n });\n }\n\n this.updateParentStates();\n this.notifyMultiselect();\n }\n\n @Listen('keydown')\n handleKeyDown(event: KeyboardEvent) {\n if (this.disabled || (this.isSearchActive && this.isSearchDisabled)) return;\n\n const target = event.target as HTMLElement;\n\n if (target.closest('.chevron-wrapper') || target.closest('.checkbox-wrapper')) {\n return;\n }\n\n if (event.key !== 'ArrowUp' && event.key !== 'ArrowDown') {\n event.stopPropagation();\n }\n\n if (event.key === 'ArrowRight' && this.hasChildren) {\n this.isExpanded = true;\n }\n\n if (event.key === 'ArrowLeft' && this.hasChildren) {\n this.isExpanded = false;\n }\n }\n\n private notifyMultiselect() {\n const updateEvent = new CustomEvent('ifx-option-changed', {\n bubbles: true,\n detail: {\n value: this.value,\n selected: this.selected,\n indeterminate: this.indeterminate\n }\n });\n this.el.dispatchEvent(updateEvent);\n }\n\n private selectAllChildren(selected: boolean) {\n const directChildren = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as any[];\n\n directChildren.forEach((child: any) => {\n const childInstance = child['__stencil_instance'];\n if (childInstance) {\n childInstance.selected = selected;\n childInstance.indeterminate = false;\n\n if (childInstance.hasChildren) {\n childInstance.isExpanded = selected;\n childInstance.selectAllChildren(selected);\n }\n childInstance.notifyMultiselect?.();\n }\n });\n }\n\n private expandAllChildren(expanded: boolean) {\n const directChildren = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as any[];\n\n directChildren.forEach((child: any) => {\n const childInstance = child['__stencil_instance'];\n if (childInstance && childInstance.hasChildren) {\n childInstance.isExpanded = expanded;\n childInstance.expandAllChildren(expanded);\n }\n });\n }\n\n private updateParentStates() {\n let parent = this.el.parentElement;\n while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {\n const parentInstance = (parent as any)['__stencil_instance'];\n if (!parentInstance) {\n parent = parent.parentElement;\n continue;\n }\n\n const siblings = Array.from(parent.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION')\n .map(child => (child as any)['__stencil_instance'])\n .filter(instance => instance !== null);\n\n const selectedCount = siblings.filter(sibling => sibling.selected).length;\n const indeterminateCount = siblings.filter(sibling => sibling.indeterminate).length;\n const totalCount = siblings.length;\n\n if (selectedCount === totalCount && indeterminateCount === 0) {\n parentInstance.selected = true;\n parentInstance.indeterminate = false;\n } else if (selectedCount === 0 && indeterminateCount === 0) {\n parentInstance.selected = false;\n parentInstance.indeterminate = false;\n } else {\n parentInstance.selected = false;\n parentInstance.indeterminate = true;\n }\n\n parentInstance.notifyMultiselect?.();\n parent = parent.parentElement;\n }\n }\n\n private toggleExpansion() {\n this.isExpanded = !this.isExpanded;\n }\n\n private handleCheckboxClick = (event: Event) => {\n if (this.disabled || (this.isSearchActive && this.isSearchDisabled)) return;\n\n event.stopPropagation();\n\n let newSelectedState: boolean;\n\n if (this.indeterminate) {\n newSelectedState = true;\n } else {\n newSelectedState = !this.selected;\n }\n\n this.selected = newSelectedState;\n this.indeterminate = false;\n\n if (this.hasChildren) {\n this.isExpanded = newSelectedState;\n\n requestAnimationFrame(() => {\n this.selectAllChildren(newSelectedState);\n this.expandAllChildren(newSelectedState);\n });\n }\n\n this.updateParentStates();\n this.notifyMultiselect();\n }\n\n private handleHeaderClick = (event: Event) => {\n event.stopPropagation();\n if (!this.disabled && !(this.isSearchActive && this.isSearchDisabled)) {\n this.handleClick(event);\n }\n }\n\n private hasAnySelectedChildren(): boolean {\n const childOptions = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as HTMLElement[];\n\n return childOptions.some(child => {\n const hasSelected = child.hasAttribute('selected');\n const hasSelectedDescendants = this.checkForSelectedDescendants(child);\n\n return hasSelected || hasSelectedDescendants;\n });\n }\n\n private checkForSelectedDescendants(element: HTMLElement): boolean {\n const nestedOptions = Array.from(element.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as HTMLElement[];\n\n return nestedOptions.some(nestedChild => {\n const isSelected = nestedChild.hasAttribute('selected');\n const hasSelectedNested = this.checkForSelectedDescendants(nestedChild);\n\n return isSelected || hasSelectedNested;\n });\n }\n\n render() {\n let isFlatMultiselect = false;\n const parentMultiselect = this.el.closest('ifx-multiselect');\n if (parentMultiselect) {\n const allOptions = Array.from(parentMultiselect.querySelectorAll('ifx-multiselect-option'));\n isFlatMultiselect = allOptions.every(option => option.children.length === 0);\n }\n\n const basePadding = this.depth * 28 + 16;\n const additionalPadding = this.hasChildren ? 0 : 28;\n let totalPadding = basePadding + additionalPadding;\n\n const optionItemStyle = isFlatMultiselect ? undefined : { paddingLeft: `${totalPadding}px` };\n\n return (\n <Host>\n <div\n class={{\n 'option': true,\n 'option--has-children': this.hasChildren,\n 'option--expanded': this.isExpanded,\n 'option--disabled': this.disabled,\n 'option--selected': this.selected,\n }}\n role=\"option\"\n aria-expanded={this.hasChildren ? (this.isExpanded ? 'true' : 'false') : undefined}\n aria-selected={this.selected ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n data-level={this.depth}\n data-value={this.value}\n >\n <div\n class=\"option-item\"\n style={optionItemStyle}\n >\n <div\n class=\"chevron-wrapper\"\n tabIndex={this.hasChildren ? 0 : -1}\n role={this.hasChildren ? \"button\" : undefined}\n aria-label={this.hasChildren ? (this.isExpanded ? \"Collapse\" : \"Expand\") : undefined}\n onClick={(e) => { e.stopPropagation(); this.toggleExpansion(); }}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n this.toggleExpansion();\n }\n }}\n >\n {this.hasChildren && (\n <ifx-icon\n class={`chevron ${this.isExpanded ? 'chevron--expanded' : 'chevron--collapsed'}`}\n icon=\"chevron-right-16\"\n />\n )}\n </div>\n\n <div class=\"checkbox-wrapper\" onClick={(e) => e.stopPropagation()}>\n <ifx-checkbox\n size='s'\n checked={(this.isSearchActive && this.isSearchDisabled) ? false : (this.indeterminate ? false : this.selected)}\n indeterminate={(this.isSearchActive && this.isSearchDisabled) ? false : this.indeterminate}\n onClick={this.handleCheckboxClick}\n disabled={this.disabled || (this.isSearchActive && this.isSearchDisabled)}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n this.handleCheckboxClick(e);\n }\n }}\n />\n </div>\n\n <div\n class=\"option-label\"\n onClick={this.handleHeaderClick}\n tabIndex={-1}\n >\n <slot/>\n </div>\n </div>\n\n {this.isExpanded && <div class=\"option-children\"><slot name=\"children\"/></div>}\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as t,c as i,h as e,a as s,g as h}from"./p-b7a462e5.js";const n=".ifx-content-switcher{background-color:#FFFFFF;border:1px solid #BFBBBB;border-radius:9999px;height:36px;width:fit-content;box-sizing:border-box;display:flex;flex-direction:row;align-items:center}.ifx-content-switcher ::slotted(ifx-content-switcher-item){position:relative}.ifx-content-switcher ::slotted(ifx-content-switcher-item:first-child){left:-1px;margin-right:-1px}.ifx-content-switcher ::slotted(ifx-content-switcher-item:last-child){right:-1px;margin-left:-1px}.ifx-content-switcher ::slotted(.ifx-content-switcher-divider){width:1px;height:20px;background-color:#8D8786;margin:0px 1px;visibility:visible}.ifx-content-switcher ::slotted(.ifx-content-switcher-divider.hidden){visibility:hidden}";const r=n;const c=class{constructor(e){t(this,e);this.ifxChange=i(this,"ifxChange",7);this.activeIndex=-1;this.hoverIndex=-1;this.focusIndex=-1;this.dividers=Array();this.eventHandlers=new Map}componentWillLoad(){this.items=Array.from(this.el.children);this.initializeDividers();this.addEventListeners();this.ensureSingleSelectedItem()}disconnectedCallback(){this.removeEventListeners()}initializeDividers(){this.items.forEach(((t,i)=>{if(i<this.items.length-1){const i=document.createElement("div");i.classList.add("ifx-content-switcher-divider");t.after(i);this.dividers.push(i)}}))}addEventListeners(){this.items.forEach(((t,i)=>{const e={click:()=>this.selectItem(i),mouseenter:()=>this.handleHover(i,true),mouseleave:()=>this.handleHover(i,false),focus:()=>this.handleFocus(i,true),blur:()=>this.handleFocus(i,false)};Object.keys(e).forEach((i=>{t.addEventListener(i,e[i])}));this.eventHandlers.set(t,e)}))}removeEventListeners(){this.eventHandlers.forEach(((t,i)=>{Object.keys(t).forEach((e=>{i.removeEventListener(e,t[e])}))}));this.eventHandlers.clear()}ensureSingleSelectedItem(){this.items.forEach(((t,i)=>{const e=t.getAttribute("selected")==="true"||t.selected;if(e){if(this.activeIndex<0){this.selectItem(i)}else{t.removeAttribute("selected");t.selected=false}}}))}handleHover(t,i){this.hoverIndex=i?t:-1;this.updateDividersOfItem(t)}handleFocus(t,i){this.focusIndex=i?t:-1;this.updateDividersOfItem(t)}updateDividersOfItem(t){if(t<this.items.length-1){this.updateDividerVisibility(t)}if(t>0){this.updateDividerVisibility(t-1)}}updateDividerVisibility(t){const i=new Set([this.activeIndex,this.activeIndex-1,this.hoverIndex,this.hoverIndex-1,this.focusIndex,this.focusIndex-1]);this.setDividerVisibility(t,i.has(t))}setDividerVisibility(t,i){if(this.dividers[t]){this.dividers[t].classList.toggle("hidden",i)}}selectItem(t){if(t===this.activeIndex)return;const i=this.activeIndex;if(i>=0){this.items[i].removeAttribute("selected")}this.activeIndex=t;this.items[t].setAttribute("selected","true");this.ifxChange.emit({oldValue:this.getValueOfItem(i),newValue:this.getValueOfItem(t)});this.updateDividersOfItem(i);this.updateDividersOfItem(t)}getValueOfItem(t){if(this.items[t]==null)return t.toLocaleString();return this.items[t].getAttribute("value")||t.toLocaleString()}render(){return e(s,{key:"9b3bb93d639c01fa5e006228f44e28578c450e10"},e("div",{key:"eab613a4ba9055f73e96fd74e42fe3c0787418a8",class:"ifx-content-switcher",role:"group"},e("slot",{key:"0578016f80517baeb8f6d19db4661046c6c43eea"})))}get el(){return h(this)}};c.style=r;export{c as ifx_content_switcher};
2
+ //# sourceMappingURL=p-2006c7a0.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["contentSwitcherCss","IfxContentSwitcherStyle0","ContentSwitcher","constructor","hostRef","this","activeIndex","hoverIndex","focusIndex","dividers","Array","eventHandlers","Map","componentWillLoad","items","from","el","children","initializeDividers","addEventListeners","ensureSingleSelectedItem","disconnectedCallback","removeEventListeners","forEach","item","index","length","divider","document","createElement","classList","add","after","push","handlers","click","selectItem","mouseenter","handleHover","mouseleave","focus","handleFocus","blur","Object","keys","event","addEventListener","set","removeEventListener","clear","isSelected","getAttribute","selected","removeAttribute","isActive","updateDividersOfItem","itemIndex","updateDividerVisibility","dividerIndex","hiddenDividers","Set","setDividerVisibility","has","hidden","toggle","oldIndex","setAttribute","ifxChange","emit","oldValue","getValueOfItem","newValue","toLocaleString","render","h","Host","key","class","role"],"sources":["src/components/content-switcher/content-switcher.scss?tag=ifx-content-switcher&encapsulation=shadow","src/components/content-switcher/content-switcher.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n.ifx-content-switcher {\n background-color: tokens.$ifxColorBaseWhite;\n border: 1px solid tokens.$ifxColorEngineering300;\n border-radius: tokens.$ifxBorderRadiusRound;\n height: tokens.$ifxSize450;\n width: fit-content;\n box-sizing: border-box;\n display: flex;\n flex-direction: row;\n align-items: center;\n\n & ::slotted(ifx-content-switcher-item) {\n position: relative;\n // top: -1px;\n }\n\n & ::slotted(ifx-content-switcher-item:first-child) {\n left: -1px;\n margin-right: -1px;\n }\n\n & ::slotted(ifx-content-switcher-item:last-child) {\n right: -1px;\n margin-left: -1px;\n }\n\n // Dividers\n & ::slotted(.ifx-content-switcher-divider) {\n width: tokens.$ifxSize12;\n height: tokens.$ifxSize250;\n background-color: tokens.$ifxColorEngineering400;\n margin: 0px 1px;\n visibility: visible;\n }\n\n & ::slotted(.ifx-content-switcher-divider.hidden) {\n visibility: hidden;\n }\n}","import { Component, h, Element, Event, EventEmitter, Host, State } from '@stencil/core';\n\nexport type ChangeEvent = { oldValue: string; newValue: string };\n\ntype ContentSwitcherItem = Element & {\n selected: boolean;\n};\n\n@Component({\n tag: 'ifx-content-switcher',\n styleUrl: './content-switcher.scss',\n shadow: true,\n})\nexport class ContentSwitcher {\n @Element() el: HTMLElement;\n\n @State() items: Element[];\n @State() activeIndex = -1;\n @State() hoverIndex: number = -1;\n @State() focusIndex: number = -1;\n\n @State() dividers: Element[] = Array();\n\n @Event() ifxChange: EventEmitter<ChangeEvent>;\n\n private eventHandlers: Map<Element, { [key: string]: EventListener }> = new Map();\n\n componentWillLoad() {\n this.items = Array.from(this.el.children);\n this.initializeDividers();\n this.addEventListeners();\n this.ensureSingleSelectedItem();\n }\n\n disconnectedCallback() {\n this.removeEventListeners();\n }\n\n /**\n * Initialize the dividers between items.\n */\n initializeDividers() {\n this.items.forEach((item, index) => {\n if (index < this.items.length - 1) {\n const divider = document.createElement('div');\n divider.classList.add('ifx-content-switcher-divider');\n item.after(divider);\n this.dividers.push(divider);\n }\n });\n }\n\n /**\n * Add event listeners for each item.\n */\n addEventListeners() {\n this.items.forEach((item, index) => {\n const handlers = {\n click: () => this.selectItem(index),\n mouseenter: () => this.handleHover(index, true),\n mouseleave: () => this.handleHover(index, false),\n focus: () => this.handleFocus(index, true),\n blur: () => this.handleFocus(index, false),\n };\n\n Object.keys(handlers).forEach(event => {\n item.addEventListener(event, handlers[event]);\n });\n\n this.eventHandlers.set(item, handlers);\n });\n }\n\n /**\n * Remove all event listeners.\n */\n removeEventListeners() {\n this.eventHandlers.forEach((handlers, item) => {\n Object.keys(handlers).forEach(event => {\n item.removeEventListener(event, handlers[event]);\n });\n });\n this.eventHandlers.clear();\n }\n\n ensureSingleSelectedItem() {\n this.items.forEach((item, index) => {\n const isSelected = (item.getAttribute('selected') === 'true') || (item as ContentSwitcherItem).selected;\n if (isSelected) {\n if (this.activeIndex < 0) {\n this.selectItem(index);\n } else {\n item.removeAttribute('selected');\n (item as ContentSwitcherItem).selected = false;\n }\n }\n });\n }\n\n /**\n * Handle hover events on an item.\n * @param index - Index of the item.\n * @param isActive - Whether the item is hovered.\n */\n handleHover(index: number, isActive: boolean) {\n this.hoverIndex = isActive ? index : -1;\n this.updateDividersOfItem(index);\n }\n\n /**\n * Handle hover events on an item.\n * @param index - Index of the item.\n * @param isActive - Whether the item is focused.\n */\n handleFocus(index: number, isActive: boolean) {\n this.focusIndex = isActive ? index : -1;\n this.updateDividersOfItem(index);\n }\n\n /**\n * Update visibility of dividers adjacent to a specific item.\n * @param itemIndex - Index of the item.\n */\n updateDividersOfItem(itemIndex: number) {\n if (itemIndex < this.items.length - 1) {\n this.updateDividerVisibility(itemIndex);\n }\n if (itemIndex > 0) {\n this.updateDividerVisibility(itemIndex - 1);\n }\n }\n\n /**\n * Update visibility of a specific divider.\n * @param dividerIndex - Index of the divider.\n */\n updateDividerVisibility(dividerIndex: number) {\n const hiddenDividers = new Set([this.activeIndex, this.activeIndex - 1, this.hoverIndex, this.hoverIndex - 1, this.focusIndex, this.focusIndex - 1]);\n this.setDividerVisibility(dividerIndex, hiddenDividers.has(dividerIndex));\n }\n\n /**\n * Set the visibility of a specific divider.\n * @param dividerIndex - Index of the divider.\n * @param hidden - Whether the divider should be hidden.\n */\n setDividerVisibility(dividerIndex: number, hidden: boolean) {\n if (this.dividers[dividerIndex]) {\n this.dividers[dividerIndex].classList.toggle('hidden', hidden);\n }\n }\n\n /**\n * Select a specific item.\n * @param itemIndex - Index of the item to be selected.\n */\n selectItem(itemIndex: number) {\n if (itemIndex === this.activeIndex) return;\n const oldIndex = this.activeIndex;\n if (oldIndex >= 0) {\n this.items[oldIndex].removeAttribute('selected');\n }\n\n this.activeIndex = itemIndex;\n this.items[itemIndex].setAttribute('selected', 'true');\n\n this.ifxChange.emit({ oldValue: this.getValueOfItem(oldIndex), newValue: this.getValueOfItem(itemIndex) });\n this.updateDividersOfItem(oldIndex);\n this.updateDividersOfItem(itemIndex);\n }\n\n /**\n * Get the value property of the item at a specific index.\n * Falls back to the index if no value is set.\n * \n * @param index - Index of the item. \n * @returns The value of the item.\n */\n getValueOfItem(index: number): string {\n if (this.items[index] == null) return index.toLocaleString();\n return this.items[index].getAttribute('value') || index.toLocaleString();\n }\n\n render() {\n return (\n <Host>\n <div class=\"ifx-content-switcher\" role=\"group\">\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,h as a,g as r}from"./p-b7a462e5.js";const t=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{display:flex}.breadcrumb{list-style:none;padding:0px;margin:0px;display:flex;flex-direction:row;font-family:var(--ifx-font-family);font-size:0.875rem;align-items:flex-start}';const o=t;const n=class{constructor(a){e(this,a)}componentDidLoad(){const e=this.el.shadowRoot.firstChild;this.validateBreadcrumbItemStructure(e)}validateBreadcrumbItemStructure(e){if(!e){console.error("element not found");return}const a=e.querySelector("slot");if(a){const e=a.assignedNodes();for(let a=0;a<e.length;a++){const r=e[a];if(r.nodeName==="IFX-BREADCRUMB-ITEM"){const e=r;const a=e.querySelector("ifx-breadcrumb-item-label");const t=e.querySelector("ifx-dropdown-menu");if(a.hasAttribute("href")&&t){throw new Error("ifx-breadcrumb-item cannot have both a href and a dropdown menu.")}}}}}render(){return a("nav",{key:"3d01af951d4a6a396545eb9cf26454cbe2b31ed0","aria-label":"Page navigation breadcrumb"},a("ol",{key:"95ae08a0de7099ecd7c3aa963c1bf9952918ecda",class:"breadcrumb"},a("slot",{key:"e9fed255fa08b28c8974498d329df69b1e92edf5"})))}get el(){return r(this)}};n.style=o;export{n as ifx_breadcrumb};
2
+ //# sourceMappingURL=p-292cff35.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["breadcrumbCss","IfxBreadcrumbStyle0","Breadcrumb","componentDidLoad","element","this","el","shadowRoot","firstChild","validateBreadcrumbItemStructure","console","error","slot","querySelector","assignedNodes","i","length","node","nodeName","breadcrumbItem","breadcrumbItemLabel","breadcrumbDropdown","hasAttribute","Error","render","h","key","class"],"sources":["src/components/breadcrumb/breadcrumb.scss?tag=ifx-breadcrumb&encapsulation=shadow","src/components/breadcrumb/breadcrumb.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n:host {\n display: flex;\n}\n\n.breadcrumb {\n list-style: none;\n padding: 0px;\n margin: 0px;\n display: flex;\n flex-direction: row;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n font-size: tokens.$ifxFontSizeS;\n align-items: flex-start;\n //gap: tokens.$ifxSpace200; //this is where the gap comes from\n\n}\n\n// .separator {\n// color: tokens.$ifxColorEngineering300;\n// margin: 0 16px;\n// }","import { Component, h, Element } from '@stencil/core';\n\n@Component({\n tag: 'ifx-breadcrumb',\n styleUrl: 'breadcrumb.scss',\n shadow: true\n})\nexport class Breadcrumb {\n @Element() el;\n\n componentDidLoad() {\n const element = this.el.shadowRoot.firstChild;\n this.validateBreadcrumbItemStructure(element);\n }\n\n private validateBreadcrumbItemStructure(element: HTMLElement) {\n if (!element) {\n console.error('element not found');\n return;\n }\n \n const slot = element.querySelector('slot');\n if(slot) { \n const assignedNodes = slot.assignedNodes();\n \n for (let i = 0; i < assignedNodes.length; i++) {\n const node = assignedNodes[i];\n if (node.nodeName === 'IFX-BREADCRUMB-ITEM') {\n const breadcrumbItem = node as HTMLIfxBreadcrumbItemElement;\n const breadcrumbItemLabel = breadcrumbItem.querySelector('ifx-breadcrumb-item-label');\n const breadcrumbDropdown = breadcrumbItem.querySelector('ifx-dropdown-menu');\n if (breadcrumbItemLabel.hasAttribute('href') && breadcrumbDropdown) {\n throw new Error('ifx-breadcrumb-item cannot have both a href and a dropdown menu.');\n }\n }\n }\n }\n }\n\n render() {\n return (\n <nav aria-label=\"Page navigation breadcrumb\">\n <ol class=\"breadcrumb\">\n <slot />\n </ol>\n </nav>\n );\n }\n}\n"],"mappings":"kDAAA,MAAMA,EAAgB,mPACtB,MAAAC,EAAeD,E,MCMFE,EAAU,M,yBAGrB,gBAAAC,GACE,MAAMC,EAAUC,KAAKC,GAAGC,WAAWC,WACnCH,KAAKI,gCAAgCL,E,CAG/B,+BAAAK,CAAgCL,GACtC,IAAKA,EAAS,CACZM,QAAQC,MAAM,qBACd,M,CAGF,MAAMC,EAAOR,EAAQS,cAAc,QACnC,GAAGD,EAAM,CACP,MAAME,EAAgBF,EAAKE,gBAE3B,IAAK,IAAIC,EAAI,EAAGA,EAAID,EAAcE,OAAQD,IAAK,CAC7C,MAAME,EAAOH,EAAcC,GAC3B,GAAIE,EAAKC,WAAa,sBAAuB,CAC3C,MAAMC,EAAiBF,EACvB,MAAMG,EAAsBD,EAAeN,cAAc,6BACzD,MAAMQ,EAAqBF,EAAeN,cAAc,qBACxD,GAAIO,EAAoBE,aAAa,SAAWD,EAAoB,CAClE,MAAM,IAAIE,MAAM,mE,KAO1B,MAAAC,GACE,OACEC,EAAA,OAAAC,IAAA,wDAAgB,8BACdD,EAAA,MAAAC,IAAA,2CAAIC,MAAM,cACRF,EAAA,QAAAC,IAAA,8C","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,c as t,h as o,a as n,g as i}from"./p-b7a462e5.js";function a(e,t,o,n=20,i=0){const s=[];if(i>=n){return s}const r=e=>{const s=e.assignedNodes().filter((e=>e.nodeType===1));if(s.length>0){const e=s[0].parentElement;return a(e,t,o,n,i+1)}return[]};const d=Array.from(e.children||[]);for(const e of d){if(t(e)){continue}if(o(e)){s.push(e)}if(e.shadowRoot!=null){s.push(...a(e.shadowRoot,t,o,n,i+1))}else if(e.tagName==="SLOT"){s.push(...r(e))}else{s.push(...a(e,t,o,n,i+1))}}return s}function s(e){return e.hasAttribute("hidden")||e.hasAttribute("aria-hidden")&&e.getAttribute("aria-hidden")!=="false"||e.style.display===`none`||e.style.opacity===`0`||e.style.visibility===`hidden`||e.style.visibility===`collapse`}function r(e){return e.hasAttribute("disabled")||e.hasAttribute("aria-disabled")&&e.getAttribute("aria-disabled")!=="false"}function d(e){if(e.getAttribute("tabindex")==="-1"||s(e)||r(e)){return false}return e.hasAttribute("tabindex")||(e instanceof HTMLAnchorElement||e instanceof HTMLAreaElement)&&e.hasAttribute("href")||e instanceof HTMLButtonElement||e instanceof HTMLInputElement||e instanceof HTMLTextAreaElement||e instanceof HTMLSelectElement||e instanceof HTMLIFrameElement}function c(e,t,o){const n=e.animate(t,Object.assign(Object.assign({},o),{fill:"both"}));n.addEventListener("finish",(()=>{n.commitStyles();n.cancel()}));return n}const l={easing:"cubic-bezier(0.390, 0.575, 0.565, 1.000)"};const f={fadeIn:[Object.assign(Object.assign({offset:0},l),{opacity:0}),Object.assign(Object.assign({offset:1},l),{opacity:1})],fadeOut:[Object.assign(Object.assign({offset:0},l),{opacity:1}),Object.assign(Object.assign({offset:1},l),{opacity:0})]};const h=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{display:block}.modal-container{display:none;justify-content:center;align-items:center;position:fixed;top:0;left:0;width:100%;height:100%;z-index:1060;overflow-y:auto;font-family:var(--ifx-font-family)}.modal-container.open{display:flex}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#1D1D1D;opacity:0.5;z-index:0}.modal-content-container{position:absolute;display:flex;justify-content:center;width:90%;min-height:218px;background-color:#fff;border-radius:0;box-shadow:0 2px 10px rgba(0, 0, 0, 0.1);box-sizing:border-box;align-items:stretch}.modal-content-container.no-overflow{overflow:hidden}.modal-content-container.no-overflow .modal-body{overflow-y:auto}@media screen and (min-width: 768px){.modal-content-container{width:540px;min-height:132px}.modal-content-container.m,.modal-content-container.l,.modal-content-container.s{width:90%}}@media screen and (min-width: 1024px){.modal-content-container.s{width:47vw}.modal-content-container.m{width:63vw}.modal-content-container.l{width:80%}}.modal-content{display:flex;flex-direction:column;width:100%;max-height:90vh}.modal-icon-container{display:flex;align-items:center;justify-content:center;width:32px;background-color:#0A8276;align-self:stretch}.modal-icon-container.danger{background-color:#CD002F}.modal-icon-container ifx-icon{color:#FFFFFF}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;min-height:76px;max-height:105px;box-sizing:border-box;border-radius:1px 1px 0px 0px;border-bottom:1px solid #EEEDED}.modal-caption{max-height:56px;display:-webkit-box;overflow:hidden;white-space:pre-wrap;word-wrap:break-word;-webkit-line-clamp:2;-webkit-box-orient:vertical}.modal-header h2{margin:0;font-weight:600;font-size:1.25rem;line-height:28px}.modal-header button{background:none;border:none;font-size:1.5em;padding:0;cursor:pointer}.modal-close-button{align-self:flex-start;margin-right:-8px}.modal-body{padding:16px 24px;min-height:56px;box-sizing:border-box;flex:1}.modal-footer.buttons-present ::slotted(*){display:flex;justify-content:flex-end;gap:16px;padding:16px 24px 32px 16px}.modal-border{display:flex;align-items:center;justify-content:center;width:100%;font-size:1.5em;flex-grow:1}.modal-border.primary{background-color:#0A8276}.modal-border.secondary{background-color:#575352}.modal-border.danger{background-color:#CD002F}.modal-border.success{background-color:#4CA460}.modal-border.warning{background-color:#E16B25}.modal-border.orange{background-color:#E16B25}.modal-border.ocean{background-color:#0A8276}.modal-border.grey{background-color:#575352}.modal-border.grey-200{background-color:#EEEDED}.modal-border.red{background-color:#CD002F}.modal-border.green{background-color:#4CA460}.modal-border.berry{background-color:#9C216E}';const b=h;const u=class{constructor(o){e(this,o);this.ifxOpen=t(this,"ifxOpen",7);this.ifxClose=t(this,"ifxClose",7);this.opened=false;this.showModal=this.opened||false;this.caption="Modal Title";this.closeOnOverlayClick=true;this.variant="default";this.size="s";this.alertIcon="";this.okButtonLabel="OK";this.cancelButtonLabel="Cancel";this.slotButtonsPresent=false;this.showCloseButton=true;this.focusableElements=[];this.handleTopFocus=()=>{this.attemptFocus(this.getLastFocusableElement())};this.handleBottomFocus=()=>{this.attemptFocus(this.getFirstFocusableElement())};this.handleKeypress=e=>{if(!this.showModal){return}if(e.key==="Escape"){this.doBeforeClose("ESCAPE_KEY")}}}componentDidLoad(){this.focusableElements=a(this.hostElement.shadowRoot,(e=>s(e)||e.matches("[data-focus-trap-edge]")),d)}componentWillRender(){if(this.showModal){this.handleComponentOverflow()}}handleComponentOverflow(){const e=this.hostElement.shadowRoot.querySelector(".modal-content-container");if(this.showModal&&this.isModalContentContainerHeightReachedViewport()){e.classList.add("no-overflow")}else if(e===null||e===void 0?void 0:e.classList.contains("no-overflow")){e===null||e===void 0?void 0:e.classList.remove("no-overflow")}}getFirstFocusableElement(){return this.focusableElements[0]}getLastFocusableElement(){return this.focusableElements[this.focusableElements.length-1]}attemptFocus(e){if(e==null){setTimeout((()=>{this.closeButton.focus()}));return}setTimeout((()=>{e.focus()}),0)}open(){this.showModal=true;try{const e=c(this.modalContainer,f.fadeIn,{duration:200});e.addEventListener("finish",(()=>{setTimeout((()=>{var e,t;(e=this.getLastFocusableElement())===null||e===void 0?void 0:e.focus();(t=this.getLastFocusableElement())===null||t===void 0?void 0:t.blur()}),0);this.ifxOpen.emit()}));this.hostElement.addEventListener("keydown",this.handleKeypress)}catch(e){this.ifxOpen.emit()}}close(){try{const e=c(this.modalContainer,f.fadeOut,{duration:200});e.addEventListener("finish",(()=>{this.showModal=false;this.ifxClose.emit()}));this.hostElement.removeEventListener("keydown",this.handleKeypress)}catch(e){this.showModal=false;this.ifxClose.emit()}}doBeforeClose(e){const t=[];t.push(e);const o=t.some((e=>e.defaultPrevented));if(!o){this.opened=false}}openedChanged(e){if(e===true){this.open()}else{this.close()}}handleOverlayClick(){if(this.closeOnOverlayClick){this.doBeforeClose("BACKDROP")}}handleContentUpdate(e){const t=e.target;const o=t.assignedNodes();if(o.length>0){o.forEach((e=>{if(e.observer){e.observer.disconnect();delete e.observer}const t=new MutationObserver(((e,t)=>{for(let t of e){if(t.type==="childList"){if(this.showModal){this.handleComponentOverflow()}}}}));t.observe(e,{attributes:true,childList:true,subtree:true});e.observer=t}))}}handleButtonsSlotChange(e){var t;if(((t=e.currentTarget.assignedElements()[0])===null||t===void 0?void 0:t.childElementCount)>0){this.slotButtonsPresent=true}else{this.slotButtonsPresent=false}}isModalContentContainerHeightReachedViewport(){return new Promise((e=>{setTimeout((()=>{const t=this.hostElement.shadowRoot.querySelector(".modal-content");const o=t.offsetHeight;const n=window.innerHeight;e(o>=n*.9)}),100)}))}render(){const e=this.variant!=="default";return o(n,{key:"fb6bc415247be8eec46bebe51f26c7bc71a5b010"},o("div",{key:"cfabe9bf352ca821f99714603a86b2cc25874af1",ref:e=>this.modalContainer=e,class:`modal-container ${this.showModal?"open":""}`},o("div",{key:"6d22eecd23e6a6017e30afa0cb0372c6518ff9ec",class:"modal-overlay",onClick:()=>this.handleOverlayClick()}),o("div",{key:"8ee13636de9b591bf7b15aa033ef158fcd70ab57","data-focus-trap-edge":true,onFocus:this.handleTopFocus,tabindex:"0"}),o("div",{key:"62a1b4e9c98f6e51936bc9af14464038b0c16639",class:`modal-content-container ${this.size}`,role:"dialog","aria-modal":"true","aria-label":this.caption},e?o("div",{class:`modal-icon-container ${this.variant==="alert-brand"?"":"danger"}`},this.alertIcon?o("ifx-icon",{icon:this.alertIcon}):null):null,o("div",{key:"699217ea2e1d414ad68939334cd078aa711fe472",class:"modal-content"},o("div",{key:"ab02f75a7b5c2befb1509731b289c4e76f7e3f3e",class:"modal-header"},o("h2",{key:"9b1adec6e486f5f03bd369709669c22bbddf3922",class:"modal-caption"},this.caption),this.showCloseButton&&o("ifx-icon-button",{key:"8edae1ae2e3ddf2517d52682fcc1ae3247b5e1e5",class:"modal-close-button",ref:e=>this.closeButton=e,icon:"cross-16",variant:"tertiary",onClick:()=>this.doBeforeClose("CLOSE_BUTTON")})),o("div",{key:"62f9c425009b5498b5301a7fc6c5490d7401086c",class:"modal-body"},o("slot",{key:"fb1494da685e6b0986ef660a9e94dfb8b43a7a48",name:"content",onSlotchange:e=>this.handleContentUpdate(e)})),o("div",{key:"3b427fe2debc1e2bea474982dfff079afdd6dfcc",class:`modal-footer ${this.slotButtonsPresent?"buttons-present":""}`},o("slot",{key:"b0874a1766cfde0f0ccb5f1ebbec6e753dfeb2f0",name:"buttons",onSlotchange:e=>this.handleButtonsSlotChange(e)})))),o("div",{key:"8b376a945b278faf81f9f3d1117cd01e3d11c8b5","data-focus-trap-edge":true,onFocus:this.handleBottomFocus,tabindex:"0"})))}get hostElement(){return i(this)}static get watchers(){return{opened:["openedChanged"]}}};u.style=b;export{u as ifx_modal};
2
+ //# sourceMappingURL=p-2d89c5e0.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["queryShadowRoot","root","skipNode","isMatch","maxDepth","depth","matches","traverseSlot","$slot","assignedNodes","filter","node","nodeType","length","$slotParent","parentElement","children","Array","from","$child","push","shadowRoot","tagName","isHidden","$elem","hasAttribute","getAttribute","style","display","opacity","visibility","isDisabled","isFocusable","HTMLAnchorElement","HTMLAreaElement","HTMLButtonElement","HTMLInputElement","HTMLTextAreaElement","HTMLSelectElement","HTMLIFrameElement","animationTo","element","keyframes","options","animated","animate","Object","assign","fill","addEventListener","commitStyles","cancel","keyframeDefaults","easing","KEYFRAMES","fadeIn","offset","fadeOut","modalCss","IfxModalStyle0","IfxModal","constructor","hostRef","this","opened","showModal","caption","closeOnOverlayClick","variant","size","alertIcon","okButtonLabel","cancelButtonLabel","slotButtonsPresent","showCloseButton","focusableElements","handleTopFocus","attemptFocus","getLastFocusableElement","handleBottomFocus","getFirstFocusableElement","handleKeypress","event","key","doBeforeClose","componentDidLoad","hostElement","el","componentWillRender","handleComponentOverflow","modalContentContainer","querySelector","isModalContentContainerHeightReachedViewport","classList","add","contains","remove","setTimeout","closeButton","focus","open","anim","modalContainer","duration","_a","_b","blur","ifxOpen","emit","err","close","ifxClose","removeEventListener","trigger","triggers","prevented","some","defaultPrevented","openedChanged","newValue","handleOverlayClick","handleContentUpdate","e","slotElement","target","nodes","forEach","observer","disconnect","MutationObserver","mutationsList","_","mutation","type","observe","attributes","childList","subtree","handleButtonsSlotChange","currentTarget","assignedElements","childElementCount","Promise","resolve","modalContent","modalContentHeight","offsetHeight","viewportHeight","window","innerHeight","render","isAlertVariant","h","Host","ref","class","onClick","onFocus","tabindex","role","icon","name","onSlotchange"],"sources":["src/global/utils/focus-trap.ts","src/global/utils/animation.ts","src/components/modal/modal.scss?tag=ifx-modal&encapsulation=shadow","src/components/modal/modal.tsx"],"sourcesContent":["/**\n * Copy/pasted from https://github.com/andreasbm/focus-trap\n */\n\n/**\n * Traverses the slots of the open shadowroots and returns all children matching the query.\n * We need to traverse each child-depth one at a time because if an element should be skipped\n * (for example because it is hidden) we need to skip all of it's children. If we use querySelectorAll(\"*\")\n * the information of whether the children is within a hidden parent is lost.\n * @param {ShadowRoot | HTMLElement} root\n * @param skipNode\n * @param isMatch\n * @param {number} maxDepth\n * @param {number} depth\n * @returns {HTMLElement[]}\n */\nexport function queryShadowRoot(\n root: ShadowRoot | HTMLElement,\n skipNode: ($elem: HTMLElement) => boolean,\n isMatch: ($elem: HTMLElement) => boolean,\n maxDepth: number = 20,\n depth: number = 0\n): HTMLElement[] {\n const matches: HTMLElement[] = [];\n\n // If the depth is above the max depth, abort the searching here.\n if (depth >= maxDepth) {\n return matches;\n }\n\n // Traverses a slot element\n const traverseSlot = ($slot: HTMLSlotElement) => {\n // Only check nodes that are of the type Node.ELEMENT_NODE\n // Read more here https://developer.mozilla.org/en-US/docs/Web/API/Node/nodeType\n const assignedNodes = $slot\n .assignedNodes()\n .filter((node) => node.nodeType === 1);\n if (assignedNodes.length > 0) {\n const $slotParent = assignedNodes[0].parentElement!;\n return queryShadowRoot(\n $slotParent,\n skipNode,\n isMatch,\n maxDepth,\n depth + 1\n );\n }\n\n return [];\n };\n\n // Go through each child and continue the traversing if necessary\n // Even though the typing says that children can't be undefined, Edge 15 sometimes gives an undefined value.\n // Therefore we fallback to an empty array if it is undefined.\n const children = Array.from(root.children || []) as HTMLElement[];\n for (const $child of children) {\n // Check if the element and its descendants should be skipped\n if (skipNode($child)) {\n // console.log('-- SKIP', $child);\n continue;\n }\n\n // console.log('$child', $child);\n\n // If the element matches we always add it\n if (isMatch($child)) {\n matches.push($child);\n }\n\n if ($child.shadowRoot != null) {\n // If the element has a shadow root we need to traverse it\n matches.push(\n ...queryShadowRoot(\n $child.shadowRoot,\n skipNode,\n isMatch,\n maxDepth,\n depth + 1\n )\n );\n } else if ($child.tagName === 'SLOT') {\n // If the child is a slot we need to traverse each assigned node\n matches.push(...traverseSlot($child as HTMLSlotElement));\n } else {\n // Traverse the children of the element\n matches.push(\n ...queryShadowRoot($child, skipNode, isMatch, maxDepth, depth + 1)\n );\n }\n }\n\n return matches;\n}\n\n/**\n * Returns whether the element is hidden.\n * @param $elem\n */\nexport function isHidden($elem: HTMLElement): boolean {\n return (\n $elem.hasAttribute('hidden') ||\n ($elem.hasAttribute('aria-hidden') &&\n $elem.getAttribute('aria-hidden') !== 'false') ||\n // A quick and dirty way to check whether the element is hidden.\n // For a more fine-grained check we could use \"window.getComputedStyle\" but we don't because of bad performance.\n // If the element has visibility set to \"hidden\" or \"collapse\", display set to \"none\" or opacity set to \"0\" through CSS\n // we won't be able to catch it here. We accept it due to the huge performance benefits.\n $elem.style.display === `none` ||\n $elem.style.opacity === `0` ||\n $elem.style.visibility === `hidden` ||\n $elem.style.visibility === `collapse`\n );\n\n // If offsetParent is null we can assume that the element is hidden\n // https://stackoverflow.com/questions/306305/what-would-make-offsetparent-null\n // || $elem.offsetParent == null;\n}\n\n/**\n * Returns whether the element is disabled.\n * @param $elem\n */\nexport function isDisabled($elem: HTMLElement): boolean {\n return (\n $elem.hasAttribute('disabled') ||\n ($elem.hasAttribute('aria-disabled') &&\n $elem.getAttribute('aria-disabled') !== 'false')\n );\n}\n\n/**\n * Determines whether an element is focusable.\n * Read more here: https://stackoverflow.com/questions/1599660/which-html-elements-can-receive-focus/1600194#1600194\n * Or here: https://stackoverflow.com/questions/18261595/how-to-check-if-a-dom-element-is-focusable\n * @param $elem\n */\nexport function isFocusable($elem: HTMLElement): boolean {\n // Discard elements that are removed from the tab order.\n if (\n $elem.getAttribute('tabindex') === '-1' ||\n isHidden($elem) ||\n isDisabled($elem)\n ) {\n return false;\n }\n\n return (\n // At this point we know that the element can have focus (eg. won't be -1) if the tabindex attribute exists\n $elem.hasAttribute('tabindex') ||\n // Anchor tags or area tags with a href set\n (($elem instanceof HTMLAnchorElement || $elem instanceof HTMLAreaElement) &&\n $elem.hasAttribute('href')) ||\n // Form elements which are not disabled\n $elem instanceof HTMLButtonElement ||\n $elem instanceof HTMLInputElement ||\n $elem instanceof HTMLTextAreaElement ||\n $elem instanceof HTMLSelectElement ||\n // IFrames\n $elem instanceof HTMLIFrameElement\n );\n}","export function animationTo(\n element: HTMLElement,\n keyframes: Keyframe | Keyframe[],\n options?: KeyframeAnimationOptions\n) {\n const animated = element.animate(keyframes, { ...options, fill: 'both' });\n animated.addEventListener('finish', () => {\n // @ts-ignore\n animated.commitStyles();\n animated.cancel();\n });\n\n return animated;\n}\n\nconst keyframeDefaults = {\n easing: 'cubic-bezier(0.390, 0.575, 0.565, 1.000)',\n};\n\nexport const KEYFRAMES = {\n fadeIn: [\n {\n offset: 0,\n ...keyframeDefaults,\n opacity: 0,\n },\n {\n offset: 1,\n ...keyframeDefaults,\n opacity: 1,\n },\n ],\n fadeOut: [\n {\n offset: 0,\n ...keyframeDefaults,\n opacity: 1,\n },\n {\n offset: 1,\n ...keyframeDefaults,\n opacity: 0,\n },\n ],\n};","@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n:host {\n display: block;\n}\n\n.modal-container {\n display: none;\n justify-content: center;\n align-items: center;\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 1060;\n overflow-y: auto;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n\n}\n\n.modal-container.open {\n display: flex;\n}\n\n.modal-overlay {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: tokens.$ifxColorBaseBlack;\n opacity: 0.5;\n z-index: 0;\n}\n\n.modal-content-container {\n position: absolute;\n display: flex;\n justify-content: center;\n width: 90%;\n min-height: 218px;\n background-color: #fff;\n border-radius: tokens.$ifxBorderRadiusNone;\n box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);\n \n //overflow: hidden;\n\n box-sizing: border-box;\n align-items: stretch;\n}\n\n.modal-content-container {\n &.no-overflow { \n overflow: hidden;\n & .modal-body { \n overflow-y: auto;\n }\n }\n}\n\n/* Add desktop size here */\n@media screen and (min-width: 768px) {\n .modal-content-container {\n width: 540px;\n min-height: 132px;\n\n &.m,\n &.l,\n &.s {\n width: 90%;\n }\n }\n}\n\n@media screen and (min-width: 1024px) {\n .modal-content-container {\n\n &.s {\n width: 47vw;\n }\n\n &.m {\n width: 63vw;\n }\n\n &.l {\n width: 80%;\n }\n }\n}\n\n.modal-content {\n display: flex;\n flex-direction: column;\n width: 100%;\n max-height: 90vh;\n}\n\n.modal-icon-container {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 32px;\n background-color: tokens.$ifxColorOcean500;\n align-self: stretch;\n\n &.danger {\n background-color: tokens.$ifxColorRed500;\n }\n\n & ifx-icon {\n color: tokens.$ifxColorBaseWhite;\n }\n}\n\n.modal-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 24px;\n min-height: 76px;\n max-height: 105px;\n box-sizing: border-box;\n border-radius: 1px 1px 0px 0px;\n border-bottom: 1px solid tokens.$ifxColorEngineering200;\n}\n\n.modal-caption {\n max-height: 56px;\n display: -webkit-box;\n overflow: hidden;\n white-space: pre-wrap;\n word-wrap: break-word;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical; \n}\n\n.modal-header h2 {\n margin: 0;\n font-weight: tokens.$ifxFontWeightSemibold;\n font-size: tokens.$ifxFontSizeXl;\n line-height: 28px;\n}\n\n.modal-header button {\n background: none;\n border: none;\n font-size: 1.5em;\n padding: 0;\n cursor: pointer;\n}\n\n.modal-close-button {\n align-self: flex-start;\n margin-right: -8px;\n}\n\n.modal-body {\n padding: 16px 24px;\n min-height: 56px;\n box-sizing: border-box;\n flex: 1;\n \n //overflow-y: auto;\n}\n\n.modal-footer.buttons-present ::slotted(*){\n display: flex;\n justify-content: flex-end;\n gap: 16px;\n padding: 16px 24px 32px 16px\n}\n\n.modal-border {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n font-size: 1.5em;\n flex-grow: 1;\n\n &.primary {\n background-color: tokens.$ifxColorOcean500;\n }\n\n &.secondary {\n background-color: tokens.$ifxColorEngineering500;\n }\n\n &.danger {\n background-color: tokens.$ifxColorRed500;\n }\n\n &.success {\n background-color: tokens.$ifxColorGreen500;\n }\n\n &.warning {\n background-color: tokens.$ifxColorOrange500;\n }\n\n &.orange {\n background-color: tokens.$ifxColorOrange500;\n }\n\n &.ocean {\n background-color: tokens.$ifxColorOcean500;\n }\n\n &.grey {\n background-color: tokens.$ifxColorEngineering500;\n }\n\n &.grey-200 {\n background-color: tokens.$ifxColorEngineering200;\n }\n\n &.red {\n background-color: tokens.$ifxColorRed500;\n }\n\n &.green {\n background-color: tokens.$ifxColorGreen500;\n }\n\n &.berry {\n background-color: tokens.$ifxColorBerry500;\n }\n}","import { Component, Prop, Element, State, Event, Host, EventEmitter, h, Watch } from '@stencil/core';\nimport { queryShadowRoot, isHidden, isFocusable } from '../../global/utils/focus-trap';\nimport { animationTo, KEYFRAMES } from '../../global/utils/animation';\n \n\ntype CloseEventTrigger = 'CLOSE_BUTTON' | 'ESCAPE_KEY' | 'BACKDROP';\n\nexport interface BeforeCloseEventDetail {\n trigger: CloseEventTrigger;\n}\n@Component({\n tag: 'ifx-modal',\n styleUrl: 'modal.scss',\n shadow: true\n})\nexport class IfxModal {\n @Prop({ reflect: true, mutable: true }) opened?: boolean = false;\n @State() showModal: boolean = this.opened || false;\n\n @Prop() caption: string = 'Modal Title';\n @Prop() closeOnOverlayClick: boolean = true;\n\n @Event() ifxOpen: EventEmitter;\n @Event() ifxClose: EventEmitter;\n\n @Prop() variant: 'default' | 'alert-brand' | 'alert-danger' = 'default';\n \n @Prop() size: 's' | 'm' | 'l' = 's';\n\n @Prop() alertIcon: string = '';\n @Prop() okButtonLabel: string = 'OK';\n @Prop() cancelButtonLabel: string = 'Cancel';\n @Element() hostElement: HTMLElement;\n\n @State() slotButtonsPresent: boolean = false;\n\n @Prop() showCloseButton: boolean = true;\n\n private modalContainer: HTMLElement;\n private focusableElements: HTMLElement[] = [];\n private closeButton: HTMLButtonElement | HTMLIfxIconButtonElement;\n\n componentDidLoad() {\n // Query all focusable elements and store them in `focusableElements`.\n // Needed for the \"focus trap\" functionality.\n this.focusableElements = queryShadowRoot(\n this.hostElement.shadowRoot,\n (el) => isHidden(el) || el.matches('[data-focus-trap-edge]'),\n isFocusable\n );\n }\n\n componentWillRender() { \n if(this.showModal) { \n this.handleComponentOverflow();\n }\n }\n\n handleComponentOverflow() { \n const modalContentContainer = this.hostElement.shadowRoot.querySelector('.modal-content-container');\n if (this.showModal && this.isModalContentContainerHeightReachedViewport()) {\n modalContentContainer.classList.add('no-overflow')\n } else if(modalContentContainer?.classList.contains('no-overflow')) { \n modalContentContainer?.classList.remove('no-overflow')\n }\n }\n\n getFirstFocusableElement(): HTMLElement | null {\n return this.focusableElements[0];\n }\n\n getLastFocusableElement(): HTMLElement | null {\n return this.focusableElements[this.focusableElements.length - 1];\n }\n\n handleTopFocus = () => {\n this.attemptFocus(this.getLastFocusableElement());\n };\n\n handleBottomFocus = () => {\n this.attemptFocus(this.getFirstFocusableElement());\n };\n\n attemptFocus(element: HTMLElement | null) {\n if (element == null) {\n setTimeout(() => { //wait until DOM is fully loaded\n this.closeButton.focus();\n },);\n return;\n }\n\n setTimeout(() => { //wait until DOM is fully loaded\n element.focus();\n }, 0);\n }\n\n open() {\n this.showModal = true;\n try {\n const anim = animationTo(this.modalContainer, KEYFRAMES.fadeIn, {\n duration: 200,\n });\n anim.addEventListener('finish', () => {\n // Setting focus on last item and removing immediately\n // so, on tab press first element is focused\n setTimeout(() => {\n this.getLastFocusableElement()?.focus();\n this.getLastFocusableElement()?.blur();\n }, 0);\n\n this.ifxOpen.emit();\n });\n\n this.hostElement.addEventListener('keydown', this.handleKeypress);\n } catch (err) {\n this.ifxOpen.emit();\n }\n }\n\n close() {\n try {\n const anim = animationTo(this.modalContainer, KEYFRAMES.fadeOut, {\n duration: 200,\n });\n anim.addEventListener('finish', () => {\n this.showModal = false;\n this.ifxClose.emit();\n });\n this.hostElement.removeEventListener('keydown', this.handleKeypress);\n } catch (err) {\n this.showModal = false;\n this.ifxClose.emit();\n }\n }\n\n handleKeypress = (event: KeyboardEvent) => {\n if (!this.showModal) {\n return;\n }\n if (event.key === 'Escape') {\n this.doBeforeClose('ESCAPE_KEY');\n }\n };\n\n doBeforeClose(trigger: CloseEventTrigger) {\n const triggers = [];\n triggers.push(trigger);\n const prevented = triggers.some((event) => event.defaultPrevented);\n if (!prevented) {\n this.opened = false;\n }\n }\n\n @Watch('opened')\n openedChanged(newValue) {\n if (newValue === true) {\n this.open();\n } else {\n this.close()\n }\n }\n\n handleOverlayClick() {\n if (this.closeOnOverlayClick) {\n this.doBeforeClose('BACKDROP')\n }\n }\n\n handleContentUpdate(e) {\n const slotElement = e.target;\n const nodes = slotElement.assignedNodes();\n if(nodes.length > 0) {\n nodes.forEach(node => {\n if (node.observer) {\n node.observer.disconnect();\n delete node.observer;\n }\n const observer = new MutationObserver((mutationsList, _) => {\n for(let mutation of mutationsList) {\n if (mutation.type === 'childList') {\n if(this.showModal) { \n this.handleComponentOverflow();\n }\n }\n }\n });\n observer.observe(node, { attributes: true, childList: true, subtree: true });\n node.observer = observer;\n });\n } \n }\n\n handleButtonsSlotChange(e) {\n if(e.currentTarget.assignedElements()[0]?.childElementCount > 0) {\n this.slotButtonsPresent = true;\n }else{\n this.slotButtonsPresent = false;\n }\n }\n\n isModalContentContainerHeightReachedViewport() {\n //Adding timeout for proper height detection on Edge browser\n return new Promise(resolve => {\n setTimeout(() => {\n const modalContent = this.hostElement.shadowRoot.querySelector('.modal-content') as HTMLElement;\n const modalContentHeight = modalContent.offsetHeight;\n const viewportHeight = window.innerHeight;\n resolve(modalContentHeight >= viewportHeight * 0.9);\n }, 100);\n });\n}\n\n\n render() {\n const isAlertVariant = this.variant !== 'default';\n return (\n <Host>\n <div\n ref={(el) => (this.modalContainer = el)}\n class={`modal-container ${this.showModal ? 'open' : ''}`}\n >\n <div\n class=\"modal-overlay\"\n onClick={() => this.handleOverlayClick()}\n ></div>\n <div\n data-focus-trap-edge\n onFocus={this.handleTopFocus}\n tabindex=\"0\"\n ></div>\n <div\n class={`modal-content-container ${this.size}`}\n role=\"dialog\"\n aria-modal=\"true\"\n aria-label={this.caption}>\n {isAlertVariant ? (\n <div class={`modal-icon-container ${this.variant === 'alert-brand' ? '' : 'danger'}`}>\n {this.alertIcon ? <ifx-icon icon={this.alertIcon} /> : null}\n </div>\n ) : null}\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <h2 class=\"modal-caption\">{this.caption}</h2>\n { \n this.showCloseButton && \n <ifx-icon-button class = 'modal-close-button' ref={(el) => (this.closeButton = el)} icon=\"cross-16\" variant=\"tertiary\" onClick={() => this.doBeforeClose('CLOSE_BUTTON') }>\n </ifx-icon-button>\n }\n </div>\n <div class=\"modal-body\">\n <slot name=\"content\" onSlotchange={(e) => this.handleContentUpdate(e)} />\n </div>\n <div class={`modal-footer ${this.slotButtonsPresent ? 'buttons-present' : ''}`}>\n <slot name=\"buttons\" onSlotchange={(e)=>this.handleButtonsSlotChange(e)}>\n </slot>\n </div>\n </div>\n </div>\n <div\n data-focus-trap-edge\n onFocus={this.handleBottomFocus}\n tabindex=\"0\"\n ></div>\n </div>\n </Host>\n\n );\n }\n}"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as t,h as n,a as o,g as e}from"./p-b7a462e5.js";import{c as i}from"./p-5cdc6210.js";const r=":host{display:inline-flex}.btn{box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:8px;gap:8px;color:#FFFFFF;flex-direction:row;font-weight:600;border-radius:1px;line-height:1.5rem;outline:none;font-family:var(--ifx-font-family);text-decoration:none;user-select:none;border:1px solid rgba(0, 0, 0, 0);font-size:1rem;transition:color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out}.btn:not(.disabled){cursor:pointer}.btn-primary{color:#FFFFFF;background-color:#0A8276}.btn-primary:disabled,.btn-primary.disabled{background-color:#BFBBBB;color:#FFFFFF;pointer-events:none}.btn-secondary{color:#0A8276;background-color:#FFFFFF;border-color:#0A8276}.btn-secondary:disabled,.btn-secondary.disabled{background-color:#FFFFFF;border:1px solid #BFBBBB;color:#BFBBBB;pointer-events:none}.btn-tertiary{background-color:transparent;color:#1D1D1D}.btn-tertiary:disabled,.btn-tertiary.disabled{color:#BFBBBB;pointer-events:none}.btn.icon-button{min-width:initial;min-height:initial;width:40px;height:40px;padding:0;justify-content:center}.btn.icon-button.btn-round{border-radius:100px}.btn.icon-button.btn-square{border-radius:1px}.btn.icon-button.btn-s{width:32px;height:32px;padding:8px}.btn.icon-button.btn-l{width:48px;height:48px;padding:8px}.btn.btn-primary:not(:disabled,.disabled):focus:not(:active,.active){outline:none;box-shadow:0 0 0 2px #FFFFFF, 0 0 0 4px #0A8276}.btn.btn-primary:not(:disabled,.disabled):hover{background-color:#08665C;border-color:#08665C}.btn.btn-primary:not(:disabled,.disabled):active,.btn.btn-primary:not(:disabled,.disabled).active{background-color:#06534B;border-color:#06534B}.btn.btn-secondary:not(:disabled,.disabled):focus:not(:active,.active){outline:none;box-shadow:0 0 0 2px #FFFFFF, 0 0 0 4px #0A8276}.btn.btn-secondary:not(:disabled,.disabled):hover{background-color:#08665C;border-color:#08665C;color:#FFFFFF}.btn.btn-secondary:not(:disabled,.disabled):active,.btn.btn-secondary:not(:disabled,.disabled).active{background-color:#06534B;border-color:#06534B}.btn.btn-tertiary:not(:disabled,.disabled):focus:not(:active,.active){outline:none;color:#1D1D1D;box-shadow:0 0 0 0px #FFFFFF, 0 0 0 2px #0A8276}.btn.btn-tertiary:not(:disabled,.disabled):hover{color:#0A8276}.btn.btn-tertiary:not(:disabled,.disabled):active,.btn.btn-tertiary:not(:disabled,.disabled).active{color:#08665C}";const s=r;const a=class{constructor(n){t(this,n);this.target="_self";this.shape="round"}handleClick(t){if(this.disabled){t.stopImmediatePropagation()}}updateIcon(t){this.internalIcon=t}async setFocus(){this.focusableElement.focus()}componentWillLoad(){if(this.shape===""){this.shape="round"}this.internalIcon=this.icon}render(){return n(o,{key:"2ab6931d60697470c7e3bebc06ab238b2383fe0b","aria-disabled":this.disabled,"aria-label":this.ariaLabel},this.href?n("a",{ref:t=>this.focusableElement=t,class:this.getClassNames(),href:!this.disabled?this.href:undefined,target:this.target,rel:this.target==="_blank"?"noopener noreferrer":undefined},n("ifx-icon",{icon:this.internalIcon})):n("button",{class:this.getClassNames(),type:"button",disabled:this.disabled},n("ifx-icon",{icon:this.internalIcon})))}getVariantClass(){return`${this.variant}`==="secondary"?`secondary`:`${this.variant}`==="tertiary"?`tertiary`:`primary`}getSizeClass(){if(`${this.size}`==="xs"){return"xs"}else if(`${this.size}`==="s"){return"s"}else if(`${this.size}`==="l"){return"l"}else return""}getClassNames(){return i("btn icon-button",`btn-${this.shape}`,this.size&&`btn-${this.getSizeClass()}`,`btn-${this.getVariantClass()}`,this.disabled?"disabled":"")}get el(){return e(this)}static get watchers(){return{icon:["updateIcon"]}}};a.style=s;export{a as ifx_icon_button};
2
+ //# sourceMappingURL=p-33a4fd0a.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["iconButtonCss","IfxIconButtonStyle0","IconButton","constructor","hostRef","this","target","shape","handleClick","event","disabled","stopImmediatePropagation","updateIcon","newIcon","internalIcon","setFocus","focusableElement","focus","componentWillLoad","icon","render","h","Host","key","ariaLabel","href","ref","el","class","getClassNames","undefined","rel","type","getVariantClass","variant","getSizeClass","size","classNames"],"sources":["src/components/icon-button/icon-button.scss?tag=ifx-icon-button&encapsulation=shadow","src/components/icon-button/icon-button.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n:host {\n display: inline-flex;\n}\n\n.btn {\n box-sizing: border-box;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n min-height: tokens.$ifxSize500;\n padding: 8px;\n gap: tokens.$ifxSpace100;\n color: tokens.$ifxColorBaseWhite;\n flex-direction: row;\n font-weight: tokens.$ifxFontWeightSemibold;\n border-radius: tokens.$ifxBorderRadius12;\n line-height: tokens.$ifxLineHeightM;\n outline: none;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n text-decoration: none;\n user-select: none;\n border: 1px solid rgba(0, 0, 0, 0);\n font-size: tokens.$ifxFontSizeM;\n transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;\n}\n\n.btn:not(.disabled) {\n cursor: pointer;\n}\n\n.btn-primary {\n color: tokens.$ifxColorBaseWhite;\n background-color: tokens.$ifxColorOcean500;\n\n &:disabled,\n &.disabled {\n background-color: tokens.$ifxColorEngineering300;\n color: tokens.$ifxColorBaseWhite;\n pointer-events: none;\n\n }\n}\n\n\n.btn-secondary {\n color: tokens.$ifxColorOcean500;\n background-color: tokens.$ifxColorBaseWhite;\n border-color: tokens.$ifxColorOcean500;\n\n &:disabled,\n &.disabled {\n background-color: tokens.$ifxColorBaseWhite;\n border: 1px solid tokens.$ifxColorEngineering300;\n color: tokens.$ifxColorEngineering300;\n pointer-events: none;\n\n }\n}\n\n.btn-tertiary {\n background-color: transparent;\n color: tokens.$ifxColorBaseBlack;\n\n &:disabled,\n &.disabled {\n color: tokens.$ifxColorEngineering300;\n pointer-events: none;\n }\n}\n\n\n.btn {\n\n &.icon-button {\n min-width: initial;\n min-height: initial;\n width: tokens.$ifxSize500;\n height: tokens.$ifxSize500;\n padding: 0;\n justify-content: center;\n\n &.btn-round {\n border-radius: 100px;\n }\n\n &.btn-square {\n border-radius: tokens.$ifxBorderRadius12;\n }\n\n &.btn-s {\n width: tokens.$ifxSize400;\n height: tokens.$ifxSize400;\n padding: 8px;\n }\n\n\n &.btn-l {\n width: tokens.$ifxSize600;\n height: tokens.$ifxSize600;\n padding: 8px;\n }\n }\n\n &.btn-primary:not(:disabled, .disabled) {\n &:focus:not(:active, .active) {\n outline: none;\n box-shadow: 0 0 0 2px tokens.$ifxColorBaseWhite, 0 0 0 4px tokens.$ifxColorOcean500;\n }\n\n &:hover {\n background-color: tokens.$ifxColorOcean600;\n border-color: tokens.$ifxColorOcean600;\n }\n\n &:active,\n &.active {\n background-color: tokens.$ifxColorOcean700;\n border-color: tokens.$ifxColorOcean700;\n }\n }\n\n\n &.btn-secondary:not(:disabled, .disabled) {\n &:focus:not(:active, .active) {\n outline: none;\n box-shadow: 0 0 0 2px tokens.$ifxColorBaseWhite, 0 0 0 4px tokens.$ifxColorOcean500;\n }\n\n &:hover {\n background-color: tokens.$ifxColorOcean600;\n border-color: tokens.$ifxColorOcean600;\n color: tokens.$ifxColorBaseWhite;\n }\n\n &:active,\n &.active {\n background-color: tokens.$ifxColorOcean700;\n border-color: tokens.$ifxColorOcean700;\n }\n }\n\n &.btn-tertiary:not(:disabled, .disabled) {\n &:focus:not(:active, .active) {\n outline: none;\n color: tokens.$ifxColorBaseBlack;\n box-shadow: 0 0 0 0px tokens.$ifxColorBaseWhite, 0 0 0 2px tokens.$ifxColorOcean500;\n }\n\n &:hover {\n color: tokens.$ifxColorOcean500;\n }\n\n &:active,\n &.active {\n color: tokens.$ifxColorOcean600;\n }\n }\n}","import { Component, Prop, h, Host, Method, Element, Listen, Watch, State } from '@stencil/core';\nimport classNames from 'classnames';\n\n@Component({\n tag: 'ifx-icon-button',\n styleUrl: 'icon-button.scss',\n shadow: true,\n})\n\nexport class IconButton {\n @Prop() variant: 'primary' | 'secondary' | 'tertiary';\n @Prop() size: string;\n @Prop() disabled: boolean;\n @Prop() icon: string;\n @Prop() href: string;\n @Prop() target: string = '_self';\n @Prop() shape: string = 'round';\n @Prop() ariaLabel: string | null;\n @State() internalIcon: string;\n @Element() el;\n\n private focusableElement: HTMLElement;\n \n @Listen('click', { capture: true })\n handleClick(event: Event) {\n if (this.disabled) {\n event.stopImmediatePropagation();\n }\n }\n\n @Watch('icon')\n updateIcon(newIcon: string) { \n this.internalIcon = newIcon;\n }\n\n @Method()\n async setFocus() {\n this.focusableElement.focus();\n }\n\n componentWillLoad() {\n if (this.shape === '') {\n this.shape = 'round';\n }\n this.internalIcon = this.icon;\n }\n\n render() {\n return (\n <Host \n aria-disabled={this.disabled}\n aria-label={this.ariaLabel}> \n {this.href ? (\n <a\n ref={(el) => (this.focusableElement = el)}\n class={this.getClassNames()}\n href={!this.disabled ? this.href : undefined} \n target={this.target}\n rel={this.target === '_blank' ? 'noopener noreferrer' : undefined}\n >\n <ifx-icon icon={this.internalIcon}></ifx-icon>\n </a>\n ) : (\n <button\n class={this.getClassNames()}\n type=\"button\"\n disabled={this.disabled}\n >\n <ifx-icon icon={this.internalIcon}></ifx-icon>\n </button>\n )}\n </Host>\n );\n }\n\n getVariantClass() {\n return `${this.variant}` === \"secondary\"\n ? `secondary`\n : `${this.variant}` === 'tertiary'\n ? `tertiary`\n : `primary`;\n }\n\n getSizeClass() {\n if (`${this.size}` === \"xs\") {\n return \"xs\"\n }\n else if (`${this.size}` === \"s\") {\n return \"s\"\n }\n else if (`${this.size}` === \"l\") {\n return \"l\"\n }\n else return \"\";\n }\n\n getClassNames() {\n return classNames(\n 'btn icon-button',\n `btn-${this.shape}`,\n this.size && `btn-${this.getSizeClass()}`,\n `btn-${this.getVariantClass()}`,\n this.disabled ? 'disabled' : ''\n );\n }\n}"],"mappings":"6FAAA,MAAMA,EAAgB,y4EACtB,MAAAC,EAAeD,E,MCQFE,EAAU,MANvB,WAAAC,CAAAC,G,UAYUC,KAAAC,OAAiB,QACjBD,KAAAE,MAAgB,O,CAQxB,WAAAC,CAAYC,GACV,GAAIJ,KAAKK,SAAU,CACjBD,EAAME,0B,EAKV,UAAAC,CAAWC,GACTR,KAAKS,aAAeD,C,CAItB,cAAME,GACJV,KAAKW,iBAAiBC,O,CAGxB,iBAAAC,GACE,GAAIb,KAAKE,QAAU,GAAI,CACrBF,KAAKE,MAAQ,O,CAEfF,KAAKS,aAAeT,KAAKc,I,CAG3B,MAAAC,GACE,OACEC,EAACC,EAAI,CAAAC,IAAA,2DACYlB,KAAKK,SAAQ,aAChBL,KAAKmB,WAChBnB,KAAKoB,KACJJ,EAAA,KACEK,IAAMC,GAAQtB,KAAKW,iBAAmBW,EACtCC,MAAOvB,KAAKwB,gBACZJ,MAAOpB,KAAKK,SAAWL,KAAKoB,KAAOK,UACnCxB,OAAQD,KAAKC,OACbyB,IAAK1B,KAAKC,SAAW,SAAW,sBAAwBwB,WAExDT,EAAA,YAAUF,KAAMd,KAAKS,gBAGvBO,EAAA,UACEO,MAAOvB,KAAKwB,gBACZG,KAAK,SACLtB,SAAUL,KAAKK,UAEfW,EAAA,YAAUF,KAAMd,KAAKS,gB,CAO/B,eAAAmB,GACE,MAAO,GAAG5B,KAAK6B,YAAc,YACzB,YACA,GAAG7B,KAAK6B,YAAc,WACpB,WACA,S,CAGR,YAAAC,GACE,GAAI,GAAG9B,KAAK+B,SAAW,KAAM,CAC3B,MAAO,I,MAEJ,GAAI,GAAG/B,KAAK+B,SAAW,IAAK,CAC/B,MAAO,G,MAEJ,GAAI,GAAG/B,KAAK+B,SAAW,IAAK,CAC/B,MAAO,G,MAEJ,MAAO,E,CAGd,aAAAP,GACE,OAAOQ,EACL,kBACA,OAAOhC,KAAKE,QACZF,KAAK+B,MAAQ,OAAO/B,KAAK8B,iBACzB,OAAO9B,KAAK4B,oBACZ5B,KAAKK,SAAW,WAAa,G","ignoreList":[]}
@@ -1,2 +1,2 @@
1
- import{r as t,c as e,h as i,a as s,g as a}from"./p-b7a462e5.js";const l=":host{display:block;width:100%}.search-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-start;margin-bottom:16px}.components-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-end;align-content:flex-end;flex-wrap:wrap;gap:16px}.filter-slot-wrapper{flex-grow:1;flex-basis:100%;max-width:100%}@media (max-width: 1024px){.more-filters-wrapper{order:3;width:100%;display:flex;justify-content:center;padding-top:16px;}}@media (min-width: 720px) and (max-width: 1024px){.filter-slot-wrapper{flex-basis:calc((100% - 16px) / 2);max-width:calc((100% - 16px) / 2)}}@media (min-width: 1025px){.filter-slot-wrapper{flex-basis:auto;max-width:200px}::slotted([slot=filter-search]){max-width:828px}}::slotted([slot=filter-search]){flex-grow:1;flex-basis:100%;width:100%}";const r=l;const f=class{constructor(i){t(this,i);this.ifxTopbarFilterChange=e(this,"ifxTopbarFilterChange",7);this.selectedOptions=[];this.showAllFilters=false;this.maxShownFilters=4;this.showMoreFiltersButton=true;this.handleMoreFiltersClick=()=>{this.showAllFilters=true;this.updateVisibleSlots()};this.handleResetEvent=()=>{var t;const e=(t=this.el.shadowRoot)===null||t===void 0?void 0:t.querySelector('slot[name="filter-search"]');if(e instanceof HTMLSlotElement){const t=e.assignedElements({flatten:true});t.forEach((t=>{const e=t.querySelector("ifx-filter-search");const i=e.shadowRoot.querySelectorAll("ifx-search-field");if(i.length>0){i.forEach((t=>{t.value=""}))}}))}this.selectedOptions=[];this.ifxTopbarFilterChange.emit(this.selectedOptions)};this.handleSearchChange=t=>{this.handleTopbarFilterChange(t)};this.handleFilterSelect=t=>{this.handleTopbarFilterChange(t)};this.handleTopbarFilterChange=t=>{const e=[...this.selectedOptions];if(t.type==="ifxFilterSearchChange"){const{filterName:i,filterValue:s}=t.detail;const a=e.findIndex((t=>t.filterName===i));if(a!==-1){e[a].filterValues=[s]}else{e.push({filterName:i,filterValues:[s],type:"text"})}}else if(t.type==="ifxFilterSelect"){const{filterName:i,filterValues:s,type:a}=t.detail;const l=e.findIndex((t=>t.filterName===i));if(l!==-1){e[l].filterValues=s;e[l].type=a}else{e.push({filterName:i,filterValues:s,type:a})}}this.selectedOptions=e;this.ifxTopbarFilterChange.emit(this.selectedOptions)}}connectedCallback(){this.el.addEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.addEventListener("ifxFilterSearchChange",this.handleSearchChange);window.addEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentWillUnload(){this.el.removeEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.removeEventListener("ifxFilterSearchChange",this.handleSearchChange);window.removeEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentDidLoad(){this.updateVisibleSlots()}updateVisibleSlots(){this.visibleSlots=this.showAllFilters?Number.MAX_SAFE_INTEGER:this.maxShownFilters}render(){const t=Math.max(0,this.visibleSlots);const e=this.el.querySelectorAll("ifx-set-filter").length;const a=Math.min(t,e,Number.MAX_SAFE_INTEGER);const l=Array.from({length:a},((t,e)=>i("div",{class:"filter-slot-wrapper"},i("slot",{name:`filter-component-${e+1}`}))));return i(s,{key:"7b2cb9b7074cd66edfe0c31ef19e18f72252e569"},i("div",{key:"fabc0fa624802d65510c4bff239f4d83bb23f520",class:"search-container"},i("slot",{key:"2a990d12a8e17c1c7a5db629b2fa050ca55b65d1",name:"filter-search"})," "),i("div",{key:"874b0e25ca8aa4465d49ebe6db00116843127242",class:"components-container"},l.length>0?l:i("slot",{name:"filter-component"}),this.showMoreFiltersButton&&!this.showAllFilters&&i("div",{key:"fe500afb7ff3ab37d8a20ccf781499501bd3b70f",class:"more-filters-wrapper",onClick:this.handleMoreFiltersClick},i("ifx-button",{key:"7d1ddf8679f50e87488cc62dd01d6571ec203a5a",type:"button",disabled:false,variant:"tertiary",size:"m",target:"_blank",theme:"default","full-width":"false"},i("ifx-icon",{key:"dfb8ae890ccb73b8635d041a5cd5344d198c647f",icon:"filter-16"}),"More filters"))))}get el(){return a(this)}};f.style=r;export{f as ifx_filter_bar};
2
- //# sourceMappingURL=p-a9cfb70d.entry.js.map
1
+ import{r as t,c as e,h as i,a as s,g as a}from"./p-b7a462e5.js";const l=":host{display:block;width:100%}.search-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-start;margin-bottom:16px}.components-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-end;align-content:flex-end;flex-wrap:wrap;gap:16px}.filter-slot-wrapper{flex-grow:1;flex-basis:100%;max-width:100%}@media (max-width: 1024px){.more-filters-wrapper{order:3;width:100%;display:flex;justify-content:center;padding-top:16px;}}@media (min-width: 720px) and (max-width: 1024px){.filter-slot-wrapper{flex-basis:calc((100% - 16px) / 2);max-width:calc((100% - 16px) / 2)}}@media (min-width: 1025px){.filter-slot-wrapper{flex-basis:auto;max-width:200px}::slotted([slot=filter-search]){max-width:828px}}::slotted([slot=filter-search]){flex-grow:1;flex-basis:100%;width:100%}";const r=l;const c=class{constructor(i){t(this,i);this.ifxTopbarFilterChange=e(this,"ifxTopbarFilterChange",7);this.selectedOptions=[];this.showAllFilters=false;this.maxShownFilters=4;this.showMoreFiltersButton=true;this.handleMoreFiltersClick=()=>{this.showAllFilters=true;this.updateVisibleSlots()};this.handleResetEvent=()=>{var t;const e=(t=this.el.shadowRoot)===null||t===void 0?void 0:t.querySelector('slot[name="filter-search"]');if(e instanceof HTMLSlotElement){const t=e.assignedElements({flatten:true});t.forEach((t=>{const e=t.querySelector("ifx-filter-search");const i=e.shadowRoot.querySelectorAll("ifx-search-field");if(i.length>0){i.forEach((t=>{t.value=""}))}}))}this.selectedOptions=[];this.ifxTopbarFilterChange.emit(this.selectedOptions)};this.handleSearchChange=t=>{this.handleTopbarFilterChange(t)};this.handleFilterSelect=t=>{this.handleTopbarFilterChange(t)};this.handleTopbarFilterChange=t=>{const e=[...this.selectedOptions];if(t.type==="ifxFilterSearchChange"){const{filterName:i,filterValue:s}=t.detail;const a=e.findIndex((t=>t.filterName===i));if(a!==-1){e[a].filterValues=[s]}else{e.push({filterName:i,filterValues:[s],type:"text"})}}else if(t.type==="ifxFilterSelect"){const{filterName:i,filterValues:s,type:a}=t.detail;const l=e.findIndex((t=>t.filterName===i));if(l!==-1){e[l].filterValues=s;e[l].type=a}else{e.push({filterName:i,filterValues:s,type:a})}}this.selectedOptions=e;this.ifxTopbarFilterChange.emit(this.selectedOptions)}}connectedCallback(){this.el.addEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.addEventListener("ifxFilterSearchChange",this.handleSearchChange);window.addEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentWillUnload(){this.el.removeEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.removeEventListener("ifxFilterSearchChange",this.handleSearchChange);window.removeEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentDidLoad(){this.updateVisibleSlots()}updateVisibleSlots(){this.visibleSlots=this.showAllFilters?Number.MAX_SAFE_INTEGER:this.maxShownFilters}render(){const t=Math.max(0,this.visibleSlots);const e=this.el.querySelectorAll("ifx-set-filter").length;const a=Math.min(t,e,Number.MAX_SAFE_INTEGER);const l=Array.from({length:a},((t,e)=>i("div",{class:"filter-slot-wrapper"},i("slot",{name:`filter-component-${e+1}`}))));return i(s,{key:"883d2316936a342059ab9009149ac8ce2ed877b2"},i("div",{key:"24e0f7e2dde9ff7ddccf19e03e075b24807ec9d4",class:"search-container"},i("slot",{key:"10bcfd474cfd9286d3e57e19d110bea6311c4297",name:"filter-search"})," "),i("div",{key:"3aa8a6c4fb666ff47c7868333c2c494d6cb7bd90",class:"components-container"},l.length>0?l:i("slot",{name:"filter-component"}),this.showMoreFiltersButton&&!this.showAllFilters&&i("div",{key:"1b87cf569495c351b639bc88d714dd195bd943b0",class:"more-filters-wrapper",onClick:this.handleMoreFiltersClick},i("ifx-button",{key:"9f8073be95597553d1aa4eaccd19fc534ce3f9c6",type:"button",disabled:false,variant:"tertiary",size:"m",target:"_blank",theme:"default","full-width":"false"},i("ifx-icon",{key:"157558f67217a770963b16ca3f6b3a5cc8ed191c",icon:"filter-16"}),"More filters"))))}get el(){return a(this)}};c.style=r;export{c as ifx_filter_bar};
2
+ //# sourceMappingURL=p-36dcebde.entry.js.map
@@ -0,0 +1,2 @@
1
+ import{r as n,c as a,h as e,g as t}from"./p-b7a462e5.js";const r=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{width:100%;display:block}.navbar__wrapper{font-family:var(--ifx-font-family);height:63px;position:sticky;z-index:1030;border-bottom:1px solid #EEEDED}.navbar__wrapper.fixed{border-bottom:none}.navbar__main-container{position:absolute;top:0;width:100%;transition:all 1s;z-index:1020}.navbar__main-container.fixed{position:fixed}.navbar__main-container.fixed .navbar__container{border-bottom:1px solid #EEEDED}.navbar__main-container.show{height:100vh;bottom:0;background-color:rgba(29, 29, 29, 0.2);transition:1s;z-index:1}.navbar__sidebar{box-sizing:border-box;position:fixed;right:-100%;top:64px;display:flex;flex-direction:column;align-items:flex-start;width:375px;height:calc(100vh - 64px);background-color:#FFFFFF;transition:right 1s;z-index:1030}.navbar__sidebar.show{right:0;transition:right 1s}.navbar__sidebar .navbar__sidebar-top-row{display:flex;padding:var(--borderRadius-none, 0px) var(--space-300, 24px) 30px var(--space-300, 24px);flex-direction:column;align-items:flex-start;gap:var(--space-200, 16px);flex:1 0 0;align-self:stretch;overflow-y:auto}.navbar__sidebar .navbar__sidebar-top-row .navbar__sidebar-top-row-wrapper{display:flex;padding-top:var(--space-200, 16px);flex-direction:column;align-items:flex-start;align-self:stretch;gap:16px}.navbar__sidebar .navbar__sidebar-top-row .navbar__sidebar-top-row-wrapper.expand{align-items:initial}.navbar__sidebar .navbar__sidebar-top-row .navbar__sidebar-top-row-wrapper .navbar__sidebar-top-row-item{display:flex;padding:var(--space-200, 0px) var(--space-50, 4px) var(--space-200, 0px) 0px;align-items:center;gap:var(--space-100, 8px);align-self:stretch;justify-content:space-between}.navbar__sidebar .navbar__sidebar-top-row .navbar__sidebar-top-row-wrapper .navbar__sidebar-top-row-item .navbar__sidebar-top-row-item-icon-wrapper ifx-icon{vertical-align:middle}.navbar__sidebar .navbar__sidebar-top-row .navbar__sidebar-top-row-wrapper .navbar__sidebar-top-row-item:hover{cursor:pointer}.navbar__sidebar .navbar__sidebar-top-row .navbar__sidebar-top-row-wrapper .navbar__sidebar-top-row-item .navbar__sidebar-top-row-item-label{color:var(--color-base-black, #1D1D1D);font-family:"Source Sans 3";font-size:16px;font-style:normal;font-weight:400;line-height:24px}.navbar__sidebar .navbar__sidebar-bottom-row{display:none;padding:var(--space-150, 12px) var(--space-300, 24px) var(--space-150, 12px) var(--space-200, 16px);flex-direction:column;align-items:flex-start;align-self:stretch;background:var(--color-engineering-100, #F7F7F7);border-top:1px solid var(--color-engineering-200, #EEEDED);gap:10px;max-height:160px;overflow-y:auto}.navbar__sidebar .navbar__sidebar-bottom-row.show{display:flex}.navbar__sidebar .navbar__sidebar-bottom-row .navbar__sidebar-bottom-row-item{display:flex;height:40px;padding-right:var(--space-50, 4px);align-items:center;gap:var(--space-100, 8px);flex:1 0 0}.navbar__sidebar .navbar__sidebar-bottom-row .navbar__sidebar-bottom-row-item .navbar__sidebar-bottom-row-item-label{color:var(--color-base-black, #1D1D1D);font-family:"Source Sans 3";font-size:16px;font-style:normal;font-weight:400;line-height:24px}.navbar__sidebar .navbar__sidebar-bottom-row .navbar__sidebar-bottom-row-item .navbar__sidebar-bottom-row-item-icon-wrapper{display:flex;align-items:center}.navbar__sidebar .navbar__sidebar-content-products,.navbar__sidebar .navbar__sidebar-content-main{display:flex;flex-direction:column;align-items:flex-start;padding:0px;gap:24px;flex:none;order:0;align-self:stretch;flex-grow:0}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-header,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-about-header,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-header,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-about-header{display:flex;flex-direction:row;align-items:center;padding:0px;gap:16px;flex:none;order:0;align-self:stretch;flex-grow:0;color:#BFBBBB}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-header span,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-about-header span,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-header span,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-about-header span{color:#1D1D1D;font-weight:600;font-size:18px;line-height:28px;display:flex;align-items:center}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-menu,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-menu,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu{display:flex;flex-direction:column;align-items:flex-start;padding:0px;gap:16px;flex:none;order:1;flex-grow:0;width:100%}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-menu .navbar__sidebar-content-products-menu-item,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu .navbar__sidebar-content-products-menu-item,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-menu .navbar__sidebar-content-products-menu-item,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu .navbar__sidebar-content-products-menu-item,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item{display:flex;flex-direction:row;align-items:center;padding:0px;flex:none;order:0;flex-grow:0}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-menu .navbar__sidebar-content-products-menu-item a,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item a,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu .navbar__sidebar-content-products-menu-item a,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item a,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-menu .navbar__sidebar-content-products-menu-item a,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item a,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu .navbar__sidebar-content-products-menu-item a,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item a{text-decoration:none;font-style:normal;font-weight:400;font-size:16px;line-height:24px;display:flex;align-items:center;color:#1D1D1D}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item{color:#BFBBBB}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item a,.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item a,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-products-menu .navbar__sidebar-content-main-menu-item a,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu .navbar__sidebar-content-main-menu-item a{font-style:normal;font-weight:600;font-size:18px;line-height:28px;display:flex;align-items:center;color:#1D1D1D;flex:none;order:0;flex-grow:1}.navbar__sidebar .navbar__sidebar-content-products .navbar__sidebar-content-main-menu,.navbar__sidebar .navbar__sidebar-content-main .navbar__sidebar-content-main-menu{align-items:normal}.navbar__container{display:flex;justify-content:space-between;align-items:center;padding:8px 40px;gap:16px;background-color:#FFFFFF;font-family:var(--ifx-font-family)}.navbar__container.expanded{justify-content:initial}.navbar__container .navbar__container-search-field-wrapper{display:none}.navbar__container .navbar__container-search-field-wrapper.show{display:flex}.navbar__container .navbar__container-left{display:flex;flex-direction:row;align-items:center;padding:0;gap:16px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-left.hide{display:none}.navbar__container .navbar__container-left.expand{justify-content:initial;flex:1}.navbar__container .navbar__container-left.expand .navbar__container-left-content{align-items:initial;flex:1}.navbar__container .navbar__container-left.expand .navbar__container-left-content .navbar__container-left-content-navigation-group{justify-content:initial;flex:1}.navbar__container .navbar__container-left.expand .navbar__container-left-content .navbar__container-left-content-navigation-group .navbar__container-left-content-navigation-item-search-bar{flex:1}.navbar__container .navbar__container-left .navbar__container-left-logo{display:flex;flex-direction:row;align-items:center;padding:0px;gap:16px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-logo.hide{display:none}.navbar__container .navbar__container-left .navbar__container-left-logo h6{position:relative;margin:0;padding:0;font-style:normal;font-weight:600;font-size:16px;display:flex;align-items:center;color:#1D1D1D;flex:none;order:1;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-logo .navbar__container-left-logo-default{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:12px 0px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-logo .navbar__container-left-logo-default svg{width:91px;height:40px;flex:none;order:0;flex-grow:0;vertical-align:bottom}.navbar__container .navbar__container-left .navbar__container-left-logo .navbar__container-left-logo-divider{width:1px;height:32px;background:#EEEDED;flex:none;order:2;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-content{display:flex;flex-direction:row;justify-content:center;align-items:flex-start;padding:0px;flex:none;order:1;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-content .navbar__container-left-content-navigation-group{display:flex;flex-direction:row;align-items:center;padding:0px;gap:4px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-content .navbar__container-left-content-navigation-group .navbar__container-left-content-navigation-item-search-bar{display:flex;flex-direction:row;align-items:center;padding:0px 8px;flex:none;order:5;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-content .navbar__container-left-content-navigation-group .navbar__container-left-content-navigation-item{display:flex;flex-direction:row;align-items:center;padding:0px 8px;gap:8px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-left .navbar__container-left-content .navbar__container-left-content-navigation-group .navbar__container-left-content-navigation-item a{display:flex;align-items:center;font-weight:400;font-size:16px;line-height:24px;color:#1D1D1D;text-decoration:none;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-right{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;padding:0;gap:8px;flex:none;order:1;flex-grow:0}.navbar__container .navbar__container-right.hide{display:none}.navbar__container .navbar__container-right.expand{justify-content:initial;flex:1}.navbar__container .navbar__container-right.expand .navbar__container-right-content{align-items:initial;flex:1}.navbar__container .navbar__container-right.expand .navbar__container-right-content .navbar__container-right-content-navigation-group{justify-content:initial;flex:1}.navbar__container .navbar__container-right.expand .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar{flex:1}.navbar__container .navbar__container-right.expand .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar .navbar__container-right-content-navigation-item-search-bar-icon-wrapper{flex:1}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper{display:flex;flex-direction:row;justify-content:center;align-items:center;padding:4px 0px 4px 16px;border-left:1px solid #BFBBBB;gap:16px;flex:none;order:1;flex-grow:0;width:41px;height:40px}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper.hide{display:none}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper .navbar__burger-icon{display:flex;align-items:center}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper .navbar__burger-icon:hover{cursor:pointer}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper .navbar__burger-icon.close{display:none}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper .navbar__cross-icon{display:none;align-items:center}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper .navbar__cross-icon.show{display:flex}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper .navbar__cross-icon.show:hover{cursor:pointer}.navbar__container .navbar__container-right .navbar__container-right-content{display:flex;flex-direction:column;align-items:flex-start;padding:0px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group{position:relative;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;padding:0px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-profile,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar{display:flex;flex-direction:row;align-items:center;padding:0px 8px;gap:4px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item .navbar__container-right-content-navigation-item-search-bar-icon-wrapper,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-profile .navbar__container-right-content-navigation-item-search-bar-icon-wrapper,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar .navbar__container-right-content-navigation-item-search-bar-icon-wrapper{display:flex;flex-direction:row;justify-content:center;align-items:center;padding:0px;gap:8px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item .navbar__container-right-content-navigation-item-search-bar-icon-wrapper.isOpen,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-profile .navbar__container-right-content-navigation-item-search-bar-icon-wrapper.isOpen,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar .navbar__container-right-content-navigation-item-search-bar-icon-wrapper.isOpen{position:absolute;top:10px}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item .navbar__container-right-content-navigation-item-navigation-profile,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-profile .navbar__container-right-content-navigation-item-navigation-profile,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar .navbar__container-right-content-navigation-item-navigation-profile{position:relative;width:24px;height:24px;background:#0A8276;border-radius:100px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item .navbar__container-right-content-navigation-item-navigation-profile a,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-profile .navbar__container-right-content-navigation-item-navigation-profile a,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar .navbar__container-right-content-navigation-item-navigation-profile a{position:absolute;width:22px;height:20px;left:calc(50% - 11px);top:calc(50% - 10px);font-style:normal;font-weight:600;font-size:14px;line-height:20px;text-decoration:none;display:flex;align-items:center;justify-content:center;text-align:center;color:#FFFFFF}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item .navbar__container-right-content-navigation-item-icon-wrapper,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-profile .navbar__container-right-content-navigation-item-icon-wrapper,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar .navbar__container-right-content-navigation-item-icon-wrapper{display:flex;flex-direction:row;justify-content:center;align-items:center;padding:0px;gap:8px;flex:none;order:0;flex-grow:0}.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item a,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-profile a,.navbar__container .navbar__container-right .navbar__container-right-content .navbar__container-right-content-navigation-group .navbar__container-right-content-navigation-item-search-bar a{font-style:normal;font-weight:400;font-size:14px;line-height:20px;color:#1D1D1D;text-decoration:none;display:flex;align-items:center;flex:none;order:1;flex-grow:0}@media screen and (max-width: 800px){.navbar__container{padding:0px 16px;height:64px;gap:initial}.navbar__container.expanded .navbar__container-right .navbar__burger-icon-wrapper{display:none}.navbar__container .navbar__container-left .navbar__container-left-content{display:none}.navbar__container .navbar__container-left .navbar__container-left-logo .navbar__container-left-logo-divider{display:none}.navbar__container .navbar__container-right{flex:1}.navbar__sidebar{width:0;transition:1s}}@media screen and (max-width: 500px){.navbar__sidebar.show{width:100%}}@media screen and (min-width: 500px){.navbar__sidebar.show{width:50%}}@media screen and (min-width: 800px){.navbar__wrapper{height:63px}.navbar__container{padding:0px 16px;height:63px;gap:initial}.navbar__container .navbar__container-right .navbar__burger-icon-wrapper{display:none}.navbar__main-container.show{height:auto;background-color:inherit;transition:none}.navbar__sidebar{width:0;transition:1s}.navbar__sidebar.show{right:-100%}}@media screen and (min-width: 1024px){.navbar__wrapper{height:72px}.navbar__container{padding:0px 24px;height:72px}.navbar__container .navbar__container-left{gap:12px;display:flex}.navbar__container .navbar__container-left .navbar__container-left-content{display:flex}.navbar__container .navbar__container-left .navbar__container-left-logo-default svg{width:72.8px;height:32px}.navbar__main-container.show{height:auto;background-color:inherit;transition:none}}@media screen and (min-width: 1200px){.navbar__wrapper{height:80px}.navbar__container{padding:0px 32px;height:80px}.navbar__container .navbar__container-left .navbar__container-left-content{justify-content:inherit}.navbar__container .navbar__container-right .navbar__container-right-content{justify-content:inherit}}@media screen and (min-width: 1440px){.navbar__wrapper{height:80px}.navbar__container{padding:0px 40px;height:80px}.navbar__container .navbar__container-left .navbar__container-left-content{justify-content:center}.navbar__container .navbar__container-right .navbar__container-right-content{justify-content:inherit}}';const i=r;const o=class{constructor(e){n(this,e);this.ifxNavbarMobileMenuIsOpen=a(this,"ifxNavbarMobileMenuIsOpen",7);this.main=true;this.products=false;this.applications=false;this.design=false;this.support=false;this.about=false;this.applicationName="";this.hasLeftMenuItems=true;this.fixed=true;this.showLogoAndAppname=true;this.logoHref="";this.internalLogoHref="";this.logoHrefTarget="_self";this.internalLogoHrefTarget="_self"}addEventListenersToHandleCustomFocusState(){const n=this.el.shadowRoot.firstChild;if(!n){console.error("element not found");return}n.tabIndex=-1;const a=n.querySelectorAll("a");for(let n=0;n<a.length;n++){a[n].tabIndex=-1}const e=n.querySelector("slot");if(e){const n=e.assignedNodes();for(let a=0;a<n.length;a++){const e=n[a];if(e.nodeName==="IFX-NAVBAR-ITEM"){const n=e;const a=n===null||n===void 0?void 0:n.shadowRoot.querySelectorAll("a");for(let n=0;n<a.length;n++){a[n].tabIndex=-1}}}}}clearFirstLayerMenu(n){if(n.detail.action==="hideFirstLayer"){const a=this.getMobileMenuTop();for(let e=0;e<a.length;e++){if(!a[e].isSameNode(n.detail.component)){a[e].hideComponent()}}}if(n.detail.action==="hideSecondLayer"){const a=n.detail.parent;const e=a.children;a.toggleFirstLayerItem("remove","add");for(let a=0;a<e.length;a++){if(!e[a].isSameNode(n.detail.component)){e[a].hideComponent()}}}if(n.detail.action==="returnToSecondLayer"){const a=n.detail.parent;const e=a.children;a.toggleFirstLayerItem("add","remove");for(let a=0;a<e.length;a++){if(!e[a].isSameNode(n.detail.component)){e[a].showComponent()}}}if(n.detail.action==="show"){const a=this.el.querySelectorAll('[slot="left-item"]');for(let e=0;e<a.length;e++){if(!a[e].isSameNode(n.detail.component)){a[e].showComponent()}}}if(n.detail.action==="return"){const a=this.getMobileMenuTop();for(let e=0;e<a.length;e++){if(!a[e].isSameNode(n.detail.component)){a[e].showComponent()}}}}getWrappers(){const n=this.el.shadowRoot.querySelector(".navbar__container-right-content-navigation-group");const a=this.el.shadowRoot.querySelector(".navbar__container-right-content-navigation-item-search-bar-icon-wrapper");const e=this.el.shadowRoot.querySelector(".navbar__container-left-content-navigation-item-search-bar");const t=n.querySelector('slot[name="right-item"]');const r=a.querySelector("slot");const i=e.querySelector("slot");const o=r.assignedNodes();const _=i.assignedNodes();const c=this.el.querySelector("ifx-navbar-profile");const b=this.el.querySelectorAll('[slot="left-item"]');const s=this.el.querySelectorAll('[slot="right-item"]');const d=this.el.shadowRoot.querySelector(".navbar__sidebar-top-row-wrapper");return{rightSideItemSlot:t,rightSideSlot:r,leftSideSlot:i,rightAssignedNodes:o,leftAssignedNodes:_,navbarProfile:c,leftMenuItems:b,rightMenuItems:s,topRowWrapper:d}}hideNavItems(){const{rightAssignedNodes:n,leftAssignedNodes:a,navbarProfile:e,leftMenuItems:t,rightMenuItems:r,topRowWrapper:i}=this.getWrappers();if(n.length!==0){this.searchBarIsOpen="right"}else if(a.length!==0){this.searchBarIsOpen="left"}if(e){e.hideComponent()}for(let n=0;n<t.length;n++){if(!i.classList.contains("expand")){t[n].hideComponent()}}for(let n=0;n<r.length;n++){if(i.classList.contains("expand")){if(!r[n].hideOnMobile){r[n].hideComponent()}}else{r[n].hideComponent()}}}showNavItems(){const{navbarProfile:n,leftMenuItems:a,rightMenuItems:e,topRowWrapper:t}=this.getWrappers();this.searchBarIsOpen=undefined;if(n){n.showComponent()}for(let n=0;n<a.length;n++){if(!t.classList.contains("expand")){a[n].showComponent()}}for(let n=0;n<e.length;n++){if(t.classList.contains("expand")){if(!e[n].hideOnMobile){e[n].showComponent()}}else{e[n].showComponent()}}}handleSearchBarToggle(n){if(n.detail){this.hideNavItems()}else if(!n.detail){this.showNavItems()}}toggleClass(n,a){n.classList.toggle(a)}handleSidebar(n){const a=n.currentTarget.closest(".navbar__burger-icon-wrapper");const e=a.querySelector(".navbar__burger-icon");const t=a.querySelector(".navbar__cross-icon");const r=n.currentTarget.closest(".navbar__main-container");const i=n.currentTarget.closest(".navbar__wrapper");const o=i.querySelector(".navbar__sidebar");this.toggleClass(i,"show");this.toggleClass(r,"show");this.toggleClass(o,"show");this.toggleClass(e,"close");this.toggleClass(t,"show");if(t.classList.contains("show")){this.handleBodyScroll("hide")}else{this.handleBodyScroll("show")}}handleBodyScroll(n){const a=this.el.closest("body");if(!this.fixed&&n==="hide"){a.style.overflow="hidden"}else if(n==="show"){a.style.overflow="visible"}}handleDropdownMenu(n){const a=n.currentTarget.querySelector(".navbar__dropdown-wrapper");a.classList.toggle("open");const e=n.currentTarget.querySelector("a");e.classList.toggle("open")}async setItemMenuPosition(){const n=this.el.querySelectorAll("ifx-navbar-item");const a=this.el.querySelector("ifx-navbar-profile");if(a){const n=a.querySelectorAll("ifx-navbar-item");if(n.length!==0){n.forEach((n=>{n.setMenuItemPosition();this.setMenuItemChildrenPosition(n)}))}}if(n.length!==0){for(let a=0;a<n.length;a++){const e=n[a];const t=e.querySelectorAll("ifx-navbar-item");if(t.length!==0){const n=await e.setItemSideSpecifications();if(n){t.forEach((n=>{n.setMenuItemPosition();this.setMenuItemChildrenPosition(n)}))}}}}}setMenuItemChildrenPosition(n){const a=n.querySelectorAll("ifx-navbar-item");if(a.length!==0){a.forEach((n=>{n.setMenuItemPosition();this.setMenuItemChildrenPosition(n)}))}}getMediaQueryList(){const n=window.matchMedia("(max-width: 800px)");return n}componentDidLoad(){this.setItemMenuPosition();this.addEventListenersToHandleCustomFocusState();const n=this.getMediaQueryList();if(n.matches){this.moveNavItemsToSidebar()}}handleMobileMenuBottom(n){const a=this.el.shadowRoot.querySelector(".navbar__sidebar-bottom-row");const e=n.target;const t=e.assignedNodes();if(t.length>0){a.classList.add("show")}else{a.classList.remove("show")}}handleLogoHrefAndTarget(){if(this.logoHref.trim()===""){this.internalLogoHref=undefined}else{this.internalLogoHref=this.logoHref}if(["_self","_blank","_parent"].includes(this.logoHrefTarget.trim())){this.internalLogoHrefTarget=this.logoHrefTarget}else{this.internalLogoHrefTarget="_self"}}componentWillLoad(){this.RemoveSpaceOnStorybookSnippet();const n=this.el.querySelector("ifx-navbar-menu");const a=this.el.querySelectorAll('[slot="left-item"]');if(!a.length&&!n){this.hasLeftMenuItems=false}this.handleLogoHrefAndTarget();const e=window.matchMedia("(max-width: 800px)");e.addEventListener("change",(n=>this.moveNavItemsToSidebar(n)))}getSearchBarLeftWrapper(){const n=this.el.shadowRoot.querySelector(".navbar__container-left-content-navigation-item-search-bar");return n}getMobileMenuTop(){const n=this.el.querySelectorAll('[slot="mobile-menu-top"]');return n}getMobileMenuBottom(){const n=this.el.querySelectorAll('[slot="mobile-menu-bottom"]');return n}handleBurgerIcon(){const n=this.getMobileMenuTop();const a=this.getMobileMenuBottom();if(!n.length&&!a.length){const n=this.el.shadowRoot.querySelector(".navbar__burger-icon-wrapper");this.toggleClass(n,"hide")}}moveNavItemsToSidebar(n){const a=this.el.shadowRoot.querySelector(".navbar__sidebar-top-row-wrapper");const e=this.getMediaQueryList();const t=n?n.matches:e.matches;if(t){a.classList.add("expand");const n=this.el.shadowRoot.querySelector(".navbar__cross-icon");if(n.classList.contains("show")){this.handleBodyScroll("hide")}const e=this.el.querySelector('[slot="search-bar-left"]');if(e){if(this.searchBarIsOpen){e.onNavbarMobile()}const n=this.getSearchBarLeftWrapper();n.classList.add("initial");e.setAttribute("slot","search-bar-right")}const t=this.el.querySelectorAll('[slot="left-item"]');for(let n=0;n<t.length;n++){t[n].setAttribute("slot","mobile-menu-top");t[n].moveChildComponentsIntoSubLayerMenu();if(this.searchBarIsOpen){t[n].showComponent()}}const r=this.el.querySelectorAll('[slot="right-item"]');for(let n=0;n<r.length;n++){if(r[n].tagName.toUpperCase()==="IFX-NAVBAR-PROFILE"){r[n].showLabel=false}else{if(r[n].hideOnMobile){r[n].setAttribute("slot","mobile-menu-bottom");r[n].toggleChildren("add");r[n].showLabel=true;if(this.searchBarIsOpen){r[n].showComponent()}}}}this.handleBurgerIcon()}else{a.classList.remove("expand");this.handleBodyScroll("show");const n=this.getSearchBarLeftWrapper();const e=n.classList.contains("initial");const t=this.el.querySelector('[slot="search-bar-right"]');if(e){if(this.searchBarIsOpen){t.onNavbarMobile()}if(t){t.setAttribute("slot","search-bar-left")}}const r=this.getMobileMenuTop();for(let n=0;n<r.length;n++){r[n].setAttribute("slot","left-item");r[n].moveChildComponentsBackIntoNavbar()}const i=this.getMobileMenuBottom();const o=this.el.querySelector("ifx-navbar-profile");if(o){const n=o.getAttribute("show-label");o.setAttribute("show-label",n)}for(let n=0;n<i.length;n++){i[n].setAttribute("slot","right-item");i[n].toggleChildren("remove");const a=i[n].getAttribute("show-label");i[n].setAttribute("show-label",a);if(this.searchBarIsOpen){i[n].hideComponent()}}}}RemoveSpaceOnStorybookSnippet(){let n=this.el.parentElement;if(n){let a=n.closest(".css-xzp052");if(a){a.style.overflow="visible"}}}render(){return e("div",{key:"416b027304db21cac3577b67655d0cdc05df6156","aria-label":"a navigation navbar",class:`navbar__wrapper ${this.fixed?"fixed":""}`},e("div",{key:"558e99ffb3a0ef30734d39b15ae810051e7d03bb",class:`navbar__main-container ${this.fixed?"fixed":""}`},e("div",{key:"30d0f4631a272ae7d496392ed9561cbc37fa0bec",class:`navbar__container ${this.searchBarIsOpen?"expanded":""}`},e("div",{key:"d97d697cdea2d5c06f700839d9cce684247e453c",class:`navbar__container-left ${this.searchBarIsOpen==="left"?"expand":this.searchBarIsOpen==="right"?"hide":""}`},this.showLogoAndAppname&&e("div",{key:"0bb9925aace648bc42c21cee37bfc9b210a701c2",class:`navbar__container-left-logo ${this.searchBarIsOpen==="left"?"hide":""}`},e("div",{key:"e9cb664a3ccea969980f354952580f16369b7080",class:"navbar__container-left-logo-default"},e("a",{key:"5480163f82147b905bc6af9c7b0470c750681fbc",href:this.internalLogoHref,target:this.internalLogoHrefTarget},e("svg",{key:"4df62198f033f8cee348ba6c5d4012a40b68797f",width:"91",height:"40",viewBox:"0 0 91 40",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e("g",{key:"cd5ed92b79d2ce8c7d81f6d818a5c6380f18a317","clip-path":"url(#clip0_2396_2480)"},e("path",{key:"2a63004962f15cddf59d8487a4db96fb51f6ce63",d:"M67.691 26.7766C71.0884 26.7766 72.1461 23.1841 72.1461 19.8802C72.1461 15.4536 70.2871 13.1441 67.691 13.1441C64.4219 13.1441 63.2681 16.7367 63.3001 19.9443C63.3322 23.1199 64.2296 26.7766 67.691 26.7766ZM66.0244 19.8481C66.0244 18.533 66.0244 15.4536 67.691 15.4536C69.4859 15.4536 69.4218 18.5009 69.4218 19.9123C69.4218 21.2595 69.4218 24.5313 67.7551 24.5313C65.9603 24.4992 66.0244 21.2274 66.0244 19.8481ZM57.8195 26.7766C59.1976 26.7766 60.3835 26.2313 61.5053 25.0445L60.5117 23.1841C59.7425 24.018 58.9733 24.4671 58.0438 24.4671C57.2746 24.4671 56.6336 24.018 56.249 23.2482C55.9285 22.5746 55.8644 21.8048 55.8644 20.9708V20.7142H61.6335V20.1368C61.6335 17.282 61.2809 15.7102 60.3835 14.5234C59.7104 13.6253 58.7169 13.1441 57.499 13.1441C56.2169 13.1441 55.1593 13.7215 54.39 14.8442C53.5567 16.0631 53.2042 17.699 53.2042 19.9443C53.1721 24.2426 54.8708 26.7766 57.8195 26.7766ZM57.531 15.2612C58.172 15.2612 58.5566 15.614 58.813 16.1914C59.0053 16.7046 59.1015 17.5707 59.1015 18.5971H55.8644C55.8964 16.3197 56.3772 15.2612 57.531 15.2612ZM74.2614 26.4559H76.7614V16.8329C77.3703 16.0952 78.0754 15.6782 78.5882 15.6782C78.9087 15.6782 79.2292 15.7423 79.4215 15.9989C79.6138 16.2876 79.71 16.7046 79.71 17.699V26.4559H82.21V16.5442C82.21 15.6782 82.1138 14.8121 81.601 14.1706C81.1523 13.5932 80.4472 13.2404 79.5497 13.2404C78.3959 13.2404 77.2101 13.914 76.569 14.6838C76.537 14.0102 76.3126 13.3687 76.2485 13.1441L73.9089 13.7536C74.0371 14.4593 74.2294 15.3253 74.2294 16.8971V26.4559H74.2614ZM45.2236 14.6838C45.1915 14.0102 44.9672 13.3687 44.9031 13.1441L42.5634 13.7536C42.6916 14.4593 42.8839 15.3253 42.8839 16.8971V26.4238H45.3838V16.8008C45.9928 16.0631 46.6979 15.6461 47.2107 15.6461C47.5312 15.6461 47.8517 15.7102 48.044 15.9669C48.2363 16.2555 48.3325 16.6725 48.3325 17.6669V26.4238H50.8324V16.5442C50.8324 15.6782 50.7363 14.8121 50.2235 14.1706C49.7748 13.5932 49.0696 13.2404 48.1722 13.2404C47.0505 13.2404 45.8646 13.914 45.2236 14.6838ZM14.6473 9.07042C16.1216 9.07042 17.3075 7.88359 17.3075 6.40807C17.3075 4.93256 16.1216 3.74573 14.6473 3.74573C13.173 3.74573 11.9871 4.93256 11.9871 6.40807C11.9871 7.88359 13.173 9.07042 14.6473 9.07042ZM26.9227 26.4559V16.5442C26.9227 15.6782 26.8265 14.8121 26.3137 14.1706C25.865 13.5932 25.1599 13.2404 24.2625 13.2404C23.1087 13.2404 21.9228 13.914 21.2818 14.6838C21.2497 14.0102 21.0254 13.3687 20.9613 13.1441L18.6536 13.7857C18.7818 14.4913 18.9741 15.3574 18.9741 16.9291V26.4559H21.4741V16.8329C22.0831 16.0952 22.7882 15.6782 23.301 15.6782C23.6215 15.6782 23.942 15.7423 24.1343 15.9989C24.3266 16.2876 24.4227 16.7046 24.4227 17.699V26.4559H26.9227ZM38.4289 8.36474C37.4994 8.36474 36.7622 9.10249 36.7622 10.0327C36.7622 10.9629 37.4994 11.7007 38.3968 11.7007C39.3263 11.7007 40.0634 10.9629 40.0634 10.0327C40.0634 9.10249 39.3263 8.36474 38.4289 8.36474ZM13.4614 26.4559H15.9614V10.8346L13.4614 11.1554V26.4559ZM33.8777 9.90441C34.3264 9.90441 34.7751 10.0648 35.0635 10.2893L35.7687 8.33266C35.0956 7.85151 34.3584 7.62698 33.429 7.62698C32.788 7.62698 32.1149 7.78736 31.5059 8.26851C30.897 8.78173 30.256 9.80818 30.256 11.7328C30.256 12.5667 30.288 13.4328 30.288 13.4328H29.4226V15.6461H30.288V26.4238H32.8521V15.6782H34.743L35.2238 13.4649H32.8841V11.4762C32.8841 10.5139 33.2687 9.90441 33.8777 9.90441ZM37.1468 26.4559H39.6788V13.2404L37.1468 13.5611V26.4559Z",fill:"#005DA9"}),e("path",{key:"eb2a7abea42ac9807a948394257d4c658205fd73",d:"M77.0816 33.5126C68.6203 36.0146 58.3321 37.1052 48.2682 37.1052C22.7239 37.1052 6.24986 29.5993 5.09604 19.6877C4.67938 15.9668 7.59599 12.3422 12.4677 9.26285C11.6023 8.62132 11.0575 7.59488 11.0254 6.44012C3.97427 10.161 0 15.0366 0 19.9764C0 30.9145 19.5188 40.1525 48.5246 39.7676C58.6205 39.6393 67.0498 38.1958 74.6778 35.6939C83.7482 32.7428 89.4532 28.5087 90.8313 26.6483C89.1968 28.1238 85.3186 31.0748 77.0816 33.5126ZM23.2687 4.38723C24.9674 3.80985 27.3712 3.0721 27.3712 3.0721C34.1339 1.21166 41.6017 0.121063 48.5566 0.185215C40.544 -0.295931 33.2365 0.185215 26.8584 1.33997C26.8584 1.33997 24.743 1.69281 22.4675 2.27018C22.4675 2.27018 21.3777 2.55887 20.7047 2.75133C20.0316 2.94379 19.1021 3.2004 19.1021 3.2004C18.4611 3.39286 17.8201 3.6174 17.1791 3.84193C17.8201 4.48346 18.2047 5.31745 18.2368 6.27974C19.3586 5.76652 21.5059 4.99668 23.2687 4.38723Z",fill:"#E30034"})),e("defs",{key:"25cbd225df6349e7f52f3a736a62876b840119c4"},e("clipPath",{key:"4110a721ef2c2420738b2f8a3e8ac1c3d9e8a4b7",id:"clip0_2396_2480"},e("rect",{key:"2bfa5ab4ddfe868a8724bc669de44c938c43af07",width:"91",height:"40",fill:"white"})))))),this.applicationName&&e("h6",{key:"948406fa9fff795d692bbedb0facaff232019e89"},this.applicationName),this.applicationName&&this.hasLeftMenuItems&&e("div",{key:"7b2240a8427cc28d9c2e677a282698727cbb7dce",class:"navbar__container-left-logo-divider"})),e("div",{key:"f30bc0f381fe39697172663299c8c76fef1572d7",class:"navbar__container-left-content"},e("div",{key:"d895428826adbdb43701910e0205b9870a4acfee",class:"navbar__container-left-content-navigation-group"},e("slot",{key:"59cfc54f1491b314a60bed89b070ee51bb6e49b2",name:"left-item"}),e("div",{key:"b13958bbfdcd6ee5df9ff5089ea1c3352e3be908",class:"navbar__container-left-content-navigation-item-search-bar"},e("slot",{key:"ccd43778bdc92bdce87d1fc3c16beac600bd7d87",name:"search-bar-left"}))))),e("div",{key:"b9f46eeb20e6b8b01aac4bf007a45e3415be60bf",class:`navbar__container-right ${this.searchBarIsOpen==="right"?"expand":this.searchBarIsOpen==="left"?"hide":""}`},e("div",{key:"1048ddc022ed7dad75f7848009b160301d5e5cf4",class:"navbar__container-right-content"},e("div",{key:"ec18a8c76af0709801ea18f005ed5e683d9602cd",class:"navbar__container-right-content-navigation-group"},e("div",{key:"4cdf960019e17d6b3f385f0bd2cf07021f84783c",class:"navbar__container-right-content-navigation-item-search-bar"},e("div",{key:"ee7d16e126763f022dd32f25b961d90ed3f7d196",class:`navbar__container-right-content-navigation-item-search-bar-icon-wrapper`},e("slot",{key:"3791b5c770703be61a6a9243369ad752f0781968",name:"search-bar-right"}))),e("slot",{key:"157fc4591be126c0c438b402c334c1c4c0c57842",name:"right-item"}))),e("div",{key:"1181662da2c835b18c9a10c159c06aeb5445e7ab",class:`navbar__burger-icon-wrapper`,onClick:this.handleSidebar.bind(this)},e("div",{key:"0bd3af38fede3b61ed3f23f2aa91f58bafed30a0",class:"navbar__burger-icon"},e("ifx-icon",{key:"340c50645be54842cc4a856e8febbe44257e7dd3",icon:"menu-right-16"})),e("div",{key:"3cdbf2f737d9f4afb366ea9f1219aa0f8671eea7",class:"navbar__cross-icon"},e("ifx-icon",{key:"0a7e8d914b312f0654b61ae6e80e4b4cf537e997",icon:"cross-16"})))))),e("div",{key:"6f28cbdf66a563fd1032594ebeb527a71186f7e6",class:"navbar__sidebar"},e("div",{key:"010ba1e43c571feeb16840b31762e6acf237c8bd",class:"navbar__sidebar-top-row"},e("div",{key:"31c0895eda2a55c71fc9d3f15dc980066778053c",class:"navbar__sidebar-top-row-wrapper"},e("slot",{key:"20585d83512eb5e12646fae63c0f97f0b6f2b692",name:"mobile-menu-top"}))),e("div",{key:"0015486d20c1e28363109e7719e59329db994597",class:"navbar__sidebar-bottom-row"},e("slot",{key:"aa36dbfb758007a8cbc3ae0cee777522bca9f7b5",name:"mobile-menu-bottom",onSlotchange:n=>this.handleMobileMenuBottom(n)}))))}get el(){return t(this)}};o.style=i;export{o as ifx_navbar};
2
+ //# sourceMappingURL=p-37d6c639.entry.js.map