@infineon/infineon-design-system-stencil 33.5.1--canary.1867.a435cc98156979ea6fc74d165a793008afc333b5.0 → 33.5.1--canary.1869.6f9372deb45bf9862ab3a91adf63bd3b39003283.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 (480) hide show
  1. package/dist/cjs/ifx-accordion_2.cjs.entry.js +1 -1
  2. package/dist/cjs/ifx-alert_2.cjs.entry.js +1 -1
  3. package/dist/cjs/ifx-badge.cjs.entry.js +1 -1
  4. package/dist/cjs/ifx-basic-table.cjs.entry.js +1 -1
  5. package/dist/cjs/ifx-breadcrumb-item-label.cjs.entry.js +1 -1
  6. package/dist/cjs/ifx-breadcrumb-item.cjs.entry.js +1 -1
  7. package/dist/cjs/ifx-breadcrumb.cjs.entry.js +1 -1
  8. package/dist/cjs/ifx-button.cjs.entry.js +1 -1
  9. package/dist/cjs/ifx-card-headline.cjs.entry.js +1 -1
  10. package/dist/cjs/ifx-card-image.cjs.entry.js +1 -1
  11. package/dist/cjs/ifx-card-links.cjs.entry.js +1 -1
  12. package/dist/cjs/ifx-card-overline.cjs.entry.js +1 -1
  13. package/dist/cjs/ifx-card-text.cjs.entry.js +1 -1
  14. package/dist/cjs/ifx-card.cjs.entry.js +1 -1
  15. package/dist/cjs/ifx-checkbox-group.cjs.entry.js +1 -1
  16. package/dist/cjs/ifx-checkbox.cjs.entry.js +1 -1
  17. package/dist/cjs/ifx-chip_3.cjs.entry.js +1 -1
  18. package/dist/cjs/ifx-content-switcher-item.cjs.entry.js +1 -1
  19. package/dist/cjs/ifx-content-switcher.cjs.entry.js +1 -1
  20. package/dist/cjs/ifx-date-picker.cjs.entry.js +1 -1
  21. package/dist/cjs/ifx-download.cjs.entry.js +1 -1
  22. package/dist/cjs/ifx-dropdown-header.cjs.entry.js +1 -1
  23. package/dist/cjs/ifx-dropdown-item.cjs.entry.js +1 -1
  24. package/dist/cjs/ifx-dropdown-menu.cjs.entry.js +1 -1
  25. package/dist/cjs/ifx-dropdown-separator.cjs.entry.js +1 -1
  26. package/dist/cjs/ifx-dropdown-trigger-button.cjs.entry.js +1 -1
  27. package/dist/cjs/ifx-dropdown-trigger.cjs.entry.js +1 -1
  28. package/dist/cjs/ifx-dropdown.cjs.entry.js +1 -1
  29. package/dist/cjs/ifx-faq.cjs.entry.js +2 -2
  30. package/dist/cjs/ifx-file-upload.cjs.entry.js +1 -1
  31. package/dist/cjs/ifx-filter-accordion.cjs.entry.js +1 -1
  32. package/dist/cjs/ifx-filter-bar.cjs.entry.js +1 -1
  33. package/dist/cjs/ifx-filter-search.cjs.entry.js +1 -1
  34. package/dist/cjs/ifx-filter-type-group.cjs.entry.js +1 -1
  35. package/dist/cjs/ifx-footer-column.cjs.entry.js +1 -1
  36. package/dist/cjs/ifx-footer.cjs.entry.js +1 -1
  37. package/dist/cjs/ifx-icon-button.cjs.entry.js +1 -1
  38. package/dist/cjs/ifx-icon.cjs.entry.js +1 -1
  39. package/dist/cjs/ifx-icons-preview.cjs.entry.js +1 -1
  40. package/dist/cjs/ifx-link.cjs.entry.js +1 -1
  41. package/dist/cjs/ifx-list-entry.cjs.entry.js +1 -1
  42. package/dist/cjs/ifx-list.cjs.entry.js +1 -1
  43. package/dist/cjs/ifx-modal.cjs.entry.js +1 -1
  44. package/dist/cjs/ifx-multiselect.cjs.entry.js +1 -1
  45. package/dist/cjs/ifx-navbar-item.cjs.entry.js +1 -1
  46. package/dist/cjs/ifx-navbar-profile.cjs.entry.js +1 -1
  47. package/dist/cjs/ifx-navbar.cjs.entry.js +1 -1
  48. package/dist/cjs/ifx-notification.cjs.entry.js +1 -1
  49. package/dist/cjs/ifx-number-indicator.cjs.entry.js +1 -1
  50. package/dist/cjs/ifx-overview-table.cjs.entry.js +1 -1
  51. package/dist/cjs/ifx-progress-bar.cjs.entry.js +1 -1
  52. package/dist/cjs/ifx-radio-button-group.cjs.entry.js +1 -1
  53. package/dist/cjs/ifx-radio-button.cjs.entry.js +1 -1
  54. package/dist/cjs/ifx-search-bar.cjs.entry.js +1 -1
  55. package/dist/cjs/ifx-search-field.cjs.entry.js +1 -1
  56. package/dist/cjs/ifx-segment.cjs.entry.js +1 -1
  57. package/dist/cjs/ifx-segmented-control.cjs.entry.js +1 -1
  58. package/dist/cjs/ifx-select.cjs.entry.js +1 -1
  59. package/dist/cjs/ifx-set-filter.cjs.entry.js +1 -1
  60. package/dist/cjs/ifx-sidebar-item.cjs.entry.js +1 -1
  61. package/dist/cjs/ifx-sidebar-title.cjs.entry.js +1 -1
  62. package/dist/cjs/ifx-sidebar.cjs.entry.js +1 -1
  63. package/dist/cjs/ifx-slider.cjs.entry.js +1 -1
  64. package/dist/cjs/ifx-spinner_2.cjs.entry.js +1 -1
  65. package/dist/cjs/ifx-status.cjs.entry.js +1 -1
  66. package/dist/cjs/ifx-step.cjs.entry.js +1 -1
  67. package/dist/cjs/ifx-stepper.cjs.entry.js +1 -1
  68. package/dist/cjs/ifx-switch.cjs.entry.js +1 -1
  69. package/dist/cjs/ifx-tab.cjs.entry.js +1 -1
  70. package/dist/cjs/ifx-table.cjs.entry.js +1 -1
  71. package/dist/cjs/ifx-tabs.cjs.entry.js +1 -1
  72. package/dist/cjs/ifx-tag.cjs.entry.js +1 -1
  73. package/dist/cjs/ifx-templates-ui.cjs.entry.js +1 -1
  74. package/dist/cjs/ifx-textarea.cjs.entry.js +1 -1
  75. package/dist/cjs/ifx-tooltip.cjs.entry.js +1 -1
  76. package/dist/cjs/ifx-tree-view-item.cjs.entry.js +327 -0
  77. package/dist/cjs/ifx-tree-view-item.cjs.entry.js.map +1 -0
  78. package/dist/cjs/ifx-tree-view.cjs.entry.js +55 -0
  79. package/dist/cjs/ifx-tree-view.cjs.entry.js.map +1 -0
  80. package/dist/cjs/{index-c9480f70.js → index-7f4df11a.js} +55 -6
  81. package/dist/cjs/index-7f4df11a.js.map +1 -0
  82. package/dist/cjs/infineon-design-system-stencil.cjs.js +2 -2
  83. package/dist/cjs/loader.cjs.js +2 -2
  84. package/dist/collection/collection-manifest.json +2 -0
  85. package/dist/collection/components/tree-view/tree-view-item.css +112 -0
  86. package/dist/collection/components/tree-view/tree-view-item.js +489 -0
  87. package/dist/collection/components/tree-view/tree-view-item.js.map +1 -0
  88. package/dist/collection/components/tree-view/tree-view.css +18 -0
  89. package/dist/collection/components/tree-view/tree-view.js +173 -0
  90. package/dist/collection/components/tree-view/tree-view.js.map +1 -0
  91. package/dist/collection/components/tree-view/tree-view.stories.js +272 -0
  92. package/dist/collection/components/tree-view/tree-view.stories.js.map +1 -0
  93. package/dist/collection/stories/setup-and-installation/faq/faq.js +1 -1
  94. package/dist/components/ifx-accordion-item.js +1 -1
  95. package/dist/components/ifx-accordion.js +1 -1
  96. package/dist/components/ifx-alert.js +1 -1
  97. package/dist/components/ifx-badge.js +1 -1
  98. package/dist/components/ifx-basic-table.js +1 -1
  99. package/dist/components/ifx-breadcrumb-item-label.js +2 -2
  100. package/dist/components/ifx-breadcrumb-item.js +1 -1
  101. package/dist/components/ifx-breadcrumb.js +1 -1
  102. package/dist/components/ifx-button.js +1 -1
  103. package/dist/components/ifx-card-headline.js +1 -1
  104. package/dist/components/ifx-card-image.js +1 -1
  105. package/dist/components/ifx-card-links.js +1 -1
  106. package/dist/components/ifx-card-overline.js +1 -1
  107. package/dist/components/ifx-card-text.js +1 -1
  108. package/dist/components/ifx-card.js +1 -1
  109. package/dist/components/ifx-checkbox-group.js +2 -2
  110. package/dist/components/ifx-checkbox.js +1 -1
  111. package/dist/components/ifx-chip-item.js +1 -1
  112. package/dist/components/ifx-chip.js +1 -1
  113. package/dist/components/ifx-content-switcher-item.js +1 -1
  114. package/dist/components/ifx-content-switcher.js +1 -1
  115. package/dist/components/ifx-date-picker.js +2 -2
  116. package/dist/components/ifx-download.js +2 -2
  117. package/dist/components/ifx-dropdown-header.js +1 -1
  118. package/dist/components/ifx-dropdown-item.js +2 -2
  119. package/dist/components/ifx-dropdown-menu.js +1 -1
  120. package/dist/components/ifx-dropdown-separator.js +1 -1
  121. package/dist/components/ifx-dropdown-trigger-button.js +3 -3
  122. package/dist/components/ifx-dropdown-trigger.js +1 -1
  123. package/dist/components/ifx-dropdown.js +1 -1
  124. package/dist/components/ifx-faq.js +5 -5
  125. package/dist/components/ifx-file-upload.js +5 -5
  126. package/dist/components/ifx-filter-accordion.js +3 -3
  127. package/dist/components/ifx-filter-bar.js +3 -3
  128. package/dist/components/ifx-filter-search.js +3 -3
  129. package/dist/components/ifx-filter-type-group.js +1 -1
  130. package/dist/components/ifx-footer-column.js +1 -1
  131. package/dist/components/ifx-footer.js +1 -1
  132. package/dist/components/ifx-icon-button.js +1 -1
  133. package/dist/components/ifx-icon.js +1 -1
  134. package/dist/components/ifx-icons-preview.js +4 -4
  135. package/dist/components/ifx-link.js +1 -1
  136. package/dist/components/ifx-list-entry.js +4 -4
  137. package/dist/components/ifx-list.js +3 -3
  138. package/dist/components/ifx-modal.js +3 -3
  139. package/dist/components/ifx-multiselect.js +1 -1
  140. package/dist/components/ifx-navbar-item.js +3 -3
  141. package/dist/components/ifx-navbar-profile.js +1 -1
  142. package/dist/components/ifx-navbar.js +2 -2
  143. package/dist/components/ifx-notification.js +1 -1
  144. package/dist/components/ifx-number-indicator.js +1 -1
  145. package/dist/components/ifx-overview-table.js +4 -4
  146. package/dist/components/ifx-pagination.js +1 -1
  147. package/dist/components/ifx-progress-bar.js +1 -1
  148. package/dist/components/ifx-radio-button-group.js +2 -2
  149. package/dist/components/ifx-radio-button.js +1 -1
  150. package/dist/components/ifx-search-bar.js +3 -3
  151. package/dist/components/ifx-search-field.js +1 -1
  152. package/dist/components/ifx-segment.js +2 -2
  153. package/dist/components/ifx-segmented-control.js +2 -2
  154. package/dist/components/ifx-select.js +1 -1
  155. package/dist/components/ifx-set-filter.js +7 -7
  156. package/dist/components/ifx-sidebar-item.js +3 -3
  157. package/dist/components/ifx-sidebar-title.js +1 -1
  158. package/dist/components/ifx-sidebar.js +1 -1
  159. package/dist/components/ifx-slider.js +2 -2
  160. package/dist/components/ifx-spinner.js +1 -1
  161. package/dist/components/ifx-status.js +1 -1
  162. package/dist/components/ifx-step.js +2 -2
  163. package/dist/components/ifx-stepper.js +1 -1
  164. package/dist/components/ifx-switch.js +1 -1
  165. package/dist/components/ifx-tab.js +1 -1
  166. package/dist/components/ifx-table.js +10 -10
  167. package/dist/components/ifx-tabs.js +2 -2
  168. package/dist/components/ifx-tag.js +2 -2
  169. package/dist/components/ifx-template.js +1 -1
  170. package/dist/components/ifx-templates-ui.js +9 -9
  171. package/dist/components/ifx-text-field.js +1 -1
  172. package/dist/components/ifx-textarea.js +1 -1
  173. package/dist/components/ifx-tooltip.js +2 -2
  174. package/dist/components/ifx-tree-view-item.d.ts +11 -0
  175. package/dist/components/ifx-tree-view-item.js +368 -0
  176. package/dist/components/ifx-tree-view-item.js.map +1 -0
  177. package/dist/components/ifx-tree-view.d.ts +11 -0
  178. package/dist/components/ifx-tree-view.js +77 -0
  179. package/dist/components/ifx-tree-view.js.map +1 -0
  180. package/dist/components/index.js +1 -1
  181. package/dist/components/{p-bfae6ae0.js → p-0ba7b063.js} +2 -2
  182. package/dist/components/{p-bfae6ae0.js.map → p-0ba7b063.js.map} +1 -1
  183. package/dist/components/{p-f8ce0088.js → p-108c28cb.js} +2 -2
  184. package/dist/components/{p-f8ce0088.js.map → p-108c28cb.js.map} +1 -1
  185. package/dist/components/{p-2a46b223.js → p-11e95622.js} +2 -2
  186. package/dist/components/{p-2a46b223.js.map → p-11e95622.js.map} +1 -1
  187. package/dist/components/{p-5fd6328a.js → p-162a9364.js} +2 -2
  188. package/dist/components/{p-5fd6328a.js.map → p-162a9364.js.map} +1 -1
  189. package/dist/components/{p-18ad1165.js → p-236bf70f.js} +3 -3
  190. package/dist/components/{p-18ad1165.js.map → p-236bf70f.js.map} +1 -1
  191. package/dist/components/{p-f69a7795.js → p-26dfe620.js} +5 -5
  192. package/dist/components/{p-f69a7795.js.map → p-26dfe620.js.map} +1 -1
  193. package/dist/components/{p-5b5399c2.js → p-2bd941eb.js} +2 -2
  194. package/dist/components/{p-5b5399c2.js.map → p-2bd941eb.js.map} +1 -1
  195. package/dist/components/{p-0aee2554.js → p-3b6a432e.js} +2 -2
  196. package/dist/components/{p-0aee2554.js.map → p-3b6a432e.js.map} +1 -1
  197. package/dist/components/{p-4d7b13e3.js → p-3ec421ea.js} +3 -3
  198. package/dist/components/{p-4d7b13e3.js.map → p-3ec421ea.js.map} +1 -1
  199. package/dist/components/{p-42dca0c9.js → p-68016aea.js} +2 -2
  200. package/dist/components/{p-42dca0c9.js.map → p-68016aea.js.map} +1 -1
  201. package/dist/components/{p-ca6c8507.js → p-6e579eb5.js} +3 -3
  202. package/dist/components/{p-ca6c8507.js.map → p-6e579eb5.js.map} +1 -1
  203. package/dist/components/{p-f76b674f.js → p-75572595.js} +3 -3
  204. package/dist/components/{p-f76b674f.js.map → p-75572595.js.map} +1 -1
  205. package/dist/components/{p-f7a8339d.js → p-817e9528.js} +3 -3
  206. package/dist/components/{p-f7a8339d.js.map → p-817e9528.js.map} +1 -1
  207. package/dist/components/{p-d64e5297.js → p-a9289acb.js} +7 -7
  208. package/dist/components/{p-d64e5297.js.map → p-a9289acb.js.map} +1 -1
  209. package/dist/components/{p-f41c84fa.js → p-a957f7ad.js} +5 -5
  210. package/dist/components/{p-f41c84fa.js.map → p-a957f7ad.js.map} +1 -1
  211. package/dist/components/{p-04cfc587.js → p-ab5c15bf.js} +3 -3
  212. package/dist/components/{p-04cfc587.js.map → p-ab5c15bf.js.map} +1 -1
  213. package/dist/components/{p-cefd9f73.js → p-b5256810.js} +4 -4
  214. package/dist/components/{p-cefd9f73.js.map → p-b5256810.js.map} +1 -1
  215. package/dist/components/{p-681bd5b1.js → p-c88b4b7c.js} +4 -4
  216. package/dist/components/{p-681bd5b1.js.map → p-c88b4b7c.js.map} +1 -1
  217. package/dist/components/{p-cc9cb040.js → p-dcecb226.js} +2 -2
  218. package/dist/components/{p-cc9cb040.js.map → p-dcecb226.js.map} +1 -1
  219. package/dist/components/{p-52c9a12e.js → p-e3cd5556.js} +3 -3
  220. package/dist/components/{p-52c9a12e.js.map → p-e3cd5556.js.map} +1 -1
  221. package/dist/components/{p-23a993bc.js → p-e73e6dce.js} +4 -4
  222. package/dist/components/{p-23a993bc.js.map → p-e73e6dce.js.map} +1 -1
  223. package/dist/components/{p-8824ca83.js → p-f511219b.js} +2 -2
  224. package/dist/components/{p-8824ca83.js.map → p-f511219b.js.map} +1 -1
  225. package/dist/components/{p-2cc378b8.js → p-f8e6a4ef.js} +43 -3
  226. package/dist/components/p-f8e6a4ef.js.map +1 -0
  227. package/dist/esm/ifx-accordion_2.entry.js +1 -1
  228. package/dist/esm/ifx-alert_2.entry.js +1 -1
  229. package/dist/esm/ifx-badge.entry.js +1 -1
  230. package/dist/esm/ifx-basic-table.entry.js +1 -1
  231. package/dist/esm/ifx-breadcrumb-item-label.entry.js +1 -1
  232. package/dist/esm/ifx-breadcrumb-item.entry.js +1 -1
  233. package/dist/esm/ifx-breadcrumb.entry.js +1 -1
  234. package/dist/esm/ifx-button.entry.js +1 -1
  235. package/dist/esm/ifx-card-headline.entry.js +1 -1
  236. package/dist/esm/ifx-card-image.entry.js +1 -1
  237. package/dist/esm/ifx-card-links.entry.js +1 -1
  238. package/dist/esm/ifx-card-overline.entry.js +1 -1
  239. package/dist/esm/ifx-card-text.entry.js +1 -1
  240. package/dist/esm/ifx-card.entry.js +1 -1
  241. package/dist/esm/ifx-checkbox-group.entry.js +1 -1
  242. package/dist/esm/ifx-checkbox.entry.js +1 -1
  243. package/dist/esm/ifx-chip_3.entry.js +1 -1
  244. package/dist/esm/ifx-content-switcher-item.entry.js +1 -1
  245. package/dist/esm/ifx-content-switcher.entry.js +1 -1
  246. package/dist/esm/ifx-date-picker.entry.js +1 -1
  247. package/dist/esm/ifx-download.entry.js +1 -1
  248. package/dist/esm/ifx-dropdown-header.entry.js +1 -1
  249. package/dist/esm/ifx-dropdown-item.entry.js +1 -1
  250. package/dist/esm/ifx-dropdown-menu.entry.js +1 -1
  251. package/dist/esm/ifx-dropdown-separator.entry.js +1 -1
  252. package/dist/esm/ifx-dropdown-trigger-button.entry.js +1 -1
  253. package/dist/esm/ifx-dropdown-trigger.entry.js +1 -1
  254. package/dist/esm/ifx-dropdown.entry.js +1 -1
  255. package/dist/esm/ifx-faq.entry.js +2 -2
  256. package/dist/esm/ifx-file-upload.entry.js +1 -1
  257. package/dist/esm/ifx-filter-accordion.entry.js +1 -1
  258. package/dist/esm/ifx-filter-bar.entry.js +1 -1
  259. package/dist/esm/ifx-filter-search.entry.js +1 -1
  260. package/dist/esm/ifx-filter-type-group.entry.js +1 -1
  261. package/dist/esm/ifx-footer-column.entry.js +1 -1
  262. package/dist/esm/ifx-footer.entry.js +1 -1
  263. package/dist/esm/ifx-icon-button.entry.js +1 -1
  264. package/dist/esm/ifx-icon.entry.js +1 -1
  265. package/dist/esm/ifx-icons-preview.entry.js +1 -1
  266. package/dist/esm/ifx-link.entry.js +1 -1
  267. package/dist/esm/ifx-list-entry.entry.js +1 -1
  268. package/dist/esm/ifx-list.entry.js +1 -1
  269. package/dist/esm/ifx-modal.entry.js +1 -1
  270. package/dist/esm/ifx-multiselect.entry.js +1 -1
  271. package/dist/esm/ifx-navbar-item.entry.js +1 -1
  272. package/dist/esm/ifx-navbar-profile.entry.js +1 -1
  273. package/dist/esm/ifx-navbar.entry.js +1 -1
  274. package/dist/esm/ifx-notification.entry.js +1 -1
  275. package/dist/esm/ifx-number-indicator.entry.js +1 -1
  276. package/dist/esm/ifx-overview-table.entry.js +1 -1
  277. package/dist/esm/ifx-progress-bar.entry.js +1 -1
  278. package/dist/esm/ifx-radio-button-group.entry.js +1 -1
  279. package/dist/esm/ifx-radio-button.entry.js +1 -1
  280. package/dist/esm/ifx-search-bar.entry.js +1 -1
  281. package/dist/esm/ifx-search-field.entry.js +1 -1
  282. package/dist/esm/ifx-segment.entry.js +1 -1
  283. package/dist/esm/ifx-segmented-control.entry.js +1 -1
  284. package/dist/esm/ifx-select.entry.js +1 -1
  285. package/dist/esm/ifx-set-filter.entry.js +1 -1
  286. package/dist/esm/ifx-sidebar-item.entry.js +1 -1
  287. package/dist/esm/ifx-sidebar-title.entry.js +1 -1
  288. package/dist/esm/ifx-sidebar.entry.js +1 -1
  289. package/dist/esm/ifx-slider.entry.js +1 -1
  290. package/dist/esm/ifx-spinner_2.entry.js +1 -1
  291. package/dist/esm/ifx-status.entry.js +1 -1
  292. package/dist/esm/ifx-step.entry.js +1 -1
  293. package/dist/esm/ifx-stepper.entry.js +1 -1
  294. package/dist/esm/ifx-switch.entry.js +1 -1
  295. package/dist/esm/ifx-tab.entry.js +1 -1
  296. package/dist/esm/ifx-table.entry.js +1 -1
  297. package/dist/esm/ifx-tabs.entry.js +1 -1
  298. package/dist/esm/ifx-tag.entry.js +1 -1
  299. package/dist/esm/ifx-templates-ui.entry.js +1 -1
  300. package/dist/esm/ifx-textarea.entry.js +1 -1
  301. package/dist/esm/ifx-tooltip.entry.js +1 -1
  302. package/dist/esm/ifx-tree-view-item.entry.js +323 -0
  303. package/dist/esm/ifx-tree-view-item.entry.js.map +1 -0
  304. package/dist/esm/ifx-tree-view.entry.js +51 -0
  305. package/dist/esm/ifx-tree-view.entry.js.map +1 -0
  306. package/dist/esm/{index-c77e25a0.js → index-6c9eba32.js} +55 -7
  307. package/dist/esm/index-6c9eba32.js.map +1 -0
  308. package/dist/esm/infineon-design-system-stencil.js +3 -3
  309. package/dist/esm/loader.js +3 -3
  310. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js +1 -1
  311. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js.map +1 -1
  312. package/dist/infineon-design-system-stencil/{p-d2dfe109.entry.js → p-00a1ec40.entry.js} +2 -2
  313. package/dist/infineon-design-system-stencil/{p-b2ff6914.entry.js → p-0262de1d.entry.js} +2 -2
  314. package/dist/infineon-design-system-stencil/{p-0474c62d.entry.js → p-03c9d3fe.entry.js} +2 -2
  315. package/dist/infineon-design-system-stencil/{p-661a7c0b.entry.js → p-07ecc076.entry.js} +2 -2
  316. package/dist/infineon-design-system-stencil/{p-f88b928c.entry.js → p-1772ef7d.entry.js} +2 -2
  317. package/dist/infineon-design-system-stencil/p-19f2f7d6.entry.js +2 -0
  318. package/dist/infineon-design-system-stencil/p-19f2f7d6.entry.js.map +1 -0
  319. package/dist/infineon-design-system-stencil/{p-ac4aaa18.entry.js → p-1a82e21d.entry.js} +2 -2
  320. package/dist/infineon-design-system-stencil/{p-1a29bbb2.entry.js → p-1d8518f1.entry.js} +2 -2
  321. package/dist/infineon-design-system-stencil/{p-b0c402e0.entry.js → p-1f24970a.entry.js} +2 -2
  322. package/dist/infineon-design-system-stencil/{p-964e15d1.entry.js → p-202a39ff.entry.js} +2 -2
  323. package/dist/infineon-design-system-stencil/{p-0333c09a.entry.js → p-20de8fb7.entry.js} +2 -2
  324. package/dist/infineon-design-system-stencil/{p-00fd53b9.entry.js → p-2281b467.entry.js} +2 -2
  325. package/dist/infineon-design-system-stencil/{p-b8e74ad3.entry.js → p-28de8581.entry.js} +2 -2
  326. package/dist/infineon-design-system-stencil/{p-fdad4729.entry.js → p-2e900240.entry.js} +2 -2
  327. package/dist/infineon-design-system-stencil/{p-723cace7.entry.js → p-30503cdf.entry.js} +2 -2
  328. package/dist/infineon-design-system-stencil/{p-e93396ed.entry.js → p-30bd18de.entry.js} +2 -2
  329. package/dist/infineon-design-system-stencil/p-34930b99.entry.js +2 -0
  330. package/dist/infineon-design-system-stencil/{p-f22dad77.entry.js → p-37c45825.entry.js} +2 -2
  331. package/dist/infineon-design-system-stencil/{p-1218cd67.entry.js → p-3a7f32df.entry.js} +2 -2
  332. package/dist/infineon-design-system-stencil/{p-edc77e53.entry.js → p-3bd9ec1c.entry.js} +2 -2
  333. package/dist/infineon-design-system-stencil/p-4304900a.entry.js +2 -0
  334. package/dist/infineon-design-system-stencil/p-4304900a.entry.js.map +1 -0
  335. package/dist/infineon-design-system-stencil/{p-fe2d60b9.entry.js → p-45ac2698.entry.js} +2 -2
  336. package/dist/infineon-design-system-stencil/p-488408d3.entry.js +2 -0
  337. package/dist/infineon-design-system-stencil/{p-41f245f6.entry.js → p-4b1e700d.entry.js} +2 -2
  338. package/dist/infineon-design-system-stencil/{p-99461b11.entry.js → p-50252b28.entry.js} +2 -2
  339. package/dist/infineon-design-system-stencil/{p-53abaa78.entry.js → p-527afe1e.entry.js} +2 -2
  340. package/dist/infineon-design-system-stencil/{p-d928585e.entry.js → p-571e0df8.entry.js} +2 -2
  341. package/dist/infineon-design-system-stencil/{p-47893f7e.entry.js → p-5efc38d5.entry.js} +2 -2
  342. package/dist/infineon-design-system-stencil/{p-b44360ea.entry.js → p-5fb32319.entry.js} +2 -2
  343. package/dist/infineon-design-system-stencil/{p-4d0da3de.entry.js → p-5fc8cf08.entry.js} +2 -2
  344. package/dist/infineon-design-system-stencil/{p-7bbaff92.entry.js → p-60ee12c3.entry.js} +2 -2
  345. package/dist/infineon-design-system-stencil/{p-3545f2d5.entry.js → p-62303f57.entry.js} +2 -2
  346. package/dist/infineon-design-system-stencil/{p-65d5e257.entry.js → p-62a04d45.entry.js} +2 -2
  347. package/dist/infineon-design-system-stencil/{p-5a5df7de.entry.js → p-676e0a62.entry.js} +2 -2
  348. package/dist/infineon-design-system-stencil/{p-b39303be.entry.js → p-6bb224ed.entry.js} +2 -2
  349. package/dist/infineon-design-system-stencil/{p-3469adb7.entry.js → p-6bd0690d.entry.js} +2 -2
  350. package/dist/infineon-design-system-stencil/{p-361d1e31.entry.js → p-7001bc7d.entry.js} +2 -2
  351. package/dist/infineon-design-system-stencil/{p-9da1f8b9.entry.js → p-715070f7.entry.js} +2 -2
  352. package/dist/infineon-design-system-stencil/{p-1958f029.entry.js → p-741ee6fd.entry.js} +2 -2
  353. package/dist/infineon-design-system-stencil/{p-2fb84e5d.entry.js → p-7c06a6bd.entry.js} +2 -2
  354. package/dist/infineon-design-system-stencil/{p-88ae2d37.entry.js → p-800704ec.entry.js} +2 -2
  355. package/dist/infineon-design-system-stencil/{p-c2cc54c0.entry.js → p-82d372b4.entry.js} +2 -2
  356. package/dist/infineon-design-system-stencil/{p-59036c10.entry.js → p-87e684d5.entry.js} +2 -2
  357. package/dist/infineon-design-system-stencil/{p-c6b76d4a.entry.js → p-8dad964c.entry.js} +2 -2
  358. package/dist/infineon-design-system-stencil/{p-a25618fd.entry.js → p-96244232.entry.js} +2 -2
  359. package/dist/infineon-design-system-stencil/{p-7355c5fe.entry.js → p-9b6f98a6.entry.js} +2 -2
  360. package/dist/infineon-design-system-stencil/{p-33f48cf1.entry.js → p-9b94e2ae.entry.js} +2 -2
  361. package/dist/infineon-design-system-stencil/{p-e5df823b.entry.js → p-9d4b5f5a.entry.js} +2 -2
  362. package/dist/infineon-design-system-stencil/{p-8a733ad7.entry.js → p-a2615d6f.entry.js} +2 -2
  363. package/dist/infineon-design-system-stencil/{p-7e55680a.entry.js → p-a3c0eb25.entry.js} +2 -2
  364. package/dist/infineon-design-system-stencil/{p-f4866ad9.entry.js → p-a74c4f55.entry.js} +2 -2
  365. package/dist/infineon-design-system-stencil/{p-6693fddc.entry.js → p-ad4305fd.entry.js} +2 -2
  366. package/dist/infineon-design-system-stencil/{p-6a8bfce7.entry.js → p-af1be17e.entry.js} +2 -2
  367. package/dist/infineon-design-system-stencil/{p-007f032b.entry.js → p-b1332d35.entry.js} +2 -2
  368. package/dist/infineon-design-system-stencil/p-b7a462e5.js +3 -0
  369. package/dist/infineon-design-system-stencil/p-b7a462e5.js.map +1 -0
  370. package/dist/infineon-design-system-stencil/{p-0a69604b.entry.js → p-b892a205.entry.js} +2 -2
  371. package/dist/infineon-design-system-stencil/{p-d5936509.entry.js → p-bab776f1.entry.js} +2 -2
  372. package/dist/infineon-design-system-stencil/{p-61117bda.entry.js → p-bf7bb869.entry.js} +2 -2
  373. package/dist/infineon-design-system-stencil/{p-2fa26bf7.entry.js → p-c0c148ec.entry.js} +2 -2
  374. package/dist/infineon-design-system-stencil/p-c1caa426.entry.js +2 -0
  375. package/dist/infineon-design-system-stencil/{p-d04dbacf.entry.js → p-cb81ea29.entry.js} +2 -2
  376. package/dist/infineon-design-system-stencil/{p-ba4f65f1.entry.js → p-cbd79068.entry.js} +2 -2
  377. package/dist/infineon-design-system-stencil/{p-3ff188be.entry.js → p-d4eff9d8.entry.js} +2 -2
  378. package/dist/infineon-design-system-stencil/{p-040dfe3a.entry.js → p-d5c87934.entry.js} +2 -2
  379. package/dist/infineon-design-system-stencil/{p-c4eac5cd.entry.js → p-d73913fd.entry.js} +2 -2
  380. package/dist/infineon-design-system-stencil/{p-29984af2.entry.js → p-dd28f3a1.entry.js} +2 -2
  381. package/dist/infineon-design-system-stencil/{p-22615332.entry.js → p-dd50c9cc.entry.js} +2 -2
  382. package/dist/infineon-design-system-stencil/{p-a8241d5d.entry.js → p-e014d22e.entry.js} +2 -2
  383. package/dist/infineon-design-system-stencil/{p-d4da0515.entry.js → p-e11f02e9.entry.js} +2 -2
  384. package/dist/infineon-design-system-stencil/{p-c172e015.entry.js → p-e913b4bc.entry.js} +2 -2
  385. package/dist/infineon-design-system-stencil/{p-b26d054b.entry.js → p-eb5e154d.entry.js} +2 -2
  386. package/dist/infineon-design-system-stencil/{p-063dc766.entry.js → p-f0233249.entry.js} +2 -2
  387. package/dist/infineon-design-system-stencil/{p-0d11b881.entry.js → p-f0c2e188.entry.js} +2 -2
  388. package/dist/infineon-design-system-stencil/{p-de733e32.entry.js → p-f41db87c.entry.js} +2 -2
  389. package/dist/infineon-design-system-stencil/{p-53411f03.entry.js → p-f9364479.entry.js} +2 -2
  390. package/dist/infineon-design-system-stencil/{p-ce448991.entry.js → p-fa81a54a.entry.js} +2 -2
  391. package/dist/infineon-design-system-stencil/{p-41846fb5.entry.js → p-fb7fbe44.entry.js} +2 -2
  392. package/dist/infineon-design-system-stencil/{p-a3ece62e.entry.js → p-fe38ca7b.entry.js} +2 -2
  393. package/dist/types/components/tree-view/tree-view-item.d.ts +50 -0
  394. package/dist/types/components/tree-view/tree-view.d.ts +12 -0
  395. package/dist/types/components/tree-view/tree-view.stories.d.ts +6 -0
  396. package/dist/types/components.d.ts +82 -0
  397. package/package.json +1 -1
  398. package/dist/cjs/index-c9480f70.js.map +0 -1
  399. package/dist/components/p-2cc378b8.js.map +0 -1
  400. package/dist/esm/index-c77e25a0.js.map +0 -1
  401. package/dist/infineon-design-system-stencil/p-406b00eb.entry.js +0 -2
  402. package/dist/infineon-design-system-stencil/p-4ddb3e72.entry.js +0 -2
  403. package/dist/infineon-design-system-stencil/p-a92465d1.entry.js +0 -2
  404. package/dist/infineon-design-system-stencil/p-e6edf72d.js +0 -3
  405. package/dist/infineon-design-system-stencil/p-e6edf72d.js.map +0 -1
  406. /package/dist/infineon-design-system-stencil/{p-d2dfe109.entry.js.map → p-00a1ec40.entry.js.map} +0 -0
  407. /package/dist/infineon-design-system-stencil/{p-b2ff6914.entry.js.map → p-0262de1d.entry.js.map} +0 -0
  408. /package/dist/infineon-design-system-stencil/{p-0474c62d.entry.js.map → p-03c9d3fe.entry.js.map} +0 -0
  409. /package/dist/infineon-design-system-stencil/{p-661a7c0b.entry.js.map → p-07ecc076.entry.js.map} +0 -0
  410. /package/dist/infineon-design-system-stencil/{p-f88b928c.entry.js.map → p-1772ef7d.entry.js.map} +0 -0
  411. /package/dist/infineon-design-system-stencil/{p-ac4aaa18.entry.js.map → p-1a82e21d.entry.js.map} +0 -0
  412. /package/dist/infineon-design-system-stencil/{p-1a29bbb2.entry.js.map → p-1d8518f1.entry.js.map} +0 -0
  413. /package/dist/infineon-design-system-stencil/{p-b0c402e0.entry.js.map → p-1f24970a.entry.js.map} +0 -0
  414. /package/dist/infineon-design-system-stencil/{p-964e15d1.entry.js.map → p-202a39ff.entry.js.map} +0 -0
  415. /package/dist/infineon-design-system-stencil/{p-0333c09a.entry.js.map → p-20de8fb7.entry.js.map} +0 -0
  416. /package/dist/infineon-design-system-stencil/{p-00fd53b9.entry.js.map → p-2281b467.entry.js.map} +0 -0
  417. /package/dist/infineon-design-system-stencil/{p-b8e74ad3.entry.js.map → p-28de8581.entry.js.map} +0 -0
  418. /package/dist/infineon-design-system-stencil/{p-fdad4729.entry.js.map → p-2e900240.entry.js.map} +0 -0
  419. /package/dist/infineon-design-system-stencil/{p-723cace7.entry.js.map → p-30503cdf.entry.js.map} +0 -0
  420. /package/dist/infineon-design-system-stencil/{p-e93396ed.entry.js.map → p-30bd18de.entry.js.map} +0 -0
  421. /package/dist/infineon-design-system-stencil/{p-406b00eb.entry.js.map → p-34930b99.entry.js.map} +0 -0
  422. /package/dist/infineon-design-system-stencil/{p-f22dad77.entry.js.map → p-37c45825.entry.js.map} +0 -0
  423. /package/dist/infineon-design-system-stencil/{p-1218cd67.entry.js.map → p-3a7f32df.entry.js.map} +0 -0
  424. /package/dist/infineon-design-system-stencil/{p-edc77e53.entry.js.map → p-3bd9ec1c.entry.js.map} +0 -0
  425. /package/dist/infineon-design-system-stencil/{p-fe2d60b9.entry.js.map → p-45ac2698.entry.js.map} +0 -0
  426. /package/dist/infineon-design-system-stencil/{p-a92465d1.entry.js.map → p-488408d3.entry.js.map} +0 -0
  427. /package/dist/infineon-design-system-stencil/{p-41f245f6.entry.js.map → p-4b1e700d.entry.js.map} +0 -0
  428. /package/dist/infineon-design-system-stencil/{p-99461b11.entry.js.map → p-50252b28.entry.js.map} +0 -0
  429. /package/dist/infineon-design-system-stencil/{p-53abaa78.entry.js.map → p-527afe1e.entry.js.map} +0 -0
  430. /package/dist/infineon-design-system-stencil/{p-d928585e.entry.js.map → p-571e0df8.entry.js.map} +0 -0
  431. /package/dist/infineon-design-system-stencil/{p-47893f7e.entry.js.map → p-5efc38d5.entry.js.map} +0 -0
  432. /package/dist/infineon-design-system-stencil/{p-b44360ea.entry.js.map → p-5fb32319.entry.js.map} +0 -0
  433. /package/dist/infineon-design-system-stencil/{p-4d0da3de.entry.js.map → p-5fc8cf08.entry.js.map} +0 -0
  434. /package/dist/infineon-design-system-stencil/{p-7bbaff92.entry.js.map → p-60ee12c3.entry.js.map} +0 -0
  435. /package/dist/infineon-design-system-stencil/{p-3545f2d5.entry.js.map → p-62303f57.entry.js.map} +0 -0
  436. /package/dist/infineon-design-system-stencil/{p-65d5e257.entry.js.map → p-62a04d45.entry.js.map} +0 -0
  437. /package/dist/infineon-design-system-stencil/{p-5a5df7de.entry.js.map → p-676e0a62.entry.js.map} +0 -0
  438. /package/dist/infineon-design-system-stencil/{p-b39303be.entry.js.map → p-6bb224ed.entry.js.map} +0 -0
  439. /package/dist/infineon-design-system-stencil/{p-3469adb7.entry.js.map → p-6bd0690d.entry.js.map} +0 -0
  440. /package/dist/infineon-design-system-stencil/{p-361d1e31.entry.js.map → p-7001bc7d.entry.js.map} +0 -0
  441. /package/dist/infineon-design-system-stencil/{p-9da1f8b9.entry.js.map → p-715070f7.entry.js.map} +0 -0
  442. /package/dist/infineon-design-system-stencil/{p-1958f029.entry.js.map → p-741ee6fd.entry.js.map} +0 -0
  443. /package/dist/infineon-design-system-stencil/{p-2fb84e5d.entry.js.map → p-7c06a6bd.entry.js.map} +0 -0
  444. /package/dist/infineon-design-system-stencil/{p-88ae2d37.entry.js.map → p-800704ec.entry.js.map} +0 -0
  445. /package/dist/infineon-design-system-stencil/{p-c2cc54c0.entry.js.map → p-82d372b4.entry.js.map} +0 -0
  446. /package/dist/infineon-design-system-stencil/{p-59036c10.entry.js.map → p-87e684d5.entry.js.map} +0 -0
  447. /package/dist/infineon-design-system-stencil/{p-c6b76d4a.entry.js.map → p-8dad964c.entry.js.map} +0 -0
  448. /package/dist/infineon-design-system-stencil/{p-a25618fd.entry.js.map → p-96244232.entry.js.map} +0 -0
  449. /package/dist/infineon-design-system-stencil/{p-7355c5fe.entry.js.map → p-9b6f98a6.entry.js.map} +0 -0
  450. /package/dist/infineon-design-system-stencil/{p-33f48cf1.entry.js.map → p-9b94e2ae.entry.js.map} +0 -0
  451. /package/dist/infineon-design-system-stencil/{p-e5df823b.entry.js.map → p-9d4b5f5a.entry.js.map} +0 -0
  452. /package/dist/infineon-design-system-stencil/{p-8a733ad7.entry.js.map → p-a2615d6f.entry.js.map} +0 -0
  453. /package/dist/infineon-design-system-stencil/{p-7e55680a.entry.js.map → p-a3c0eb25.entry.js.map} +0 -0
  454. /package/dist/infineon-design-system-stencil/{p-f4866ad9.entry.js.map → p-a74c4f55.entry.js.map} +0 -0
  455. /package/dist/infineon-design-system-stencil/{p-6693fddc.entry.js.map → p-ad4305fd.entry.js.map} +0 -0
  456. /package/dist/infineon-design-system-stencil/{p-6a8bfce7.entry.js.map → p-af1be17e.entry.js.map} +0 -0
  457. /package/dist/infineon-design-system-stencil/{p-007f032b.entry.js.map → p-b1332d35.entry.js.map} +0 -0
  458. /package/dist/infineon-design-system-stencil/{p-0a69604b.entry.js.map → p-b892a205.entry.js.map} +0 -0
  459. /package/dist/infineon-design-system-stencil/{p-d5936509.entry.js.map → p-bab776f1.entry.js.map} +0 -0
  460. /package/dist/infineon-design-system-stencil/{p-61117bda.entry.js.map → p-bf7bb869.entry.js.map} +0 -0
  461. /package/dist/infineon-design-system-stencil/{p-2fa26bf7.entry.js.map → p-c0c148ec.entry.js.map} +0 -0
  462. /package/dist/infineon-design-system-stencil/{p-4ddb3e72.entry.js.map → p-c1caa426.entry.js.map} +0 -0
  463. /package/dist/infineon-design-system-stencil/{p-d04dbacf.entry.js.map → p-cb81ea29.entry.js.map} +0 -0
  464. /package/dist/infineon-design-system-stencil/{p-ba4f65f1.entry.js.map → p-cbd79068.entry.js.map} +0 -0
  465. /package/dist/infineon-design-system-stencil/{p-3ff188be.entry.js.map → p-d4eff9d8.entry.js.map} +0 -0
  466. /package/dist/infineon-design-system-stencil/{p-040dfe3a.entry.js.map → p-d5c87934.entry.js.map} +0 -0
  467. /package/dist/infineon-design-system-stencil/{p-c4eac5cd.entry.js.map → p-d73913fd.entry.js.map} +0 -0
  468. /package/dist/infineon-design-system-stencil/{p-29984af2.entry.js.map → p-dd28f3a1.entry.js.map} +0 -0
  469. /package/dist/infineon-design-system-stencil/{p-22615332.entry.js.map → p-dd50c9cc.entry.js.map} +0 -0
  470. /package/dist/infineon-design-system-stencil/{p-a8241d5d.entry.js.map → p-e014d22e.entry.js.map} +0 -0
  471. /package/dist/infineon-design-system-stencil/{p-d4da0515.entry.js.map → p-e11f02e9.entry.js.map} +0 -0
  472. /package/dist/infineon-design-system-stencil/{p-c172e015.entry.js.map → p-e913b4bc.entry.js.map} +0 -0
  473. /package/dist/infineon-design-system-stencil/{p-b26d054b.entry.js.map → p-eb5e154d.entry.js.map} +0 -0
  474. /package/dist/infineon-design-system-stencil/{p-063dc766.entry.js.map → p-f0233249.entry.js.map} +0 -0
  475. /package/dist/infineon-design-system-stencil/{p-0d11b881.entry.js.map → p-f0c2e188.entry.js.map} +0 -0
  476. /package/dist/infineon-design-system-stencil/{p-de733e32.entry.js.map → p-f41db87c.entry.js.map} +0 -0
  477. /package/dist/infineon-design-system-stencil/{p-53411f03.entry.js.map → p-f9364479.entry.js.map} +0 -0
  478. /package/dist/infineon-design-system-stencil/{p-ce448991.entry.js.map → p-fa81a54a.entry.js.map} +0 -0
  479. /package/dist/infineon-design-system-stencil/{p-41846fb5.entry.js.map → p-fb7fbe44.entry.js.map} +0 -0
  480. /package/dist/infineon-design-system-stencil/{p-a3ece62e.entry.js.map → p-fe38ca7b.entry.js.map} +0 -0
