@infineon/infineon-design-system-stencil 36.1.1--canary.1935.4c802385604f5b96d3f68ddec57be22228530228.0 → 37.0.0--canary.1926.fb96c7ae3f791f0a522da4d207e38965cf9cb62b.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 (717) hide show
  1. package/dist/cjs/ifx-accordion_2.cjs.entry.js +1 -8
  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 +1 -6
  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 +1 -31
  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 +929 -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 +2 -7
  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-stepper.cjs.entry.js +2 -7
  79. package/dist/cjs/ifx-stepper.cjs.entry.js.map +1 -1
  80. package/dist/cjs/ifx-switch.cjs.entry.js +1 -6
  81. package/dist/cjs/ifx-switch.cjs.entry.js.map +1 -1
  82. package/dist/cjs/ifx-tab.cjs.entry.js +1 -1
  83. package/dist/cjs/ifx-table.cjs.entry.js +2 -7
  84. package/dist/cjs/ifx-table.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ifx-tabs.cjs.entry.js +2 -7
  86. package/dist/cjs/ifx-tabs.cjs.entry.js.map +1 -1
  87. package/dist/cjs/ifx-tag.cjs.entry.js +1 -9
  88. package/dist/cjs/ifx-tag.cjs.entry.js.map +1 -1
  89. package/dist/cjs/ifx-templates-ui.cjs.entry.js +1 -1
  90. package/dist/cjs/ifx-textarea.cjs.entry.js +1 -6
  91. package/dist/cjs/ifx-textarea.cjs.entry.js.map +1 -1
  92. package/dist/cjs/ifx-tooltip.cjs.entry.js +4 -9
  93. package/dist/cjs/ifx-tooltip.cjs.entry.js.map +1 -1
  94. package/dist/cjs/ifx-tree-view-item.cjs.entry.js +2 -2
  95. package/dist/cjs/ifx-tree-view.cjs.entry.js +1 -9
  96. package/dist/cjs/ifx-tree-view.cjs.entry.js.map +1 -1
  97. package/dist/cjs/index-7f4df11a.js +14 -14
  98. package/dist/cjs/infineon-design-system-stencil.cjs.js +1 -1
  99. package/dist/cjs/loader.cjs.js +1 -1
  100. package/dist/collection/collection-manifest.json +1 -0
  101. package/dist/collection/components/accordion/accordion.js +2 -8
  102. package/dist/collection/components/accordion/accordion.js.map +1 -1
  103. package/dist/collection/components/alert/alert.js +0 -6
  104. package/dist/collection/components/alert/alert.js.map +1 -1
  105. package/dist/collection/components/badge/badge.js +1 -9
  106. package/dist/collection/components/badge/badge.js.map +1 -1
  107. package/dist/collection/components/breadcrumb/breadcrumb.js +1 -8
  108. package/dist/collection/components/breadcrumb/breadcrumb.js.map +1 -1
  109. package/dist/collection/components/button/button.js +1 -6
  110. package/dist/collection/components/button/button.js.map +1 -1
  111. package/dist/collection/components/card/card.js +3 -8
  112. package/dist/collection/components/card/card.js.map +1 -1
  113. package/dist/collection/components/checkbox/checkbox.js +3 -8
  114. package/dist/collection/components/checkbox/checkbox.js.map +1 -1
  115. package/dist/collection/components/checkbox-group/checkbox-group.js +1 -6
  116. package/dist/collection/components/checkbox-group/checkbox-group.js.map +1 -1
  117. package/dist/collection/components/chip/chip.js +8 -13
  118. package/dist/collection/components/chip/chip.js.map +1 -1
  119. package/dist/collection/components/content-switcher/content-switcher.js +1 -6
  120. package/dist/collection/components/content-switcher/content-switcher.js.map +1 -1
  121. package/dist/collection/components/date-picker/date-picker.js +2 -9
  122. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  123. package/dist/collection/components/dropdown/dropdown.js +1 -6
  124. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  125. package/dist/collection/components/file-upload/file-upload.js +2 -9
  126. package/dist/collection/components/file-upload/file-upload.js.map +1 -1
  127. package/dist/collection/components/footer/footer.js +4 -9
  128. package/dist/collection/components/footer/footer.js.map +1 -1
  129. package/dist/collection/components/icon/infineonIconStencil.js +1 -31
  130. package/dist/collection/components/icon/infineonIconStencil.js.map +1 -1
  131. package/dist/collection/components/icon-button/icon-button.js +1 -6
  132. package/dist/collection/components/icon-button/icon-button.js.map +1 -1
  133. package/dist/collection/components/indicator/indicator.js +2 -7
  134. package/dist/collection/components/indicator/indicator.js.map +1 -1
  135. package/dist/collection/components/link/link.js +1 -9
  136. package/dist/collection/components/link/link.js.map +1 -1
  137. package/dist/collection/components/modal/modal.js +2 -9
  138. package/dist/collection/components/modal/modal.js.map +1 -1
  139. package/dist/collection/components/navigation/navbar/navbar.js +3 -5
  140. package/dist/collection/components/navigation/navbar/navbar.js.map +1 -1
  141. package/dist/collection/components/navigation/sidebar/sidebar.js +5 -7
  142. package/dist/collection/components/navigation/sidebar/sidebar.js.map +1 -1
  143. package/dist/collection/components/notification/notification.js +2 -10
  144. package/dist/collection/components/notification/notification.js.map +1 -1
  145. package/dist/collection/components/pagination/pagination.js +1 -6
  146. package/dist/collection/components/pagination/pagination.js.map +1 -1
  147. package/dist/collection/components/progress-bar/progress-bar.js +1 -7
  148. package/dist/collection/components/progress-bar/progress-bar.js.map +1 -1
  149. package/dist/collection/components/radio-button/radio-button.js +2 -7
  150. package/dist/collection/components/radio-button/radio-button.js.map +1 -1
  151. package/dist/collection/components/radio-button-group/radio-button-group.js +1 -6
  152. package/dist/collection/components/radio-button-group/radio-button-group.js.map +1 -1
  153. package/dist/collection/components/search-bar/search-bar.js +1 -6
  154. package/dist/collection/components/search-bar/search-bar.js.map +1 -1
  155. package/dist/collection/components/search-field/search-field.js +1 -9
  156. package/dist/collection/components/search-field/search-field.js.map +1 -1
  157. package/dist/collection/components/segmented-control/segmented-control.js +2 -9
  158. package/dist/collection/components/segmented-control/segmented-control.js.map +1 -1
  159. package/dist/collection/components/select/multi-select/interfaces.js.map +1 -1
  160. package/dist/collection/components/select/multi-select/multiselect-option.css +112 -0
  161. package/dist/collection/components/select/multi-select/multiselect-option.js +505 -0
  162. package/dist/collection/components/select/multi-select/multiselect-option.js.map +1 -0
  163. package/dist/collection/components/select/multi-select/multiselect.css +60 -65
  164. package/dist/collection/components/select/multi-select/multiselect.js +675 -432
  165. package/dist/collection/components/select/multi-select/multiselect.js.map +1 -1
  166. package/dist/collection/components/select/multi-select/multiselect.stories.js +439 -135
  167. package/dist/collection/components/select/multi-select/multiselect.stories.js.map +1 -1
  168. package/dist/collection/components/select/single-select/select.js +2 -7
  169. package/dist/collection/components/select/single-select/select.js.map +1 -1
  170. package/dist/collection/components/slider/slider.js +2 -7
  171. package/dist/collection/components/slider/slider.js.map +1 -1
  172. package/dist/collection/components/spinner/spinner.js +2 -10
  173. package/dist/collection/components/spinner/spinner.js.map +1 -1
  174. package/dist/collection/components/status/status.js +1 -9
  175. package/dist/collection/components/status/status.js.map +1 -1
  176. package/dist/collection/components/stepper/step/step.js +4 -4
  177. package/dist/collection/components/stepper/stepper.js +2 -7
  178. package/dist/collection/components/stepper/stepper.js.map +1 -1
  179. package/dist/collection/components/switch/switch.js +1 -6
  180. package/dist/collection/components/switch/switch.js.map +1 -1
  181. package/dist/collection/components/table-advanced-version/filter-bar/filter-bar.js +1 -1
  182. package/dist/collection/components/table-advanced-version/filter-type-group/filter-accordion/filter-accordion.js +2 -2
  183. package/dist/collection/components/table-advanced-version/filter-type-group/filter-search/filter-search.js +1 -1
  184. package/dist/collection/components/table-advanced-version/filter-type-group/filter-type-group.js +1 -1
  185. package/dist/collection/components/table-advanced-version/list/list-entry/list-entry.js +1 -1
  186. package/dist/collection/components/table-advanced-version/set-filter/setFilter.js +19 -2
  187. package/dist/collection/components/table-advanced-version/set-filter/setFilter.js.map +1 -1
  188. package/dist/collection/components/table-advanced-version/table.js +2 -7
  189. package/dist/collection/components/table-advanced-version/table.js.map +1 -1
  190. package/dist/collection/components/table-advanced-version/table.stories.js +2 -3
  191. package/dist/collection/components/table-advanced-version/table.stories.js.map +1 -1
  192. package/dist/collection/components/table-basic-version/table.js +1 -6
  193. package/dist/collection/components/table-basic-version/table.js.map +1 -1
  194. package/dist/collection/components/tabs/tab.js +1 -1
  195. package/dist/collection/components/tabs/tabs.js +3 -7
  196. package/dist/collection/components/tabs/tabs.js.map +1 -1
  197. package/dist/collection/components/tag/tag.js +1 -9
  198. package/dist/collection/components/tag/tag.js.map +1 -1
  199. package/dist/collection/components/templates/template/template.js +1 -1
  200. package/dist/collection/components/templates/templates-ui/templates-ui.js +1 -1
  201. package/dist/collection/components/text-field/text-field.js +4 -9
  202. package/dist/collection/components/text-field/text-field.js.map +1 -1
  203. package/dist/collection/components/textarea/textarea.js +1 -6
  204. package/dist/collection/components/textarea/textarea.js.map +1 -1
  205. package/dist/collection/components/tooltip/tooltip.js +4 -9
  206. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  207. package/dist/collection/components/tree-view/tree-view-item.js +2 -2
  208. package/dist/collection/components/tree-view/tree-view.js +1 -9
  209. package/dist/collection/components/tree-view/tree-view.js.map +1 -1
  210. package/dist/collection/stories/setup-and-installation/faq/faq.js +1 -1
  211. package/dist/components/ifx-accordion-item.js +1 -1
  212. package/dist/components/ifx-accordion.js +1 -1
  213. package/dist/components/ifx-alert.js +1 -1
  214. package/dist/components/ifx-badge.js +1 -9
  215. package/dist/components/ifx-badge.js.map +1 -1
  216. package/dist/components/ifx-basic-table.js +1 -6
  217. package/dist/components/ifx-basic-table.js.map +1 -1
  218. package/dist/components/ifx-breadcrumb-item-label.js +1 -1
  219. package/dist/components/ifx-breadcrumb.js +1 -8
  220. package/dist/components/ifx-breadcrumb.js.map +1 -1
  221. package/dist/components/ifx-button.js +1 -1
  222. package/dist/components/ifx-card.js +3 -8
  223. package/dist/components/ifx-card.js.map +1 -1
  224. package/dist/components/ifx-checkbox-group.js +2 -7
  225. package/dist/components/ifx-checkbox-group.js.map +1 -1
  226. package/dist/components/ifx-checkbox.js +1 -1
  227. package/dist/components/ifx-chip-item.js +1 -1
  228. package/dist/components/ifx-chip.js +1 -1
  229. package/dist/components/ifx-content-switcher.js +1 -6
  230. package/dist/components/ifx-content-switcher.js.map +1 -1
  231. package/dist/components/ifx-date-picker.js +3 -10
  232. package/dist/components/ifx-date-picker.js.map +1 -1
  233. package/dist/components/ifx-download.js +1 -1
  234. package/dist/components/ifx-dropdown-item.js +1 -1
  235. package/dist/components/ifx-dropdown-separator.js +29 -1
  236. package/dist/components/ifx-dropdown-separator.js.map +1 -1
  237. package/dist/components/ifx-dropdown-trigger-button.js +2 -2
  238. package/dist/components/ifx-dropdown.js +1 -6
  239. package/dist/components/ifx-dropdown.js.map +1 -1
  240. package/dist/components/ifx-faq.js +4 -4
  241. package/dist/components/ifx-file-upload.js +6 -13
  242. package/dist/components/ifx-file-upload.js.map +1 -1
  243. package/dist/components/ifx-filter-accordion.js +4 -4
  244. package/dist/components/ifx-filter-bar.js +3 -3
  245. package/dist/components/ifx-filter-search.js +3 -3
  246. package/dist/components/ifx-filter-type-group.js +1 -1
  247. package/dist/components/ifx-footer.js +4 -9
  248. package/dist/components/ifx-footer.js.map +1 -1
  249. package/dist/components/ifx-icon-button.js +1 -1
  250. package/dist/components/ifx-icon.js +1 -1
  251. package/dist/components/ifx-icons-preview.js +4 -4
  252. package/dist/components/ifx-indicator.js +1 -1
  253. package/dist/components/ifx-link.js +1 -1
  254. package/dist/components/ifx-list-entry.js +4 -4
  255. package/dist/components/ifx-list.js +2 -2
  256. package/dist/components/ifx-modal.js +4 -11
  257. package/dist/components/ifx-modal.js.map +1 -1
  258. package/dist/components/ifx-multiselect-option.d.ts +11 -0
  259. package/dist/components/ifx-multiselect-option.js +8 -0
  260. package/dist/components/ifx-multiselect-option.js.map +1 -0
  261. package/dist/components/ifx-multiselect.js +1 -1
  262. package/dist/components/ifx-navbar-item.js +2 -2
  263. package/dist/components/ifx-navbar.js +4 -6
  264. package/dist/components/ifx-navbar.js.map +1 -1
  265. package/dist/components/ifx-notification.js +1 -1
  266. package/dist/components/ifx-overview-table.js +3 -3
  267. package/dist/components/ifx-pagination.js +1 -1
  268. package/dist/components/ifx-progress-bar.js +1 -1
  269. package/dist/components/ifx-radio-button-group.js +2 -7
  270. package/dist/components/ifx-radio-button-group.js.map +1 -1
  271. package/dist/components/ifx-radio-button.js +1 -1
  272. package/dist/components/ifx-search-bar.js +3 -8
  273. package/dist/components/ifx-search-bar.js.map +1 -1
  274. package/dist/components/ifx-search-field.js +1 -1
  275. package/dist/components/ifx-segment.js +1 -1
  276. package/dist/components/ifx-segmented-control.js +3 -10
  277. package/dist/components/ifx-segmented-control.js.map +1 -1
  278. package/dist/components/ifx-select.js +1 -1
  279. package/dist/components/ifx-set-filter.js +35 -12
  280. package/dist/components/ifx-set-filter.js.map +1 -1
  281. package/dist/components/ifx-sidebar-item.js +2 -2
  282. package/dist/components/ifx-sidebar.js +5 -7
  283. package/dist/components/ifx-sidebar.js.map +1 -1
  284. package/dist/components/ifx-slider.js +3 -8
  285. package/dist/components/ifx-slider.js.map +1 -1
  286. package/dist/components/ifx-spinner.js +1 -1
  287. package/dist/components/ifx-status.js +1 -9
  288. package/dist/components/ifx-status.js.map +1 -1
  289. package/dist/components/ifx-step.js +5 -5
  290. package/dist/components/ifx-stepper.js +2 -7
  291. package/dist/components/ifx-stepper.js.map +1 -1
  292. package/dist/components/ifx-switch.js +1 -6
  293. package/dist/components/ifx-switch.js.map +1 -1
  294. package/dist/components/ifx-tab.js +1 -1
  295. package/dist/components/ifx-table.js +11 -16
  296. package/dist/components/ifx-table.js.map +1 -1
  297. package/dist/components/ifx-tabs.js +3 -8
  298. package/dist/components/ifx-tabs.js.map +1 -1
  299. package/dist/components/ifx-tag.js +2 -10
  300. package/dist/components/ifx-tag.js.map +1 -1
  301. package/dist/components/ifx-template.js +1 -1
  302. package/dist/components/ifx-templates-ui.js +9 -9
  303. package/dist/components/ifx-text-field.js +1 -1
  304. package/dist/components/ifx-textarea.js +1 -6
  305. package/dist/components/ifx-textarea.js.map +1 -1
  306. package/dist/components/ifx-tooltip.js +5 -10
  307. package/dist/components/ifx-tooltip.js.map +1 -1
  308. package/dist/components/ifx-tree-view-item.js +4 -4
  309. package/dist/components/ifx-tree-view.js +1 -9
  310. package/dist/components/ifx-tree-view.js.map +1 -1
  311. package/dist/components/{p-9b236210.js → p-030c9f43.js} +7 -7
  312. package/dist/components/{p-9b236210.js.map → p-030c9f43.js.map} +1 -1
  313. package/dist/components/{p-b1ca5daf.js → p-0c449780.js} +3 -8
  314. package/dist/components/p-0c449780.js.map +1 -0
  315. package/dist/components/{p-816b2612.js → p-17df0350.js} +2 -7
  316. package/dist/components/p-17df0350.js.map +1 -0
  317. package/dist/components/{p-331ca3f3.js → p-186dacc8.js} +5 -10
  318. package/dist/components/p-186dacc8.js.map +1 -0
  319. package/dist/components/p-320bce19.js +432 -0
  320. package/dist/components/p-320bce19.js.map +1 -0
  321. package/dist/components/{p-e126ea6f.js → p-351949f1.js} +3 -11
  322. package/dist/components/p-351949f1.js.map +1 -0
  323. package/dist/components/{p-54b39a91.js → p-357107c5.js} +3 -8
  324. package/dist/components/p-357107c5.js.map +1 -0
  325. package/dist/components/{p-c6e5f94d.js → p-38396fe7.js} +3 -11
  326. package/dist/components/p-38396fe7.js.map +1 -0
  327. package/dist/components/{p-b4630d0d.js → p-526e05ad.js} +6 -11
  328. package/dist/components/p-526e05ad.js.map +1 -0
  329. package/dist/components/{p-9ea9e274.js → p-53d4339c.js} +2 -10
  330. package/dist/components/p-53d4339c.js.map +1 -0
  331. package/dist/components/{p-6d95b3c1.js → p-5e9d3450.js} +2 -8
  332. package/dist/components/p-5e9d3450.js.map +1 -0
  333. package/dist/components/{p-ab4beff7.js → p-6d12f845.js} +5 -13
  334. package/dist/components/p-6d12f845.js.map +1 -0
  335. package/dist/components/{p-94da6823.js → p-9142f93b.js} +3 -8
  336. package/dist/components/p-9142f93b.js.map +1 -0
  337. package/dist/components/{p-927d5fd1.js → p-a8d0ef73.js} +11 -16
  338. package/dist/components/p-a8d0ef73.js.map +1 -0
  339. package/dist/components/p-a9d3e6d2.js +599 -0
  340. package/dist/components/p-a9d3e6d2.js.map +1 -0
  341. package/dist/components/{p-f9815000.js → p-b0039ef1.js} +2 -8
  342. package/dist/components/p-b0039ef1.js.map +1 -0
  343. package/dist/components/{p-0e4632d4.js → p-bb4de57d.js} +2 -32
  344. package/dist/components/p-bb4de57d.js.map +1 -0
  345. package/dist/components/{p-be3268af.js → p-c3c4dfdd.js} +5 -10
  346. package/dist/components/p-c3c4dfdd.js.map +1 -0
  347. package/dist/components/{p-940ee336.js → p-cd913238.js} +3 -3
  348. package/dist/components/{p-940ee336.js.map → p-cd913238.js.map} +1 -1
  349. package/dist/components/{p-39859c18.js → p-cec3c56f.js} +4 -9
  350. package/dist/components/p-cec3c56f.js.map +1 -0
  351. package/dist/components/{p-0590639e.js → p-d1790232.js} +2 -2
  352. package/dist/components/{p-0590639e.js.map → p-d1790232.js.map} +1 -1
  353. package/dist/components/{p-cca71d97.js → p-ed739e86.js} +2 -9
  354. package/dist/components/p-ed739e86.js.map +1 -0
  355. package/dist/esm/ifx-accordion_2.entry.js +1 -8
  356. package/dist/esm/ifx-accordion_2.entry.js.map +1 -1
  357. package/dist/esm/ifx-alert_2.entry.js +1 -7
  358. package/dist/esm/ifx-alert_2.entry.js.map +1 -1
  359. package/dist/esm/ifx-badge.entry.js +2 -10
  360. package/dist/esm/ifx-badge.entry.js.map +1 -1
  361. package/dist/esm/ifx-basic-table.entry.js +1 -6
  362. package/dist/esm/ifx-basic-table.entry.js.map +1 -1
  363. package/dist/esm/ifx-breadcrumb.entry.js +1 -8
  364. package/dist/esm/ifx-breadcrumb.entry.js.map +1 -1
  365. package/dist/esm/ifx-button.entry.js +1 -6
  366. package/dist/esm/ifx-button.entry.js.map +1 -1
  367. package/dist/esm/ifx-card.entry.js +3 -8
  368. package/dist/esm/ifx-card.entry.js.map +1 -1
  369. package/dist/esm/ifx-checkbox-group.entry.js +1 -6
  370. package/dist/esm/ifx-checkbox-group.entry.js.map +1 -1
  371. package/dist/esm/ifx-checkbox.entry.js +3 -8
  372. package/dist/esm/ifx-checkbox.entry.js.map +1 -1
  373. package/dist/esm/ifx-chip_3.entry.js +9 -17
  374. package/dist/esm/ifx-chip_3.entry.js.map +1 -1
  375. package/dist/esm/ifx-content-switcher.entry.js +1 -6
  376. package/dist/esm/ifx-content-switcher.entry.js.map +1 -1
  377. package/dist/esm/ifx-date-picker.entry.js +2 -9
  378. package/dist/esm/ifx-date-picker.entry.js.map +1 -1
  379. package/dist/esm/ifx-dropdown.entry.js +1 -6
  380. package/dist/esm/ifx-dropdown.entry.js.map +1 -1
  381. package/dist/esm/ifx-faq.entry.js +1 -1
  382. package/dist/esm/ifx-file-upload.entry.js +2 -9
  383. package/dist/esm/ifx-file-upload.entry.js.map +1 -1
  384. package/dist/esm/ifx-filter-accordion.entry.js +2 -2
  385. package/dist/esm/ifx-filter-bar.entry.js +1 -1
  386. package/dist/esm/ifx-filter-search.entry.js +1 -1
  387. package/dist/esm/ifx-filter-type-group.entry.js +1 -1
  388. package/dist/esm/ifx-footer.entry.js +4 -9
  389. package/dist/esm/ifx-footer.entry.js.map +1 -1
  390. package/dist/esm/ifx-icon-button.entry.js +1 -6
  391. package/dist/esm/ifx-icon-button.entry.js.map +1 -1
  392. package/dist/esm/ifx-icon.entry.js +2 -32
  393. package/dist/esm/ifx-icon.entry.js.map +1 -1
  394. package/dist/esm/ifx-indicator.entry.js +2 -7
  395. package/dist/esm/ifx-indicator.entry.js.map +1 -1
  396. package/dist/esm/ifx-link.entry.js +2 -10
  397. package/dist/esm/ifx-link.entry.js.map +1 -1
  398. package/dist/esm/ifx-list-entry.entry.js +1 -1
  399. package/dist/esm/ifx-modal.entry.js +2 -9
  400. package/dist/esm/ifx-modal.entry.js.map +1 -1
  401. package/dist/esm/ifx-multiselect_2.entry.js +924 -0
  402. package/dist/esm/ifx-multiselect_2.entry.js.map +1 -0
  403. package/dist/esm/ifx-navbar.entry.js +3 -5
  404. package/dist/esm/ifx-navbar.entry.js.map +1 -1
  405. package/dist/esm/ifx-notification.entry.js +3 -11
  406. package/dist/esm/ifx-notification.entry.js.map +1 -1
  407. package/dist/esm/ifx-progress-bar.entry.js +2 -8
  408. package/dist/esm/ifx-progress-bar.entry.js.map +1 -1
  409. package/dist/esm/ifx-radio-button-group.entry.js +1 -6
  410. package/dist/esm/ifx-radio-button-group.entry.js.map +1 -1
  411. package/dist/esm/ifx-radio-button.entry.js +2 -7
  412. package/dist/esm/ifx-radio-button.entry.js.map +1 -1
  413. package/dist/esm/ifx-search-bar.entry.js +1 -6
  414. package/dist/esm/ifx-search-bar.entry.js.map +1 -1
  415. package/dist/esm/ifx-search-field.entry.js +2 -10
  416. package/dist/esm/ifx-search-field.entry.js.map +1 -1
  417. package/dist/esm/ifx-segmented-control.entry.js +2 -9
  418. package/dist/esm/ifx-segmented-control.entry.js.map +1 -1
  419. package/dist/esm/ifx-select.entry.js +2 -7
  420. package/dist/esm/ifx-select.entry.js.map +1 -1
  421. package/dist/esm/ifx-set-filter.entry.js +19 -2
  422. package/dist/esm/ifx-set-filter.entry.js.map +1 -1
  423. package/dist/esm/ifx-sidebar.entry.js +5 -7
  424. package/dist/esm/ifx-sidebar.entry.js.map +1 -1
  425. package/dist/esm/ifx-slider.entry.js +2 -7
  426. package/dist/esm/ifx-slider.entry.js.map +1 -1
  427. package/dist/esm/ifx-spinner_2.entry.js +7 -18
  428. package/dist/esm/ifx-spinner_2.entry.js.map +1 -1
  429. package/dist/esm/ifx-status.entry.js +2 -10
  430. package/dist/esm/ifx-status.entry.js.map +1 -1
  431. package/dist/esm/ifx-step.entry.js +4 -4
  432. package/dist/esm/ifx-stepper.entry.js +2 -7
  433. package/dist/esm/ifx-stepper.entry.js.map +1 -1
  434. package/dist/esm/ifx-switch.entry.js +1 -6
  435. package/dist/esm/ifx-switch.entry.js.map +1 -1
  436. package/dist/esm/ifx-tab.entry.js +1 -1
  437. package/dist/esm/ifx-table.entry.js +2 -7
  438. package/dist/esm/ifx-table.entry.js.map +1 -1
  439. package/dist/esm/ifx-tabs.entry.js +2 -7
  440. package/dist/esm/ifx-tabs.entry.js.map +1 -1
  441. package/dist/esm/ifx-tag.entry.js +2 -10
  442. package/dist/esm/ifx-tag.entry.js.map +1 -1
  443. package/dist/esm/ifx-templates-ui.entry.js +1 -1
  444. package/dist/esm/ifx-textarea.entry.js +1 -6
  445. package/dist/esm/ifx-textarea.entry.js.map +1 -1
  446. package/dist/esm/ifx-tooltip.entry.js +4 -9
  447. package/dist/esm/ifx-tooltip.entry.js.map +1 -1
  448. package/dist/esm/ifx-tree-view-item.entry.js +2 -2
  449. package/dist/esm/ifx-tree-view.entry.js +2 -10
  450. package/dist/esm/ifx-tree-view.entry.js.map +1 -1
  451. package/dist/esm/index-6c9eba32.js +14 -14
  452. package/dist/esm/infineon-design-system-stencil.js +1 -1
  453. package/dist/esm/loader.js +1 -1
  454. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js +1 -1
  455. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js.map +1 -1
  456. package/dist/infineon-design-system-stencil/p-02496917.entry.js +2 -0
  457. package/dist/infineon-design-system-stencil/p-02496917.entry.js.map +1 -0
  458. package/dist/infineon-design-system-stencil/{p-f2bea855.entry.js → p-04d8ea38.entry.js} +2 -2
  459. package/dist/infineon-design-system-stencil/p-061bfdb1.entry.js +2 -0
  460. package/dist/infineon-design-system-stencil/p-061bfdb1.entry.js.map +1 -0
  461. package/dist/infineon-design-system-stencil/{p-87fbd617.entry.js → p-0c1c831c.entry.js} +2 -2
  462. package/dist/infineon-design-system-stencil/{p-76914839.entry.js → p-0d3e5a0d.entry.js} +2 -2
  463. package/dist/infineon-design-system-stencil/p-0d3e5a0d.entry.js.map +1 -0
  464. package/dist/infineon-design-system-stencil/p-13c107bf.entry.js +2 -0
  465. package/dist/infineon-design-system-stencil/p-13c107bf.entry.js.map +1 -0
  466. package/dist/infineon-design-system-stencil/p-17f3f2f5.entry.js +2 -0
  467. package/dist/infineon-design-system-stencil/p-17f3f2f5.entry.js.map +1 -0
  468. package/dist/infineon-design-system-stencil/{p-2b38c405.entry.js → p-18a81f5f.entry.js} +2 -2
  469. package/dist/infineon-design-system-stencil/p-2006c7a0.entry.js +2 -0
  470. package/dist/infineon-design-system-stencil/p-2006c7a0.entry.js.map +1 -0
  471. package/dist/infineon-design-system-stencil/p-25204a1e.entry.js +2 -0
  472. package/dist/infineon-design-system-stencil/p-25204a1e.entry.js.map +1 -0
  473. package/dist/infineon-design-system-stencil/p-292cff35.entry.js +2 -0
  474. package/dist/infineon-design-system-stencil/p-292cff35.entry.js.map +1 -0
  475. package/dist/infineon-design-system-stencil/p-2d89c5e0.entry.js +2 -0
  476. package/dist/infineon-design-system-stencil/p-2d89c5e0.entry.js.map +1 -0
  477. package/dist/infineon-design-system-stencil/p-2e7d87ed.entry.js +2 -0
  478. package/dist/infineon-design-system-stencil/p-2e7d87ed.entry.js.map +1 -0
  479. package/dist/infineon-design-system-stencil/p-33a4fd0a.entry.js +2 -0
  480. package/dist/infineon-design-system-stencil/p-33a4fd0a.entry.js.map +1 -0
  481. package/dist/infineon-design-system-stencil/{p-a9cfb70d.entry.js → p-36dcebde.entry.js} +2 -2
  482. package/dist/infineon-design-system-stencil/p-37d6c639.entry.js +2 -0
  483. package/dist/infineon-design-system-stencil/p-37d6c639.entry.js.map +1 -0
  484. package/dist/infineon-design-system-stencil/{p-0f096cf1.entry.js → p-3d037fa4.entry.js} +2 -2
  485. package/dist/infineon-design-system-stencil/p-3d23deba.entry.js +2 -0
  486. package/dist/infineon-design-system-stencil/p-3d23deba.entry.js.map +1 -0
  487. package/dist/infineon-design-system-stencil/p-3ff96710.entry.js +2 -0
  488. package/dist/infineon-design-system-stencil/p-3ff96710.entry.js.map +1 -0
  489. package/dist/infineon-design-system-stencil/p-4764665d.entry.js +2 -0
  490. package/dist/infineon-design-system-stencil/p-4764665d.entry.js.map +1 -0
  491. package/dist/infineon-design-system-stencil/p-47a3e831.entry.js +2 -0
  492. package/dist/infineon-design-system-stencil/p-47a3e831.entry.js.map +1 -0
  493. package/dist/infineon-design-system-stencil/p-487d2155.entry.js +2 -0
  494. package/dist/infineon-design-system-stencil/p-487d2155.entry.js.map +1 -0
  495. package/dist/infineon-design-system-stencil/p-4d9a4329.entry.js +2 -0
  496. package/dist/infineon-design-system-stencil/p-4d9a4329.entry.js.map +1 -0
  497. package/dist/infineon-design-system-stencil/p-5285ca40.entry.js +2 -0
  498. package/dist/infineon-design-system-stencil/p-5285ca40.entry.js.map +1 -0
  499. package/dist/infineon-design-system-stencil/p-5b5c144f.entry.js +2 -0
  500. package/dist/infineon-design-system-stencil/p-5b5c144f.entry.js.map +1 -0
  501. package/dist/infineon-design-system-stencil/p-5e376887.entry.js +2 -0
  502. package/dist/infineon-design-system-stencil/p-5e376887.entry.js.map +1 -0
  503. package/dist/infineon-design-system-stencil/p-5f38cace.entry.js +2 -0
  504. package/dist/infineon-design-system-stencil/p-5f38cace.entry.js.map +1 -0
  505. package/dist/infineon-design-system-stencil/p-6250b9f6.entry.js +2 -0
  506. package/dist/infineon-design-system-stencil/p-6250b9f6.entry.js.map +1 -0
  507. package/dist/infineon-design-system-stencil/p-65fe2246.entry.js +2 -0
  508. package/dist/infineon-design-system-stencil/p-65fe2246.entry.js.map +1 -0
  509. package/dist/infineon-design-system-stencil/p-676fb63a.entry.js +2 -0
  510. package/dist/infineon-design-system-stencil/p-676fb63a.entry.js.map +1 -0
  511. package/dist/infineon-design-system-stencil/p-6790d912.entry.js +2 -0
  512. package/dist/infineon-design-system-stencil/p-6790d912.entry.js.map +1 -0
  513. package/dist/infineon-design-system-stencil/p-6bdca580.entry.js +2 -0
  514. package/dist/infineon-design-system-stencil/p-6bdca580.entry.js.map +1 -0
  515. package/dist/infineon-design-system-stencil/{p-babf3f2d.entry.js → p-6c2698a3.entry.js} +2 -2
  516. package/dist/infineon-design-system-stencil/p-6c999b11.entry.js +2 -0
  517. package/dist/infineon-design-system-stencil/p-6c999b11.entry.js.map +1 -0
  518. package/dist/infineon-design-system-stencil/p-741ee6fd.entry.js +2 -0
  519. package/dist/infineon-design-system-stencil/p-741ee6fd.entry.js.map +1 -0
  520. package/dist/infineon-design-system-stencil/p-76e0c34f.entry.js +2 -0
  521. package/dist/infineon-design-system-stencil/p-76e0c34f.entry.js.map +1 -0
  522. package/dist/infineon-design-system-stencil/{p-6d99d01d.entry.js → p-7adee2dd.entry.js} +2 -2
  523. package/dist/infineon-design-system-stencil/p-9149a20a.entry.js +2 -0
  524. package/dist/infineon-design-system-stencil/p-9149a20a.entry.js.map +1 -0
  525. package/dist/infineon-design-system-stencil/p-9fc0f50d.entry.js +2 -0
  526. package/dist/infineon-design-system-stencil/p-9fc0f50d.entry.js.map +1 -0
  527. package/dist/infineon-design-system-stencil/p-a2a44fbe.entry.js +2 -0
  528. package/dist/infineon-design-system-stencil/p-a80e321b.entry.js +2 -0
  529. package/dist/infineon-design-system-stencil/p-a80e321b.entry.js.map +1 -0
  530. package/dist/infineon-design-system-stencil/p-aadd1a9d.entry.js +2 -0
  531. package/dist/infineon-design-system-stencil/p-aadd1a9d.entry.js.map +1 -0
  532. package/dist/infineon-design-system-stencil/p-ad1ec9d6.entry.js +2 -0
  533. package/dist/infineon-design-system-stencil/p-ad1ec9d6.entry.js.map +1 -0
  534. package/dist/infineon-design-system-stencil/p-ad7b58c3.entry.js +2 -0
  535. package/dist/infineon-design-system-stencil/p-ad7b58c3.entry.js.map +1 -0
  536. package/dist/infineon-design-system-stencil/{p-9c28f35f.entry.js → p-b6dd2ac0.entry.js} +3 -3
  537. package/dist/infineon-design-system-stencil/p-b6dd2ac0.entry.js.map +1 -0
  538. package/dist/infineon-design-system-stencil/p-b73a5f18.entry.js +2 -0
  539. package/dist/infineon-design-system-stencil/p-b73a5f18.entry.js.map +1 -0
  540. package/dist/infineon-design-system-stencil/{p-7b7ac7fa.entry.js → p-c7e86c7c.entry.js} +2 -2
  541. package/dist/infineon-design-system-stencil/p-c84ef603.entry.js +2 -0
  542. package/dist/infineon-design-system-stencil/p-c84ef603.entry.js.map +1 -0
  543. package/dist/infineon-design-system-stencil/p-d890b0de.entry.js +2 -0
  544. package/dist/infineon-design-system-stencil/p-d890b0de.entry.js.map +1 -0
  545. package/dist/infineon-design-system-stencil/p-dd28f3a1.entry.js +2 -0
  546. package/dist/infineon-design-system-stencil/p-dd28f3a1.entry.js.map +1 -0
  547. package/dist/infineon-design-system-stencil/p-e571c002.entry.js +2 -0
  548. package/dist/infineon-design-system-stencil/p-ef6d0dc6.entry.js +2 -0
  549. package/dist/infineon-design-system-stencil/p-ef6d0dc6.entry.js.map +1 -0
  550. package/dist/infineon-design-system-stencil/p-f338fb85.entry.js +2 -0
  551. package/dist/infineon-design-system-stencil/p-f338fb85.entry.js.map +1 -0
  552. package/dist/types/components/accordion/accordion.d.ts +0 -1
  553. package/dist/types/components/alert/alert.d.ts +0 -1
  554. package/dist/types/components/badge/badge.d.ts +0 -2
  555. package/dist/types/components/breadcrumb/breadcrumb.d.ts +0 -1
  556. package/dist/types/components/date-picker/date-picker.d.ts +0 -1
  557. package/dist/types/components/file-upload/file-upload.d.ts +0 -1
  558. package/dist/types/components/icon/infineonIconStencil.d.ts +0 -3
  559. package/dist/types/components/link/link.d.ts +0 -2
  560. package/dist/types/components/modal/modal.d.ts +0 -1
  561. package/dist/types/components/notification/notification.d.ts +0 -2
  562. package/dist/types/components/progress-bar/progress-bar.d.ts +0 -1
  563. package/dist/types/components/search-field/search-field.d.ts +0 -2
  564. package/dist/types/components/segmented-control/segmented-control.d.ts +0 -1
  565. package/dist/types/components/select/multi-select/interfaces.d.ts +1 -1
  566. package/dist/types/components/select/multi-select/multiselect-option.d.ts +36 -0
  567. package/dist/types/components/select/multi-select/multiselect.d.ts +39 -61
  568. package/dist/types/components/select/multi-select/multiselect.stories.d.ts +219 -30
  569. package/dist/types/components/spinner/spinner.d.ts +0 -2
  570. package/dist/types/components/status/status.d.ts +0 -2
  571. package/dist/types/components/tag/tag.d.ts +0 -2
  572. package/dist/types/components/tree-view/tree-view.d.ts +0 -2
  573. package/dist/types/components.d.ts +54 -8
  574. package/package.json +1 -1
  575. package/dist/cjs/dom-utils-2c4573c2.js +0 -20
  576. package/dist/cjs/dom-utils-2c4573c2.js.map +0 -1
  577. package/dist/cjs/ifx-multiselect.cjs.entry.js +0 -550
  578. package/dist/cjs/ifx-multiselect.cjs.entry.js.map +0 -1
  579. package/dist/cjs/tracking-f00364dc.js +0 -41
  580. package/dist/cjs/tracking-f00364dc.js.map +0 -1
  581. package/dist/collection/global/utils/dom-utils.js +0 -15
  582. package/dist/collection/global/utils/dom-utils.js.map +0 -1
  583. package/dist/collection/global/utils/tracking.js +0 -37
  584. package/dist/collection/global/utils/tracking.js.map +0 -1
  585. package/dist/components/p-0e4632d4.js.map +0 -1
  586. package/dist/components/p-1ecafb97.js +0 -18
  587. package/dist/components/p-1ecafb97.js.map +0 -1
  588. package/dist/components/p-331ca3f3.js.map +0 -1
  589. package/dist/components/p-39859c18.js.map +0 -1
  590. package/dist/components/p-54b39a91.js.map +0 -1
  591. package/dist/components/p-68016aea.js +0 -33
  592. package/dist/components/p-68016aea.js.map +0 -1
  593. package/dist/components/p-6d95b3c1.js.map +0 -1
  594. package/dist/components/p-6ecb6a6f.js +0 -39
  595. package/dist/components/p-6ecb6a6f.js.map +0 -1
  596. package/dist/components/p-816b2612.js.map +0 -1
  597. package/dist/components/p-927d5fd1.js.map +0 -1
  598. package/dist/components/p-94da6823.js.map +0 -1
  599. package/dist/components/p-9ea9e274.js.map +0 -1
  600. package/dist/components/p-ab4beff7.js.map +0 -1
  601. package/dist/components/p-b1ca5daf.js.map +0 -1
  602. package/dist/components/p-b4630d0d.js.map +0 -1
  603. package/dist/components/p-be3268af.js.map +0 -1
  604. package/dist/components/p-c6e5f94d.js.map +0 -1
  605. package/dist/components/p-cca71d97.js.map +0 -1
  606. package/dist/components/p-df486632.js +0 -603
  607. package/dist/components/p-df486632.js.map +0 -1
  608. package/dist/components/p-e126ea6f.js.map +0 -1
  609. package/dist/components/p-f9815000.js.map +0 -1
  610. package/dist/esm/dom-utils-1988cdf1.js +0 -18
  611. package/dist/esm/dom-utils-1988cdf1.js.map +0 -1
  612. package/dist/esm/ifx-multiselect.entry.js +0 -546
  613. package/dist/esm/ifx-multiselect.entry.js.map +0 -1
  614. package/dist/esm/tracking-a7efdbcd.js +0 -39
  615. package/dist/esm/tracking-a7efdbcd.js.map +0 -1
  616. package/dist/infineon-design-system-stencil/p-0c60ce87.entry.js +0 -2
  617. package/dist/infineon-design-system-stencil/p-0c60ce87.entry.js.map +0 -1
  618. package/dist/infineon-design-system-stencil/p-14525860.entry.js +0 -2
  619. package/dist/infineon-design-system-stencil/p-14525860.entry.js.map +0 -1
  620. package/dist/infineon-design-system-stencil/p-14842bbb.entry.js +0 -2
  621. package/dist/infineon-design-system-stencil/p-14842bbb.entry.js.map +0 -1
  622. package/dist/infineon-design-system-stencil/p-19fcf1db.entry.js +0 -2
  623. package/dist/infineon-design-system-stencil/p-19fcf1db.entry.js.map +0 -1
  624. package/dist/infineon-design-system-stencil/p-1ecafb97.js +0 -2
  625. package/dist/infineon-design-system-stencil/p-1ecafb97.js.map +0 -1
  626. package/dist/infineon-design-system-stencil/p-1fd80576.entry.js +0 -2
  627. package/dist/infineon-design-system-stencil/p-1fd80576.entry.js.map +0 -1
  628. package/dist/infineon-design-system-stencil/p-227fa186.entry.js +0 -2
  629. package/dist/infineon-design-system-stencil/p-227fa186.entry.js.map +0 -1
  630. package/dist/infineon-design-system-stencil/p-26c73456.entry.js +0 -2
  631. package/dist/infineon-design-system-stencil/p-26c73456.entry.js.map +0 -1
  632. package/dist/infineon-design-system-stencil/p-296f215f.entry.js +0 -2
  633. package/dist/infineon-design-system-stencil/p-296f215f.entry.js.map +0 -1
  634. package/dist/infineon-design-system-stencil/p-32b0dfda.entry.js +0 -2
  635. package/dist/infineon-design-system-stencil/p-32b0dfda.entry.js.map +0 -1
  636. package/dist/infineon-design-system-stencil/p-34738a10.entry.js +0 -2
  637. package/dist/infineon-design-system-stencil/p-45ac2698.entry.js +0 -2
  638. package/dist/infineon-design-system-stencil/p-45ac2698.entry.js.map +0 -1
  639. package/dist/infineon-design-system-stencil/p-4eda4ef3.entry.js +0 -2
  640. package/dist/infineon-design-system-stencil/p-4eda4ef3.entry.js.map +0 -1
  641. package/dist/infineon-design-system-stencil/p-52420868.entry.js +0 -2
  642. package/dist/infineon-design-system-stencil/p-52420868.entry.js.map +0 -1
  643. package/dist/infineon-design-system-stencil/p-5493e6f5.entry.js +0 -2
  644. package/dist/infineon-design-system-stencil/p-5493e6f5.entry.js.map +0 -1
  645. package/dist/infineon-design-system-stencil/p-5a12d20a.entry.js +0 -2
  646. package/dist/infineon-design-system-stencil/p-5a12d20a.entry.js.map +0 -1
  647. package/dist/infineon-design-system-stencil/p-65255c40.entry.js +0 -2
  648. package/dist/infineon-design-system-stencil/p-65255c40.entry.js.map +0 -1
  649. package/dist/infineon-design-system-stencil/p-65e57b85.entry.js +0 -2
  650. package/dist/infineon-design-system-stencil/p-68423787.entry.js +0 -2
  651. package/dist/infineon-design-system-stencil/p-68423787.entry.js.map +0 -1
  652. package/dist/infineon-design-system-stencil/p-6d72ad32.entry.js +0 -2
  653. package/dist/infineon-design-system-stencil/p-6d72ad32.entry.js.map +0 -1
  654. package/dist/infineon-design-system-stencil/p-6ecb6a6f.js +0 -2
  655. package/dist/infineon-design-system-stencil/p-6ecb6a6f.js.map +0 -1
  656. package/dist/infineon-design-system-stencil/p-73d39ed6.entry.js +0 -2
  657. package/dist/infineon-design-system-stencil/p-73d39ed6.entry.js.map +0 -1
  658. package/dist/infineon-design-system-stencil/p-76914839.entry.js.map +0 -1
  659. package/dist/infineon-design-system-stencil/p-796675ed.entry.js +0 -2
  660. package/dist/infineon-design-system-stencil/p-796675ed.entry.js.map +0 -1
  661. package/dist/infineon-design-system-stencil/p-79b7d7a2.entry.js +0 -2
  662. package/dist/infineon-design-system-stencil/p-79b7d7a2.entry.js.map +0 -1
  663. package/dist/infineon-design-system-stencil/p-82c59e6b.entry.js +0 -2
  664. package/dist/infineon-design-system-stencil/p-82c59e6b.entry.js.map +0 -1
  665. package/dist/infineon-design-system-stencil/p-82dd7e7d.entry.js +0 -2
  666. package/dist/infineon-design-system-stencil/p-82dd7e7d.entry.js.map +0 -1
  667. package/dist/infineon-design-system-stencil/p-877e1d37.entry.js +0 -2
  668. package/dist/infineon-design-system-stencil/p-877e1d37.entry.js.map +0 -1
  669. package/dist/infineon-design-system-stencil/p-8a7bfe65.entry.js +0 -2
  670. package/dist/infineon-design-system-stencil/p-8a7bfe65.entry.js.map +0 -1
  671. package/dist/infineon-design-system-stencil/p-98532a0e.entry.js +0 -2
  672. package/dist/infineon-design-system-stencil/p-98532a0e.entry.js.map +0 -1
  673. package/dist/infineon-design-system-stencil/p-9c28f35f.entry.js.map +0 -1
  674. package/dist/infineon-design-system-stencil/p-a0006775.entry.js +0 -2
  675. package/dist/infineon-design-system-stencil/p-a0006775.entry.js.map +0 -1
  676. package/dist/infineon-design-system-stencil/p-ac7db8d1.entry.js +0 -2
  677. package/dist/infineon-design-system-stencil/p-ac7db8d1.entry.js.map +0 -1
  678. package/dist/infineon-design-system-stencil/p-ae8110b7.entry.js +0 -2
  679. package/dist/infineon-design-system-stencil/p-ae8110b7.entry.js.map +0 -1
  680. package/dist/infineon-design-system-stencil/p-aeaa6d0b.entry.js +0 -2
  681. package/dist/infineon-design-system-stencil/p-aeaa6d0b.entry.js.map +0 -1
  682. package/dist/infineon-design-system-stencil/p-b17a0e8c.entry.js +0 -2
  683. package/dist/infineon-design-system-stencil/p-b17a0e8c.entry.js.map +0 -1
  684. package/dist/infineon-design-system-stencil/p-bb7b2a3c.entry.js +0 -2
  685. package/dist/infineon-design-system-stencil/p-bb7b2a3c.entry.js.map +0 -1
  686. package/dist/infineon-design-system-stencil/p-c164c83b.entry.js +0 -2
  687. package/dist/infineon-design-system-stencil/p-c164c83b.entry.js.map +0 -1
  688. package/dist/infineon-design-system-stencil/p-c220733b.entry.js +0 -2
  689. package/dist/infineon-design-system-stencil/p-c220733b.entry.js.map +0 -1
  690. package/dist/infineon-design-system-stencil/p-c88876dc.entry.js +0 -2
  691. package/dist/infineon-design-system-stencil/p-c88876dc.entry.js.map +0 -1
  692. package/dist/infineon-design-system-stencil/p-e0978af0.entry.js +0 -2
  693. package/dist/infineon-design-system-stencil/p-e0978af0.entry.js.map +0 -1
  694. package/dist/infineon-design-system-stencil/p-e5018880.entry.js +0 -2
  695. package/dist/infineon-design-system-stencil/p-e5018880.entry.js.map +0 -1
  696. package/dist/infineon-design-system-stencil/p-ed869b07.entry.js +0 -2
  697. package/dist/infineon-design-system-stencil/p-ed869b07.entry.js.map +0 -1
  698. package/dist/infineon-design-system-stencil/p-eeb59f76.entry.js +0 -2
  699. package/dist/infineon-design-system-stencil/p-eeb59f76.entry.js.map +0 -1
  700. package/dist/infineon-design-system-stencil/p-f3f8d603.entry.js +0 -2
  701. package/dist/infineon-design-system-stencil/p-f3f8d603.entry.js.map +0 -1
  702. package/dist/infineon-design-system-stencil/p-fb6a813b.entry.js +0 -2
  703. package/dist/infineon-design-system-stencil/p-fb6a813b.entry.js.map +0 -1
  704. package/dist/infineon-design-system-stencil/p-fe22fc31.entry.js +0 -2
  705. package/dist/infineon-design-system-stencil/p-fe22fc31.entry.js.map +0 -1
  706. package/dist/types/global/utils/dom-utils.d.ts +0 -1
  707. package/dist/types/global/utils/tracking.d.ts +0 -9
  708. /package/dist/infineon-design-system-stencil/{p-f2bea855.entry.js.map → p-04d8ea38.entry.js.map} +0 -0
  709. /package/dist/infineon-design-system-stencil/{p-87fbd617.entry.js.map → p-0c1c831c.entry.js.map} +0 -0
  710. /package/dist/infineon-design-system-stencil/{p-2b38c405.entry.js.map → p-18a81f5f.entry.js.map} +0 -0
  711. /package/dist/infineon-design-system-stencil/{p-a9cfb70d.entry.js.map → p-36dcebde.entry.js.map} +0 -0
  712. /package/dist/infineon-design-system-stencil/{p-0f096cf1.entry.js.map → p-3d037fa4.entry.js.map} +0 -0
  713. /package/dist/infineon-design-system-stencil/{p-babf3f2d.entry.js.map → p-6c2698a3.entry.js.map} +0 -0
  714. /package/dist/infineon-design-system-stencil/{p-6d99d01d.entry.js.map → p-7adee2dd.entry.js.map} +0 -0
  715. /package/dist/infineon-design-system-stencil/{p-65e57b85.entry.js.map → p-a2a44fbe.entry.js.map} +0 -0
  716. /package/dist/infineon-design-system-stencil/{p-7b7ac7fa.entry.js.map → p-c7e86c7c.entry.js.map} +0 -0
  717. /package/dist/infineon-design-system-stencil/{p-34738a10.entry.js.map → p-e571c002.entry.js.map} +0 -0
@@ -0,0 +1,505 @@
1
+ import { h, Host } from "@stencil/core";
2
+ export class MultiselectOption {
3
+ constructor() {
4
+ this.selected = false;
5
+ this.disabled = false;
6
+ this.indeterminate = false;
7
+ this.isExpanded = false;
8
+ this.hasChildren = false;
9
+ this.depth = 0;
10
+ this.searchTerm = '';
11
+ this.isSearchActive = false;
12
+ this.isSearchDisabled = false;
13
+ this.handleSearchFilter = (event) => {
14
+ const { searchTerm, isActive } = event.detail;
15
+ this.searchTerm = searchTerm.toLowerCase();
16
+ this.isSearchActive = isActive;
17
+ requestAnimationFrame(() => {
18
+ this.updateSearchClasses();
19
+ });
20
+ };
21
+ this.handleCheckboxClick = (event) => {
22
+ if (this.disabled || (this.isSearchActive && this.isSearchDisabled))
23
+ return;
24
+ event.stopPropagation();
25
+ let newSelectedState;
26
+ if (this.indeterminate) {
27
+ newSelectedState = true;
28
+ }
29
+ else {
30
+ newSelectedState = !this.selected;
31
+ }
32
+ this.selected = newSelectedState;
33
+ this.indeterminate = false;
34
+ if (this.hasChildren) {
35
+ this.isExpanded = newSelectedState;
36
+ requestAnimationFrame(() => {
37
+ this.selectAllChildren(newSelectedState);
38
+ this.expandAllChildren(newSelectedState);
39
+ });
40
+ }
41
+ this.updateParentStates();
42
+ this.notifyMultiselect();
43
+ };
44
+ this.handleHeaderClick = (event) => {
45
+ event.stopPropagation();
46
+ if (!this.disabled && !(this.isSearchActive && this.isSearchDisabled)) {
47
+ this.handleClick(event);
48
+ }
49
+ };
50
+ }
51
+ componentWillLoad() {
52
+ this.hasChildren = this.el.children.length > 0;
53
+ this.depth = this.calculateDepth();
54
+ this.el.setAttribute('data-level', this.depth.toString());
55
+ if (this.hasChildren) {
56
+ const hasSelectedChildren = this.hasAnySelectedChildren();
57
+ if (hasSelectedChildren) {
58
+ this.isExpanded = true;
59
+ }
60
+ }
61
+ }
62
+ componentDidLoad() {
63
+ this.el['__stencil_instance'] = this;
64
+ this.notifyMultiselect();
65
+ this.el.addEventListener('ifx-search-filter', this.handleSearchFilter);
66
+ }
67
+ disconnectedCallback() {
68
+ this.el.removeEventListener('ifx-search-filter', this.handleSearchFilter);
69
+ }
70
+ updateSearchClasses() {
71
+ var _a;
72
+ const optionDiv = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.option');
73
+ if (!optionDiv)
74
+ return;
75
+ if (!this.isSearchActive) {
76
+ optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');
77
+ this.removeHighlighting();
78
+ this.isSearchDisabled = false;
79
+ return;
80
+ }
81
+ const textContent = this.getTextContent().toLowerCase();
82
+ const matchesSearch = textContent.includes(this.searchTerm);
83
+ const hasMatchingParent = this.hasMatchingParent();
84
+ requestAnimationFrame(() => {
85
+ const hasMatchingChildren = this.hasMatchingChildren();
86
+ optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');
87
+ this.isSearchDisabled = false;
88
+ if (matchesSearch && !this.hasChildren) {
89
+ optionDiv.classList.add('search-match');
90
+ this.highlightSearchTerm();
91
+ }
92
+ else if (matchesSearch && this.hasChildren) {
93
+ optionDiv.classList.add('search-match');
94
+ this.highlightSearchTerm();
95
+ this.isExpanded = true;
96
+ }
97
+ else if (!matchesSearch && this.hasChildren && hasMatchingChildren) {
98
+ optionDiv.classList.add('search-parent');
99
+ this.removeHighlighting();
100
+ this.isExpanded = true;
101
+ this.isSearchDisabled = true;
102
+ }
103
+ else if (hasMatchingParent) {
104
+ optionDiv.classList.add('search-match');
105
+ this.removeHighlighting();
106
+ }
107
+ else {
108
+ optionDiv.classList.add('search-hidden');
109
+ this.removeHighlighting();
110
+ }
111
+ });
112
+ }
113
+ highlightSearchTerm() {
114
+ var _a;
115
+ if (!this.searchTerm)
116
+ return;
117
+ const labelElement = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.option-label');
118
+ if (!labelElement)
119
+ return;
120
+ const slotElement = labelElement.querySelector('slot');
121
+ if (!slotElement)
122
+ return;
123
+ this.removeHighlighting();
124
+ const originalText = this.getTextContent();
125
+ const searchTermLower = this.searchTerm.toLowerCase();
126
+ const originalTextLower = originalText.toLowerCase();
127
+ if (!originalTextLower.includes(searchTermLower))
128
+ return;
129
+ const searchIndex = originalTextLower.indexOf(searchTermLower);
130
+ if (searchIndex === -1)
131
+ return;
132
+ const beforeMatch = originalText.substring(0, searchIndex);
133
+ const matchText = originalText.substring(searchIndex, searchIndex + searchTermLower.length);
134
+ const afterMatch = originalText.substring(searchIndex + searchTermLower.length);
135
+ const highlightedContent = document.createElement('span');
136
+ highlightedContent.className = 'highlighted-text';
137
+ if (beforeMatch) {
138
+ highlightedContent.appendChild(document.createTextNode(beforeMatch));
139
+ }
140
+ const boldElement = document.createElement('strong');
141
+ boldElement.className = 'search-highlight';
142
+ boldElement.textContent = matchText;
143
+ highlightedContent.appendChild(boldElement);
144
+ if (afterMatch) {
145
+ highlightedContent.appendChild(document.createTextNode(afterMatch));
146
+ }
147
+ labelElement.setAttribute('data-original-content', 'true');
148
+ slotElement.style.display = 'none';
149
+ labelElement.appendChild(highlightedContent);
150
+ }
151
+ removeHighlighting() {
152
+ var _a;
153
+ const labelElement = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.option-label');
154
+ if (!labelElement)
155
+ return;
156
+ const slotElement = labelElement.querySelector('slot');
157
+ const highlightedElement = labelElement.querySelector('.highlighted-text');
158
+ if (highlightedElement) {
159
+ labelElement.removeChild(highlightedElement);
160
+ }
161
+ if (slotElement) {
162
+ slotElement.style.display = '';
163
+ }
164
+ labelElement.removeAttribute('data-original-content');
165
+ }
166
+ getTextContent() {
167
+ let text = '';
168
+ Array.from(this.el.childNodes).forEach(node => {
169
+ var _a;
170
+ if (node.nodeType === Node.TEXT_NODE) {
171
+ text += ((_a = node.textContent) === null || _a === void 0 ? void 0 : _a.trim()) || '';
172
+ }
173
+ });
174
+ return text || this.value || '';
175
+ }
176
+ hasMatchingChildren() {
177
+ if (!this.hasChildren)
178
+ return false;
179
+ const childOptions = Array.from(this.el.children)
180
+ .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
181
+ return childOptions.some(child => {
182
+ const childInstance = child['__stencil_instance'];
183
+ if (!childInstance)
184
+ return false;
185
+ const childText = childInstance.getTextContent().toLowerCase();
186
+ const childMatches = childText.includes(this.searchTerm);
187
+ const grandChildrenMatch = childInstance.hasMatchingChildren();
188
+ return childMatches || grandChildrenMatch;
189
+ });
190
+ }
191
+ hasMatchingParent() {
192
+ let parent = this.el.parentElement;
193
+ while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {
194
+ const parentInstance = parent['__stencil_instance'];
195
+ if (parentInstance) {
196
+ const parentText = parentInstance.getTextContent().toLowerCase();
197
+ if (parentText.includes(this.searchTerm)) {
198
+ return true;
199
+ }
200
+ }
201
+ parent = parent.parentElement;
202
+ }
203
+ return false;
204
+ }
205
+ calculateDepth() {
206
+ let depth = 0;
207
+ let parent = this.el.parentElement;
208
+ while (parent && parent.tagName !== 'IFX-MULTISELECT') {
209
+ if (parent.tagName === 'IFX-MULTISELECT-OPTION') {
210
+ depth++;
211
+ }
212
+ parent = parent.parentElement;
213
+ }
214
+ return depth;
215
+ }
216
+ handleClick(event) {
217
+ if (this.disabled || (this.isSearchActive && this.isSearchDisabled))
218
+ return;
219
+ event.stopPropagation();
220
+ if (event.type === 'click' && event.target.closest('.chevron-wrapper')) {
221
+ this.toggleExpansion();
222
+ return;
223
+ }
224
+ let newSelectedState;
225
+ if (this.indeterminate) {
226
+ newSelectedState = true;
227
+ }
228
+ else {
229
+ newSelectedState = !this.selected;
230
+ }
231
+ this.selected = newSelectedState;
232
+ this.indeterminate = false;
233
+ if (this.hasChildren) {
234
+ this.isExpanded = newSelectedState;
235
+ requestAnimationFrame(() => {
236
+ this.selectAllChildren(newSelectedState);
237
+ this.expandAllChildren(newSelectedState);
238
+ });
239
+ }
240
+ this.updateParentStates();
241
+ this.notifyMultiselect();
242
+ }
243
+ handleKeyDown(event) {
244
+ if (this.disabled || (this.isSearchActive && this.isSearchDisabled))
245
+ return;
246
+ const target = event.target;
247
+ if (target.closest('.chevron-wrapper') || target.closest('.checkbox-wrapper')) {
248
+ return;
249
+ }
250
+ if (event.key !== 'ArrowUp' && event.key !== 'ArrowDown') {
251
+ event.stopPropagation();
252
+ }
253
+ if (event.key === 'ArrowRight' && this.hasChildren) {
254
+ this.isExpanded = true;
255
+ }
256
+ if (event.key === 'ArrowLeft' && this.hasChildren) {
257
+ this.isExpanded = false;
258
+ }
259
+ }
260
+ notifyMultiselect() {
261
+ const updateEvent = new CustomEvent('ifx-option-changed', {
262
+ bubbles: true,
263
+ detail: {
264
+ value: this.value,
265
+ selected: this.selected,
266
+ indeterminate: this.indeterminate
267
+ }
268
+ });
269
+ this.el.dispatchEvent(updateEvent);
270
+ }
271
+ selectAllChildren(selected) {
272
+ const directChildren = Array.from(this.el.children)
273
+ .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
274
+ directChildren.forEach((child) => {
275
+ var _a;
276
+ const childInstance = child['__stencil_instance'];
277
+ if (childInstance) {
278
+ childInstance.selected = selected;
279
+ childInstance.indeterminate = false;
280
+ if (childInstance.hasChildren) {
281
+ childInstance.isExpanded = selected;
282
+ childInstance.selectAllChildren(selected);
283
+ }
284
+ (_a = childInstance.notifyMultiselect) === null || _a === void 0 ? void 0 : _a.call(childInstance);
285
+ }
286
+ });
287
+ }
288
+ expandAllChildren(expanded) {
289
+ const directChildren = Array.from(this.el.children)
290
+ .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
291
+ directChildren.forEach((child) => {
292
+ const childInstance = child['__stencil_instance'];
293
+ if (childInstance && childInstance.hasChildren) {
294
+ childInstance.isExpanded = expanded;
295
+ childInstance.expandAllChildren(expanded);
296
+ }
297
+ });
298
+ }
299
+ updateParentStates() {
300
+ var _a;
301
+ let parent = this.el.parentElement;
302
+ while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {
303
+ const parentInstance = parent['__stencil_instance'];
304
+ if (!parentInstance) {
305
+ parent = parent.parentElement;
306
+ continue;
307
+ }
308
+ const siblings = Array.from(parent.children)
309
+ .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION')
310
+ .map(child => child['__stencil_instance'])
311
+ .filter(instance => instance !== null);
312
+ const selectedCount = siblings.filter(sibling => sibling.selected).length;
313
+ const indeterminateCount = siblings.filter(sibling => sibling.indeterminate).length;
314
+ const totalCount = siblings.length;
315
+ if (selectedCount === totalCount && indeterminateCount === 0) {
316
+ parentInstance.selected = true;
317
+ parentInstance.indeterminate = false;
318
+ }
319
+ else if (selectedCount === 0 && indeterminateCount === 0) {
320
+ parentInstance.selected = false;
321
+ parentInstance.indeterminate = false;
322
+ }
323
+ else {
324
+ parentInstance.selected = false;
325
+ parentInstance.indeterminate = true;
326
+ }
327
+ (_a = parentInstance.notifyMultiselect) === null || _a === void 0 ? void 0 : _a.call(parentInstance);
328
+ parent = parent.parentElement;
329
+ }
330
+ }
331
+ toggleExpansion() {
332
+ this.isExpanded = !this.isExpanded;
333
+ }
334
+ hasAnySelectedChildren() {
335
+ const childOptions = Array.from(this.el.children)
336
+ .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
337
+ return childOptions.some(child => {
338
+ const hasSelected = child.hasAttribute('selected');
339
+ const hasSelectedDescendants = this.checkForSelectedDescendants(child);
340
+ return hasSelected || hasSelectedDescendants;
341
+ });
342
+ }
343
+ checkForSelectedDescendants(element) {
344
+ const nestedOptions = Array.from(element.children)
345
+ .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
346
+ return nestedOptions.some(nestedChild => {
347
+ const isSelected = nestedChild.hasAttribute('selected');
348
+ const hasSelectedNested = this.checkForSelectedDescendants(nestedChild);
349
+ return isSelected || hasSelectedNested;
350
+ });
351
+ }
352
+ render() {
353
+ let isFlatMultiselect = false;
354
+ const parentMultiselect = this.el.closest('ifx-multiselect');
355
+ if (parentMultiselect) {
356
+ const allOptions = Array.from(parentMultiselect.querySelectorAll('ifx-multiselect-option'));
357
+ isFlatMultiselect = allOptions.every(option => option.children.length === 0);
358
+ }
359
+ const basePadding = this.depth * 28 + 16;
360
+ const additionalPadding = this.hasChildren ? 0 : 28;
361
+ let totalPadding = basePadding + additionalPadding;
362
+ const optionItemStyle = isFlatMultiselect ? undefined : { paddingLeft: `${totalPadding}px` };
363
+ return (h(Host, { key: 'f836f58884e2e57c4c5fb4953f10d5ff4a34c8da' }, h("div", { key: '9eca6e87bb3c21512a051596b1e92931b707e88f', class: {
364
+ 'option': true,
365
+ 'option--has-children': this.hasChildren,
366
+ 'option--expanded': this.isExpanded,
367
+ 'option--disabled': this.disabled,
368
+ 'option--selected': this.selected,
369
+ }, role: "option", "aria-expanded": this.hasChildren ? (this.isExpanded ? 'true' : 'false') : undefined, "aria-selected": this.selected ? 'true' : 'false', "aria-disabled": this.disabled ? 'true' : 'false', "data-level": this.depth, "data-value": this.value }, h("div", { key: '41d24ef38470f5f7f8aa36daa33b339b7d8079f3', class: "option-item", style: optionItemStyle }, h("div", { key: '27d33336e7d15ccce1703429b70494fe86808214', class: "chevron-wrapper", tabIndex: this.hasChildren ? 0 : -1, role: this.hasChildren ? "button" : undefined, "aria-label": this.hasChildren ? (this.isExpanded ? "Collapse" : "Expand") : undefined, onClick: (e) => { e.stopPropagation(); this.toggleExpansion(); }, onKeyDown: (e) => {
370
+ if (e.key === 'Enter' || e.key === ' ') {
371
+ e.preventDefault();
372
+ e.stopPropagation();
373
+ this.toggleExpansion();
374
+ }
375
+ } }, this.hasChildren && (h("ifx-icon", { key: '68e975b49b4aa9edf564b80644c5a55809185629', class: `chevron ${this.isExpanded ? 'chevron--expanded' : 'chevron--collapsed'}`, icon: "chevron-right-16" }))), h("div", { key: 'f651aefe4cc30db6056331ffaafd8e6ea17039fc', class: "checkbox-wrapper", onClick: (e) => e.stopPropagation() }, h("ifx-checkbox", { key: 'e8cb2c7a75921a81e0321ff22718d9373cb6f437', size: 's', checked: (this.isSearchActive && this.isSearchDisabled) ? false : (this.indeterminate ? false : this.selected), indeterminate: (this.isSearchActive && this.isSearchDisabled) ? false : this.indeterminate, onClick: this.handleCheckboxClick, disabled: this.disabled || (this.isSearchActive && this.isSearchDisabled), onKeyDown: (e) => {
376
+ if (e.key === 'Enter' || e.key === ' ') {
377
+ e.preventDefault();
378
+ e.stopPropagation();
379
+ this.handleCheckboxClick(e);
380
+ }
381
+ } })), h("div", { key: '4f626380753927d4bedca0f78643e6647eff6356', class: "option-label", onClick: this.handleHeaderClick, tabIndex: -1 }, h("slot", { key: '8207d9f952bff231fda0bf0be43e1c567aa6a6da' }))), this.isExpanded && h("div", { key: '930d611f27451ff393d1403386bb6cd6b4a54980', class: "option-children" }, h("slot", { key: '269eb6381257f82b74b888188646559e6881a9d9', name: "children" })))));
382
+ }
383
+ static get is() { return "ifx-multiselect-option"; }
384
+ static get encapsulation() { return "shadow"; }
385
+ static get originalStyleUrls() {
386
+ return {
387
+ "$": ["multiselect-option.scss"]
388
+ };
389
+ }
390
+ static get styleUrls() {
391
+ return {
392
+ "$": ["multiselect-option.css"]
393
+ };
394
+ }
395
+ static get properties() {
396
+ return {
397
+ "value": {
398
+ "type": "string",
399
+ "mutable": false,
400
+ "complexType": {
401
+ "original": "string",
402
+ "resolved": "string",
403
+ "references": {}
404
+ },
405
+ "required": false,
406
+ "optional": false,
407
+ "docs": {
408
+ "tags": [],
409
+ "text": ""
410
+ },
411
+ "getter": false,
412
+ "setter": false,
413
+ "attribute": "value",
414
+ "reflect": false
415
+ },
416
+ "selected": {
417
+ "type": "boolean",
418
+ "mutable": true,
419
+ "complexType": {
420
+ "original": "boolean",
421
+ "resolved": "boolean",
422
+ "references": {}
423
+ },
424
+ "required": false,
425
+ "optional": false,
426
+ "docs": {
427
+ "tags": [],
428
+ "text": ""
429
+ },
430
+ "getter": false,
431
+ "setter": false,
432
+ "attribute": "selected",
433
+ "reflect": true,
434
+ "defaultValue": "false"
435
+ },
436
+ "disabled": {
437
+ "type": "boolean",
438
+ "mutable": true,
439
+ "complexType": {
440
+ "original": "boolean",
441
+ "resolved": "boolean",
442
+ "references": {}
443
+ },
444
+ "required": false,
445
+ "optional": false,
446
+ "docs": {
447
+ "tags": [],
448
+ "text": ""
449
+ },
450
+ "getter": false,
451
+ "setter": false,
452
+ "attribute": "disabled",
453
+ "reflect": true,
454
+ "defaultValue": "false"
455
+ },
456
+ "indeterminate": {
457
+ "type": "boolean",
458
+ "mutable": true,
459
+ "complexType": {
460
+ "original": "boolean",
461
+ "resolved": "boolean",
462
+ "references": {}
463
+ },
464
+ "required": false,
465
+ "optional": false,
466
+ "docs": {
467
+ "tags": [],
468
+ "text": ""
469
+ },
470
+ "getter": false,
471
+ "setter": false,
472
+ "attribute": "indeterminate",
473
+ "reflect": true,
474
+ "defaultValue": "false"
475
+ }
476
+ };
477
+ }
478
+ static get states() {
479
+ return {
480
+ "isExpanded": {},
481
+ "hasChildren": {},
482
+ "depth": {},
483
+ "searchTerm": {},
484
+ "isSearchActive": {},
485
+ "isSearchDisabled": {}
486
+ };
487
+ }
488
+ static get elementRef() { return "el"; }
489
+ static get listeners() {
490
+ return [{
491
+ "name": "click",
492
+ "method": "handleClick",
493
+ "target": undefined,
494
+ "capture": false,
495
+ "passive": false
496
+ }, {
497
+ "name": "keydown",
498
+ "method": "handleKeyDown",
499
+ "target": undefined,
500
+ "capture": false,
501
+ "passive": false
502
+ }];
503
+ }
504
+ }
505
+ //# sourceMappingURL=multiselect-option.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multiselect-option.js","sourceRoot":"","sources":["../../../../src/components/select/multi-select/multiselect-option.tsx"],"names":[],"mappings":"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","sourcesContent":["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 if (this.hasChildren) {\n const hasSelectedChildren = this.hasAnySelectedChildren();\n if (hasSelectedChildren) {\n this.isExpanded = true;\n }\n }\n }\n\n componentDidLoad() {\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"]}