@@ -0,0 +1,327 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-7f4df11a.js');
6
+
7
+ const treeViewItemCss = ".tree-item{position:relative;cursor:pointer;list-style:none}.tree-item.tree-item--expanded{position:relative}.tree-item.tree-item--has-children{position:relative}.tree-item.tree-item--has-children .tree-item__header>.tree-item__chevron-container{display:flex}.tree-item.tree-item--has-children.tree-item--expanded .tree-item__header>.tree-item__chevron-container::after{display:block}.tree-item--disabled{cursor:not-allowed;pointer-events:none;color:#BFBBBB}.tree-item__content{display:flex;flex-direction:row}.tree-item__content:hover .tree-item__checkbox-container,.tree-item__content:hover .tree-item__header{background-color:#F7F7F7}.tree-item__checkbox-container{position:sticky;left:0;z-index:10;padding:4px;background-color:#FFFFFF}.tree-item__header{flex-grow:1;display:flex;align-items:center;white-space:nowrap;height:20px;padding-top:4px;padding-right:16px;padding-bottom:4px;padding-left:8px}.tree-item__chevron-container{display:none;align-items:center;margin-right:8px;height:20px}.tree-item__chevron-container::after{--height-line-start:28px;display:none;content:\"\";position:absolute;z-index:1;top:var(--height-line-start);left:auto;margin-left:8px;width:1px;height:calc(100% - var(--height-line-start));background-color:#EEEDED}.tree-item--disabled .tree-item__chevron-container::after{color:#EEEDED}.tree-item__chevron.chevron-down{transform:rotate(90deg)}.tree-item__chevron.chevron-right{transform:rotate(0)}.tree-item__label-icon-container{display:flex;align-items:center}.tree-item__label-icon-container:focus{outline:none}.tree-item__label-icon-container:focus-visible{outline:2px solid #0A8276;outline-offset:2px;border-radius:1px}.tree-item__icon-container{position:relative;width:16px;height:16px}.tree-item__icon-container ifx-icon{position:absolute;left:0;top:0;opacity:1;transition:opacity 0.2s ease-in-out}.tree-item__icon-container ifx-icon.icon--hidden{opacity:0}.tree-item__label{padding-left:8px}.tree-item__children{display:none}.tree-item[aria-expanded=true]>.tree-item__children{display:block}";
8
+ const IfxTreeViewItemStyle0 = treeViewItemCss;
9
+
10
+ const TreeViewItem = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.ifxTreeViewItemExpandChange = index.createEvent(this, "ifxTreeViewItemExpandChange", 7);
14
+ this.ifxTreeViewItemCheckChange = index.createEvent(this, "ifxTreeViewItemCheckChange", 7);
15
+ this.ifxTreeViewItemDisableChange = index.createEvent(this, "ifxTreeViewItemDisableChange", 7);
16
+ this.expanded = false;
17
+ this.initiallyExpanded = false;
18
+ this.disableItem = false;
19
+ this.ariaLabel = 'Tree Item';
20
+ this.hasChildren = false;
21
+ this.isChecked = false;
22
+ this.partialChecked = false;
23
+ this.level = 0;
24
+ this.disableAllItems = false;
25
+ this.expandAllItems = false;
26
+ this.findChildren = () => Array.from(this.host.children)
27
+ .filter((child) => child instanceof HTMLElement && child.tagName === 'IFX-TREE-VIEW-ITEM');
28
+ this.calculateNodeLevel = () => {
29
+ let level = 0, parent = this.host.parentElement;
30
+ while (parent) {
31
+ if (parent.tagName === 'IFX-TREE-VIEW-ITEM')
32
+ level++;
33
+ parent = parent.parentElement;
34
+ }
35
+ return level;
36
+ };
37
+ this.handleStateChange = (event) => {
38
+ if (this.disabled)
39
+ return;
40
+ event.stopPropagation();
41
+ this.updateCheckState(event.detail.checked);
42
+ };
43
+ this.handleCheckboxChange = (event) => {
44
+ var _a, _b;
45
+ if (this.disabled)
46
+ return;
47
+ this.updateCheckState((_b = (_a = event.detail) === null || _a === void 0 ? void 0 : _a.checked) !== null && _b !== void 0 ? _b : !this.isChecked);
48
+ };
49
+ this.handleHeaderClick = ({ target }) => {
50
+ if (this.disabled)
51
+ return;
52
+ if (!target.closest('.tree-item__checkbox-container, .tree-item__chevron-container')) {
53
+ this.updateCheckState(!this.isChecked);
54
+ }
55
+ };
56
+ this.toggleExpand = () => {
57
+ if (this.disabled)
58
+ return;
59
+ this.hasChildren && (this.expanded = !this.expanded);
60
+ };
61
+ this.handleKeyDown = (event) => {
62
+ var _a, _b, _c, _d, _e, _f;
63
+ const allItems = Array.from(((_a = this.host
64
+ .closest('ifx-tree-view')) === null || _a === void 0 ? void 0 : _a.querySelectorAll('ifx-tree-view-item')) || []);
65
+ const visibleItems = allItems.filter(item => {
66
+ var _a, _b;
67
+ let parent = (_a = item.parentElement) === null || _a === void 0 ? void 0 : _a.closest('ifx-tree-view-item');
68
+ while (parent) {
69
+ const parentCmp = parent;
70
+ if (!(parentCmp.expandAllItems || parentCmp.expanded)) {
71
+ return false;
72
+ }
73
+ parent = (_b = parent.parentElement) === null || _b === void 0 ? void 0 : _b.closest('ifx-tree-view-item');
74
+ }
75
+ return true;
76
+ });
77
+ const currentIndex = visibleItems.findIndex(el => el === this.host);
78
+ function focusLabelIcon(el) {
79
+ el === null || el === void 0 ? void 0 : el.focus();
80
+ }
81
+ switch (event.key) {
82
+ case 'ArrowDown': {
83
+ event.preventDefault();
84
+ let nextIndex = currentIndex + 1;
85
+ while (nextIndex < visibleItems.length) {
86
+ const next = visibleItems[nextIndex];
87
+ if (!next.disabled) {
88
+ focusLabelIcon((_b = next.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.tree-item__label-icon-container'));
89
+ break;
90
+ }
91
+ nextIndex++;
92
+ }
93
+ break;
94
+ }
95
+ case 'ArrowUp': {
96
+ event.preventDefault();
97
+ let prevIndex = currentIndex - 1;
98
+ while (prevIndex >= 0) {
99
+ const prev = visibleItems[prevIndex];
100
+ if (!prev.disabled) {
101
+ focusLabelIcon((_c = prev.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('.tree-item__label-icon-container'));
102
+ break;
103
+ }
104
+ prevIndex--;
105
+ }
106
+ break;
107
+ }
108
+ case 'ArrowRight': {
109
+ event.preventDefault();
110
+ if (!this.isExpanded && this.hasChildren) {
111
+ this.expanded = true;
112
+ }
113
+ else if (this.isExpanded && this.hasChildren) {
114
+ const firstChild = this.host.querySelector('ifx-tree-view-item');
115
+ if (firstChild && !firstChild.disabled) {
116
+ focusLabelIcon((_d = firstChild.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.tree-item__label-icon-container'));
117
+ }
118
+ }
119
+ break;
120
+ }
121
+ case 'ArrowLeft': {
122
+ event.preventDefault();
123
+ if (this.isExpanded && this.hasChildren) {
124
+ this.expanded = false;
125
+ }
126
+ else {
127
+ const parent = (_e = this.host.parentElement) === null || _e === void 0 ? void 0 : _e.closest('ifx-tree-view-item');
128
+ if (parent && !parent.disabled) {
129
+ focusLabelIcon((_f = parent.shadowRoot) === null || _f === void 0 ? void 0 : _f.querySelector('.tree-item__label-icon-container'));
130
+ }
131
+ }
132
+ break;
133
+ }
134
+ case ' ':
135
+ case 'Enter': {
136
+ event.preventDefault();
137
+ this.updateCheckState(!this.isChecked);
138
+ break;
139
+ }
140
+ }
141
+ };
142
+ }
143
+ get disabled() {
144
+ return this.disableAllItems || this.disableItem;
145
+ }
146
+ get isExpanded() {
147
+ return this.expandAllItems || this.expanded;
148
+ }
149
+ componentWillLoad() {
150
+ this.initializeNode();
151
+ this.setupEventListeners();
152
+ }
153
+ componentDidLoad() {
154
+ this.observeDisableAllItems();
155
+ this.observeExpandAllItems();
156
+ if (this.shouldExpandFromParent()) {
157
+ this.expandAllDescendants();
158
+ }
159
+ }
160
+ shouldExpandFromParent() {
161
+ let parent = this.host.parentElement;
162
+ while (parent) {
163
+ if (parent.tagName === 'IFX-TREE-VIEW' &&
164
+ (parent.hasAttribute('expand-all-items') || parent.hasAttribute('data-expand-all-items'))) {
165
+ return true;
166
+ }
167
+ parent = parent.parentElement;
168
+ }
169
+ return false;
170
+ }
171
+ expandAllDescendants() {
172
+ this.expanded = true;
173
+ const children = this.findChildren();
174
+ for (const child of children) {
175
+ if (typeof child.expanded !== 'undefined') {
176
+ child.expanded = true;
177
+ }
178
+ if (typeof child.expandAllDescendants === 'function') {
179
+ child.expandAllDescendants();
180
+ }
181
+ }
182
+ }
183
+ observeDisableAllItems() {
184
+ let parent = this.host.parentElement;
185
+ while (parent) {
186
+ if (parent.tagName === 'IFX-TREE-VIEW') {
187
+ const observer = new MutationObserver(mutations => {
188
+ for (const mutation of mutations) {
189
+ if (mutation.type === 'attributes' &&
190
+ mutation.attributeName === 'disable-all-items') {
191
+ const disableAll = parent.disableAllItems;
192
+ this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');
193
+ }
194
+ }
195
+ });
196
+ observer.observe(parent, { attributes: true });
197
+ const disableAll = parent.disableAllItems;
198
+ this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');
199
+ break;
200
+ }
201
+ parent = parent.parentElement;
202
+ }
203
+ }
204
+ observeExpandAllItems() {
205
+ let parent = this.host.parentElement;
206
+ while (parent) {
207
+ if (parent.tagName === 'IFX-TREE-VIEW' || parent.hasAttribute('data-expand-all-items')) {
208
+ const observer = new MutationObserver(mutations => {
209
+ for (const mutation of mutations) {
210
+ if (mutation.type === 'attributes' &&
211
+ mutation.attributeName === 'data-expand-all-items') {
212
+ this.expandAllItems = parent.hasAttribute('data-expand-all-items');
213
+ }
214
+ }
215
+ });
216
+ observer.observe(parent, { attributes: true });
217
+ this.expandAllItems = parent.hasAttribute('data-expand-all-items');
218
+ break;
219
+ }
220
+ parent = parent.parentElement;
221
+ }
222
+ }
223
+ initializeNode() {
224
+ this.expanded = this.initiallyExpanded;
225
+ this.hasChildren = this.findChildren().length > 0;
226
+ this.level = this.calculateNodeLevel();
227
+ this.host.setAttribute('data-level', this.level.toString());
228
+ }
229
+ setupEventListeners() {
230
+ this.host.addEventListener('internal-check-state-change', this.handleStateChange);
231
+ }
232
+ async updateCheckState(checked) {
233
+ if (this.disabled)
234
+ return;
235
+ this.setNodeState({ isChecked: checked, partialChecked: false });
236
+ await this.updateChildrenState(checked);
237
+ this.updateParentState();
238
+ }
239
+ handleExpandedChange(newValue) {
240
+ this.ifxTreeViewItemExpandChange.emit(newValue);
241
+ }
242
+ handleDisableItemChange(newValue) {
243
+ this.ifxTreeViewItemDisableChange.emit(newValue);
244
+ }
245
+ setNodeState(state) {
246
+ this.isChecked = state.isChecked;
247
+ this.partialChecked = state.partialChecked;
248
+ this.ifxTreeViewItemCheckChange.emit({
249
+ checked: this.isChecked,
250
+ indeterminate: this.partialChecked,
251
+ });
252
+ }
253
+ async updateChildrenState(checked) {
254
+ const children = this.findChildren();
255
+ for (const child of children) {
256
+ await child.componentOnReady();
257
+ child.dispatchEvent(new CustomEvent('internal-check-state-change', {
258
+ detail: { checked },
259
+ bubbles: false,
260
+ composed: true
261
+ }));
262
+ }
263
+ }
264
+ findSiblingNodes(parent) {
265
+ const parentEl = parent.parentElement;
266
+ if (!parentEl)
267
+ return [];
268
+ return Array.from(parentEl.querySelectorAll('ifx-tree-view-item')).map(el => el);
269
+ }
270
+ updateParentState() {
271
+ var _a;
272
+ const parent = (_a = this.host.parentElement) === null || _a === void 0 ? void 0 : _a.closest('ifx-tree-view-item');
273
+ if (!parent)
274
+ return;
275
+ parent.componentOnReady().then(resolved => {
276
+ const parentNode = resolved;
277
+ if (!(parentNode === null || parentNode === void 0 ? void 0 : parentNode.updateParentState))
278
+ return;
279
+ const siblings = this.findSiblingNodes(parent);
280
+ const states = this.calculateSiblingStates(siblings);
281
+ parentNode.setNodeState({
282
+ isChecked: states.allChecked,
283
+ partialChecked: !states.allChecked && states.someChecked
284
+ });
285
+ parentNode.updateParentState();
286
+ });
287
+ }
288
+ calculateSiblingStates(siblings) {
289
+ return {
290
+ allChecked: siblings.every(sib => sib.isChecked),
291
+ someChecked: siblings.some(sib => {
292
+ const node = sib;
293
+ return node.isChecked || node.partialChecked;
294
+ })
295
+ };
296
+ }
297
+ render() {
298
+ return (index.h("div", { key: '65ba2eeeaa7ff90c1d3d5ee625baa1f0c0e544fa', class: {
299
+ 'tree-item': true,
300
+ 'tree-item--expanded': this.isExpanded,
301
+ 'tree-item--has-children': this.hasChildren,
302
+ 'tree-item--disabled': this.disabled,
303
+ }, role: "treeitem", "aria-expanded": this.isExpanded ? 'true' : 'false', "data-level": this.level, "aria-disabled": this.disabled ? 'true' : undefined, "aria-label": this.ariaLabel }, index.h("div", { key: '0b0f15544f9a9895882e60c712ddec3c4bf64c06', class: "tree-item__content" }, this.renderCheckbox(), this.renderHeader()), this.isExpanded && index.h("div", { key: '9473f80a1c8b29035e49a6ab2c89e27896bf6725', class: "tree-item__children" }, index.h("slot", { key: 'b822aa9540bc6b1aac6344809ad39b3c1efeaf07' }))));
304
+ }
305
+ renderHeader() {
306
+ return (index.h("div", { class: "tree-item__header", style: { paddingLeft: `${this.level * 24 + 10}px` }, onClick: this.handleHeaderClick, tabIndex: -1, "aria-disabled": this.disabled ? 'true' : undefined }, this.renderControls()));
307
+ }
308
+ renderCheckbox() {
309
+ return (index.h("div", { class: "tree-item__checkbox-container", onClick: e => e.stopPropagation() }, index.h("ifx-checkbox", { size: 's', checked: this.isChecked, indeterminate: this.partialChecked, onIfxChange: this.handleCheckboxChange, disabled: this.disabled })));
310
+ }
311
+ renderControls() {
312
+ return [
313
+ this.hasChildren && (index.h("div", { class: "tree-item__chevron-container", onClick: this.toggleExpand }, index.h("ifx-icon", { class: `tree-item__chevron ${this.isExpanded ? 'chevron-down' : 'chevron-right'}`, icon: "chevron-right-16" }), index.h("div", { class: "tree-item__line" }))),
314
+ index.h("div", { class: "tree-item__label-icon-container", tabIndex: this.disabled ? -1 : 0, onKeyDown: this.handleKeyDown }, index.h("div", { class: "tree-item__icon-container" }, this.hasChildren ? (index.h(index.Fragment, null, index.h("ifx-icon", { class: { 'icon--hidden': this.isExpanded }, icon: "folder-16" }), index.h("ifx-icon", { class: { 'icon--hidden': !this.isExpanded }, icon: "folder-open-16" }))) : (index.h("ifx-icon", { icon: "file-16" }))), index.h("span", { class: "tree-item__label" }, this.label))
315
+ ];
316
+ }
317
+ get host() { return index.getElement(this); }
318
+ static get watchers() { return {
319
+ "expanded": ["handleExpandedChange"],
320
+ "disableItem": ["handleDisableItemChange"]
321
+ }; }
322
+ };
323
+ TreeViewItem.style = IfxTreeViewItemStyle0;
324
+
325
+ exports.ifx_tree_view_item = TreeViewItem;
326
+
327
+ //# sourceMappingURL=ifx-tree-view-item.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"ifx-tree-view-item.entry.cjs.js","mappings":"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","names":["h","Fragment"],"sources":["src/components/tree-view/tree-view-item.scss?tag=ifx-tree-view-item&encapsulation=shadow","src/components/tree-view/tree-view-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n.tree-item {\n position: relative;\n cursor: pointer;\n list-style: none;\n\n &.tree-item--expanded {\n position: relative;\n }\n\n &.tree-item--has-children {\n position: relative;\n\n .tree-item__header > .tree-item__chevron-container {\n display: flex;\n }\n\n &.tree-item--expanded {\n .tree-item__header > .tree-item__chevron-container::after {\n display: block;\n }\n }\n }\n\n &--disabled {\n cursor: not-allowed;\n pointer-events: none;\n color: tokens.$ifxColorEngineering300;\n }\n\n &__content {\n display: flex;\n flex-direction: row;\n\n &:hover {\n .tree-item__checkbox-container,\n .tree-item__header {\n background-color: tokens.$ifxColorEngineering100;\n }\n }\n }\n\n &__checkbox-container {\n position: sticky;\n left: 0;\n z-index: 10;\n padding: tokens.$ifxSpace50;\n background-color: tokens.$ifxColorBaseWhite;\n }\n\n &__header {\n flex-grow: 1;\n display: flex;\n align-items: center;\n white-space: nowrap;\n height: tokens.$ifxSize250;\n padding-top: tokens.$ifxSpace50;\n padding-right: tokens.$ifxSpace200;\n padding-bottom: tokens.$ifxSpace50;\n padding-left: tokens.$ifxSpace100;\n }\n\n &__chevron-container {\n display: none;\n align-items: center;\n margin-right: tokens.$ifxSpace100;\n height: tokens.$ifxSize250;\n\n &::after {\n --height-line-start: 28px;\n\n display: none;\n content: '';\n position: absolute;\n z-index: 1;\n top: var(--height-line-start);\n left: auto;\n margin-left: tokens.$ifxSpace100;\n width: tokens.$ifxSize12;\n height: calc(100% - var(--height-line-start));\n background-color: tokens.$ifxColorEngineering200;\n\n .tree-item--disabled & {\n color: tokens.$ifxColorEngineering200;\n }\n }\n }\n\n &__chevron {\n &.chevron-down {\n transform: rotate(90deg);\n }\n\n &.chevron-right {\n transform: rotate(0);\n }\n }\n\n &__label-icon-container {\n display: flex;\n align-items: center;\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 &__icon-container {\n position: relative;\n width: tokens.$ifxSize200;\n height: tokens.$ifxSize200;\n\n ifx-icon {\n position: absolute;\n left: 0;\n top: 0;\n opacity: 1;\n transition: opacity 0.2s ease-in-out;\n\n &.icon--hidden {\n opacity: 0;\n }\n }\n }\n\n &__label {\n padding-left: tokens.$ifxSpace100;\n }\n\n &__children {\n display: none;\n\n .tree-item[aria-expanded=\"true\"] > & {\n display: block;\n }\n }\n}\n\n","import { Component, h, Prop, State, Element, Fragment, Event, EventEmitter, Watch } from '@stencil/core';\n\ninterface TreeState {\n isChecked: boolean;\n partialChecked: boolean;\n}\n\ntype HTMLIfxTreeViewItemElement = HTMLElement & { componentOnReady: () => Promise<unknown> };\n\n@Component({\n tag: 'ifx-tree-view-item',\n styleUrl: 'tree-view-item.scss',\n shadow: true,\n})\nexport class TreeViewItem {\n @Element() host: HTMLElement;\n @Prop() label: string;\n @Prop({ reflect: true, mutable: true }) expanded: boolean = false;\n @Prop() initiallyExpanded: boolean = false;\n @Prop() disableItem: boolean = false;\n @Prop() ariaLabel: string = 'Tree Item';\n\n @Event() ifxTreeViewItemExpandChange: EventEmitter<boolean>;\n @Event() ifxTreeViewItemCheckChange: EventEmitter<{ checked: boolean; indeterminate: boolean }>;\n @Event() ifxTreeViewItemDisableChange: EventEmitter<boolean>;\n\n @State() private hasChildren: boolean = false;\n @State() private isChecked: boolean = false;\n @State() private partialChecked: boolean = false;\n @State() private level: number = 0;\n @State() private disableAllItems: boolean = false;\n @State() private expandAllItems: boolean = false;\n\n private get disabled() {\n return this.disableAllItems || this.disableItem;\n }\n\n private get isExpanded() {\n return this.expandAllItems || this.expanded;\n }\n\n private findChildren = () => Array.from(this.host.children)\n .filter((child): child is HTMLElement =>\n child instanceof HTMLElement && child.tagName === 'IFX-TREE-VIEW-ITEM'\n );\n\n private calculateNodeLevel = (): number => {\n let level = 0, parent = this.host.parentElement;\n while (parent) {\n if (parent.tagName === 'IFX-TREE-VIEW-ITEM') level++;\n parent = parent.parentElement;\n }\n return level;\n };\n\n componentWillLoad() {\n this.initializeNode();\n this.setupEventListeners();\n }\n\n componentDidLoad() {\n this.observeDisableAllItems();\n this.observeExpandAllItems();\n if (this.shouldExpandFromParent()) {\n this.expandAllDescendants();\n }\n }\n\n private shouldExpandFromParent(): boolean {\n let parent = this.host.parentElement;\n while (parent) {\n if (\n parent.tagName === 'IFX-TREE-VIEW' &&\n (parent.hasAttribute('expand-all-items') || parent.hasAttribute('data-expand-all-items'))\n ) {\n return true;\n }\n parent = parent.parentElement;\n }\n return false;\n }\n\n private expandAllDescendants() {\n this.expanded = true;\n const children = this.findChildren();\n for (const child of children) {\n if (typeof (child as any).expanded !== 'undefined') {\n (child as any).expanded = true;\n }\n if (typeof (child as any).expandAllDescendants === 'function') {\n (child as any).expandAllDescendants();\n }\n }\n }\n\n private observeDisableAllItems() {\n let parent = this.host.parentElement;\n while (parent) {\n if (parent.tagName === 'IFX-TREE-VIEW') {\n const observer = new MutationObserver(mutations => {\n for (const mutation of mutations) {\n if (\n mutation.type === 'attributes' &&\n mutation.attributeName === 'disable-all-items'\n ) {\n const disableAll = (parent as any).disableAllItems;\n this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');\n }\n }\n });\n observer.observe(parent, { attributes: true });\n const disableAll = (parent as any).disableAllItems;\n this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');\n break;\n }\n parent = parent.parentElement;\n }\n }\n\n private observeExpandAllItems() {\n let parent = this.host.parentElement;\n while (parent) {\n if (parent.tagName === 'IFX-TREE-VIEW' || parent.hasAttribute('data-expand-all-items')) {\n const observer = new MutationObserver(mutations => {\n for (const mutation of mutations) {\n if (\n mutation.type === 'attributes' &&\n mutation.attributeName === 'data-expand-all-items'\n ) {\n this.expandAllItems = parent.hasAttribute('data-expand-all-items');\n }\n }\n });\n observer.observe(parent, { attributes: true });\n this.expandAllItems = parent.hasAttribute('data-expand-all-items');\n break;\n }\n parent = parent.parentElement;\n }\n }\n\n private initializeNode() {\n this.expanded = this.initiallyExpanded;\n this.hasChildren = this.findChildren().length > 0;\n this.level = this.calculateNodeLevel();\n this.host.setAttribute('data-level', this.level.toString());\n }\n\n private setupEventListeners() {\n this.host.addEventListener('internal-check-state-change', this.handleStateChange);\n }\n\n private handleStateChange = (event: CustomEvent) => {\n if (this.disabled) return;\n event.stopPropagation();\n this.updateCheckState(event.detail.checked);\n };\n\n private handleCheckboxChange = (event: CustomEvent) => {\n if (this.disabled) return;\n this.updateCheckState(event.detail?.checked ?? !this.isChecked);\n };\n\n private handleHeaderClick = ({ target }: MouseEvent) => {\n if (this.disabled) return;\n if (!(target as HTMLElement).closest('.tree-item__checkbox-container, .tree-item__chevron-container')) {\n this.updateCheckState(!this.isChecked);\n }\n };\n\n private async updateCheckState(checked: boolean) {\n if (this.disabled) return;\n this.setNodeState({ isChecked: checked, partialChecked: false });\n await this.updateChildrenState(checked);\n this.updateParentState();\n }\n\n @Watch('expanded')\n handleExpandedChange(newValue: boolean) {\n this.ifxTreeViewItemExpandChange.emit(newValue);\n }\n\n @Watch('disableItem')\n handleDisableItemChange(newValue: boolean) {\n this.ifxTreeViewItemDisableChange.emit(newValue);\n }\n\n private setNodeState(state: TreeState) {\n this.isChecked = state.isChecked;\n this.partialChecked = state.partialChecked;\n this.ifxTreeViewItemCheckChange.emit({\n checked: this.isChecked,\n indeterminate: this.partialChecked,\n });\n }\n\n private async updateChildrenState(checked: boolean) {\n const children = this.findChildren();\n for (const child of children) {\n await (child as HTMLIfxTreeViewItemElement).componentOnReady();\n child.dispatchEvent(new CustomEvent('internal-check-state-change', {\n detail: { checked },\n bubbles: false,\n composed: true\n }));\n }\n }\n\n private findSiblingNodes(parent: HTMLElement): HTMLIfxTreeViewItemElement[] {\n const parentEl = parent.parentElement;\n if (!parentEl) return [];\n return Array.from(\n parentEl.querySelectorAll('ifx-tree-view-item')\n ).map(el => el as HTMLIfxTreeViewItemElement);\n }\n\n private updateParentState() {\n const parent = this.host.parentElement?.closest('ifx-tree-view-item') as HTMLIfxTreeViewItemElement;\n if (!parent) return;\n parent.componentOnReady().then(resolved => {\n const parentNode = resolved as unknown as TreeViewItem;\n if (!parentNode?.updateParentState) return;\n const siblings = this.findSiblingNodes(parent);\n const states = this.calculateSiblingStates(siblings);\n parentNode.setNodeState({\n isChecked: states.allChecked,\n partialChecked: !states.allChecked && states.someChecked\n });\n parentNode.updateParentState();\n });\n }\n\n private calculateSiblingStates(siblings: HTMLIfxTreeViewItemElement[]) {\n return {\n allChecked: siblings.every(sib => (sib as unknown as TreeViewItem).isChecked),\n someChecked: siblings.some(sib => {\n const node = sib as unknown as TreeViewItem;\n return node.isChecked || node.partialChecked;\n })\n };\n }\n\n private toggleExpand = () => {\n if (this.disabled) return;\n this.hasChildren && (this.expanded = !this.expanded);\n };\n\n private handleKeyDown = (event: KeyboardEvent) => {\n\n const allItems = Array.from(\n this.host\n .closest('ifx-tree-view')\n ?.querySelectorAll('ifx-tree-view-item') || []\n );\n\n const visibleItems = allItems.filter(item => {\n let parent = item.parentElement?.closest('ifx-tree-view-item');\n while (parent) {\n const parentCmp = parent as any;\n if (!(parentCmp.expandAllItems || parentCmp.expanded)) {\n return false;\n }\n parent = parent.parentElement?.closest('ifx-tree-view-item');\n }\n return true;\n });\n\n const currentIndex = visibleItems.findIndex(el => el === this.host);\n\n function focusLabelIcon(el: Element | null) {\n (el as HTMLElement | null)?.focus();\n }\n\n switch (event.key) {\n case 'ArrowDown': {\n event.preventDefault();\n let nextIndex = currentIndex + 1;\n while (nextIndex < visibleItems.length) {\n const next = visibleItems[nextIndex] as any;\n if (!next.disabled) {\n focusLabelIcon(next.shadowRoot?.querySelector('.tree-item__label-icon-container'));\n break;\n }\n nextIndex++;\n }\n break;\n }\n case 'ArrowUp': {\n event.preventDefault();\n let prevIndex = currentIndex - 1;\n while (prevIndex >= 0) {\n const prev = visibleItems[prevIndex] as any;\n if (!prev.disabled) {\n focusLabelIcon(prev.shadowRoot?.querySelector('.tree-item__label-icon-container'));\n break;\n }\n prevIndex--;\n }\n break;\n }\n case 'ArrowRight': {\n event.preventDefault();\n if (!this.isExpanded && this.hasChildren) {\n this.expanded = true;\n } else if (this.isExpanded && this.hasChildren) {\n const firstChild = this.host.querySelector('ifx-tree-view-item');\n if (firstChild && !(firstChild as any).disabled) {\n focusLabelIcon((firstChild as HTMLElement).shadowRoot?.querySelector('.tree-item__label-icon-container'));\n }\n }\n break;\n }\n case 'ArrowLeft': {\n event.preventDefault();\n if (this.isExpanded && this.hasChildren) {\n this.expanded = false;\n } else {\n const parent = this.host.parentElement?.closest('ifx-tree-view-item');\n if (parent && !(parent as any).disabled) {\n focusLabelIcon((parent as HTMLElement).shadowRoot?.querySelector('.tree-item__label-icon-container'));\n }\n }\n break;\n }\n case ' ':\n case 'Enter': {\n event.preventDefault();\n this.updateCheckState(!this.isChecked);\n break;\n }\n }\n };\n\n render() {\n return (\n <div\n class={{\n 'tree-item': true,\n 'tree-item--expanded': this.isExpanded,\n 'tree-item--has-children': this.hasChildren,\n 'tree-item--disabled': this.disabled,\n }}\n role=\"treeitem\"\n aria-expanded={this.isExpanded ? 'true' : 'false'}\n data-level={this.level}\n aria-disabled={this.disabled ? 'true' : undefined}\n aria-label={this.ariaLabel}\n >\n <div class=\"tree-item__content\">\n {this.renderCheckbox()}\n {this.renderHeader()}\n </div>\n {this.isExpanded && <div class=\"tree-item__children\"><slot/></div>}\n </div>\n );\n }\n\n private renderHeader() {\n return (\n <div\n class=\"tree-item__header\"\n style={{ paddingLeft: `${this.level * 24 + 10}px` }}\n onClick={this.handleHeaderClick}\n tabIndex={-1}\n aria-disabled={this.disabled ? 'true' : undefined}\n >\n {this.renderControls()}\n </div>\n );\n }\n\n private renderCheckbox() {\n return (\n <div class=\"tree-item__checkbox-container\" onClick={e => e.stopPropagation()}>\n <ifx-checkbox\n size='s'\n checked={this.isChecked}\n indeterminate={this.partialChecked}\n onIfxChange={this.handleCheckboxChange}\n disabled={this.disabled}\n />\n </div>\n );\n }\n\n private renderControls() {\n return [\n this.hasChildren && (\n <div class=\"tree-item__chevron-container\" onClick={this.toggleExpand}>\n <ifx-icon class={`tree-item__chevron ${this.isExpanded ? 'chevron-down' : 'chevron-right'}`}\n icon=\"chevron-right-16\"/>\n <div class=\"tree-item__line\"/>\n </div>\n ),\n <div\n class=\"tree-item__label-icon-container\"\n tabIndex={this.disabled ? -1 : 0}\n onKeyDown={this.handleKeyDown}\n >\n <div class=\"tree-item__icon-container\">\n {\n this.hasChildren ? (\n <Fragment>\n <ifx-icon class={{'icon--hidden': this.isExpanded}} icon=\"folder-16\"/>\n <ifx-icon class={{'icon--hidden': !this.isExpanded}} icon=\"folder-open-16\"/>\n </Fragment>\n ) : (\n <ifx-icon icon=\"file-16\"/>\n )\n }\n </div>\n <span class=\"tree-item__label\">{this.label}</span>\n </div>\n ];\n }\n}\n"],"version":3}
@@ -0,0 +1,55 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-7f4df11a.js');
6
+
7
+ const treeViewCss = ":host{display:block}.tree-view{font-family:var(--ifx-font-family, sans-serif);font-size:14px;color:var(--ifx-color-text, #1a1a1a);display:flex;flex-wrap:wrap;flex-direction:column;overflow-x:auto;overflow-y:hidden}.tree-view__label{font:600 1.125rem/1.625rem \"Source Sans 3\";margin-bottom:8px}";
8
+ const IfxTreeViewStyle0 = treeViewCss;
9
+
10
+ const TreeView = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.ifxTreeViewExpandAllChange = index.createEvent(this, "ifxTreeViewExpandAllChange", 7);
14
+ this.ifxTreeViewDisableAllChange = index.createEvent(this, "ifxTreeViewDisableAllChange", 7);
15
+ this.disableAllItems = false;
16
+ this.expandAllItems = false;
17
+ this.ariaLabel = 'Tree View';
18
+ }
19
+ handleExpandAllItemsChange(newValue) {
20
+ this.ifxTreeViewExpandAllChange.emit(newValue);
21
+ }
22
+ handleDisableAllItemsChange(newValue) {
23
+ this.ifxTreeViewDisableAllChange.emit(newValue);
24
+ }
25
+ render() {
26
+ return (index.h("div", { key: '80685b84144c9e87bb01449f28b512e331884cf3', class: {
27
+ 'tree-view': true,
28
+ 'tree-view--disabled': this.disableAllItems,
29
+ }, role: "tree", "aria-label": this.ariaLabel }, this.label && this.label.trim() !== '' && index.h("div", { key: '8f4cf624d49def348e24c569436d3665f6777404', class: "tree-view__label" }, this.label), index.h("slot", { key: 'b36f590b814b3e7e1d46f91c046c1af37c469e1b', ref: el => {
30
+ if (el) {
31
+ if (this.disableAllItems) {
32
+ el.setAttribute('data-disable-all-items', 'true');
33
+ }
34
+ else {
35
+ el.removeAttribute('data-disable-all-items');
36
+ }
37
+ if (this.expandAllItems) {
38
+ el.setAttribute('data-expand-all-items', 'true');
39
+ }
40
+ else {
41
+ el.removeAttribute('data-expand-all-items');
42
+ }
43
+ }
44
+ } })));
45
+ }
46
+ static get watchers() { return {
47
+ "expandAllItems": ["handleExpandAllItemsChange"],
48
+ "disableAllItems": ["handleDisableAllItemsChange"]
49
+ }; }
50
+ };
51
+ TreeView.style = IfxTreeViewStyle0;
52
+
53
+ exports.ifx_tree_view = TreeView;
54
+
55
+ //# sourceMappingURL=ifx-tree-view.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"ifx-tree-view.entry.cjs.js","mappings":";;;;;;AAAA,MAAM,WAAW,GAAG,ySAAyS,CAAC;AAC9T,0BAAe,WAAW;;MCMb,QAAQ;IALrB;;;;QAOU,oBAAe,GAAY,KAAK,CAAC;QACjC,mBAAc,GAAY,KAAK,CAAC;QAChC,cAAS,GAAW,WAAW,CAAC;KA2CzC;IArCC,0BAA0B,CAAC,QAAiB;QAC1C,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KAChD;IAGD,2BAA2B,CAAC,QAAiB;QAC3C,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KACjD;IAED,MAAM;QACJ,QACEA,kEACE,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI;gBACjB,qBAAqB,EAAE,IAAI,CAAC,eAAe;aAC5C,EACD,IAAI,EAAC,MAAM,gBACC,IAAI,CAAC,SAAS,IAEzB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,IAAIA,kEAAK,KAAK,EAAC,kBAAkB,IAAE,IAAI,CAAC,KAAK,CAAO,EAC3FA,mEAAM,GAAG,EAAE,EAAE;gBACX,IAAI,EAAE,EAAE;oBACN,IAAI,IAAI,CAAC,eAAe,EAAE;wBACxB,EAAE,CAAC,YAAY,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;qBACnD;yBAAM;wBACL,EAAE,CAAC,eAAe,CAAC,wBAAwB,CAAC,CAAC;qBAC9C;oBACD,IAAI,IAAI,CAAC,cAAc,EAAE;wBACvB,EAAE,CAAC,YAAY,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;qBAClD;yBAAM;wBACL,EAAE,CAAC,eAAe,CAAC,uBAAuB,CAAC,CAAC;qBAC7C;iBACF;aACF,GAAS,CACN,EACN;KACH;;;;;;;;;;","names":["h"],"sources":["src/components/tree-view/tree-view.scss?tag=ifx-tree-view&encapsulation=shadow","src/components/tree-view/tree-view.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n:host {\n display: block;\n}\n\n.tree-view {\n font-family: var(--ifx-font-family, sans-serif);\n font-size: 14px;\n color: var(--ifx-color-text, #1a1a1a);\n\n display: flex;\n flex-wrap: wrap;\n flex-direction: column;\n overflow-x: auto;\n overflow-y: hidden;\n\n &__label {\n font: tokens.$ifxHeadingHeading06;\n margin-bottom: tokens.$ifxSpace100;\n }\n}\n","import { Component, h, Prop, Event, EventEmitter, Watch } from '@stencil/core';\n\n@Component({\n tag: 'ifx-tree-view',\n styleUrl: 'tree-view.scss',\n shadow: true,\n})\nexport class TreeView {\n @Prop() label?: string;\n @Prop() disableAllItems: boolean = false;\n @Prop() expandAllItems: boolean = false;\n @Prop() ariaLabel: string = 'Tree View';\n\n @Event() ifxTreeViewExpandAllChange: EventEmitter<boolean>;\n @Event() ifxTreeViewDisableAllChange: EventEmitter<boolean>;\n\n @Watch('expandAllItems')\n handleExpandAllItemsChange(newValue: boolean) {\n this.ifxTreeViewExpandAllChange.emit(newValue);\n }\n\n @Watch('disableAllItems')\n handleDisableAllItemsChange(newValue: boolean) {\n this.ifxTreeViewDisableAllChange.emit(newValue);\n }\n\n render() {\n return (\n <div\n class={{\n 'tree-view': true,\n 'tree-view--disabled': this.disableAllItems,\n }}\n role=\"tree\"\n aria-label={this.ariaLabel}\n >\n {this.label && this.label.trim() !== '' && <div class=\"tree-view__label\">{this.label}</div>}\n <slot ref={el => {\n if (el) {\n if (this.disableAllItems) {\n el.setAttribute('data-disable-all-items', 'true');\n } else {\n el.removeAttribute('data-disable-all-items');\n }\n if (this.expandAllItems) {\n el.setAttribute('data-expand-all-items', 'true');\n } else {\n el.removeAttribute('data-expand-all-items');\n }\n }\n }}></slot>\n </div>\n );\n }\n}\n"],"version":3}
@@ -21,7 +21,7 @@ function _interopNamespace(e) {
21
21
  }
22
22
 
23
23
  const NAMESPACE = 'infineon-design-system-stencil';
24
- const BUILD = /* infineon-design-system-stencil */ { allRenderFn: true, appendChildSlotFix: false, asyncLoading: true, asyncQueue: false, attachStyles: true, cloneNodeFix: true, constructableCSS: true, cssAnnotations: true, devTools: false, element: false, event: true, experimentalScopedSlotChanges: false, experimentalSlotFixes: false, formAssociated: true, hasRenderFn: true, hostListener: true, hostListenerTarget: true, hostListenerTargetBody: true, hostListenerTargetDocument: true, hostListenerTargetParent: false, hostListenerTargetWindow: true, hotModuleReplacement: false, hydrateClientSide: false, hydrateServerSide: false, hydratedAttribute: false, hydratedClass: true, hydratedSelectorName: "hydrated", initializeNextTick: false, invisiblePrehydration: true, isDebug: false, isDev: false, isTesting: false, lazyLoad: true, lifecycle: true, lifecycleDOMEvents: false, member: true, method: true, mode: false, modernPropertyDecls: false, observeAttribute: true, profile: false, prop: true, propBoolean: true, propMutable: true, propNumber: true, propString: true, reflect: true, scoped: false, scopedSlotTextContentFix: false, scriptDataOpts: false, shadowDelegatesFocus: true, shadowDom: true, slot: true, slotChildNodesFix: false, slotRelocation: true, state: true, style: true, svg: true, taskQueue: true, transformTagName: false, updatable: true, vdomAttribute: true, vdomClass: true, vdomFunctional: false, vdomKey: true, vdomListener: true, vdomPropOrAttr: true, vdomRef: true, vdomRender: true, vdomStyle: true, vdomText: true, vdomXlink: true, watchCallback: true };
24
+ const BUILD = /* infineon-design-system-stencil */ { allRenderFn: true, appendChildSlotFix: false, asyncLoading: true, asyncQueue: false, attachStyles: true, cloneNodeFix: true, constructableCSS: true, cssAnnotations: true, devTools: false, element: false, event: true, experimentalScopedSlotChanges: false, experimentalSlotFixes: false, formAssociated: true, hasRenderFn: true, hostListener: true, hostListenerTarget: true, hostListenerTargetBody: true, hostListenerTargetDocument: true, hostListenerTargetParent: false, hostListenerTargetWindow: true, hotModuleReplacement: false, hydrateClientSide: false, hydrateServerSide: false, hydratedAttribute: false, hydratedClass: true, hydratedSelectorName: "hydrated", initializeNextTick: false, invisiblePrehydration: true, isDebug: false, isDev: false, isTesting: false, lazyLoad: true, lifecycle: true, lifecycleDOMEvents: false, member: true, method: true, mode: false, modernPropertyDecls: false, observeAttribute: true, profile: false, prop: true, propBoolean: true, propMutable: true, propNumber: true, propString: true, reflect: true, scoped: false, scopedSlotTextContentFix: false, scriptDataOpts: false, shadowDelegatesFocus: true, shadowDom: true, slot: true, slotChildNodesFix: false, slotRelocation: true, state: true, style: true, svg: true, taskQueue: true, transformTagName: false, updatable: true, vdomAttribute: true, vdomClass: true, vdomFunctional: true, vdomKey: true, vdomListener: true, vdomPropOrAttr: true, vdomRef: true, vdomRender: true, vdomStyle: true, vdomText: true, vdomXlink: true, watchCallback: true };
25
25
 
26
26
  /*
27
27
  Stencil Client Platform v4.27.2 | MIT Licensed | https://stenciljs.com
@@ -321,6 +321,14 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
321
321
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
322
322
  /* webpackMode: "lazy" */
323
323
  './ifx-tooltip.cjs.entry.js')); }).then(processMod, consoleError);
324
+ case 'ifx-tree-view.cjs':
325
+ return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
326
+ /* webpackMode: "lazy" */
327
+ './ifx-tree-view.cjs.entry.js')); }).then(processMod, consoleError);
328
+ case 'ifx-tree-view-item.cjs':
329
+ return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
330
+ /* webpackMode: "lazy" */
331
+ './ifx-tree-view-item.cjs.entry.js')); }).then(processMod, consoleError);
324
332
  case 'ifx-accordion_2.cjs':
325
333
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
326
334
  /* webpackMode: "lazy" */
@@ -365,10 +373,6 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
365
373
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
366
374
  /* webpackMode: "lazy" */
367
375
  './ifx-select.cjs.entry.js')); }).then(processMod, consoleError);
368
- case 'ifx-checkbox.cjs':
369
- return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
370
- /* webpackMode: "lazy" */
371
- './ifx-checkbox.cjs.entry.js')); }).then(processMod, consoleError);
372
376
  case 'ifx-icon-button.cjs':
373
377
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
374
378
  /* webpackMode: "lazy" */
@@ -377,6 +381,10 @@ var loadModule = (cmpMeta, hostRef, hmrVersionId) => {
377
381
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
378
382
  /* webpackMode: "lazy" */
379
383
  './ifx-button.cjs.entry.js')); }).then(processMod, consoleError);
384
+ case 'ifx-checkbox.cjs':
385
+ return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
386
+ /* webpackMode: "lazy" */
387
+ './ifx-checkbox.cjs.entry.js')); }).then(processMod, consoleError);
380
388
  case 'ifx-number-indicator.cjs':
381
389
  return Promise.resolve().then(function () { return /*#__PURE__*/_interopNamespace(require(
382
390
  /* webpackMode: "lazy" */
@@ -765,6 +773,13 @@ var h = (nodeName, vnodeData, ...children) => {
765
773
  }
766
774
  }
767
775
  }
776
+ if (typeof nodeName === "function") {
777
+ return nodeName(
778
+ vnodeData === null ? {} : vnodeData,
779
+ vNodeChildren,
780
+ vdomFnUtils
781
+ );
782
+ }
768
783
  const vnode = newVNode(nodeName, null);
769
784
  vnode.$attrs$ = vnodeData;
770
785
  if (vNodeChildren.length > 0) {
@@ -799,6 +814,36 @@ var newVNode = (tag, text) => {
799
814
  };
800
815
  var Host = {};
801
816
  var isHost = (node) => node && node.$tag$ === Host;
817
+ var vdomFnUtils = {
818
+ forEach: (children, cb) => children.map(convertToPublic).forEach(cb),
819
+ map: (children, cb) => children.map(convertToPublic).map(cb).map(convertToPrivate)
820
+ };
821
+ var convertToPublic = (node) => ({
822
+ vattrs: node.$attrs$,
823
+ vchildren: node.$children$,
824
+ vkey: node.$key$,
825
+ vname: node.$name$,
826
+ vtag: node.$tag$,
827
+ vtext: node.$text$
828
+ });
829
+ var convertToPrivate = (node) => {
830
+ if (typeof node.vtag === "function") {
831
+ const vnodeData = { ...node.vattrs };
832
+ if (node.vkey) {
833
+ vnodeData.key = node.vkey;
834
+ }
835
+ if (node.vname) {
836
+ vnodeData.name = node.vname;
837
+ }
838
+ return h(node.vtag, vnodeData, ...node.vchildren || []);
839
+ }
840
+ const vnode = newVNode(node.vtag, node.vtext);
841
+ vnode.$attrs$ = node.vattrs;
842
+ vnode.$children$ = node.vchildren;
843
+ vnode.$key$ = node.vkey;
844
+ vnode.$name$ = node.vname;
845
+ return vnode;
846
+ };
802
847
  var parsePropertyValue = (propValue, propType) => {
803
848
  if (propValue != null && !isComplexType(propValue)) {
804
849
  if (propType & 4 /* Boolean */) {
@@ -2210,6 +2255,9 @@ var bootstrapLazy = (lazyBundles, options = {}) => {
2210
2255
  }
2211
2256
  endBootstrap();
2212
2257
  };
2258
+
2259
+ // src/runtime/fragment.ts
2260
+ var Fragment = (_, children) => children;
2213
2261
  var addHostEventListeners = (elm, hostRef, listeners, attachParentListeners) => {
2214
2262
  if (listeners && win.document) {
2215
2263
  listeners.map(([flags, name, method]) => {
@@ -2255,6 +2303,7 @@ var hostListenerOpts = (flags) => supportsListenerOptions ? {
2255
2303
  // src/runtime/nonce.ts
2256
2304
  var setNonce = (nonce) => plt.$nonce$ = nonce;
2257
2305
 
2306
+ exports.Fragment = Fragment;
2258
2307
  exports.H = H;
2259
2308
  exports.Host = Host;
2260
2309
  exports.bootstrapLazy = bootstrapLazy;
@@ -2266,4 +2315,4 @@ exports.promiseResolve = promiseResolve;
2266
2315
  exports.registerInstance = registerInstance;
2267
2316
  exports.setNonce = setNonce;
2268
2317
 
2269
- //# sourceMappingURL=index-c9480f70.js.map
2318
+ //# sourceMappingURL=index-7f4df11a.js.map