@infineon/infineon-design-system-stencil 39.5.1--canary.2128.32855eaced35e683ae58f61e74597b349ac6110b.0 → 39.5.1--canary.1723.6fd541188ecfae7cc95cc1472bc61a6b121619e5.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 (759) hide show
  1. package/dist/cjs/ifx-accordion.ifx-accordion-item.entry.cjs.js.map +1 -1
  2. package/dist/cjs/ifx-accordion_2.cjs.entry.js +3 -3
  3. package/dist/cjs/ifx-accordion_2.cjs.entry.js.map +1 -1
  4. package/dist/cjs/ifx-action-list-item.cjs.entry.js +2 -2
  5. package/dist/cjs/ifx-action-list-item.cjs.entry.js.map +1 -1
  6. package/dist/cjs/ifx-action-list-item.entry.cjs.js.map +1 -1
  7. package/dist/cjs/ifx-action-list.cjs.entry.js +2 -2
  8. package/dist/cjs/ifx-action-list.cjs.entry.js.map +1 -1
  9. package/dist/cjs/ifx-action-list.entry.cjs.js.map +1 -1
  10. package/dist/cjs/ifx-alert.ifx-template.entry.cjs.js.map +1 -1
  11. package/dist/cjs/ifx-alert_2.cjs.entry.js +2 -2
  12. package/dist/cjs/ifx-alert_2.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ifx-basic-table.cjs.entry.js +2 -2
  14. package/dist/cjs/ifx-basic-table.cjs.entry.js.map +1 -1
  15. package/dist/cjs/ifx-basic-table.entry.cjs.js.map +1 -1
  16. package/dist/cjs/ifx-breadcrumb-item-label.cjs.entry.js +2 -2
  17. package/dist/cjs/ifx-breadcrumb-item-label.cjs.entry.js.map +1 -1
  18. package/dist/cjs/ifx-breadcrumb-item-label.entry.cjs.js.map +1 -1
  19. package/dist/cjs/ifx-breadcrumb-item.cjs.entry.js +2 -2
  20. package/dist/cjs/ifx-breadcrumb-item.cjs.entry.js.map +1 -1
  21. package/dist/cjs/ifx-breadcrumb-item.entry.cjs.js.map +1 -1
  22. package/dist/cjs/ifx-breadcrumb.cjs.entry.js +2 -2
  23. package/dist/cjs/ifx-breadcrumb.cjs.entry.js.map +1 -1
  24. package/dist/cjs/ifx-breadcrumb.entry.cjs.js.map +1 -1
  25. package/dist/cjs/ifx-button.cjs.entry.js +2 -2
  26. package/dist/cjs/ifx-button.cjs.entry.js.map +1 -1
  27. package/dist/cjs/ifx-button.entry.cjs.js.map +1 -1
  28. package/dist/cjs/ifx-card-headline.cjs.entry.js +2 -2
  29. package/dist/cjs/ifx-card-headline.cjs.entry.js.map +1 -1
  30. package/dist/cjs/ifx-card-headline.entry.cjs.js.map +1 -1
  31. package/dist/cjs/ifx-card-image.cjs.entry.js +1 -1
  32. package/dist/cjs/ifx-card-links.cjs.entry.js +2 -2
  33. package/dist/cjs/ifx-card-links.cjs.entry.js.map +1 -1
  34. package/dist/cjs/ifx-card-links.entry.cjs.js.map +1 -1
  35. package/dist/cjs/ifx-card-overline.cjs.entry.js +2 -2
  36. package/dist/cjs/ifx-card-overline.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ifx-card-overline.entry.cjs.js.map +1 -1
  38. package/dist/cjs/ifx-card-text.cjs.entry.js +2 -2
  39. package/dist/cjs/ifx-card-text.cjs.entry.js.map +1 -1
  40. package/dist/cjs/ifx-card-text.entry.cjs.js.map +1 -1
  41. package/dist/cjs/ifx-card.cjs.entry.js +2 -2
  42. package/dist/cjs/ifx-card.cjs.entry.js.map +1 -1
  43. package/dist/cjs/ifx-card.entry.cjs.js.map +1 -1
  44. package/dist/cjs/ifx-checkbox-group.cjs.entry.js +2 -2
  45. package/dist/cjs/ifx-checkbox-group.cjs.entry.js.map +1 -1
  46. package/dist/cjs/ifx-checkbox-group.entry.cjs.js.map +1 -1
  47. package/dist/cjs/ifx-checkbox.cjs.entry.js +1 -1
  48. package/dist/cjs/ifx-chip.ifx-chip-item.ifx-pagination.entry.cjs.js.map +1 -1
  49. package/dist/cjs/ifx-chip_3.cjs.entry.js +4 -4
  50. package/dist/cjs/ifx-chip_3.cjs.entry.js.map +1 -1
  51. package/dist/cjs/ifx-content-switcher-item.cjs.entry.js +1 -1
  52. package/dist/cjs/ifx-content-switcher.cjs.entry.js +1 -1
  53. package/dist/cjs/ifx-date-picker.cjs.entry.js +1 -1
  54. package/dist/cjs/ifx-download.cjs.entry.js +1 -1
  55. package/dist/cjs/ifx-dropdown-header.cjs.entry.js +2 -2
  56. package/dist/cjs/ifx-dropdown-header.cjs.entry.js.map +1 -1
  57. package/dist/cjs/ifx-dropdown-header.entry.cjs.js.map +1 -1
  58. package/dist/cjs/ifx-dropdown-item.cjs.entry.js +2 -2
  59. package/dist/cjs/ifx-dropdown-item.cjs.entry.js.map +1 -1
  60. package/dist/cjs/ifx-dropdown-item.entry.cjs.js.map +1 -1
  61. package/dist/cjs/ifx-dropdown-menu.cjs.entry.js +1 -1
  62. package/dist/cjs/ifx-dropdown-separator.cjs.entry.js +1 -1
  63. package/dist/cjs/ifx-dropdown-trigger-button.cjs.entry.js +1 -1
  64. package/dist/cjs/ifx-dropdown-trigger.cjs.entry.js +1 -1
  65. package/dist/cjs/ifx-dropdown.cjs.entry.js +1 -1
  66. package/dist/cjs/ifx-faq.cjs.entry.js +1 -1
  67. package/dist/cjs/ifx-file-upload.cjs.entry.js +2 -2
  68. package/dist/cjs/ifx-file-upload.cjs.entry.js.map +1 -1
  69. package/dist/cjs/ifx-file-upload.entry.cjs.js.map +1 -1
  70. package/dist/cjs/ifx-filter-accordion.cjs.entry.js +1 -1
  71. package/dist/cjs/ifx-filter-bar.cjs.entry.js +1 -1
  72. package/dist/cjs/ifx-filter-search.cjs.entry.js +1 -1
  73. package/dist/cjs/ifx-filter-type-group.cjs.entry.js +1 -1
  74. package/dist/cjs/ifx-footer-column.cjs.entry.js +2 -2
  75. package/dist/cjs/ifx-footer-column.cjs.entry.js.map +1 -1
  76. package/dist/cjs/ifx-footer-column.entry.cjs.js.map +1 -1
  77. package/dist/cjs/ifx-footer.cjs.entry.js +2 -2
  78. package/dist/cjs/ifx-footer.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ifx-footer.entry.cjs.js.map +1 -1
  80. package/dist/cjs/ifx-icon-button.cjs.entry.js +1 -1
  81. package/dist/cjs/ifx-icon.cjs.entry.js +1 -1
  82. package/dist/cjs/ifx-icons-preview.cjs.entry.js +1 -1
  83. package/dist/cjs/ifx-indicator.cjs.entry.js +2 -2
  84. package/dist/cjs/ifx-indicator.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ifx-indicator.entry.cjs.js.map +1 -1
  86. package/dist/cjs/ifx-link.cjs.entry.js +2 -2
  87. package/dist/cjs/ifx-link.cjs.entry.js.map +1 -1
  88. package/dist/cjs/ifx-link.entry.cjs.js.map +1 -1
  89. package/dist/cjs/ifx-list-entry.cjs.entry.js +1 -1
  90. package/dist/cjs/ifx-list.cjs.entry.js +1 -1
  91. package/dist/cjs/ifx-modal.cjs.entry.js +2 -2
  92. package/dist/cjs/ifx-modal.cjs.entry.js.map +1 -1
  93. package/dist/cjs/ifx-modal.entry.cjs.js.map +1 -1
  94. package/dist/cjs/ifx-multiselect.ifx-multiselect-option.entry.cjs.js.map +1 -1
  95. package/dist/cjs/ifx-multiselect_2.cjs.entry.js +2 -2
  96. package/dist/cjs/ifx-multiselect_2.cjs.entry.js.map +1 -1
  97. package/dist/cjs/ifx-navbar-item.cjs.entry.js +1 -1
  98. package/dist/cjs/ifx-navbar-profile.cjs.entry.js +1 -1
  99. package/dist/cjs/ifx-navbar.cjs.entry.js +2 -2
  100. package/dist/cjs/ifx-navbar.cjs.entry.js.map +1 -1
  101. package/dist/cjs/ifx-navbar.entry.cjs.js.map +1 -1
  102. package/dist/cjs/ifx-notification.cjs.entry.js +2 -2
  103. package/dist/cjs/ifx-notification.cjs.entry.js.map +1 -1
  104. package/dist/cjs/ifx-notification.entry.cjs.js.map +1 -1
  105. package/dist/cjs/ifx-overview-table.cjs.entry.js +1 -1
  106. package/dist/cjs/ifx-progress-bar.cjs.entry.js +2 -2
  107. package/dist/cjs/ifx-progress-bar.cjs.entry.js.map +1 -1
  108. package/dist/cjs/ifx-progress-bar.entry.cjs.js.map +1 -1
  109. package/dist/cjs/ifx-radio-button-group.cjs.entry.js +2 -2
  110. package/dist/cjs/ifx-radio-button-group.cjs.entry.js.map +1 -1
  111. package/dist/cjs/ifx-radio-button-group.entry.cjs.js.map +1 -1
  112. package/dist/cjs/ifx-radio-button.cjs.entry.js +2 -2
  113. package/dist/cjs/ifx-radio-button.cjs.entry.js.map +1 -1
  114. package/dist/cjs/ifx-radio-button.entry.cjs.js.map +1 -1
  115. package/dist/cjs/ifx-search-bar.cjs.entry.js +2 -2
  116. package/dist/cjs/ifx-search-bar.cjs.entry.js.map +1 -1
  117. package/dist/cjs/ifx-search-bar.entry.cjs.js.map +1 -1
  118. package/dist/cjs/ifx-search-field.cjs.entry.js +2 -2
  119. package/dist/cjs/ifx-search-field.cjs.entry.js.map +1 -1
  120. package/dist/cjs/ifx-search-field.entry.cjs.js.map +1 -1
  121. package/dist/cjs/ifx-segment.cjs.entry.js +2 -2
  122. package/dist/cjs/ifx-segment.cjs.entry.js.map +1 -1
  123. package/dist/cjs/ifx-segment.entry.cjs.js.map +1 -1
  124. package/dist/cjs/ifx-segmented-control.cjs.entry.js +2 -2
  125. package/dist/cjs/ifx-segmented-control.cjs.entry.js.map +1 -1
  126. package/dist/cjs/ifx-segmented-control.entry.cjs.js.map +1 -1
  127. package/dist/cjs/ifx-select.cjs.entry.js +2 -2
  128. package/dist/cjs/ifx-select.cjs.entry.js.map +1 -1
  129. package/dist/cjs/ifx-select.entry.cjs.js.map +1 -1
  130. package/dist/cjs/ifx-set-filter.cjs.entry.js +1 -1
  131. package/dist/cjs/ifx-sidebar-item.cjs.entry.js +2 -2
  132. package/dist/cjs/ifx-sidebar-item.cjs.entry.js.map +1 -1
  133. package/dist/cjs/ifx-sidebar-item.entry.cjs.js.map +1 -1
  134. package/dist/cjs/ifx-sidebar-title.cjs.entry.js +2 -2
  135. package/dist/cjs/ifx-sidebar-title.cjs.entry.js.map +1 -1
  136. package/dist/cjs/ifx-sidebar-title.entry.cjs.js.map +1 -1
  137. package/dist/cjs/ifx-sidebar.cjs.entry.js +2 -2
  138. package/dist/cjs/ifx-sidebar.cjs.entry.js.map +1 -1
  139. package/dist/cjs/ifx-sidebar.entry.cjs.js.map +1 -1
  140. package/dist/cjs/ifx-slider.cjs.entry.js +2 -2
  141. package/dist/cjs/ifx-slider.cjs.entry.js.map +1 -1
  142. package/dist/cjs/ifx-slider.entry.cjs.js.map +1 -1
  143. package/dist/cjs/ifx-spinner.ifx-text-field.entry.cjs.js.map +1 -1
  144. package/dist/cjs/ifx-spinner_2.cjs.entry.js +2 -2
  145. package/dist/cjs/ifx-spinner_2.cjs.entry.js.map +1 -1
  146. package/dist/cjs/ifx-status.cjs.entry.js +2 -2
  147. package/dist/cjs/ifx-status.cjs.entry.js.map +1 -1
  148. package/dist/cjs/ifx-status.entry.cjs.js.map +1 -1
  149. package/dist/cjs/ifx-step.cjs.entry.js +2 -2
  150. package/dist/cjs/ifx-step.cjs.entry.js.map +1 -1
  151. package/dist/cjs/ifx-step.entry.cjs.js.map +1 -1
  152. package/dist/cjs/ifx-stepper.cjs.entry.js +2 -2
  153. package/dist/cjs/ifx-stepper.cjs.entry.js.map +1 -1
  154. package/dist/cjs/ifx-stepper.entry.cjs.js.map +1 -1
  155. package/dist/cjs/ifx-switch.cjs.entry.js +2 -2
  156. package/dist/cjs/ifx-switch.cjs.entry.js.map +1 -1
  157. package/dist/cjs/ifx-switch.entry.cjs.js.map +1 -1
  158. package/dist/cjs/ifx-tab.cjs.entry.js +1 -1
  159. package/dist/cjs/ifx-table.cjs.entry.js +2 -2
  160. package/dist/cjs/ifx-table.cjs.entry.js.map +1 -1
  161. package/dist/cjs/ifx-table.entry.cjs.js.map +1 -1
  162. package/dist/cjs/ifx-tabs.cjs.entry.js +2 -2
  163. package/dist/cjs/ifx-tabs.cjs.entry.js.map +1 -1
  164. package/dist/cjs/ifx-tabs.entry.cjs.js.map +1 -1
  165. package/dist/cjs/ifx-templates-ui.cjs.entry.js +1 -1
  166. package/dist/cjs/ifx-textarea.cjs.entry.js +2 -2
  167. package/dist/cjs/ifx-textarea.cjs.entry.js.map +1 -1
  168. package/dist/cjs/ifx-textarea.entry.cjs.js.map +1 -1
  169. package/dist/cjs/ifx-tooltip.cjs.entry.js +2 -2
  170. package/dist/cjs/ifx-tooltip.cjs.entry.js.map +1 -1
  171. package/dist/cjs/ifx-tooltip.entry.cjs.js.map +1 -1
  172. package/dist/cjs/ifx-tree-view-item.cjs.entry.js +1 -1
  173. package/dist/cjs/ifx-tree-view.cjs.entry.js +1 -1
  174. package/dist/cjs/{index-n_pDKBY2.js → index-Dc5gCGlQ.js} +3 -3
  175. package/dist/cjs/index-Dc5gCGlQ.js.map +1 -0
  176. package/dist/cjs/infineon-design-system-stencil.cjs.js +1 -1
  177. package/dist/cjs/loader.cjs.js +1 -1
  178. package/dist/collection/components/accordion/accordion.css +1 -1
  179. package/dist/collection/components/accordion/accordionItem.css +1 -1
  180. package/dist/collection/components/action-list/action-list-item.css +1 -1
  181. package/dist/collection/components/action-list/action-list.css +1 -1
  182. package/dist/collection/components/alert/alert.css +1 -1
  183. package/dist/collection/components/breadcrumb/breadcrumb-item-label.css +1 -1
  184. package/dist/collection/components/breadcrumb/breadcrumb-item.css +1 -1
  185. package/dist/collection/components/breadcrumb/breadcrumb.css +1 -1
  186. package/dist/collection/components/button/button.css +1 -1
  187. package/dist/collection/components/card/card-headline/card-headline.css +1 -1
  188. package/dist/collection/components/card/card-links/card-links.css +1 -1
  189. package/dist/collection/components/card/card-overline/card-overline.css +1 -1
  190. package/dist/collection/components/card/card-text/card-text.css +1 -1
  191. package/dist/collection/components/card/card.css +1 -1
  192. package/dist/collection/components/checkbox-group/checkbox-group.css +1 -1
  193. package/dist/collection/components/chip/chip-item/chip-item.css +1 -1
  194. package/dist/collection/components/chip/chip.css +1 -1
  195. package/dist/collection/components/dropdown/dropdown-header/dropdown-header.css +1 -1
  196. package/dist/collection/components/dropdown/dropdown-item/dropdown-item.css +1 -1
  197. package/dist/collection/components/file-upload/file-upload.css +1 -1
  198. package/dist/collection/components/footer/footer-column.css +1 -1
  199. package/dist/collection/components/footer/footer.css +2 -2
  200. package/dist/collection/components/footer/footer.stories.js +20 -17
  201. package/dist/collection/components/footer/footer.stories.js.map +1 -1
  202. package/dist/collection/components/indicator/indicator.css +1 -1
  203. package/dist/collection/components/link/link.css +1 -1
  204. package/dist/collection/components/modal/modal.css +1 -1
  205. package/dist/collection/components/navigation/navbar/navbar.css +1 -1
  206. package/dist/collection/components/navigation/sidebar/sidebar-item.css +1 -1
  207. package/dist/collection/components/navigation/sidebar/sidebar-title.css +1 -1
  208. package/dist/collection/components/navigation/sidebar/sidebar.css +1 -1
  209. package/dist/collection/components/notification/notification.css +1 -1
  210. package/dist/collection/components/pagination/pagination.css +1 -1
  211. package/dist/collection/components/progress-bar/progress-bar.css +1 -1
  212. package/dist/collection/components/radio-button/radio-button.css +1 -1
  213. package/dist/collection/components/radio-button-group/radio-button-group.css +1 -1
  214. package/dist/collection/components/search-bar/search-bar.css +1 -1
  215. package/dist/collection/components/search-field/search-field.css +1 -1
  216. package/dist/collection/components/segmented-control/segment/segment.css +1 -1
  217. package/dist/collection/components/segmented-control/segmented-control.css +1 -1
  218. package/dist/collection/components/select/multi-select/multiselect.css +1 -1
  219. package/dist/collection/components/select/single-select/select.css +1 -1
  220. package/dist/collection/components/slider/slider.css +1 -1
  221. package/dist/collection/components/status/status.css +1 -1
  222. package/dist/collection/components/stepper/step/step.css +1 -1
  223. package/dist/collection/components/stepper/stepper.css +1 -1
  224. package/dist/collection/components/switch/switch.css +1 -1
  225. package/dist/collection/components/table-advanced-version/table.css +1 -1
  226. package/dist/collection/components/table-basic-version/table.css +1 -1
  227. package/dist/collection/components/tabs/tabs.css +1 -1
  228. package/dist/collection/components/text-field/text-field.css +1 -1
  229. package/dist/collection/components/textarea/textarea.css +1 -1
  230. package/dist/collection/components/tooltip/tooltip.css +1 -1
  231. package/dist/components/ifx-accordion-item.js +1 -1
  232. package/dist/components/ifx-accordion.js +1 -1
  233. package/dist/components/ifx-action-list-item.js +1 -1
  234. package/dist/components/ifx-action-list-item.js.map +1 -1
  235. package/dist/components/ifx-action-list.js +1 -1
  236. package/dist/components/ifx-action-list.js.map +1 -1
  237. package/dist/components/ifx-alert.js +1 -1
  238. package/dist/components/ifx-basic-table.js +1 -1
  239. package/dist/components/ifx-basic-table.js.map +1 -1
  240. package/dist/components/ifx-breadcrumb-item-label.js +1 -1
  241. package/dist/components/ifx-breadcrumb-item-label.js.map +1 -1
  242. package/dist/components/ifx-breadcrumb-item.js +1 -1
  243. package/dist/components/ifx-breadcrumb-item.js.map +1 -1
  244. package/dist/components/ifx-breadcrumb.js +1 -1
  245. package/dist/components/ifx-breadcrumb.js.map +1 -1
  246. package/dist/components/ifx-button.js +1 -1
  247. package/dist/components/ifx-card-headline.js +1 -1
  248. package/dist/components/ifx-card-headline.js.map +1 -1
  249. package/dist/components/ifx-card-links.js +1 -1
  250. package/dist/components/ifx-card-links.js.map +1 -1
  251. package/dist/components/ifx-card-overline.js +1 -1
  252. package/dist/components/ifx-card-overline.js.map +1 -1
  253. package/dist/components/ifx-card-text.js +1 -1
  254. package/dist/components/ifx-card-text.js.map +1 -1
  255. package/dist/components/ifx-card.js +1 -1
  256. package/dist/components/ifx-card.js.map +1 -1
  257. package/dist/components/ifx-checkbox-group.js +1 -1
  258. package/dist/components/ifx-checkbox-group.js.map +1 -1
  259. package/dist/components/ifx-chip-item.js +1 -1
  260. package/dist/components/ifx-chip.js +1 -1
  261. package/dist/components/ifx-download.js +1 -1
  262. package/dist/components/ifx-dropdown-header.js +1 -1
  263. package/dist/components/ifx-dropdown-header.js.map +1 -1
  264. package/dist/components/ifx-dropdown-item.js +1 -1
  265. package/dist/components/ifx-dropdown-item.js.map +1 -1
  266. package/dist/components/ifx-dropdown-trigger-button.js +1 -1
  267. package/dist/components/ifx-faq.js +2 -2
  268. package/dist/components/ifx-file-upload.js +3 -3
  269. package/dist/components/ifx-file-upload.js.map +1 -1
  270. package/dist/components/ifx-filter-accordion.js +1 -1
  271. package/dist/components/ifx-filter-bar.js +1 -1
  272. package/dist/components/ifx-filter-search.js +1 -1
  273. package/dist/components/ifx-footer-column.js +1 -1
  274. package/dist/components/ifx-footer-column.js.map +1 -1
  275. package/dist/components/ifx-footer.js +1 -1
  276. package/dist/components/ifx-footer.js.map +1 -1
  277. package/dist/components/ifx-icons-preview.js +3 -3
  278. package/dist/components/ifx-indicator.js +1 -1
  279. package/dist/components/ifx-link.js +1 -1
  280. package/dist/components/ifx-list-entry.js +1 -1
  281. package/dist/components/ifx-list.js +1 -1
  282. package/dist/components/ifx-modal.js +1 -1
  283. package/dist/components/ifx-modal.js.map +1 -1
  284. package/dist/components/ifx-multiselect.js +1 -1
  285. package/dist/components/ifx-navbar-item.js +1 -1
  286. package/dist/components/ifx-navbar.js +1 -1
  287. package/dist/components/ifx-navbar.js.map +1 -1
  288. package/dist/components/ifx-notification.js +1 -1
  289. package/dist/components/ifx-overview-table.js +2 -2
  290. package/dist/components/ifx-pagination.js +1 -1
  291. package/dist/components/ifx-progress-bar.js +1 -1
  292. package/dist/components/ifx-radio-button-group.js +1 -1
  293. package/dist/components/ifx-radio-button-group.js.map +1 -1
  294. package/dist/components/ifx-radio-button.js +1 -1
  295. package/dist/components/ifx-search-bar.js +2 -2
  296. package/dist/components/ifx-search-bar.js.map +1 -1
  297. package/dist/components/ifx-search-field.js +1 -1
  298. package/dist/components/ifx-segment.js +1 -1
  299. package/dist/components/ifx-segment.js.map +1 -1
  300. package/dist/components/ifx-segmented-control.js +1 -1
  301. package/dist/components/ifx-segmented-control.js.map +1 -1
  302. package/dist/components/ifx-select.js +1 -1
  303. package/dist/components/ifx-set-filter.js +4 -4
  304. package/dist/components/ifx-sidebar-item.js +2 -2
  305. package/dist/components/ifx-sidebar-item.js.map +1 -1
  306. package/dist/components/ifx-sidebar-title.js +1 -1
  307. package/dist/components/ifx-sidebar-title.js.map +1 -1
  308. package/dist/components/ifx-sidebar.js +1 -1
  309. package/dist/components/ifx-sidebar.js.map +1 -1
  310. package/dist/components/ifx-slider.js +1 -1
  311. package/dist/components/ifx-slider.js.map +1 -1
  312. package/dist/components/ifx-status.js +1 -1
  313. package/dist/components/ifx-status.js.map +1 -1
  314. package/dist/components/ifx-step.js +1 -1
  315. package/dist/components/ifx-step.js.map +1 -1
  316. package/dist/components/ifx-stepper.js +1 -1
  317. package/dist/components/ifx-stepper.js.map +1 -1
  318. package/dist/components/ifx-switch.js +1 -1
  319. package/dist/components/ifx-switch.js.map +1 -1
  320. package/dist/components/ifx-table.js +7 -7
  321. package/dist/components/ifx-table.js.map +1 -1
  322. package/dist/components/ifx-tabs.js +1 -1
  323. package/dist/components/ifx-tabs.js.map +1 -1
  324. package/dist/components/ifx-template.js +1 -1
  325. package/dist/components/ifx-templates-ui.js +5 -5
  326. package/dist/components/ifx-text-field.js +1 -1
  327. package/dist/components/ifx-textarea.js +1 -1
  328. package/dist/components/ifx-textarea.js.map +1 -1
  329. package/dist/components/ifx-tooltip.js +1 -1
  330. package/dist/components/ifx-tooltip.js.map +1 -1
  331. package/dist/components/index.js +1 -1
  332. package/dist/components/index.js.map +1 -1
  333. package/dist/components/{p-DFnvAzL-.js → p-B2vrW4WM.js} +4 -4
  334. package/dist/components/{p-DFnvAzL-.js.map → p-B2vrW4WM.js.map} +1 -1
  335. package/dist/components/{p-Bux5F8Jt.js → p-BGgzlGhs.js} +3 -3
  336. package/dist/components/{p-Bux5F8Jt.js.map → p-BGgzlGhs.js.map} +1 -1
  337. package/dist/components/{p-BRgFU560.js → p-BR9GBwm3.js} +3 -3
  338. package/dist/components/{p-BRgFU560.js.map → p-BR9GBwm3.js.map} +1 -1
  339. package/dist/components/{p-BXaDLEOt.js → p-BVJl-hTu.js} +3 -3
  340. package/dist/components/{p-BXaDLEOt.js.map → p-BVJl-hTu.js.map} +1 -1
  341. package/dist/components/{p-opY5IicW.js → p-BnMuxXaP.js} +3 -3
  342. package/dist/components/{p-opY5IicW.js.map → p-BnMuxXaP.js.map} +1 -1
  343. package/dist/components/{p-BJpqCkkb.js → p-BxahGQyq.js} +3 -3
  344. package/dist/components/{p-BJpqCkkb.js.map → p-BxahGQyq.js.map} +1 -1
  345. package/dist/components/{p-BxvlRqa4.js → p-C12r4j5b.js} +3 -3
  346. package/dist/components/{p-BxvlRqa4.js.map → p-C12r4j5b.js.map} +1 -1
  347. package/dist/components/{p-JGvjDmyq.js → p-CIw3efEg.js} +4 -4
  348. package/dist/components/{p-JGvjDmyq.js.map → p-CIw3efEg.js.map} +1 -1
  349. package/dist/components/{p-Bp-4o66i.js → p-CKT_EeVj.js} +4 -4
  350. package/dist/components/{p-Bp-4o66i.js.map → p-CKT_EeVj.js.map} +1 -1
  351. package/dist/components/{p-DfEokGrI.js → p-CLqzdlSR.js} +3 -3
  352. package/dist/components/{p-DfEokGrI.js.map → p-CLqzdlSR.js.map} +1 -1
  353. package/dist/components/{p-DTFUtGIP.js → p-CbDS7fbn.js} +3 -3
  354. package/dist/components/{p-DTFUtGIP.js.map → p-CbDS7fbn.js.map} +1 -1
  355. package/dist/components/{p-ByCglXwi.js → p-DD80oicI.js} +3 -3
  356. package/dist/components/{p-ByCglXwi.js.map → p-DD80oicI.js.map} +1 -1
  357. package/dist/components/{p-BNvn6vYq.js → p-DX0ddaB9.js} +3 -3
  358. package/dist/components/{p-BNvn6vYq.js.map → p-DX0ddaB9.js.map} +1 -1
  359. package/dist/components/{p-CC7uHVL3.js → p-DkRZn47g.js} +4 -4
  360. package/dist/components/{p-CC7uHVL3.js.map → p-DkRZn47g.js.map} +1 -1
  361. package/dist/components/{p-iB0ABW13.js → p-Enb5HFzA.js} +5 -5
  362. package/dist/components/{p-iB0ABW13.js.map → p-Enb5HFzA.js.map} +1 -1
  363. package/dist/components/{p-Dn3cSDWF.js → p-R79iWjuc.js} +3 -3
  364. package/dist/components/{p-Dn3cSDWF.js.map → p-R79iWjuc.js.map} +1 -1
  365. package/dist/components/{p-D9skJwQF.js → p-RF9z92mE.js} +3 -3
  366. package/dist/components/{p-D9skJwQF.js.map → p-RF9z92mE.js.map} +1 -1
  367. package/dist/esm/ifx-accordion.ifx-accordion-item.entry.js.map +1 -1
  368. package/dist/esm/ifx-accordion_2.entry.js +3 -3
  369. package/dist/esm/ifx-accordion_2.entry.js.map +1 -1
  370. package/dist/esm/ifx-action-list-item.entry.js +2 -2
  371. package/dist/esm/ifx-action-list-item.entry.js.map +1 -1
  372. package/dist/esm/ifx-action-list.entry.js +2 -2
  373. package/dist/esm/ifx-action-list.entry.js.map +1 -1
  374. package/dist/esm/ifx-alert.ifx-template.entry.js.map +1 -1
  375. package/dist/esm/ifx-alert_2.entry.js +2 -2
  376. package/dist/esm/ifx-alert_2.entry.js.map +1 -1
  377. package/dist/esm/ifx-basic-table.entry.js +2 -2
  378. package/dist/esm/ifx-basic-table.entry.js.map +1 -1
  379. package/dist/esm/ifx-breadcrumb-item-label.entry.js +2 -2
  380. package/dist/esm/ifx-breadcrumb-item-label.entry.js.map +1 -1
  381. package/dist/esm/ifx-breadcrumb-item.entry.js +2 -2
  382. package/dist/esm/ifx-breadcrumb-item.entry.js.map +1 -1
  383. package/dist/esm/ifx-breadcrumb.entry.js +2 -2
  384. package/dist/esm/ifx-breadcrumb.entry.js.map +1 -1
  385. package/dist/esm/ifx-button.entry.js +2 -2
  386. package/dist/esm/ifx-button.entry.js.map +1 -1
  387. package/dist/esm/ifx-card-headline.entry.js +2 -2
  388. package/dist/esm/ifx-card-headline.entry.js.map +1 -1
  389. package/dist/esm/ifx-card-image.entry.js +1 -1
  390. package/dist/esm/ifx-card-links.entry.js +2 -2
  391. package/dist/esm/ifx-card-links.entry.js.map +1 -1
  392. package/dist/esm/ifx-card-overline.entry.js +2 -2
  393. package/dist/esm/ifx-card-overline.entry.js.map +1 -1
  394. package/dist/esm/ifx-card-text.entry.js +2 -2
  395. package/dist/esm/ifx-card-text.entry.js.map +1 -1
  396. package/dist/esm/ifx-card.entry.js +2 -2
  397. package/dist/esm/ifx-card.entry.js.map +1 -1
  398. package/dist/esm/ifx-checkbox-group.entry.js +2 -2
  399. package/dist/esm/ifx-checkbox-group.entry.js.map +1 -1
  400. package/dist/esm/ifx-checkbox.entry.js +1 -1
  401. package/dist/esm/ifx-chip.ifx-chip-item.ifx-pagination.entry.js.map +1 -1
  402. package/dist/esm/ifx-chip_3.entry.js +4 -4
  403. package/dist/esm/ifx-chip_3.entry.js.map +1 -1
  404. package/dist/esm/ifx-content-switcher-item.entry.js +1 -1
  405. package/dist/esm/ifx-content-switcher.entry.js +1 -1
  406. package/dist/esm/ifx-date-picker.entry.js +1 -1
  407. package/dist/esm/ifx-download.entry.js +1 -1
  408. package/dist/esm/ifx-dropdown-header.entry.js +2 -2
  409. package/dist/esm/ifx-dropdown-header.entry.js.map +1 -1
  410. package/dist/esm/ifx-dropdown-item.entry.js +2 -2
  411. package/dist/esm/ifx-dropdown-item.entry.js.map +1 -1
  412. package/dist/esm/ifx-dropdown-menu.entry.js +1 -1
  413. package/dist/esm/ifx-dropdown-separator.entry.js +1 -1
  414. package/dist/esm/ifx-dropdown-trigger-button.entry.js +1 -1
  415. package/dist/esm/ifx-dropdown-trigger.entry.js +1 -1
  416. package/dist/esm/ifx-dropdown.entry.js +1 -1
  417. package/dist/esm/ifx-faq.entry.js +1 -1
  418. package/dist/esm/ifx-file-upload.entry.js +2 -2
  419. package/dist/esm/ifx-file-upload.entry.js.map +1 -1
  420. package/dist/esm/ifx-filter-accordion.entry.js +1 -1
  421. package/dist/esm/ifx-filter-bar.entry.js +1 -1
  422. package/dist/esm/ifx-filter-search.entry.js +1 -1
  423. package/dist/esm/ifx-filter-type-group.entry.js +1 -1
  424. package/dist/esm/ifx-footer-column.entry.js +2 -2
  425. package/dist/esm/ifx-footer-column.entry.js.map +1 -1
  426. package/dist/esm/ifx-footer.entry.js +2 -2
  427. package/dist/esm/ifx-footer.entry.js.map +1 -1
  428. package/dist/esm/ifx-icon-button.entry.js +1 -1
  429. package/dist/esm/ifx-icon.entry.js +1 -1
  430. package/dist/esm/ifx-icons-preview.entry.js +1 -1
  431. package/dist/esm/ifx-indicator.entry.js +2 -2
  432. package/dist/esm/ifx-indicator.entry.js.map +1 -1
  433. package/dist/esm/ifx-link.entry.js +2 -2
  434. package/dist/esm/ifx-link.entry.js.map +1 -1
  435. package/dist/esm/ifx-list-entry.entry.js +1 -1
  436. package/dist/esm/ifx-list.entry.js +1 -1
  437. package/dist/esm/ifx-modal.entry.js +2 -2
  438. package/dist/esm/ifx-modal.entry.js.map +1 -1
  439. package/dist/esm/ifx-multiselect.ifx-multiselect-option.entry.js.map +1 -1
  440. package/dist/esm/ifx-multiselect_2.entry.js +2 -2
  441. package/dist/esm/ifx-multiselect_2.entry.js.map +1 -1
  442. package/dist/esm/ifx-navbar-item.entry.js +1 -1
  443. package/dist/esm/ifx-navbar-profile.entry.js +1 -1
  444. package/dist/esm/ifx-navbar.entry.js +2 -2
  445. package/dist/esm/ifx-navbar.entry.js.map +1 -1
  446. package/dist/esm/ifx-notification.entry.js +2 -2
  447. package/dist/esm/ifx-notification.entry.js.map +1 -1
  448. package/dist/esm/ifx-overview-table.entry.js +1 -1
  449. package/dist/esm/ifx-progress-bar.entry.js +2 -2
  450. package/dist/esm/ifx-progress-bar.entry.js.map +1 -1
  451. package/dist/esm/ifx-radio-button-group.entry.js +2 -2
  452. package/dist/esm/ifx-radio-button-group.entry.js.map +1 -1
  453. package/dist/esm/ifx-radio-button.entry.js +2 -2
  454. package/dist/esm/ifx-radio-button.entry.js.map +1 -1
  455. package/dist/esm/ifx-search-bar.entry.js +2 -2
  456. package/dist/esm/ifx-search-bar.entry.js.map +1 -1
  457. package/dist/esm/ifx-search-field.entry.js +2 -2
  458. package/dist/esm/ifx-search-field.entry.js.map +1 -1
  459. package/dist/esm/ifx-segment.entry.js +2 -2
  460. package/dist/esm/ifx-segment.entry.js.map +1 -1
  461. package/dist/esm/ifx-segmented-control.entry.js +2 -2
  462. package/dist/esm/ifx-segmented-control.entry.js.map +1 -1
  463. package/dist/esm/ifx-select.entry.js +2 -2
  464. package/dist/esm/ifx-select.entry.js.map +1 -1
  465. package/dist/esm/ifx-set-filter.entry.js +1 -1
  466. package/dist/esm/ifx-sidebar-item.entry.js +2 -2
  467. package/dist/esm/ifx-sidebar-item.entry.js.map +1 -1
  468. package/dist/esm/ifx-sidebar-title.entry.js +2 -2
  469. package/dist/esm/ifx-sidebar-title.entry.js.map +1 -1
  470. package/dist/esm/ifx-sidebar.entry.js +2 -2
  471. package/dist/esm/ifx-sidebar.entry.js.map +1 -1
  472. package/dist/esm/ifx-slider.entry.js +2 -2
  473. package/dist/esm/ifx-slider.entry.js.map +1 -1
  474. package/dist/esm/ifx-spinner.ifx-text-field.entry.js.map +1 -1
  475. package/dist/esm/ifx-spinner_2.entry.js +2 -2
  476. package/dist/esm/ifx-spinner_2.entry.js.map +1 -1
  477. package/dist/esm/ifx-status.entry.js +2 -2
  478. package/dist/esm/ifx-status.entry.js.map +1 -1
  479. package/dist/esm/ifx-step.entry.js +2 -2
  480. package/dist/esm/ifx-step.entry.js.map +1 -1
  481. package/dist/esm/ifx-stepper.entry.js +2 -2
  482. package/dist/esm/ifx-stepper.entry.js.map +1 -1
  483. package/dist/esm/ifx-switch.entry.js +2 -2
  484. package/dist/esm/ifx-switch.entry.js.map +1 -1
  485. package/dist/esm/ifx-tab.entry.js +1 -1
  486. package/dist/esm/ifx-table.entry.js +2 -2
  487. package/dist/esm/ifx-table.entry.js.map +1 -1
  488. package/dist/esm/ifx-tabs.entry.js +2 -2
  489. package/dist/esm/ifx-tabs.entry.js.map +1 -1
  490. package/dist/esm/ifx-templates-ui.entry.js +1 -1
  491. package/dist/esm/ifx-textarea.entry.js +2 -2
  492. package/dist/esm/ifx-textarea.entry.js.map +1 -1
  493. package/dist/esm/ifx-tooltip.entry.js +2 -2
  494. package/dist/esm/ifx-tooltip.entry.js.map +1 -1
  495. package/dist/esm/ifx-tree-view-item.entry.js +1 -1
  496. package/dist/esm/ifx-tree-view.entry.js +1 -1
  497. package/dist/esm/{index-DtIEDtZ8.js → index-PqnYwNKt.js} +3 -3
  498. package/dist/esm/index-PqnYwNKt.js.map +1 -0
  499. package/dist/esm/infineon-design-system-stencil.js +2 -2
  500. package/dist/esm/loader.js +2 -2
  501. package/dist/infineon-design-system-stencil/ifx-accordion.ifx-accordion-item.entry.esm.js.map +1 -1
  502. package/dist/infineon-design-system-stencil/ifx-action-list-item.entry.esm.js.map +1 -1
  503. package/dist/infineon-design-system-stencil/ifx-action-list.entry.esm.js.map +1 -1
  504. package/dist/infineon-design-system-stencil/ifx-alert.ifx-template.entry.esm.js.map +1 -1
  505. package/dist/infineon-design-system-stencil/ifx-basic-table.entry.esm.js.map +1 -1
  506. package/dist/infineon-design-system-stencil/ifx-breadcrumb-item-label.entry.esm.js.map +1 -1
  507. package/dist/infineon-design-system-stencil/ifx-breadcrumb-item.entry.esm.js.map +1 -1
  508. package/dist/infineon-design-system-stencil/ifx-breadcrumb.entry.esm.js.map +1 -1
  509. package/dist/infineon-design-system-stencil/ifx-button.entry.esm.js.map +1 -1
  510. package/dist/infineon-design-system-stencil/ifx-card-headline.entry.esm.js.map +1 -1
  511. package/dist/infineon-design-system-stencil/ifx-card-links.entry.esm.js.map +1 -1
  512. package/dist/infineon-design-system-stencil/ifx-card-overline.entry.esm.js.map +1 -1
  513. package/dist/infineon-design-system-stencil/ifx-card-text.entry.esm.js.map +1 -1
  514. package/dist/infineon-design-system-stencil/ifx-card.entry.esm.js.map +1 -1
  515. package/dist/infineon-design-system-stencil/ifx-checkbox-group.entry.esm.js.map +1 -1
  516. package/dist/infineon-design-system-stencil/ifx-chip.ifx-chip-item.ifx-pagination.entry.esm.js.map +1 -1
  517. package/dist/infineon-design-system-stencil/ifx-dropdown-header.entry.esm.js.map +1 -1
  518. package/dist/infineon-design-system-stencil/ifx-dropdown-item.entry.esm.js.map +1 -1
  519. package/dist/infineon-design-system-stencil/ifx-file-upload.entry.esm.js.map +1 -1
  520. package/dist/infineon-design-system-stencil/ifx-footer-column.entry.esm.js.map +1 -1
  521. package/dist/infineon-design-system-stencil/ifx-footer.entry.esm.js.map +1 -1
  522. package/dist/infineon-design-system-stencil/ifx-indicator.entry.esm.js.map +1 -1
  523. package/dist/infineon-design-system-stencil/ifx-link.entry.esm.js.map +1 -1
  524. package/dist/infineon-design-system-stencil/ifx-modal.entry.esm.js.map +1 -1
  525. package/dist/infineon-design-system-stencil/ifx-multiselect.ifx-multiselect-option.entry.esm.js.map +1 -1
  526. package/dist/infineon-design-system-stencil/ifx-navbar.entry.esm.js.map +1 -1
  527. package/dist/infineon-design-system-stencil/ifx-notification.entry.esm.js.map +1 -1
  528. package/dist/infineon-design-system-stencil/ifx-progress-bar.entry.esm.js.map +1 -1
  529. package/dist/infineon-design-system-stencil/ifx-radio-button-group.entry.esm.js.map +1 -1
  530. package/dist/infineon-design-system-stencil/ifx-radio-button.entry.esm.js.map +1 -1
  531. package/dist/infineon-design-system-stencil/ifx-search-bar.entry.esm.js.map +1 -1
  532. package/dist/infineon-design-system-stencil/ifx-search-field.entry.esm.js.map +1 -1
  533. package/dist/infineon-design-system-stencil/ifx-segment.entry.esm.js.map +1 -1
  534. package/dist/infineon-design-system-stencil/ifx-segmented-control.entry.esm.js.map +1 -1
  535. package/dist/infineon-design-system-stencil/ifx-select.entry.esm.js.map +1 -1
  536. package/dist/infineon-design-system-stencil/ifx-sidebar-item.entry.esm.js.map +1 -1
  537. package/dist/infineon-design-system-stencil/ifx-sidebar-title.entry.esm.js.map +1 -1
  538. package/dist/infineon-design-system-stencil/ifx-sidebar.entry.esm.js.map +1 -1
  539. package/dist/infineon-design-system-stencil/ifx-slider.entry.esm.js.map +1 -1
  540. package/dist/infineon-design-system-stencil/ifx-spinner.ifx-text-field.entry.esm.js.map +1 -1
  541. package/dist/infineon-design-system-stencil/ifx-status.entry.esm.js.map +1 -1
  542. package/dist/infineon-design-system-stencil/ifx-step.entry.esm.js.map +1 -1
  543. package/dist/infineon-design-system-stencil/ifx-stepper.entry.esm.js.map +1 -1
  544. package/dist/infineon-design-system-stencil/ifx-switch.entry.esm.js.map +1 -1
  545. package/dist/infineon-design-system-stencil/ifx-table.entry.esm.js.map +1 -1
  546. package/dist/infineon-design-system-stencil/ifx-tabs.entry.esm.js.map +1 -1
  547. package/dist/infineon-design-system-stencil/ifx-textarea.entry.esm.js.map +1 -1
  548. package/dist/infineon-design-system-stencil/ifx-tooltip.entry.esm.js.map +1 -1
  549. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.css +1 -1
  550. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js +1 -1
  551. package/dist/infineon-design-system-stencil/p-05f66dcb.entry.js +2 -0
  552. package/dist/infineon-design-system-stencil/{p-412f510b.entry.js.map → p-05f66dcb.entry.js.map} +1 -1
  553. package/dist/infineon-design-system-stencil/{p-0dbe2818.entry.js → p-060845fd.entry.js} +2 -2
  554. package/dist/infineon-design-system-stencil/p-06d2f85b.entry.js +2 -0
  555. package/dist/infineon-design-system-stencil/{p-13fed6df.entry.js.map → p-06d2f85b.entry.js.map} +1 -1
  556. package/dist/infineon-design-system-stencil/p-0929589d.entry.js +2 -0
  557. package/dist/infineon-design-system-stencil/{p-4850e2df.entry.js.map → p-0929589d.entry.js.map} +1 -1
  558. package/dist/infineon-design-system-stencil/p-0be8f0c9.entry.js +2 -0
  559. package/dist/infineon-design-system-stencil/{p-58552d96.entry.js.map → p-0be8f0c9.entry.js.map} +1 -1
  560. package/dist/infineon-design-system-stencil/{p-dfd77261.entry.js → p-0fb9f42b.entry.js} +2 -2
  561. package/dist/infineon-design-system-stencil/{p-d3a6bbf7.entry.js → p-116c853e.entry.js} +2 -2
  562. package/dist/infineon-design-system-stencil/p-169f26ae.entry.js +2 -0
  563. package/dist/infineon-design-system-stencil/{p-1df9b181.entry.js.map → p-169f26ae.entry.js.map} +1 -1
  564. package/dist/infineon-design-system-stencil/p-1c1b1a1f.entry.js +2 -0
  565. package/dist/infineon-design-system-stencil/{p-240a4cb3.entry.js.map → p-1c1b1a1f.entry.js.map} +1 -1
  566. package/dist/infineon-design-system-stencil/{p-fd206fce.entry.js → p-1d494424.entry.js} +2 -2
  567. package/dist/infineon-design-system-stencil/p-22e9960d.entry.js +2 -0
  568. package/dist/infineon-design-system-stencil/{p-f5811026.entry.js.map → p-22e9960d.entry.js.map} +1 -1
  569. package/dist/infineon-design-system-stencil/p-2503d869.entry.js +2 -0
  570. package/dist/infineon-design-system-stencil/{p-84735ae2.entry.js.map → p-2503d869.entry.js.map} +1 -1
  571. package/dist/infineon-design-system-stencil/p-273907cb.entry.js +2 -0
  572. package/dist/infineon-design-system-stencil/{p-a1c63832.entry.js.map → p-273907cb.entry.js.map} +1 -1
  573. package/dist/infineon-design-system-stencil/p-2813423a.entry.js +2 -0
  574. package/dist/infineon-design-system-stencil/{p-249372a1.entry.js.map → p-2813423a.entry.js.map} +1 -1
  575. package/dist/infineon-design-system-stencil/p-2b4b2b06.entry.js +2 -0
  576. package/dist/infineon-design-system-stencil/{p-fe373208.entry.js.map → p-2b4b2b06.entry.js.map} +1 -1
  577. package/dist/infineon-design-system-stencil/{p-8c44be53.entry.js → p-2e172019.entry.js} +2 -2
  578. package/dist/infineon-design-system-stencil/p-307e6a72.entry.js +2 -0
  579. package/dist/infineon-design-system-stencil/p-35d2266a.entry.js +2 -0
  580. package/dist/infineon-design-system-stencil/{p-4016e7cf.entry.js.map → p-35d2266a.entry.js.map} +1 -1
  581. package/dist/infineon-design-system-stencil/p-380368ca.entry.js +2 -0
  582. package/dist/infineon-design-system-stencil/{p-4c846056.entry.js.map → p-380368ca.entry.js.map} +1 -1
  583. package/dist/infineon-design-system-stencil/p-39561a49.entry.js +2 -0
  584. package/dist/infineon-design-system-stencil/{p-0100cbfb.entry.js.map → p-39561a49.entry.js.map} +1 -1
  585. package/dist/infineon-design-system-stencil/{p-0d9da371.entry.js → p-39e3ee45.entry.js} +2 -2
  586. package/dist/infineon-design-system-stencil/{p-0d9da371.entry.js.map → p-39e3ee45.entry.js.map} +1 -1
  587. package/dist/infineon-design-system-stencil/p-3d77ef02.entry.js +2 -0
  588. package/dist/infineon-design-system-stencil/{p-d3236a63.entry.js.map → p-3d77ef02.entry.js.map} +1 -1
  589. package/dist/infineon-design-system-stencil/p-3eeacac9.entry.js +2 -0
  590. package/dist/infineon-design-system-stencil/{p-c6fa6fd3.entry.js.map → p-3eeacac9.entry.js.map} +1 -1
  591. package/dist/infineon-design-system-stencil/{p-ba4ee343.entry.js → p-45dad0d1.entry.js} +2 -2
  592. package/dist/infineon-design-system-stencil/{p-7468590a.entry.js → p-4669e01f.entry.js} +2 -2
  593. package/dist/infineon-design-system-stencil/p-4da5a2a5.entry.js +2 -0
  594. package/dist/infineon-design-system-stencil/{p-ae513612.entry.js.map → p-4da5a2a5.entry.js.map} +1 -1
  595. package/dist/infineon-design-system-stencil/p-4fba0543.entry.js +2 -0
  596. package/dist/infineon-design-system-stencil/{p-b23596f4.entry.js.map → p-4fba0543.entry.js.map} +1 -1
  597. package/dist/infineon-design-system-stencil/p-5367db9d.entry.js +2 -0
  598. package/dist/infineon-design-system-stencil/{p-ee2ca575.entry.js.map → p-5367db9d.entry.js.map} +1 -1
  599. package/dist/infineon-design-system-stencil/p-58dd6f5c.entry.js +2 -0
  600. package/dist/infineon-design-system-stencil/{p-43943864.entry.js.map → p-58dd6f5c.entry.js.map} +1 -1
  601. package/dist/infineon-design-system-stencil/p-5b571505.entry.js +2 -0
  602. package/dist/infineon-design-system-stencil/{p-9ea43bb7.entry.js.map → p-5b571505.entry.js.map} +1 -1
  603. package/dist/infineon-design-system-stencil/{p-f63ba4a3.entry.js → p-5e3d0ff0.entry.js} +2 -2
  604. package/dist/infineon-design-system-stencil/p-5fb3eb8b.entry.js +2 -0
  605. package/dist/infineon-design-system-stencil/{p-ad702dcc.entry.js.map → p-5fb3eb8b.entry.js.map} +1 -1
  606. package/dist/infineon-design-system-stencil/p-6a07106e.entry.js +2 -0
  607. package/dist/infineon-design-system-stencil/{p-29d78bf2.entry.js.map → p-6a07106e.entry.js.map} +1 -1
  608. package/dist/infineon-design-system-stencil/p-6e115707.entry.js +2 -0
  609. package/dist/infineon-design-system-stencil/{p-8ab64504.entry.js.map → p-6e115707.entry.js.map} +1 -1
  610. package/dist/infineon-design-system-stencil/{p-e7b72d33.entry.js → p-744c1c8e.entry.js} +2 -2
  611. package/dist/infineon-design-system-stencil/p-760cfc7e.entry.js +2 -0
  612. package/dist/infineon-design-system-stencil/{p-765dd1b4.entry.js.map → p-760cfc7e.entry.js.map} +1 -1
  613. package/dist/infineon-design-system-stencil/{p-1bbaae5e.entry.js → p-77e54475.entry.js} +2 -2
  614. package/dist/infineon-design-system-stencil/{p-eed36710.entry.js → p-8ceb2ccc.entry.js} +2 -2
  615. package/dist/infineon-design-system-stencil/{p-d4fea918.entry.js → p-92ee6f73.entry.js} +2 -2
  616. package/dist/infineon-design-system-stencil/{p-c9d594e1.entry.js → p-94dfe026.entry.js} +2 -2
  617. package/dist/infineon-design-system-stencil/{p-0d4211db.entry.js → p-9517d1b0.entry.js} +2 -2
  618. package/dist/infineon-design-system-stencil/p-97b2ac42.entry.js +2 -0
  619. package/dist/infineon-design-system-stencil/{p-933da006.entry.js.map → p-97b2ac42.entry.js.map} +1 -1
  620. package/dist/infineon-design-system-stencil/{p-5c673497.entry.js → p-9b06df76.entry.js} +2 -2
  621. package/dist/infineon-design-system-stencil/p-9ba730bb.entry.js +2 -0
  622. package/dist/infineon-design-system-stencil/{p-d56ee584.entry.js.map → p-9ba730bb.entry.js.map} +1 -1
  623. package/dist/infineon-design-system-stencil/p-9deaa65e.entry.js +2 -0
  624. package/dist/infineon-design-system-stencil/{p-1c2d0b17.entry.js.map → p-9deaa65e.entry.js.map} +1 -1
  625. package/dist/infineon-design-system-stencil/{p-DtIEDtZ8.js → p-PqnYwNKt.js} +2 -2
  626. package/dist/infineon-design-system-stencil/p-PqnYwNKt.js.map +1 -0
  627. package/dist/infineon-design-system-stencil/p-a4dd2fe1.entry.js +2 -0
  628. package/dist/infineon-design-system-stencil/{p-453bd9bd.entry.js.map → p-a4dd2fe1.entry.js.map} +1 -1
  629. package/dist/infineon-design-system-stencil/{p-06215925.entry.js → p-a85754a5.entry.js} +3 -3
  630. package/dist/infineon-design-system-stencil/{p-06215925.entry.js.map → p-a85754a5.entry.js.map} +1 -1
  631. package/dist/infineon-design-system-stencil/p-ab326703.entry.js +2 -0
  632. package/dist/infineon-design-system-stencil/p-ab326703.entry.js.map +1 -0
  633. package/dist/infineon-design-system-stencil/{p-b969b2c0.entry.js → p-b7672947.entry.js} +2 -2
  634. package/dist/infineon-design-system-stencil/p-bd8c6834.entry.js +2 -0
  635. package/dist/infineon-design-system-stencil/{p-550283fa.entry.js.map → p-bd8c6834.entry.js.map} +1 -1
  636. package/dist/infineon-design-system-stencil/{p-27808b00.entry.js → p-beaba918.entry.js} +2 -2
  637. package/dist/infineon-design-system-stencil/{p-b5efb1d6.entry.js → p-c578a728.entry.js} +2 -2
  638. package/dist/infineon-design-system-stencil/{p-2151de2a.entry.js → p-c6826c1e.entry.js} +2 -2
  639. package/dist/infineon-design-system-stencil/p-ca312cbb.entry.js +2 -0
  640. package/dist/infineon-design-system-stencil/{p-6407c496.entry.js.map → p-ca312cbb.entry.js.map} +1 -1
  641. package/dist/infineon-design-system-stencil/p-ca870353.entry.js +2 -0
  642. package/dist/infineon-design-system-stencil/{p-3f29b8fd.entry.js.map → p-ca870353.entry.js.map} +1 -1
  643. package/dist/infineon-design-system-stencil/p-ce799b3d.entry.js +2 -0
  644. package/dist/infineon-design-system-stencil/{p-913a8693.entry.js.map → p-ce799b3d.entry.js.map} +1 -1
  645. package/dist/infineon-design-system-stencil/p-d267f6d2.entry.js +2 -0
  646. package/dist/infineon-design-system-stencil/{p-dd1b2b14.entry.js.map → p-d267f6d2.entry.js.map} +1 -1
  647. package/dist/infineon-design-system-stencil/{p-213a4829.entry.js → p-d2b076fe.entry.js} +2 -2
  648. package/dist/infineon-design-system-stencil/{p-55227732.entry.js → p-d4373c36.entry.js} +2 -2
  649. package/dist/infineon-design-system-stencil/p-d65a334c.entry.js +2 -0
  650. package/dist/infineon-design-system-stencil/{p-dcc7240e.entry.js.map → p-d65a334c.entry.js.map} +1 -1
  651. package/dist/infineon-design-system-stencil/p-dac7d817.entry.js +2 -0
  652. package/dist/infineon-design-system-stencil/{p-7910df8a.entry.js.map → p-dac7d817.entry.js.map} +1 -1
  653. package/dist/infineon-design-system-stencil/p-dbc6ae20.entry.js +2 -0
  654. package/dist/infineon-design-system-stencil/{p-cae1ea22.entry.js.map → p-dbc6ae20.entry.js.map} +1 -1
  655. package/dist/infineon-design-system-stencil/{p-372fa9eb.entry.js → p-dcd0af23.entry.js} +2 -2
  656. package/dist/infineon-design-system-stencil/{p-83816596.entry.js → p-e3c11b6c.entry.js} +2 -2
  657. package/dist/infineon-design-system-stencil/{p-22a45c93.entry.js → p-e6c4c4cf.entry.js} +2 -2
  658. package/dist/infineon-design-system-stencil/{p-8a9d3e04.entry.js → p-e78ffc43.entry.js} +2 -2
  659. package/dist/infineon-design-system-stencil/p-e7c656cd.entry.js +2 -0
  660. package/dist/infineon-design-system-stencil/{p-6ceae9a3.entry.js.map → p-e7c656cd.entry.js.map} +1 -1
  661. package/dist/infineon-design-system-stencil/p-edbfa46e.entry.js +2 -0
  662. package/dist/infineon-design-system-stencil/{p-98c2e3a9.entry.js.map → p-edbfa46e.entry.js.map} +1 -1
  663. package/dist/infineon-design-system-stencil/p-ee04eb6e.entry.js +2 -0
  664. package/dist/infineon-design-system-stencil/{p-6504f8d0.entry.js.map → p-ee04eb6e.entry.js.map} +1 -1
  665. package/dist/infineon-design-system-stencil/p-f06b0ae3.entry.js +2 -0
  666. package/dist/infineon-design-system-stencil/{p-6af7d062.entry.js.map → p-f06b0ae3.entry.js.map} +1 -1
  667. package/dist/infineon-design-system-stencil/p-f1ba768a.entry.js +2 -0
  668. package/dist/infineon-design-system-stencil/{p-af1e0cb5.entry.js.map → p-f1ba768a.entry.js.map} +1 -1
  669. package/dist/infineon-design-system-stencil/p-f2c8c7a6.entry.js +2 -0
  670. package/dist/infineon-design-system-stencil/{p-3f3a5140.entry.js.map → p-f2c8c7a6.entry.js.map} +1 -1
  671. package/dist/infineon-design-system-stencil/{p-988ad5f6.entry.js → p-f85c9454.entry.js} +2 -2
  672. package/dist/infineon-design-system-stencil/p-fb92000d.entry.js +2 -0
  673. package/dist/infineon-design-system-stencil/p-fc359efa.entry.js +2 -0
  674. package/dist/infineon-design-system-stencil/p-fc359efa.entry.js.map +1 -0
  675. package/dist/infineon-design-system-stencil/{p-54785004.entry.js → p-fcae5dc1.entry.js} +2 -2
  676. package/dist/infineon-design-system-stencil/{p-54785004.entry.js.map → p-fcae5dc1.entry.js.map} +1 -1
  677. package/dist/infineon-design-system-stencil/{p-91ce7e7b.entry.js → p-ff4cc197.entry.js} +2 -2
  678. package/package.json +1 -1
  679. package/dist/cjs/index-n_pDKBY2.js.map +0 -1
  680. package/dist/esm/index-DtIEDtZ8.js.map +0 -1
  681. package/dist/infineon-design-system-stencil/p-0100cbfb.entry.js +0 -2
  682. package/dist/infineon-design-system-stencil/p-13fed6df.entry.js +0 -2
  683. package/dist/infineon-design-system-stencil/p-1c2d0b17.entry.js +0 -2
  684. package/dist/infineon-design-system-stencil/p-1df9b181.entry.js +0 -2
  685. package/dist/infineon-design-system-stencil/p-240a4cb3.entry.js +0 -2
  686. package/dist/infineon-design-system-stencil/p-249372a1.entry.js +0 -2
  687. package/dist/infineon-design-system-stencil/p-29d78bf2.entry.js +0 -2
  688. package/dist/infineon-design-system-stencil/p-3cdd03ed.entry.js +0 -2
  689. package/dist/infineon-design-system-stencil/p-3cdd03ed.entry.js.map +0 -1
  690. package/dist/infineon-design-system-stencil/p-3f29b8fd.entry.js +0 -2
  691. package/dist/infineon-design-system-stencil/p-3f3a5140.entry.js +0 -2
  692. package/dist/infineon-design-system-stencil/p-4016e7cf.entry.js +0 -2
  693. package/dist/infineon-design-system-stencil/p-412f510b.entry.js +0 -2
  694. package/dist/infineon-design-system-stencil/p-43943864.entry.js +0 -2
  695. package/dist/infineon-design-system-stencil/p-453bd9bd.entry.js +0 -2
  696. package/dist/infineon-design-system-stencil/p-4850e2df.entry.js +0 -2
  697. package/dist/infineon-design-system-stencil/p-4afddabf.entry.js +0 -2
  698. package/dist/infineon-design-system-stencil/p-4c846056.entry.js +0 -2
  699. package/dist/infineon-design-system-stencil/p-550283fa.entry.js +0 -2
  700. package/dist/infineon-design-system-stencil/p-58552d96.entry.js +0 -2
  701. package/dist/infineon-design-system-stencil/p-6407c496.entry.js +0 -2
  702. package/dist/infineon-design-system-stencil/p-6504f8d0.entry.js +0 -2
  703. package/dist/infineon-design-system-stencil/p-6af7d062.entry.js +0 -2
  704. package/dist/infineon-design-system-stencil/p-6ceae9a3.entry.js +0 -2
  705. package/dist/infineon-design-system-stencil/p-765dd1b4.entry.js +0 -2
  706. package/dist/infineon-design-system-stencil/p-7910df8a.entry.js +0 -2
  707. package/dist/infineon-design-system-stencil/p-84735ae2.entry.js +0 -2
  708. package/dist/infineon-design-system-stencil/p-8ab64504.entry.js +0 -2
  709. package/dist/infineon-design-system-stencil/p-913a8693.entry.js +0 -2
  710. package/dist/infineon-design-system-stencil/p-933da006.entry.js +0 -2
  711. package/dist/infineon-design-system-stencil/p-98c2e3a9.entry.js +0 -2
  712. package/dist/infineon-design-system-stencil/p-9ea43bb7.entry.js +0 -2
  713. package/dist/infineon-design-system-stencil/p-DtIEDtZ8.js.map +0 -1
  714. package/dist/infineon-design-system-stencil/p-a1c63832.entry.js +0 -2
  715. package/dist/infineon-design-system-stencil/p-ad702dcc.entry.js +0 -2
  716. package/dist/infineon-design-system-stencil/p-ae513612.entry.js +0 -2
  717. package/dist/infineon-design-system-stencil/p-af1e0cb5.entry.js +0 -2
  718. package/dist/infineon-design-system-stencil/p-b23596f4.entry.js +0 -2
  719. package/dist/infineon-design-system-stencil/p-b5db443a.entry.js +0 -2
  720. package/dist/infineon-design-system-stencil/p-b5db443a.entry.js.map +0 -1
  721. package/dist/infineon-design-system-stencil/p-c6fa6fd3.entry.js +0 -2
  722. package/dist/infineon-design-system-stencil/p-cae1ea22.entry.js +0 -2
  723. package/dist/infineon-design-system-stencil/p-d3236a63.entry.js +0 -2
  724. package/dist/infineon-design-system-stencil/p-d56ee584.entry.js +0 -2
  725. package/dist/infineon-design-system-stencil/p-dcc7240e.entry.js +0 -2
  726. package/dist/infineon-design-system-stencil/p-dd1b2b14.entry.js +0 -2
  727. package/dist/infineon-design-system-stencil/p-ee2ca575.entry.js +0 -2
  728. package/dist/infineon-design-system-stencil/p-f5811026.entry.js +0 -2
  729. package/dist/infineon-design-system-stencil/p-f68887c5.entry.js +0 -2
  730. package/dist/infineon-design-system-stencil/p-fe373208.entry.js +0 -2
  731. /package/dist/infineon-design-system-stencil/{p-0dbe2818.entry.js.map → p-060845fd.entry.js.map} +0 -0
  732. /package/dist/infineon-design-system-stencil/{p-dfd77261.entry.js.map → p-0fb9f42b.entry.js.map} +0 -0
  733. /package/dist/infineon-design-system-stencil/{p-d3a6bbf7.entry.js.map → p-116c853e.entry.js.map} +0 -0
  734. /package/dist/infineon-design-system-stencil/{p-fd206fce.entry.js.map → p-1d494424.entry.js.map} +0 -0
  735. /package/dist/infineon-design-system-stencil/{p-8c44be53.entry.js.map → p-2e172019.entry.js.map} +0 -0
  736. /package/dist/infineon-design-system-stencil/{p-4afddabf.entry.js.map → p-307e6a72.entry.js.map} +0 -0
  737. /package/dist/infineon-design-system-stencil/{p-ba4ee343.entry.js.map → p-45dad0d1.entry.js.map} +0 -0
  738. /package/dist/infineon-design-system-stencil/{p-7468590a.entry.js.map → p-4669e01f.entry.js.map} +0 -0
  739. /package/dist/infineon-design-system-stencil/{p-f63ba4a3.entry.js.map → p-5e3d0ff0.entry.js.map} +0 -0
  740. /package/dist/infineon-design-system-stencil/{p-e7b72d33.entry.js.map → p-744c1c8e.entry.js.map} +0 -0
  741. /package/dist/infineon-design-system-stencil/{p-1bbaae5e.entry.js.map → p-77e54475.entry.js.map} +0 -0
  742. /package/dist/infineon-design-system-stencil/{p-eed36710.entry.js.map → p-8ceb2ccc.entry.js.map} +0 -0
  743. /package/dist/infineon-design-system-stencil/{p-d4fea918.entry.js.map → p-92ee6f73.entry.js.map} +0 -0
  744. /package/dist/infineon-design-system-stencil/{p-c9d594e1.entry.js.map → p-94dfe026.entry.js.map} +0 -0
  745. /package/dist/infineon-design-system-stencil/{p-0d4211db.entry.js.map → p-9517d1b0.entry.js.map} +0 -0
  746. /package/dist/infineon-design-system-stencil/{p-5c673497.entry.js.map → p-9b06df76.entry.js.map} +0 -0
  747. /package/dist/infineon-design-system-stencil/{p-b969b2c0.entry.js.map → p-b7672947.entry.js.map} +0 -0
  748. /package/dist/infineon-design-system-stencil/{p-27808b00.entry.js.map → p-beaba918.entry.js.map} +0 -0
  749. /package/dist/infineon-design-system-stencil/{p-b5efb1d6.entry.js.map → p-c578a728.entry.js.map} +0 -0
  750. /package/dist/infineon-design-system-stencil/{p-2151de2a.entry.js.map → p-c6826c1e.entry.js.map} +0 -0
  751. /package/dist/infineon-design-system-stencil/{p-213a4829.entry.js.map → p-d2b076fe.entry.js.map} +0 -0
  752. /package/dist/infineon-design-system-stencil/{p-55227732.entry.js.map → p-d4373c36.entry.js.map} +0 -0
  753. /package/dist/infineon-design-system-stencil/{p-372fa9eb.entry.js.map → p-dcd0af23.entry.js.map} +0 -0
  754. /package/dist/infineon-design-system-stencil/{p-83816596.entry.js.map → p-e3c11b6c.entry.js.map} +0 -0
  755. /package/dist/infineon-design-system-stencil/{p-22a45c93.entry.js.map → p-e6c4c4cf.entry.js.map} +0 -0
  756. /package/dist/infineon-design-system-stencil/{p-8a9d3e04.entry.js.map → p-e78ffc43.entry.js.map} +0 -0
  757. /package/dist/infineon-design-system-stencil/{p-988ad5f6.entry.js.map → p-f85c9454.entry.js.map} +0 -0
  758. /package/dist/infineon-design-system-stencil/{p-f68887c5.entry.js.map → p-fb92000d.entry.js.map} +0 -0
  759. /package/dist/infineon-design-system-stencil/{p-91ce7e7b.entry.js.map → p-ff4cc197.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":["alertCss","Alert","constructor","hostRef","this","variant","closable","AriaLive","alertTypeDescription","primary","success","danger","warning","info","handleClose","ifxClose","emit","renderCloseButton","h","class","onClick","bind","icon","generateUniqueId","prefix","Math","random","toString","substring","componentWillLoad","uniqueId","componentDidLoad","isNestedInIfxComponent","el","framework","detectFramework","trackComponent","render","role","name","id","templateCss","Template","repoDetails","desc","showDetails","isTemplatePage","isLoading","clientId","redirectUri","scope","state","authUser","authorizationUrl","window","open","url","URL","location","href","code","searchParams","get","templateName","getLocalStorageValues","toggleTemplates","getUserToken","repoName","localStorage","getItem","repoDesc","repoFramework","authCode","fetch","then","response","ok","text","errorMessage","Error","data","repoUrl","clear","catch","error","repoError","message","console","handleUserInput","e","type","Object","assign","target","value","submitUserData","setItem","fieldError","togglePadding","action","parent","parentElement","rootNode","getRootNode","ShadowRoot","host","style","padding","handleCurrentTemplate","targetTemplate","currentTarget","toggleTemplate","currTemp","templateWrapper","shadowRoot","querySelector","classList","contains","add","remove","key","size","src","thumbnail","onInput","htmlFor","disabled","required","placeholder","fullWidth"],"sources":["src/components/alert/alert.scss?tag=ifx-alert&encapsulation=shadow","src/components/alert/alert.tsx","src/components/templates/template/template.scss?tag=ifx-template&encapsulation=shadow","src/components/templates/template/template.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n:host {\n display: block;\n}\n\n.alert__info-wrapper {\n display: flex;\n padding: 16px 24px;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n box-shadow: 0px 6px 9px 0px #1D1D1D1A;\n\n & .info__text-wrapper {\n display: flex;\n flex-direction: column;\n gap: tokens.$ifxSpace100;\n width: 100%;\n\n & .info__headline-wrapper {\n display: -webkit-box;\n -webkit-line-clamp: 1;\n line-clamp: 1;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n & .info__headline-wrapper,\n .info__description-wrapper {\n color: #1D1D1D;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n\n ::slotted(p) {\n padding: 0;\n margin: 0;\n }\n }\n\n & .info__description-wrapper {\n font-weight: 400;\n }\n }\n\n & .close-icon-wrapper {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: flex-start;\n //min-width: tokens.$ifxSize500;\n\n & button {\n all: unset;\n display: flex;\n align-items: center;\n justify-content: center;\n line-height: 0;\n color: tokens.$ifxColorBaseBlack;\n height: tokens.$ifxSize300;\n width: tokens.$ifxSize300;\n\n\n &:focus {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n }\n }\n }\n}\n\n.alert {\n display: flex;\n border: 1px solid tokens.$ifxColorOcean500;\n border-radius: tokens.$ifxBorderRadius12;\n color: tokens.$ifxColorBaseBlack;\n background-color: tokens.$ifxColorBaseWhite;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n box-shadow: 0px 6px 9px 0px #1D1D1D1A;\n\n\n & .close-icon-wrapper {\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: tokens.$ifxSize500;\n\n & button {\n all: unset;\n display: flex;\n align-items: center;\n justify-content: center;\n line-height: 0;\n color: tokens.$ifxColorBaseBlack;\n height: tokens.$ifxSize300;\n width: tokens.$ifxSize300;\n\n &:focus {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n }\n }\n }\n\n & .icon-wrapper {\n position: relative;\n min-width: tokens.$ifxSize600;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: tokens.$ifxColorOcean500;\n }\n\n & .alert-text {\n font-size: 16px;\n width: 100%;\n padding: 12px 0px 12px 12px;\n color: tokens.$ifxColorBaseBlack;\n\n white-space: pre-wrap;\n /* wraps text at spaces and within words */\n word-wrap: break-word;\n /* breaks text within a word if necessary */\n overflow-wrap: anywhere;\n /* breaks text at arbitrary points when needed */\n }\n\n &.primary {\n border: 1px solid tokens.$ifxColorOcean500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorOcean500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.success {\n border: 1px solid tokens.$ifxColorGreen500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorGreen500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.danger {\n border: 1px solid tokens.$ifxColorRed500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorRed500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.warning {\n border: 1px solid tokens.$ifxColorOrange500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorOrange500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n}\n\n.close-icon-wrapper {\n & ifx-icon {\n &:hover {\n cursor: pointer;\n }\n }\n}","import { Component, Prop, h, Event, EventEmitter, State, Element } from '@stencil/core';\nimport { trackComponent } from '../../global/utils/tracking';\nimport { isNestedInIfxComponent } from '../../global/utils/dom-utils';\nimport { detectFramework } from '../../global/utils/framework-detection';\n\n@Component({\n tag: 'ifx-alert',\n styleUrl: 'alert.scss',\n shadow: true,\n})\nexport class Alert {\n @Element() el: HTMLElement;\n @Prop() variant: 'primary' | 'success' | 'danger' | 'warning' | 'info' = 'primary';\n @Prop() icon: string;\n @Event() ifxClose: EventEmitter;\n @Prop() closable: boolean = true;\n @Prop() AriaLive = 'assertive';\n @State() uniqueId: string;\n\n alertTypeDescription = {\n \"primary\": 'Neutral alert',\n \"success\": 'Success Alert',\n \"danger\": 'Error Alert',\n \"warning\": 'Warning Alert',\n \"info\": 'Neutral alert',\n };\n\n handleClose() {\n this.ifxClose.emit();\n }\n\n renderCloseButton() {\n return (\n <div class=\"close-icon-wrapper\">\n <button onClick={this.handleClose.bind(this)} aria-label=\"Dismiss alert\">\n <ifx-icon icon=\"cross-16\" />\n </button>\n </div>\n );\n }\n\n generateUniqueId(prefix = 'id') {\n return `${prefix}-${Math.random().toString(36).substring(2, 9)}`;\n }\n\n componentWillLoad() { \n if (!this.uniqueId) {\n this.uniqueId = this.generateUniqueId('alert');\n }\n }\n\n async componentDidLoad() { \n if(!isNestedInIfxComponent(this.el)) {\n const framework = await detectFramework();\n trackComponent('ifx-alert', framework);\n }\n }\n\n render() {\n return this.variant === 'info' ? (\n <div class=\"alert__info-wrapper\" role=\"alert\" aria-live={this.AriaLive} aria-describedby={this.alertTypeDescription[this.variant]} aria-labelledby=\"alert-text alert-description\">\n <div class=\"info__text-wrapper\">\n <div class=\"info__headline-wrapper\">\n <slot name=\"headline\" />\n </div>\n <div id={`alert-description-${this.uniqueId}`} class=\"info__description-wrapper\">\n <slot name=\"desc\" />\n </div>\n </div>\n {this.closable ? this.renderCloseButton() : null}\n </div>\n ) : (\n <div class={`alert ${this.variant}`} role=\"alert\">\n {this.icon && (\n <div class=\"icon-wrapper\">\n <ifx-icon icon={this.icon} />\n </div>\n )}\n <div class=\"alert-text\" id={`alert-text-${this.uniqueId}`}>\n <slot />\n </div>\n {this.closable ? this.renderCloseButton() : null}\n </div>\n );\n }\n}\n","\n.react__template-wrapper { \n display: flex;\n width: 300px;\n height: 200px;\n border-radius: 3px;\n border: 1px solid #ccc;\n\n &.hide { \n display: none;\n }\n \n &:hover { \n cursor: pointer;\n }\n}\n\n.template__page-wrapper {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n text-align: center;\n\n & .repository__url { \n text-decoration: none;\n }\n}\n\n.input__fields-wrapper { \n display: flex;\n flex-direction: column;\n gap: 10px;\n\n}\n\n.details__wrapper { \n display: flex;\n flex-direction: column;\n gap: 10px;\n}\n\n.selection__buttons-wrapper { \n display: flex;\n gap: 10px;\n padding-top: 10px;\n align-items: center;\n & .vue__label { \n color: #ccc;\n }\n\n & label:not(.vue__label) { \n &:hover { \n cursor: pointer;\n }\n }\n\n & .selection__input { \n display: flex;\n align-items: center;\n gap: 5px;\n & input { \n margin: 0;\n height: 20px;\n width: 20px;\n &:hover:not(.vue__input) { \n cursor: pointer;\n }\n }\n }\n}\n\n.image__wrapper { \n img { \n position: relative;\n width: 300px;\n height: 100%;\n border-radius: 3px;\n object-fit: contain;\n transition: transform .2s;\n &:hover { \n transform: scale(2);\n top: 50px;\n z-index: 100;\n }\n }\n}","import { Component, h, Element, State, Prop, Event, EventEmitter, Method } from '@stencil/core';\n\n@Component({\n tag: 'ifx-template',\n styleUrl: 'template.scss',\n shadow: true,\n})\nexport class Template {\n @Element() el: HTMLElement;\n @State() repoDetails: { name: string, desc: string, framework: string } = { name: \"\", desc: \"\", framework: \"\" };\n @State() repoUrl: string;\n @State() showDetails: boolean = false;\n @State() isTemplatePage: boolean = false;\n @State() isLoading: boolean = true;\n @State() repoError: string;\n @Prop() name: string;\n @Event() toggleTemplates: EventEmitter;\n @Event() fieldError: EventEmitter;\n @Prop() thumbnail: string;\n \n private clientId = 'Ov23lixmXiNTTNb6V5W6'\n private redirectUri = 'https://infineon.github.io/infineon-design-system-stencil/?path=/docs/dds-templates--development';\n private scope = 'repo workflow'\n private state = 'template123'\n\n authUser() { \n const authorizationUrl = `https://github.com/login/oauth/authorize?` +\n `client_id=${this.clientId}&` +\n `redirect_uri=${this.redirectUri}&` +\n `scope=${this.scope}&` +\n `state=${this.state}`;\n \n window.open(authorizationUrl, '_blank'); \n }\n\n componentDidLoad() { \n const url = new URL(window.location.href);\n const code = url.searchParams.get('code');\n const { templateName } = this.getLocalStorageValues()\n if(code && this.name === templateName) { \n this.isTemplatePage = true;\n this.toggleTemplates.emit('details')\n this.getUserToken(code)\n } \n }\n\n getLocalStorageValues() { \n const repoName = localStorage.getItem('repo_name');\n const repoDesc = localStorage.getItem('repo_desc');\n const repoFramework = localStorage.getItem('repo_framework');\n const templateName = localStorage.getItem('selectedTemplate');\n return { repoName, repoDesc, repoFramework, templateName }\n }\n\n async getUserToken(authCode) {\n const { repoName, repoDesc, repoFramework, templateName } = this.getLocalStorageValues();\n\n fetch(`https://ddstemplate-srv.cfapps.eu10-004.hana.ondemand.com/token/${authCode}/${repoName}/${repoDesc}/${repoFramework}/${templateName}`)\n .then(response => {\n if (response.ok) {\n return response.text();\n } else {\n return response.text().then(errorMessage => {\n throw new Error(errorMessage);\n });\n }\n })\n .then(data => { \n if(data) { \n this.isLoading = false;\n this.repoUrl = data;\n localStorage.clear();\n } \n })\n .catch(error => {\n this.repoError = error.message;\n console.error('Error:', error.message)\n });\n }\n\n handleUserInput(e, type) { \n if (type === 'name') {\n this.repoDetails = { ...this.repoDetails, name: e.target.value };\n } else if (type === 'desc') {\n this.repoDetails = { ...this.repoDetails, desc: e.target.value };\n } else if(type === 'framework') { \n this.repoDetails = { ...this.repoDetails, framework: e.target.value };\n }\n }\n\n submitUserData() { \n if(this.repoDetails.name && this.repoDetails.desc && this.repoDetails.framework) { \n localStorage.setItem('repo_name', this.repoDetails.name);\n localStorage.setItem('repo_desc', this.repoDetails.desc);\n localStorage.setItem('repo_framework', this.repoDetails.framework);\n localStorage.setItem('selectedTemplate', this.name);\n this.fieldError.emit(false)\n this.authUser()\n } else { \n this.fieldError.emit('All fields are mandatory')\n }\n }\n\n togglePadding(action) { \n let parent = this.el.parentElement;\n if (parent) {\n const rootNode = parent.getRootNode();\n if (rootNode instanceof ShadowRoot) {\n parent = rootNode.host.parentElement;\n } else {\n parent = parent.parentElement;\n }\n if(action === 'remove') { \n parent.parentElement.style.padding = '0px';\n } else if(action === 'add') { \n parent.parentElement.style.padding = '4rem 20px';\n }\n }\n }\n\n handleCurrentTemplate(e) { \n if(e && !this.showDetails) { \n this.togglePadding('remove')\n const targetTemplate = e.currentTarget;\n this.toggleTemplates.emit(targetTemplate)\n this.showDetails = true;\n } \n }\n\n @Method()\n async toggleTemplate(currTemp) { \n const templateWrapper = this.el.shadowRoot.querySelector('.react__template-wrapper');\n if(templateWrapper) { \n if(!templateWrapper.classList.contains('hide') && currTemp ) { \n if(templateWrapper !== currTemp) {\n templateWrapper.classList.add('hide')\n }\n } else { \n if(this.showDetails) { \n this.showDetails = false;\n }\n this.togglePadding('add')\n templateWrapper.classList.remove('hide')\n }\n }\n }\n\n \n render() {\n return (\n <div>\n {this.isTemplatePage \n ? \n <div class=\"template__page-wrapper\">\n {!this.repoUrl && !this.repoError && \n <div>\n <h3>Your repository is getting ready..</h3>\n <p>This will only take a minute.</p>\n </div>}\n {this.isLoading && !this.repoError && <div><ifx-spinner variant='default' size='s' /></div>}\n {this.repoUrl && <ifx-link href={this.repoUrl} target=\"_parent\" size=\"m\" variant=\"underlined\">Your repository</ifx-link>}\n {this.repoError && <div>{this.repoError}</div>}\n </div> \n : \n <div class=\"react__template-container\">\n <div class=\"react__template-wrapper\" onClick={(e) => this.handleCurrentTemplate(e)}>\n <div class=\"image__wrapper\">\n <img src={this.thumbnail} />\n </div>\n </div>\n {this.showDetails && \n <div class=\"details__wrapper\">\n <div class=\"selection__buttons-wrapper\">\n <div class=\"selection__input\">\n <input type=\"radio\" id=\"react\" name=\"chosen_framework\" value=\"react\" onInput={(e) => this.handleUserInput(e, 'framework')} />\n <label htmlFor=\"react\">React</label>\n </div>\n <div class=\"selection__input vue\">\n <input class=\"vue__input\" disabled type=\"radio\" id=\"vue\" name=\"chosen_framework\" value=\"vue\" onInput={(e) => this.handleUserInput(e, 'framework')}/>\n <label class=\"vue__label\" htmlFor=\"vue\">Vue</label> (Soon)\n </div>\n </div>\n \n\n <div class=\"input__fields-wrapper\">\n <ifx-text-field required={true} onInput={(e) => this.handleUserInput(e, 'name')} size=\"m\" icon=\"c-info-16\" placeholder=\"Your repository name\">Repository Name</ifx-text-field>\n\n <ifx-text-field required={true} size=\"m\" icon=\"c-info-16\" onInput={(e) => this.handleUserInput(e, 'desc')} placeholder=\"Your repository description\">Repository Description</ifx-text-field>\n\n <ifx-button fullWidth={true} onClick={() => this.submitUserData()} variant='primary'>Generate template</ifx-button>\n </div>\n \n </div>}\n </div>}\n </div>\n );\n }\n}"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["alertCss","Alert","constructor","hostRef","this","variant","closable","AriaLive","alertTypeDescription","primary","success","danger","warning","info","handleClose","ifxClose","emit","renderCloseButton","h","class","onClick","bind","icon","generateUniqueId","prefix","Math","random","toString","substring","componentWillLoad","uniqueId","componentDidLoad","isNestedInIfxComponent","el","framework","detectFramework","trackComponent","render","role","name","id","templateCss","Template","repoDetails","desc","showDetails","isTemplatePage","isLoading","clientId","redirectUri","scope","state","authUser","authorizationUrl","window","open","url","URL","location","href","code","searchParams","get","templateName","getLocalStorageValues","toggleTemplates","getUserToken","repoName","localStorage","getItem","repoDesc","repoFramework","authCode","fetch","then","response","ok","text","errorMessage","Error","data","repoUrl","clear","catch","error","repoError","message","console","handleUserInput","e","type","Object","assign","target","value","submitUserData","setItem","fieldError","togglePadding","action","parent","parentElement","rootNode","getRootNode","ShadowRoot","host","style","padding","handleCurrentTemplate","targetTemplate","currentTarget","toggleTemplate","currTemp","templateWrapper","shadowRoot","querySelector","classList","contains","add","remove","key","size","src","thumbnail","onInput","htmlFor","disabled","required","placeholder","fullWidth"],"sources":["src/components/alert/alert.scss?tag=ifx-alert&encapsulation=shadow","src/components/alert/alert.tsx","src/components/templates/template/template.scss?tag=ifx-template&encapsulation=shadow","src/components/templates/template/template.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n:host {\n display: block;\n}\n\n.alert__info-wrapper {\n display: flex;\n padding: 16px 24px;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n box-shadow: 0px 6px 9px 0px #1D1D1D1A;\n\n & .info__text-wrapper {\n display: flex;\n flex-direction: column;\n gap: tokens.$ifxSpace100;\n width: 100%;\n\n & .info__headline-wrapper {\n display: -webkit-box;\n -webkit-line-clamp: 1;\n line-clamp: 1;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n & .info__headline-wrapper,\n .info__description-wrapper {\n color: #1D1D1D;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n\n ::slotted(p) {\n padding: 0;\n margin: 0;\n }\n }\n\n & .info__description-wrapper {\n font-weight: 400;\n }\n }\n\n & .close-icon-wrapper {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: flex-start;\n //min-width: tokens.$ifxSize500;\n\n & button {\n all: unset;\n display: flex;\n align-items: center;\n justify-content: center;\n line-height: 0;\n color: tokens.$ifxColorBaseBlack;\n height: tokens.$ifxSize300;\n width: tokens.$ifxSize300;\n\n\n &:focus {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n }\n }\n }\n}\n\n.alert {\n display: flex;\n border: 1px solid tokens.$ifxColorOcean500;\n border-radius: tokens.$ifxBorderRadius12;\n color: tokens.$ifxColorBaseBlack;\n background-color: tokens.$ifxColorBaseWhite;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n box-shadow: 0px 6px 9px 0px #1D1D1D1A;\n\n\n & .close-icon-wrapper {\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: tokens.$ifxSize500;\n\n & button {\n all: unset;\n display: flex;\n align-items: center;\n justify-content: center;\n line-height: 0;\n color: tokens.$ifxColorBaseBlack;\n height: tokens.$ifxSize300;\n width: tokens.$ifxSize300;\n\n &:focus {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n }\n }\n }\n\n & .icon-wrapper {\n position: relative;\n min-width: tokens.$ifxSize600;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: tokens.$ifxColorOcean500;\n }\n\n & .alert-text {\n font-size: 16px;\n width: 100%;\n padding: 12px 0px 12px 12px;\n color: tokens.$ifxColorBaseBlack;\n\n white-space: pre-wrap;\n /* wraps text at spaces and within words */\n word-wrap: break-word;\n /* breaks text within a word if necessary */\n overflow-wrap: anywhere;\n /* breaks text at arbitrary points when needed */\n }\n\n &.primary {\n border: 1px solid tokens.$ifxColorOcean500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorOcean500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.success {\n border: 1px solid tokens.$ifxColorGreen500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorGreen500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.danger {\n border: 1px solid tokens.$ifxColorRed500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorRed500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.warning {\n border: 1px solid tokens.$ifxColorOrange500;\n\n & .icon-wrapper {\n background-color: tokens.$ifxColorOrange500;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n}\n\n.close-icon-wrapper {\n & ifx-icon {\n &:hover {\n cursor: pointer;\n }\n }\n}","import { Component, Prop, h, Event, EventEmitter, State, Element } from '@stencil/core';\nimport { trackComponent } from '../../global/utils/tracking';\nimport { isNestedInIfxComponent } from '../../global/utils/dom-utils';\nimport { detectFramework } from '../../global/utils/framework-detection';\n\n@Component({\n tag: 'ifx-alert',\n styleUrl: 'alert.scss',\n shadow: true,\n})\nexport class Alert {\n @Element() el: HTMLElement;\n @Prop() variant: 'primary' | 'success' | 'danger' | 'warning' | 'info' = 'primary';\n @Prop() icon: string;\n @Event() ifxClose: EventEmitter;\n @Prop() closable: boolean = true;\n @Prop() AriaLive = 'assertive';\n @State() uniqueId: string;\n\n alertTypeDescription = {\n \"primary\": 'Neutral alert',\n \"success\": 'Success Alert',\n \"danger\": 'Error Alert',\n \"warning\": 'Warning Alert',\n \"info\": 'Neutral alert',\n };\n\n handleClose() {\n this.ifxClose.emit();\n }\n\n renderCloseButton() {\n return (\n <div class=\"close-icon-wrapper\">\n <button onClick={this.handleClose.bind(this)} aria-label=\"Dismiss alert\">\n <ifx-icon icon=\"cross-16\" />\n </button>\n </div>\n );\n }\n\n generateUniqueId(prefix = 'id') {\n return `${prefix}-${Math.random().toString(36).substring(2, 9)}`;\n }\n\n componentWillLoad() { \n if (!this.uniqueId) {\n this.uniqueId = this.generateUniqueId('alert');\n }\n }\n\n async componentDidLoad() { \n if(!isNestedInIfxComponent(this.el)) {\n const framework = await detectFramework();\n trackComponent('ifx-alert', framework);\n }\n }\n\n render() {\n return this.variant === 'info' ? (\n <div class=\"alert__info-wrapper\" role=\"alert\" aria-live={this.AriaLive} aria-describedby={this.alertTypeDescription[this.variant]} aria-labelledby=\"alert-text alert-description\">\n <div class=\"info__text-wrapper\">\n <div class=\"info__headline-wrapper\">\n <slot name=\"headline\" />\n </div>\n <div id={`alert-description-${this.uniqueId}`} class=\"info__description-wrapper\">\n <slot name=\"desc\" />\n </div>\n </div>\n {this.closable ? this.renderCloseButton() : null}\n </div>\n ) : (\n <div class={`alert ${this.variant}`} role=\"alert\">\n {this.icon && (\n <div class=\"icon-wrapper\">\n <ifx-icon icon={this.icon} />\n </div>\n )}\n <div class=\"alert-text\" id={`alert-text-${this.uniqueId}`}>\n <slot />\n </div>\n {this.closable ? this.renderCloseButton() : null}\n </div>\n );\n }\n}\n","\n.react__template-wrapper { \n display: flex;\n width: 300px;\n height: 200px;\n border-radius: 3px;\n border: 1px solid #ccc;\n\n &.hide { \n display: none;\n }\n \n &:hover { \n cursor: pointer;\n }\n}\n\n.template__page-wrapper {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n text-align: center;\n\n & .repository__url { \n text-decoration: none;\n }\n}\n\n.input__fields-wrapper { \n display: flex;\n flex-direction: column;\n gap: 10px;\n\n}\n\n.details__wrapper { \n display: flex;\n flex-direction: column;\n gap: 10px;\n}\n\n.selection__buttons-wrapper { \n display: flex;\n gap: 10px;\n padding-top: 10px;\n align-items: center;\n & .vue__label { \n color: #ccc;\n }\n\n & label:not(.vue__label) { \n &:hover { \n cursor: pointer;\n }\n }\n\n & .selection__input { \n display: flex;\n align-items: center;\n gap: 5px;\n & input { \n margin: 0;\n height: 20px;\n width: 20px;\n &:hover:not(.vue__input) { \n cursor: pointer;\n }\n }\n }\n}\n\n.image__wrapper { \n img { \n position: relative;\n width: 300px;\n height: 100%;\n border-radius: 3px;\n object-fit: contain;\n transition: transform .2s;\n &:hover { \n transform: scale(2);\n top: 50px;\n z-index: 100;\n }\n }\n}","import { Component, h, Element, State, Prop, Event, EventEmitter, Method } from '@stencil/core';\n\n@Component({\n tag: 'ifx-template',\n styleUrl: 'template.scss',\n shadow: true,\n})\nexport class Template {\n @Element() el: HTMLElement;\n @State() repoDetails: { name: string, desc: string, framework: string } = { name: \"\", desc: \"\", framework: \"\" };\n @State() repoUrl: string;\n @State() showDetails: boolean = false;\n @State() isTemplatePage: boolean = false;\n @State() isLoading: boolean = true;\n @State() repoError: string;\n @Prop() name: string;\n @Event() toggleTemplates: EventEmitter;\n @Event() fieldError: EventEmitter;\n @Prop() thumbnail: string;\n \n private clientId = 'Ov23lixmXiNTTNb6V5W6'\n private redirectUri = 'https://infineon.github.io/infineon-design-system-stencil/?path=/docs/dds-templates--development';\n private scope = 'repo workflow'\n private state = 'template123'\n\n authUser() { \n const authorizationUrl = `https://github.com/login/oauth/authorize?` +\n `client_id=${this.clientId}&` +\n `redirect_uri=${this.redirectUri}&` +\n `scope=${this.scope}&` +\n `state=${this.state}`;\n \n window.open(authorizationUrl, '_blank'); \n }\n\n componentDidLoad() { \n const url = new URL(window.location.href);\n const code = url.searchParams.get('code');\n const { templateName } = this.getLocalStorageValues()\n if(code && this.name === templateName) { \n this.isTemplatePage = true;\n this.toggleTemplates.emit('details')\n this.getUserToken(code)\n } \n }\n\n getLocalStorageValues() { \n const repoName = localStorage.getItem('repo_name');\n const repoDesc = localStorage.getItem('repo_desc');\n const repoFramework = localStorage.getItem('repo_framework');\n const templateName = localStorage.getItem('selectedTemplate');\n return { repoName, repoDesc, repoFramework, templateName }\n }\n\n async getUserToken(authCode) {\n const { repoName, repoDesc, repoFramework, templateName } = this.getLocalStorageValues();\n\n fetch(`https://ddstemplate-srv.cfapps.eu10-004.hana.ondemand.com/token/${authCode}/${repoName}/${repoDesc}/${repoFramework}/${templateName}`)\n .then(response => {\n if (response.ok) {\n return response.text();\n } else {\n return response.text().then(errorMessage => {\n throw new Error(errorMessage);\n });\n }\n })\n .then(data => { \n if(data) { \n this.isLoading = false;\n this.repoUrl = data;\n localStorage.clear();\n } \n })\n .catch(error => {\n this.repoError = error.message;\n console.error('Error:', error.message)\n });\n }\n\n handleUserInput(e, type) { \n if (type === 'name') {\n this.repoDetails = { ...this.repoDetails, name: e.target.value };\n } else if (type === 'desc') {\n this.repoDetails = { ...this.repoDetails, desc: e.target.value };\n } else if(type === 'framework') { \n this.repoDetails = { ...this.repoDetails, framework: e.target.value };\n }\n }\n\n submitUserData() { \n if(this.repoDetails.name && this.repoDetails.desc && this.repoDetails.framework) { \n localStorage.setItem('repo_name', this.repoDetails.name);\n localStorage.setItem('repo_desc', this.repoDetails.desc);\n localStorage.setItem('repo_framework', this.repoDetails.framework);\n localStorage.setItem('selectedTemplate', this.name);\n this.fieldError.emit(false)\n this.authUser()\n } else { \n this.fieldError.emit('All fields are mandatory')\n }\n }\n\n togglePadding(action) { \n let parent = this.el.parentElement;\n if (parent) {\n const rootNode = parent.getRootNode();\n if (rootNode instanceof ShadowRoot) {\n parent = rootNode.host.parentElement;\n } else {\n parent = parent.parentElement;\n }\n if(action === 'remove') { \n parent.parentElement.style.padding = '0px';\n } else if(action === 'add') { \n parent.parentElement.style.padding = '4rem 20px';\n }\n }\n }\n\n handleCurrentTemplate(e) { \n if(e && !this.showDetails) { \n this.togglePadding('remove')\n const targetTemplate = e.currentTarget;\n this.toggleTemplates.emit(targetTemplate)\n this.showDetails = true;\n } \n }\n\n @Method()\n async toggleTemplate(currTemp) { \n const templateWrapper = this.el.shadowRoot.querySelector('.react__template-wrapper');\n if(templateWrapper) { \n if(!templateWrapper.classList.contains('hide') && currTemp ) { \n if(templateWrapper !== currTemp) {\n templateWrapper.classList.add('hide')\n }\n } else { \n if(this.showDetails) { \n this.showDetails = false;\n }\n this.togglePadding('add')\n templateWrapper.classList.remove('hide')\n }\n }\n }\n\n \n render() {\n return (\n <div>\n {this.isTemplatePage \n ? \n <div class=\"template__page-wrapper\">\n {!this.repoUrl && !this.repoError && \n <div>\n <h3>Your repository is getting ready..</h3>\n <p>This will only take a minute.</p>\n </div>}\n {this.isLoading && !this.repoError && <div><ifx-spinner variant='default' size='s' /></div>}\n {this.repoUrl && <ifx-link href={this.repoUrl} target=\"_parent\" size=\"m\" variant=\"underlined\">Your repository</ifx-link>}\n {this.repoError && <div>{this.repoError}</div>}\n </div> \n : \n <div class=\"react__template-container\">\n <div class=\"react__template-wrapper\" onClick={(e) => this.handleCurrentTemplate(e)}>\n <div class=\"image__wrapper\">\n <img src={this.thumbnail} />\n </div>\n </div>\n {this.showDetails && \n <div class=\"details__wrapper\">\n <div class=\"selection__buttons-wrapper\">\n <div class=\"selection__input\">\n <input type=\"radio\" id=\"react\" name=\"chosen_framework\" value=\"react\" onInput={(e) => this.handleUserInput(e, 'framework')} />\n <label htmlFor=\"react\">React</label>\n </div>\n <div class=\"selection__input vue\">\n <input class=\"vue__input\" disabled type=\"radio\" id=\"vue\" name=\"chosen_framework\" value=\"vue\" onInput={(e) => this.handleUserInput(e, 'framework')}/>\n <label class=\"vue__label\" htmlFor=\"vue\">Vue</label> (Soon)\n </div>\n </div>\n \n\n <div class=\"input__fields-wrapper\">\n <ifx-text-field required={true} onInput={(e) => this.handleUserInput(e, 'name')} size=\"m\" icon=\"c-info-16\" placeholder=\"Your repository name\">Repository Name</ifx-text-field>\n\n <ifx-text-field required={true} size=\"m\" icon=\"c-info-16\" onInput={(e) => this.handleUserInput(e, 'desc')} placeholder=\"Your repository description\">Repository Description</ifx-text-field>\n\n <ifx-button fullWidth={true} onClick={() => this.submitUserData()} variant='primary'>Generate template</ifx-button>\n </div>\n \n </div>}\n </div>}\n </div>\n );\n }\n}"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,h as t,a as i}from"./p-PqnYwNKt.js";import{d as o,t as r}from"./p-DcmcuUOA.js";import{i as s}from"./p-Bw2fh5LT.js";const c=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}.checkbox-group-container{display:flex;flex-direction:column}.checkbox-group{display:flex;gap:8px}.checkbox-group.horizontal{flex-direction:row;column-gap:12px}.checkbox-group.vertical{flex-direction:column;row-gap:12px}.group-label{font-size:1rem;color:#1D1D1D;line-height:1.5rem;font-weight:400;margin-bottom:8px;text-align:left;text-underline-position:from-font;text-decoration-skip-ink:none}.group-label .required{color:#575352;margin-left:4px}.group-label .required.error{color:#CD002F}.caption{margin-top:8px;align-self:flex-start;display:flex;width:100%;column-gap:8px;justify-content:space-between;align-items:center}.caption.default{color:#1D1D1D}.caption.error{color:#CD002F}.caption-text{font-weight:400;font-size:0.75rem;line-height:1rem;flex:1;text-align:left;text-underline-position:from-font;text-decoration-skip-ink:none}.caption-icon{flex:0;display:flex}';const n=class{constructor(t){e(this,t);this.errorStates=new Map;this.alignment="vertical";this.groupLabelText="Group Label Text";this.required=false;this.hasErrors=false;this.handleSlotChange=()=>{this.initializeState()}}handleCheckboxError(e){const t=e.target;if(t.tagName.toLowerCase()==="ifx-checkbox"){this.errorStates.set(t,e.detail);this.updateHasErrors()}}async setGroupError(e){const t=Array.from(this.el.querySelectorAll("ifx-checkbox"));t.forEach((t=>{t.error=e}))}componentWillLoad(){this.initializeState()}async componentDidLoad(){if(!s(this.el)){const e=o();r("ifx-checkbox-group",await e)}}initializeState(){this.errorStates.clear();const e=Array.from(this.el.querySelectorAll("ifx-checkbox"));e.forEach((e=>{if(!this.errorStates.has(e)){this.errorStates.set(e,e.error||false)}}));this.updateHasErrors()}updateHasErrors(){this.hasErrors=Array.from(this.errorStates.values()).some((e=>e))}render(){return t("div",{key:"c9424a54db6fcce412275bea3e584b6985cf6479",class:"checkbox-group-container"},this.showGroupLabel&&t("div",{key:"9ebd83b86b4be4de0107edeae3101cd64915e6b1",class:"group-label"},this.groupLabelText,this.required&&t("span",{key:"d83004ec7fc85d23453db833e4b87748be2d088f",class:`required ${this.hasErrors?"error":""}`},"*")),t("div",{key:"647c87572ee92805df964c05b59f59886592c273",class:`checkbox-group ${this.alignment} ${this.size}`},t("slot",{key:"2ed8287636dda53576fd27440ae9d99b569951d8",onSlotchange:this.handleSlotChange})),this.showCaption?t("div",{class:`caption ${this.hasErrors?"error":"default"}`},this.showCaptionIcon?t("div",{class:"caption-icon"},t("ifx-icon",{icon:"c-info-16"})):"",t("div",{class:"caption-text"},this.captionText)):"")}get el(){return i(this)}};n.style=c;export{n as ifx_checkbox_group};
2
+ //# sourceMappingURL=p-0929589d.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["checkboxGroupCss","CheckboxGroup","constructor","hostRef","this","errorStates","Map","alignment","groupLabelText","required","hasErrors","handleSlotChange","initializeState","handleCheckboxError","event","checkbox","target","tagName","toLowerCase","set","detail","updateHasErrors","setGroupError","error","checkboxes","Array","from","el","querySelectorAll","forEach","componentWillLoad","componentDidLoad","isNestedInIfxComponent","framework","detectFramework","trackComponent","clear","has","values","some","render","h","key","class","showGroupLabel","size","onSlotchange","showCaption","showCaptionIcon","icon","captionText"],"sources":["src/components/checkbox-group/checkbox-group.scss?tag=ifx-checkbox-group&encapsulation=shadow","src/components/checkbox-group/checkbox-group.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n.checkbox-group-container {\n display: flex;\n flex-direction: column;\n}\n\n.checkbox-group {\n display: flex;\n gap: tokens.$ifxSpace100;\n\n &.horizontal {\n flex-direction: row;\n column-gap: tokens.$ifxSpace150;\n }\n\n &.vertical {\n flex-direction: column;\n row-gap: tokens.$ifxSpace150;\n }\n}\n\n.group-label {\n font-size: tokens.$ifxFontSizeM;\n color: tokens.$ifxColorBaseBlack;\n line-height: tokens.$ifxLineHeightM;\n font-weight: tokens.$ifxFontWeightRegular;\n margin-bottom: tokens.$ifxSpace100;\n text-align: left;\n text-underline-position: from-font;\n text-decoration-skip-ink: none;\n}\n\n.group-label .required {\n color: tokens.$ifxColorEngineering500;\n margin-left: tokens.$ifxSpace50;\n}\n\n.group-label .required.error {\n color: tokens.$ifxColorRed500;\n}\n\n.caption {\n margin-top: tokens.$ifxSpace100;\n align-self: flex-start;\n display: flex;\n width: 100%;\n column-gap: tokens.$ifxSpace100;\n justify-content: space-between;\n align-items: center;\n\n &.default {\n color: tokens.$ifxColorBaseBlack;\n }\n\n &.error {\n color: tokens.$ifxColorRed500;\n }\n}\n\n.caption-text {\n font-weight: tokens.$ifxFontWeightRegular;\n font-size: tokens.$ifxFontSizeXs;\n line-height: tokens.$ifxLineHeightXs;\n flex: 1;\n text-align: left;\n text-underline-position: from-font;\n text-decoration-skip-ink: none;\n}\n\n.caption-icon {\n flex:0;\n display: flex;\n}","import { Component, State, Prop, h, Element, Listen, Method } from '@stencil/core';\nimport { trackComponent } from '../../global/utils/tracking';\nimport { isNestedInIfxComponent } from '../../global/utils/dom-utils';\nimport { detectFramework } from '../../global/utils/framework-detection';\n\n@Component({\n tag: 'ifx-checkbox-group',\n styleUrl: 'checkbox-group.scss',\n shadow: true,\n // formAssociated: true\n})\n\nexport class CheckboxGroup {\n private errorStates: Map<HTMLElement, boolean> = new Map();\n\n @Element() el: HTMLElement;\n @Prop() alignment: 'horizontal' | 'vertical' = 'vertical';\n @Prop() size: string;\n @Prop() showGroupLabel: boolean;\n @Prop() groupLabelText: string = 'Group Label Text';\n @Prop() showCaption: boolean;\n @Prop() captionText: string;\n @Prop() showCaptionIcon: boolean;\n @Prop() required: boolean = false;\n @State() hasErrors: boolean = false;\n\n @Listen('ifxError')\n handleCheckboxError(event: CustomEvent) {\n const checkbox = event.target as HTMLElement;\n if (checkbox.tagName.toLowerCase() === 'ifx-checkbox') {\n this.errorStates.set(checkbox, event.detail);\n this.updateHasErrors();\n }\n }\n\n // Method to set the error state of all checkboxes in the group\n @Method()\n async setGroupError(error: boolean) {\n const checkboxes = Array.from(this.el.querySelectorAll('ifx-checkbox'));\n checkboxes.forEach((checkbox) => {\n (checkbox as any).error = error;\n });\n }\n\n componentWillLoad() {\n this.initializeState();\n\n }\n\n async componentDidLoad() { \n if(!isNestedInIfxComponent(this.el)) { \n const framework = detectFramework();\n trackComponent('ifx-checkbox-group', await framework)\n }\n }\n\n handleSlotChange = () => {\n this.initializeState();\n };\n\n private initializeState() {\n this.errorStates.clear();\n const checkboxes = Array.from(this.el.querySelectorAll('ifx-checkbox'));\n checkboxes.forEach((checkbox) => {\n if (!this.errorStates.has(checkbox)) {\n this.errorStates.set(checkbox, (checkbox as any).error || false);\n }\n });\n this.updateHasErrors();\n }\n\n private updateHasErrors() {\n this.hasErrors = Array.from(this.errorStates.values()).some((error) => error);\n }\n\n render() {\n return (\n <div class='checkbox-group-container'>\n {this.showGroupLabel && (\n <div class=\"group-label\">\n {this.groupLabelText}\n {this.required && <span class={`required ${this.hasErrors ? 'error' : ''}`}>*</span>}\n </div>\n )}\n <div class={`checkbox-group ${this.alignment} ${this.size}`}>\n <slot onSlotchange={this.handleSlotChange}></slot>\n </div>\n {this.showCaption ? (\n <div class={`caption ${this.hasErrors ? 'error' : 'default'}`}>\n {this.showCaptionIcon ? <div class='caption-icon'><ifx-icon icon=\"c-info-16\">\n </ifx-icon></div> : ''}\n <div class='caption-text'>{this.captionText}</div>\n </div>) : ''}\n </div>\n );\n }\n}"],"mappings":"iIAAA,MAAMA,EAAmB,y6B,MCYZC,EAAa,MAP1B,WAAAC,CAAAC,G,UAQUC,KAAAC,YAAyC,IAAIC,IAG7CF,KAASG,UAA8B,WAGvCH,KAAcI,eAAW,mBAIzBJ,KAAQK,SAAY,MACnBL,KAASM,UAAY,MAgC9BN,KAAgBO,iBAAG,KACjBP,KAAKQ,iBAAiB,CAuCzB,CArEC,mBAAAC,CAAoBC,GAClB,MAAMC,EAAWD,EAAME,OACvB,GAAID,EAASE,QAAQC,gBAAkB,eAAgB,CACrDd,KAAKC,YAAYc,IAAIJ,EAAUD,EAAMM,QACrChB,KAAKiB,iB,EAMT,mBAAMC,CAAcC,GAClB,MAAMC,EAAaC,MAAMC,KAAKtB,KAAKuB,GAAGC,iBAAiB,iBACvDJ,EAAWK,SAASd,IACjBA,EAAiBQ,MAAQA,CAAK,G,CAInC,iBAAAO,GACE1B,KAAKQ,iB,CAIP,sBAAMmB,GACJ,IAAIC,EAAuB5B,KAAKuB,IAAK,CACnC,MAAMM,EAAYC,IAClBC,EAAe,2BAA4BF,E,EAQvC,eAAArB,GACNR,KAAKC,YAAY+B,QACjB,MAAMZ,EAAaC,MAAMC,KAAKtB,KAAKuB,GAAGC,iBAAiB,iBACvDJ,EAAWK,SAASd,IAClB,IAAKX,KAAKC,YAAYgC,IAAItB,GAAW,CACnCX,KAAKC,YAAYc,IAAIJ,EAAWA,EAAiBQ,OAAS,M,KAG9DnB,KAAKiB,iB,CAGC,eAAAA,GACNjB,KAAKM,UAAYe,MAAMC,KAAKtB,KAAKC,YAAYiC,UAAUC,MAAMhB,GAAUA,G,CAGzE,MAAAiB,GACE,OACEC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,4BACRvC,KAAKwC,gBACJH,EAAK,OAAAC,IAAA,2CAAAC,MAAM,eACRvC,KAAKI,eACLJ,KAAKK,UAAYgC,EAAA,QAAAC,IAAA,2CAAMC,MAAO,YAAYvC,KAAKM,UAAY,QAAU,MAAc,MAGxF+B,EAAK,OAAAC,IAAA,2CAAAC,MAAO,kBAAkBvC,KAAKG,aAAaH,KAAKyC,QACnDJ,EAAA,QAAAC,IAAA,2CAAMI,aAAc1C,KAAKO,oBAE1BP,KAAK2C,YACJN,EAAA,OAAKE,MAAO,WAAWvC,KAAKM,UAAY,QAAU,aAC/CN,KAAK4C,gBAAkBP,EAAK,OAAAE,MAAM,gBAAeF,EAAU,YAAAQ,KAAK,eAC7C,GACpBR,EAAA,OAAKE,MAAM,gBAAgBvC,KAAK8C,cACxB,G","ignoreList":[]}
1
+ {"version":3,"names":["checkboxGroupCss","CheckboxGroup","constructor","hostRef","this","errorStates","Map","alignment","groupLabelText","required","hasErrors","handleSlotChange","initializeState","handleCheckboxError","event","checkbox","target","tagName","toLowerCase","set","detail","updateHasErrors","setGroupError","error","checkboxes","Array","from","el","querySelectorAll","forEach","componentWillLoad","componentDidLoad","isNestedInIfxComponent","framework","detectFramework","trackComponent","clear","has","values","some","render","h","key","class","showGroupLabel","size","onSlotchange","showCaption","showCaptionIcon","icon","captionText"],"sources":["src/components/checkbox-group/checkbox-group.scss?tag=ifx-checkbox-group&encapsulation=shadow","src/components/checkbox-group/checkbox-group.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n.checkbox-group-container {\n display: flex;\n flex-direction: column;\n}\n\n.checkbox-group {\n display: flex;\n gap: tokens.$ifxSpace100;\n\n &.horizontal {\n flex-direction: row;\n column-gap: tokens.$ifxSpace150;\n }\n\n &.vertical {\n flex-direction: column;\n row-gap: tokens.$ifxSpace150;\n }\n}\n\n.group-label {\n font-size: tokens.$ifxFontSizeM;\n color: tokens.$ifxColorBaseBlack;\n line-height: tokens.$ifxLineHeightM;\n font-weight: tokens.$ifxFontWeightRegular;\n margin-bottom: tokens.$ifxSpace100;\n text-align: left;\n text-underline-position: from-font;\n text-decoration-skip-ink: none;\n}\n\n.group-label .required {\n color: tokens.$ifxColorEngineering500;\n margin-left: tokens.$ifxSpace50;\n}\n\n.group-label .required.error {\n color: tokens.$ifxColorRed500;\n}\n\n.caption {\n margin-top: tokens.$ifxSpace100;\n align-self: flex-start;\n display: flex;\n width: 100%;\n column-gap: tokens.$ifxSpace100;\n justify-content: space-between;\n align-items: center;\n\n &.default {\n color: tokens.$ifxColorBaseBlack;\n }\n\n &.error {\n color: tokens.$ifxColorRed500;\n }\n}\n\n.caption-text {\n font-weight: tokens.$ifxFontWeightRegular;\n font-size: tokens.$ifxFontSizeXs;\n line-height: tokens.$ifxLineHeightXs;\n flex: 1;\n text-align: left;\n text-underline-position: from-font;\n text-decoration-skip-ink: none;\n}\n\n.caption-icon {\n flex:0;\n display: flex;\n}","import { Component, State, Prop, h, Element, Listen, Method } from '@stencil/core';\nimport { trackComponent } from '../../global/utils/tracking';\nimport { isNestedInIfxComponent } from '../../global/utils/dom-utils';\nimport { detectFramework } from '../../global/utils/framework-detection';\n\n@Component({\n tag: 'ifx-checkbox-group',\n styleUrl: 'checkbox-group.scss',\n shadow: true,\n // formAssociated: true\n})\n\nexport class CheckboxGroup {\n private errorStates: Map<HTMLElement, boolean> = new Map();\n\n @Element() el: HTMLElement;\n @Prop() alignment: 'horizontal' | 'vertical' = 'vertical';\n @Prop() size: string;\n @Prop() showGroupLabel: boolean;\n @Prop() groupLabelText: string = 'Group Label Text';\n @Prop() showCaption: boolean;\n @Prop() captionText: string;\n @Prop() showCaptionIcon: boolean;\n @Prop() required: boolean = false;\n @State() hasErrors: boolean = false;\n\n @Listen('ifxError')\n handleCheckboxError(event: CustomEvent) {\n const checkbox = event.target as HTMLElement;\n if (checkbox.tagName.toLowerCase() === 'ifx-checkbox') {\n this.errorStates.set(checkbox, event.detail);\n this.updateHasErrors();\n }\n }\n\n // Method to set the error state of all checkboxes in the group\n @Method()\n async setGroupError(error: boolean) {\n const checkboxes = Array.from(this.el.querySelectorAll('ifx-checkbox'));\n checkboxes.forEach((checkbox) => {\n (checkbox as any).error = error;\n });\n }\n\n componentWillLoad() {\n this.initializeState();\n\n }\n\n async componentDidLoad() { \n if(!isNestedInIfxComponent(this.el)) { \n const framework = detectFramework();\n trackComponent('ifx-checkbox-group', await framework)\n }\n }\n\n handleSlotChange = () => {\n this.initializeState();\n };\n\n private initializeState() {\n this.errorStates.clear();\n const checkboxes = Array.from(this.el.querySelectorAll('ifx-checkbox'));\n checkboxes.forEach((checkbox) => {\n if (!this.errorStates.has(checkbox)) {\n this.errorStates.set(checkbox, (checkbox as any).error || false);\n }\n });\n this.updateHasErrors();\n }\n\n private updateHasErrors() {\n this.hasErrors = Array.from(this.errorStates.values()).some((error) => error);\n }\n\n render() {\n return (\n <div class='checkbox-group-container'>\n {this.showGroupLabel && (\n <div class=\"group-label\">\n {this.groupLabelText}\n {this.required && <span class={`required ${this.hasErrors ? 'error' : ''}`}>*</span>}\n </div>\n )}\n <div class={`checkbox-group ${this.alignment} ${this.size}`}>\n <slot onSlotchange={this.handleSlotChange}></slot>\n </div>\n {this.showCaption ? (\n <div class={`caption ${this.hasErrors ? 'error' : 'default'}`}>\n {this.showCaptionIcon ? <div class='caption-icon'><ifx-icon icon=\"c-info-16\">\n </ifx-icon></div> : ''}\n <div class='caption-text'>{this.captionText}</div>\n </div>) : ''}\n </div>\n );\n }\n}"],"mappings":"iIAAA,MAAMA,EAAmB,u6B,MCYZC,EAAa,MAP1B,WAAAC,CAAAC,G,UAQUC,KAAAC,YAAyC,IAAIC,IAG7CF,KAASG,UAA8B,WAGvCH,KAAcI,eAAW,mBAIzBJ,KAAQK,SAAY,MACnBL,KAASM,UAAY,MAgC9BN,KAAgBO,iBAAG,KACjBP,KAAKQ,iBAAiB,CAuCzB,CArEC,mBAAAC,CAAoBC,GAClB,MAAMC,EAAWD,EAAME,OACvB,GAAID,EAASE,QAAQC,gBAAkB,eAAgB,CACrDd,KAAKC,YAAYc,IAAIJ,EAAUD,EAAMM,QACrChB,KAAKiB,iB,EAMT,mBAAMC,CAAcC,GAClB,MAAMC,EAAaC,MAAMC,KAAKtB,KAAKuB,GAAGC,iBAAiB,iBACvDJ,EAAWK,SAASd,IACjBA,EAAiBQ,MAAQA,CAAK,G,CAInC,iBAAAO,GACE1B,KAAKQ,iB,CAIP,sBAAMmB,GACJ,IAAIC,EAAuB5B,KAAKuB,IAAK,CACnC,MAAMM,EAAYC,IAClBC,EAAe,2BAA4BF,E,EAQvC,eAAArB,GACNR,KAAKC,YAAY+B,QACjB,MAAMZ,EAAaC,MAAMC,KAAKtB,KAAKuB,GAAGC,iBAAiB,iBACvDJ,EAAWK,SAASd,IAClB,IAAKX,KAAKC,YAAYgC,IAAItB,GAAW,CACnCX,KAAKC,YAAYc,IAAIJ,EAAWA,EAAiBQ,OAAS,M,KAG9DnB,KAAKiB,iB,CAGC,eAAAA,GACNjB,KAAKM,UAAYe,MAAMC,KAAKtB,KAAKC,YAAYiC,UAAUC,MAAMhB,GAAUA,G,CAGzE,MAAAiB,GACE,OACEC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,4BACRvC,KAAKwC,gBACJH,EAAK,OAAAC,IAAA,2CAAAC,MAAM,eACRvC,KAAKI,eACLJ,KAAKK,UAAYgC,EAAA,QAAAC,IAAA,2CAAMC,MAAO,YAAYvC,KAAKM,UAAY,QAAU,MAAc,MAGxF+B,EAAK,OAAAC,IAAA,2CAAAC,MAAO,kBAAkBvC,KAAKG,aAAaH,KAAKyC,QACnDJ,EAAA,QAAAC,IAAA,2CAAMI,aAAc1C,KAAKO,oBAE1BP,KAAK2C,YACJN,EAAA,OAAKE,MAAO,WAAWvC,KAAKM,UAAY,QAAU,aAC/CN,KAAK4C,gBAAkBP,EAAK,OAAAE,MAAM,gBAAeF,EAAU,YAAAQ,KAAK,eAC7C,GACpBR,EAAA,OAAKE,MAAM,gBAAgBvC,KAAK8C,cACxB,G","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,c as i,h as t,a as s}from"./p-PqnYwNKt.js";const a=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{position:relative;display:block}:host([data-has-icon=false]){display:var(--ifx-sidebar-item-without-icon-display, block)}.sidebar__nav-item:focus-visible,.sidebar__nav-item.header__section:focus-visible{outline:none;box-shadow:0 0 0 2px #FFFFFF, 0 0 0 4px #0A8276}.sidebar__nav-item:focus-visible .sidebar__nav-item-icon-wrapper,.sidebar__nav-item.header__section:focus-visible .sidebar__nav-item-icon-wrapper{color:#08665C}.sidebar__nav-item:focus-visible .sidebar__nav-item-label,.sidebar__nav-item.header__section:focus-visible .sidebar__nav-item-label{outline:none;color:#08665C}.sidebar__nav-item:focus-visible .sidebar__nav-item-indicator .item__arrow-wrapper ifx-icon,.sidebar__nav-item.header__section:focus-visible .sidebar__nav-item-indicator .item__arrow-wrapper ifx-icon{color:#08665C}.sidebar__nav-item:hover,.sidebar__nav-item.header__section:hover{outline:none}.sidebar__nav-item:hover .sidebar__nav-item-icon-wrapper,.sidebar__nav-item.header__section:hover .sidebar__nav-item-icon-wrapper{color:#08665C}.sidebar__nav-item:hover .sidebar__nav-item-label,.sidebar__nav-item.header__section:hover .sidebar__nav-item-label{outline:none;color:#08665C}.sidebar__nav-item:hover .sidebar__nav-item-indicator .item__arrow-wrapper ifx-icon,.sidebar__nav-item.header__section:hover .sidebar__nav-item-indicator .item__arrow-wrapper ifx-icon{color:#08665C}.sidebar__nav-item{display:flex;flex-direction:var(--ifx-sidebar-item-flex-direction, row);align-items:center;width:100%;padding:8px 0px;gap:4px;flex:none;order:0;flex-grow:0;text-decoration:none;color:#1D1D1D;cursor:pointer;font-family:var(--ifx-font-family)}.sidebar__nav-item.extra-padding__bottom{padding:8px 0px 16px 0px}.sidebar__nav-item.active{color:#0A8276}.sidebar__nav-item.active-section::before{content:"";position:absolute;left:-32px;height:40px;width:2px;background:#0A8276}.sidebar__nav-item.open{padding:8px 0px}.sidebar__nav-item.open .sidebar__nav-item-label{font-size:16px;font-style:normal;font-weight:400;line-height:24px}.sidebar__nav-item.open .sidebar__nav-item-indicator .item__arrow-wrapper ifx-icon{transform:rotate(-180deg)}.sidebar__nav-item.header__section{box-sizing:padding-box;border-top:1px solid #EEEDED;padding:16px 0px;display:-webkit-flex;-webkit-line-clamp:1;-webkit-box-orient:horizontal;overflow:hidden;text-overflow:ellipsis}.sidebar__nav-item.header__section.no-top-border{border-top:none}.sidebar__nav-item.header__section.active-section::before{content:"";position:absolute;left:-32px;height:40px;width:2px;background:#0A8276}.sidebar__nav-item.header__section.open{padding:16px 0px 8px 0px}.sidebar__nav-item.header__section.open .sidebar__nav-item-indicator .item__arrow-wrapper ifx-icon{transform:rotate(-180deg)}.sidebar__nav-item.header__section .sidebar__nav-item-label{color:#1D1D1D;font-family:Source Sans 3;font-size:16px;font-style:normal;font-weight:600;line-height:24px}.sidebar__nav-item.submenu__item{padding:4px 0px}.sidebar__nav-item.submenu__item.extra-padding__bottom{padding:4px 0px 16px 0px}.sidebar__nav-item .sidebar__nav-item-icon-wrapper{display:flex;width:24px;height:24px;justify-content:center;align-items:center;gap:8px;flex-shrink:0}.sidebar__nav-item .sidebar__nav-item-icon-wrapper.noIcon{display:none}.sidebar__nav-item .sidebar__nav-item-icon-wrapper ifx-icon{width:16px;height:16px}.sidebar__nav-item .sidebar__nav-item-label{font-style:normal;font-weight:400;font-size:1rem;line-height:1.5rem;display:flex;align-items:center;flex:none;order:1;flex-grow:1;cursor:pointer;display:var(--ifx-sidebar-item-text-display, flex)}.sidebar__nav-item .sidebar__nav-item-indicator{display:var(--ifx-sidebar-item-text-display, flex);flex-direction:row;justify-content:center;align-items:center;padding:0px 4px;flex:none;order:2;flex-grow:0;position:relative}:host([data-sidebar-collapsed]) .sidebar__nav-item .sidebar__nav-item-indicator{position:absolute;top:0;right:0;z-index:10;padding:0}.expandable__submenu{display:none;list-style-type:none;flex-direction:column;padding:0;margin:0;padding-left:40px}.expandable__submenu.open{display:flex}.header__section+.expandable__submenu{padding-left:0}';const n=class{constructor(t){e(this,t);this.ifxSidebarMenu=i(this,"ifxSidebarMenu",7);this.ifxSidebarNavigationItem=i(this,"ifxSidebarNavigationItem",7);this.ifxSidebarActionItem=i(this,"ifxSidebarActionItem",7);this.icon="";this.showIcon=true;this.showIconWrapper=false;this.href="";this.internalHref="";this.target="_self";this.isExpandable=false;this.isNested=true;this.isSubMenuItem=false;this.active=false;this.isActionItem=false;this.indicatorVariant="number";this.internalActiveState=false;this.titleText=""}handleActiveChange(e,i){if(this.isActionItem){this.internalActiveState=false;return}this.internalActiveState=e;if(e!==i){let i=this.getNavItem(this.el.shadowRoot);if(!this.isExpandable&&!e){this.handleClassList(i,"remove","active")}if(!this.isExpandable&&e){this.handleClassList(i,"add","active")}}}handleNumberIndicatorChange(){this.updateIndicatorVariant()}handleConsoleError(e){if(e.detail){this.showIcon=false}else{this.showIcon=true}}handleEventEmission(){this.ifxSidebarMenu.emit(this.el)}handleClassList(e,i,t){e.classList[i](t);if(i==="contains"){return e.classList.contains(t)}}getExpandableMenu(){const e=this.el.shadowRoot.querySelector(".expandable__submenu");return e}getNavItem(e){return e===null||e===void 0?void 0:e.querySelector(".sidebar__nav-item")}getSidebarMenuItems(e=this.el){const i=e.querySelectorAll("ifx-sidebar-item");if(i.length===0){return e.shadowRoot.querySelectorAll("ifx-sidebar-item")}return i}getSidebarMenuItem(){const e=this.el.shadowRoot.querySelector(".sidebar__nav-item");return e}toggleSubmenu(){if(this.isExpandable){const e=this.getSidebarMenuItem();const i=this.getExpandableMenu();this.handleClassList(i,"toggle","open");this.handleClassList(e,"toggle","open");this.handleEventEmission()}else{if(this.isActionItem){this.ifxSidebarActionItem.emit(this.el);return}else{this.handleActiveChange(true,this.internalActiveState);this.ifxSidebarNavigationItem.emit(this.el)}if(this.handleItemClick){this.handleItemClick(this.el)}}}handleExpandableMenu(e){const i=this.getExpandableMenu();e.forEach((e=>{const t=document.createElement("li");t.appendChild(e);i.appendChild(t)}))}parentElementIsSidebar(){const e=this.el.parentElement;if(e.tagName.toUpperCase()==="IFX-SIDEBAR"){return true}else return false}checkIfMenuItemIsNested(){const e=this.parentElementIsSidebar();if(e){this.isNested=false}}checkIfMenuItemIsSubMenu(){const e=this.el.parentElement;const i=this.getNavItem(e.shadowRoot);if(e.tagName.toUpperCase()==="IFX-SIDEBAR-ITEM"&&!this.handleClassList(i,"contains","header__section")){this.isSubMenuItem=true}else{this.isSubMenuItem=false}}isActive(e){const i=e.getAttribute("active");const t=i==="true";return t}getParentSection(e){let i=e.parentElement;while(i&&i.tagName.toUpperCase()!=="IFX-SIDEBAR"){if(i.tagName.toUpperCase()==="IFX-SIDEBAR-ITEM"){return i}i=i.parentElement}return null}handleBorderIndicatorDisplacement(e){const i=(e,t)=>{const s=this.isActive(e);if(s){const e=this.handleClassList(t,"contains","open");const i=this.getActiveItemSection();if(!e){this.handleClassList(i,"add","active-section")}else{this.handleClassList(i,"remove","active-section")}}const a=this.getSidebarMenuItems(e);a.forEach((e=>i(e,t)))};const t=this.getSidebarMenuItems();t.forEach((t=>i(t,e)))}setHref(){if(this.href.toLowerCase().trim()===""){this.internalHref=undefined}else this.internalHref=this.href}getActiveItemSection(){const e=this.parentElementIsSidebar();if(e){const e=this.getNavItem(this.el.shadowRoot);return e}else{const e=this.getNavItem(this.el.shadowRoot);return e}}async setActiveClasses(){const e=this.getNavItem(this.el.shadowRoot);this.handleClassList(e,"add","active")}async expandMenu(e){const i=this.getSidebarMenuItem();const t=this.getExpandableMenu();this.handleClassList(t,"add","open");this.handleClassList(i,"add","open");if(e){this.handleClassList(t,"remove","active-section");this.handleClassList(i,"remove","active-section")}}async isItemExpandable(){return this.isExpandable}handleActiveState(){if(this.internalActiveState){this.setActiveClasses()}}handleKeyDown(e){if(e.key==="Enter"){this.toggleSubmenu()}}componentDidLoad(){this.handleActiveState();if(this.isExpandable){const e=this.getSidebarMenuItems();this.handleExpandableMenu(e)}this.updateIndicatorVariant();this.observeCollapsedState();this.extractTitleText()}extractTitleText(){const e=this.el.shadowRoot.querySelector("slot");if(e){const i=e.assignedNodes();this.titleText=i.filter((e=>e.nodeType===Node.TEXT_NODE||e.nodeType===Node.ELEMENT_NODE)).map((e=>{var i;return((i=e.textContent)===null||i===void 0?void 0:i.trim())||""})).join(" ").trim()}}updateIndicatorVariant(){const e=this.el.hasAttribute("data-sidebar-collapsed");if(this.numberIndicator>0){this.indicatorVariant=e?"dot":"number"}}observeCollapsedState(){const e=new MutationObserver((()=>{this.updateIndicatorVariant()}));e.observe(this.el,{attributes:true,attributeFilter:["data-sidebar-collapsed"]})}componentWillLoad(){this.internalActiveState=this.active;this.checkIfMenuItemIsNested();this.checkIfMenuItemIsSubMenu();this.setHref();this.el.setAttribute("data-has-icon",this.icon?"true":"false");const e=this.getSidebarMenuItems();if(e.length!==0){this.isExpandable=true}else{this.isExpandable=false}}componentWillUpdate(){if(this.active&&!this.internalActiveState){this.internalActiveState=this.active;this.ifxSidebarNavigationItem.emit(this.el)}}render(){const e=this.el.hasAttribute("data-sidebar-collapsed");const i=this.el.hasAttribute("data-hide-in-collapsed");return t("div",{key:"491cbffba289bab9d633a08724a2bf1575b92d9f",style:{display:i?"none":"block"}},t("a",{key:"50a8e5dd2298c86711260427549b7d86601d5b46",tabIndex:1,onKeyDown:e=>this.handleKeyDown(e),href:this.internalHref,onClick:()=>this.toggleSubmenu(),target:this.target,class:`sidebar__nav-item ${!this.isNested&&this.isExpandable?"header__section":""} ${this.isSubMenuItem?"submenu__item":""}`,title:this.titleText},this.icon&&t("div",{key:"b27c805c73bd5404b648f493c4ded4d689b9eb3c",class:`sidebar__nav-item-icon-wrapper ${!this.showIcon&&!e?"noIcon":""}`},t("ifx-icon",{key:"2049a5d0f58106ad977b68c848c8c0f21182a86d",icon:this.icon})),t("div",{key:"c140a72eb126c87989c71066f287cea862060562",class:"sidebar__nav-item-label"},t("slot",{key:"ee9708e5f3591b34e7251546cab50224967abffe"})),(this.isExpandable||!isNaN(this.numberIndicator))&&t("div",{key:"d5ac6af6cf668e3463626c7b0f8f5694d23d2d1f",class:"sidebar__nav-item-indicator",style:{display:!e||this.icon?"flex":"none"}},this.isExpandable&&t("span",{key:"7ff6bd7e736d73392e8786980b740b0d1f1b1ac2",class:"item__arrow-wrapper"},t("ifx-icon",{key:"dc62663bee631edbb5a1126b5b2cd4bfb6125c98",icon:"chevron-down-16"})),this.numberIndicator>0&&!this.isExpandable&&!this.isNested&&t("span",{key:"2a02e2d009f260b57c7fb75cdce87366e56e5a53",class:"item__number-indicator"},t("ifx-indicator",{key:"8dcaf820d27afd21722e4f02f81e4d52441d5458",variant:this.indicatorVariant,number:this.numberIndicator})))),this.isExpandable&&t("ul",{key:"c55eb1c02512807fe889dff1e2b9e3455bc5cc23",class:"expandable__submenu"}))}get el(){return s(this)}static get watchers(){return{active:["handleActiveChange"],numberIndicator:["handleNumberIndicatorChange"]}}};n.style=a;export{n as ifx_sidebar_item};
2
+ //# sourceMappingURL=p-0be8f0c9.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["sidebarItemCss","SidebarItem","constructor","hostRef","this","icon","showIcon","showIconWrapper","href","internalHref","target","isExpandable","isNested","isSubMenuItem","active","isActionItem","indicatorVariant","internalActiveState","titleText","handleActiveChange","newValue","oldValue","labelElement","getNavItem","el","shadowRoot","handleClassList","handleNumberIndicatorChange","updateIndicatorVariant","handleConsoleError","event","detail","handleEventEmission","ifxSidebarMenu","emit","type","className","classList","contains","getExpandableMenu","expandableSubmenu","querySelector","getSidebarMenuItems","sidebarItems","querySelectorAll","length","getSidebarMenuItem","sidebarItem","toggleSubmenu","menuItem","expandableMenu","ifxSidebarActionItem","ifxSidebarNavigationItem","handleItemClick","handleExpandableMenu","sidebarExpandableMenu","forEach","li","document","createElement","appendChild","parentElementIsSidebar","parentElement","tagName","toUpperCase","checkIfMenuItemIsNested","parentIsSidebar","checkIfMenuItemIsSubMenu","navItem","isActive","iteratedComponent","activeAttributeValue","getAttribute","getParentSection","handleBorderIndicatorDisplacement","handleItem","item","isOpen","activeMenuItemSection","getActiveItemSection","children","child","topLevelItems","setHref","toLowerCase","trim","undefined","setActiveClasses","activeMenuItem","expandMenu","ac","isItemExpandable","handleActiveState","handleKeyDown","key","componentDidLoad","observeCollapsedState","extractTitleText","slotElement","assignedNodes","filter","node","nodeType","Node","TEXT_NODE","ELEMENT_NODE","map","_a","textContent","join","isCollapsed","hasAttribute","numberIndicator","observer","MutationObserver","observe","attributes","attributeFilter","componentWillLoad","setAttribute","componentWillUpdate","render","shouldHide","h","style","display","tabIndex","onKeyDown","onClick","class","title","isNaN","variant","number"],"sources":["src/components/navigation/sidebar/sidebar-item.scss?tag=ifx-sidebar-item&encapsulation=shadow","src/components/navigation/sidebar/sidebar-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../../global/font.scss\";\n\n:host {\n position: relative;\n display: block;\n}\n\n:host([data-has-icon=\"false\"]) {\n display: var(--ifx-sidebar-item-without-icon-display, block);\n}\n\n.sidebar__nav-item,\n.sidebar__nav-item.header__section {\n &:focus-visible {\n outline: none;\n box-shadow: 0 0 0 2px tokens.$ifxColorBaseWhite, 0 0 0 4px tokens.$ifxColorOcean500;\n\n & .sidebar__nav-item-icon-wrapper {\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-label {\n outline: none;\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n color: tokens.$ifxColorOcean600;\n }\n }\n }\n }\n\n\n\n &:hover {\n outline: none;\n\n & .sidebar__nav-item-icon-wrapper {\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-label {\n outline: none;\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n color: tokens.$ifxColorOcean600;\n }\n }\n }\n }\n}\n\n.sidebar__nav-item {\n display: flex;\n flex-direction: var(--ifx-sidebar-item-flex-direction, row);\n align-items: center;\n width: 100%;\n padding: 8px 0px;\n gap: 4px;\n flex: none;\n order: 0;\n flex-grow: 0;\n text-decoration: none;\n color: tokens.$ifxColorBaseBlack;\n cursor: pointer;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n\n &.extra-padding__bottom {\n padding: 8px 0px 16px 0px;\n }\n\n &.active {\n color: tokens.$ifxColorOcean500;\n }\n\n &.active-section {\n &::before {\n content: \"\";\n position: absolute;\n left: -32px;\n height: 40px;\n width: 2px;\n background: tokens.$ifxColorOcean500;\n }\n }\n\n\n &.open {\n padding: 8px 0px;\n\n & .sidebar__nav-item-label {\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 24px;\n }\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n transform: rotate(-180deg);\n }\n }\n }\n }\n\n &.header__section {\n box-sizing: padding-box;\n border-top: 1px solid tokens.$ifxColorEngineering200;\n padding: 16px 0px;\n display: -webkit-flex;\n -webkit-line-clamp: 1;\n -webkit-box-orient: horizontal;\n overflow: hidden;\n text-overflow: ellipsis;\n\n &.no-top-border {\n border-top: none;\n }\n\n &.active-section {\n &::before {\n content: \"\";\n position: absolute;\n left: -32px;\n height: 40px;\n width: 2px;\n background: tokens.$ifxColorOcean500;\n }\n }\n\n &.open {\n\n padding: 16px 0px 8px 0px;\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n transform: rotate(-180deg);\n }\n }\n }\n }\n\n & .sidebar__nav-item-label {\n color: tokens.$ifxColorBaseBlack;\n font-family: Source Sans 3;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n }\n\n &.submenu__item {\n padding: 4px 0px;\n\n &.extra-padding__bottom {\n padding: 4px 0px 16px 0px;\n }\n }\n\n & .sidebar__nav-item-icon-wrapper {\n display: flex;\n width: tokens.$ifxSize300;\n height: tokens.$ifxSize300;\n justify-content: center;\n align-items: center;\n gap: tokens.$ifxSpace100;\n flex-shrink: 0;\n\n &.noIcon {\n display: none;\n }\n\n & ifx-icon {\n width: tokens.$ifxSize200;\n height: tokens.$ifxSize200;\n }\n }\n\n & .sidebar__nav-item-label {\n font-style: normal;\n font-weight: 400;\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n display: flex;\n align-items: center;\n flex: none;\n order: 1;\n flex-grow: 1;\n cursor: pointer;\n display: var(--ifx-sidebar-item-text-display, flex);\n }\n\n & .sidebar__nav-item-indicator {\n display: var(--ifx-sidebar-item-text-display, flex);\n flex-direction: row;\n justify-content: center;\n align-items: center;\n padding: 0px 4px;\n flex: none;\n order: 2;\n flex-grow: 0;\n position: relative;\n\n // Collapsed state styling - position indicator over icon\n :host([data-sidebar-collapsed]) & {\n position: absolute;\n top: 0;\n right: 0;\n z-index: 10;\n padding: 0;\n }\n }\n}\n\n.expandable__submenu {\n display: none;\n list-style-type: none;\n flex-direction: column;\n padding: 0;\n margin: 0;\n padding-left: 40px;\n\n &.open {\n display: flex;\n }\n}\n\n.header__section+.expandable__submenu {\n padding-left: 0;\n}","import { Component, h, Prop, Element, State, Listen, Watch, Event, EventEmitter, Method } from '@stencil/core';\n\n@Component({\n tag: 'ifx-sidebar-item',\n styleUrl: 'sidebar-item.scss',\n shadow: true\n})\nexport class SidebarItem {\n @Element() el;\n @Prop() icon: string = \"\"\n @State() showIcon: boolean = true;\n @State() showIconWrapper: boolean = false;\n @Prop() href: string = \"\";\n @State() internalHref: string = \"\";\n @Prop() target: string = \"_self\";\n @State() isExpandable: boolean = false;\n @State() isNested: boolean = true;\n @State() isSubMenuItem: boolean = false;\n @Prop() numberIndicator: number;\n @Prop() active: boolean = false; // set to true manually or by clicking on a navigation item\n @Prop() isActionItem: boolean = false; // if an item is an action item, it can not become active\n @State() indicatorVariant: 'number' | 'dot' = 'number';\n\n @State() internalActiveState: boolean = false;\n \n @Event({ bubbles: true, composed: true }) ifxSidebarMenu: EventEmitter;\n @Event({ bubbles: true, composed: true }) ifxSidebarNavigationItem: EventEmitter;\n @Event({ bubbles: true, composed: true }) ifxSidebarActionItem: EventEmitter;\n\n @Prop() handleItemClick: (item: HTMLElement) => void;\n\n private titleText: string = '';\n\n @Watch('active')\n handleActiveChange(newValue: boolean, oldValue: boolean) {\n // If the item is an action item, ignore the active prop\n if (this.isActionItem) {\n this.internalActiveState = false;\n return;\n }\n this.internalActiveState = newValue;\n if (newValue !== oldValue) {\n let labelElement = this.getNavItem(this.el.shadowRoot)\n if (!this.isExpandable && !newValue) {\n this.handleClassList(labelElement, 'remove', 'active');\n }\n if (!this.isExpandable && newValue) {\n this.handleClassList(labelElement, 'add', 'active');\n }\n }\n }\n\n @Watch('numberIndicator') \n handleNumberIndicatorChange() {\n this.updateIndicatorVariant();\n }\n\n @Listen('consoleError')\n handleConsoleError(event: CustomEvent<boolean>) {\n if (event.detail) {\n this.showIcon = false;\n } else {\n this.showIcon = true;\n }\n }\n\n handleEventEmission() {\n // Get the active item section\n this.ifxSidebarMenu.emit(this.el)\n }\n\n handleClassList(el, type, className) {\n el.classList[type](className)\n if (type === 'contains') {\n return el.classList.contains(className)\n }\n }\n\n getExpandableMenu() {\n const expandableSubmenu = this.el.shadowRoot.querySelector('.expandable__submenu')\n return expandableSubmenu\n }\n\n getNavItem(el) {\n return el?.querySelector('.sidebar__nav-item')\n }\n\n\n\n getSidebarMenuItems(el = this.el) {\n const sidebarItems = el.querySelectorAll('ifx-sidebar-item');\n if (sidebarItems.length === 0) {\n return el.shadowRoot.querySelectorAll('ifx-sidebar-item');\n }\n return sidebarItems;\n }\n\n getSidebarMenuItem() {\n const sidebarItem = this.el.shadowRoot.querySelector('.sidebar__nav-item')\n return sidebarItem;\n }\n\n\n toggleSubmenu() {\n if (this.isExpandable) {\n const menuItem = this.getSidebarMenuItem();\n const expandableMenu = this.getExpandableMenu();\n this.handleClassList(expandableMenu, 'toggle', 'open');\n this.handleClassList(menuItem, 'toggle', 'open');\n // Emit an event with the current component\n this.handleEventEmission();\n } else {\n // If the sidebar item is not expandable, it's a leaf item without a submenu.\n // Emit an event to the parent `ifx-sidebar` component to notify it that a leaf item has been clicked.\n if (this.isActionItem) { //its an action item that eg opens an overlay etc and should not influence the active state of the item\n this.ifxSidebarActionItem.emit(this.el); // emit new event if isActionItem is true\n return;\n } else { //its a navigation item which becomes active after clicking it\n this.handleActiveChange(true, this.internalActiveState)\n this.ifxSidebarNavigationItem.emit(this.el);\n }\n // If the sidebar item is selectable (not expandable), then call the handler function with the current element.\n if (this.handleItemClick) {\n this.handleItemClick(this.el);\n }\n }\n // // Emit an event with the current component\n // this.handleEventEmission();\n }\n\n\n\n handleExpandableMenu(sidebarItems) {\n const sidebarExpandableMenu = this.getExpandableMenu();\n sidebarItems.forEach((el: HTMLElement) => {\n const li = document.createElement('li')\n li.appendChild(el)\n sidebarExpandableMenu.appendChild(li)\n })\n }\n\n parentElementIsSidebar() {\n const parentElement = this.el.parentElement;\n if (parentElement.tagName.toUpperCase() === 'IFX-SIDEBAR') {\n return true;\n } else return false;\n }\n\n checkIfMenuItemIsNested() {\n const parentIsSidebar = this.parentElementIsSidebar()\n if (parentIsSidebar) {\n this.isNested = false;\n }\n }\n\n checkIfMenuItemIsSubMenu() {\n const parentElement = this.el.parentElement;\n const navItem = this.getNavItem(parentElement.shadowRoot);\n if(parentElement.tagName.toUpperCase() === 'IFX-SIDEBAR-ITEM' && !this.handleClassList(navItem, 'contains', 'header__section')) {\n this.isSubMenuItem = true;\n }else {\n this.isSubMenuItem = false;\n }\n }\n\n isActive(iteratedComponent) {\n const activeAttributeValue = iteratedComponent.getAttribute('active');\n const isActive = activeAttributeValue === 'true';\n return isActive\n }\n\n getParentSection(el: HTMLElement) {\n let parentElement = el.parentElement;\n\n while (parentElement && parentElement.tagName.toUpperCase() !== 'IFX-SIDEBAR') {\n if (parentElement.tagName.toUpperCase() === 'IFX-SIDEBAR-ITEM') {\n return parentElement;\n }\n parentElement = parentElement.parentElement;\n }\n\n return null;\n }\n\n\n\n handleBorderIndicatorDisplacement(menuItem) {\n // Recursive function to handle each item\n const handleItem = (item, menuItem) => {\n const isActive = this.isActive(item);\n if (isActive) {\n const isOpen = this.handleClassList(menuItem, 'contains', 'open');\n const activeMenuItemSection = this.getActiveItemSection();\n if (!isOpen) {\n this.handleClassList(activeMenuItemSection, 'add', 'active-section');\n } else {\n this.handleClassList(activeMenuItemSection, 'remove', 'active-section');\n }\n }\n\n // Process each child item\n const children = this.getSidebarMenuItems(item);\n children.forEach((child) => handleItem(child, menuItem));\n }\n\n // Start with the top-level items\n const topLevelItems = this.getSidebarMenuItems();\n topLevelItems.forEach((item) => handleItem(item, menuItem));\n }\n\n\n setHref() {\n if (this.href.toLowerCase().trim() === \"\") {\n this.internalHref = undefined;\n } else this.internalHref = this.href;\n }\n\n getActiveItemSection() {\n const parentIsSidebar = this.parentElementIsSidebar()\n if (parentIsSidebar) {\n const labelElement = this.getNavItem(this.el.shadowRoot)\n return labelElement;\n } else {\n const labelElement = this.getNavItem(this.el.shadowRoot)\n return labelElement;\n }\n }\n\n @Method()\n async setActiveClasses() {\n const activeMenuItem = this.getNavItem(this.el.shadowRoot)\n this.handleClassList(activeMenuItem, 'add', 'active')\n }\n\n @Method()\n async expandMenu(ac: boolean){\n const menuItem = this.getSidebarMenuItem();\n const expandableMenu = this.getExpandableMenu();\n this.handleClassList(expandableMenu, 'add', 'open');\n this.handleClassList(menuItem, 'add', 'open');\n if(ac){\n this.handleClassList(expandableMenu, 'remove', 'active-section')\n this.handleClassList(menuItem, 'remove', 'active-section')\n }\n }\n\n @Method()\n async isItemExpandable(){\n return this.isExpandable;\n }\n\n handleActiveState() {\n if (this.internalActiveState) {\n this.setActiveClasses()\n }\n }\n\n handleKeyDown(event: KeyboardEvent) {\n if (event.key === 'Enter') {\n this.toggleSubmenu()\n }\n }\n\n componentDidLoad() {\n this.handleActiveState();\n if (this.isExpandable) {\n const sidebarItems = this.getSidebarMenuItems();\n this.handleExpandableMenu(sidebarItems)\n }\n // Listen for collapsed state changes\n this.updateIndicatorVariant();\n // Set up MutationObserver to watch for CSS custom property changes\n this.observeCollapsedState();\n // Extract text content for title attribute\n this.extractTitleText();\n }\n\n private extractTitleText() {\n // Get the text content from the slot\n const slotElement = this.el.shadowRoot.querySelector('slot');\n if (slotElement) {\n const assignedNodes = slotElement.assignedNodes();\n this.titleText = assignedNodes\n .filter(node => node.nodeType === Node.TEXT_NODE || node.nodeType === Node.ELEMENT_NODE)\n .map(node => node.textContent?.trim() || '')\n .join(' ')\n .trim();\n }\n }\n\n private updateIndicatorVariant() {\n // Check the data attribute on this element\n const isCollapsed = this.el.hasAttribute('data-sidebar-collapsed');\n //this.indicatorVariant = isCollapsed ? 'dot' : 'number';\n if (this.numberIndicator > 0) {\n this.indicatorVariant = isCollapsed ? 'dot' : 'number';\n }\n }\n\n private observeCollapsedState() {\n // Create a MutationObserver to watch for data-sidebar-collapsed attribute changes\n const observer = new MutationObserver(() => {\n this.updateIndicatorVariant();\n });\n\n observer.observe(this.el, {\n attributes: true,\n attributeFilter: ['data-sidebar-collapsed']\n });\n }\n\n componentWillLoad() {\n this.internalActiveState = this.active;\n this.checkIfMenuItemIsNested();\n this.checkIfMenuItemIsSubMenu();\n this.setHref()\n\n // Set attribute to track if item has icon\n this.el.setAttribute('data-has-icon', this.icon ? 'true' : 'false');\n\n const sidebarItems = this.getSidebarMenuItems();\n if (sidebarItems.length !== 0) {\n this.isExpandable = true;\n } else {\n this.isExpandable = false;\n }\n }\n\n componentWillUpdate() {\n // If the active prop has been set to true and the internalActiveState has not been set to true yet\n if (this.active && !this.internalActiveState) {\n // Set the internal active state to true\n this.internalActiveState = this.active;\n\n // Emit the event to notify the parent Sidebar\n this.ifxSidebarNavigationItem.emit(this.el);\n }\n }\n\n\nrender() {\n const isCollapsed = this.el.hasAttribute('data-sidebar-collapsed');\n const shouldHide = this.el.hasAttribute('data-hide-in-collapsed');\n\n return (\n <div style={{ display: shouldHide ? 'none' : 'block' }}>\n <a\n tabIndex={1}\n onKeyDown={(event) => this.handleKeyDown(event)}\n href={this.internalHref}\n onClick={() => this.toggleSubmenu()}\n target={this.target}\n class={`sidebar__nav-item ${!this.isNested && this.isExpandable ? 'header__section' : \"\"} ${this.isSubMenuItem ? 'submenu__item' : \"\"}`}\n title={this.titleText}\n >\n {this.icon &&\n <div class={`sidebar__nav-item-icon-wrapper ${!this.showIcon && !isCollapsed ? 'noIcon' : \"\"}`}>\n <ifx-icon icon={this.icon}></ifx-icon>\n </div>}\n <div class=\"sidebar__nav-item-label\">\n <slot />\n </div>\n {\n (this.isExpandable || !isNaN(this.numberIndicator)) &&\n <div class=\"sidebar__nav-item-indicator\" style={{\n display: (!isCollapsed || this.icon) ? 'flex' : 'none'\n }}>\n {this.isExpandable &&\n <span class='item__arrow-wrapper'>\n <ifx-icon icon=\"chevron-down-16\" />\n </span>\n }\n\n {this.numberIndicator > 0 && !this.isExpandable && !this.isNested &&\n <span class=\"item__number-indicator\">\n <ifx-indicator\n variant={this.indicatorVariant}\n number={this.numberIndicator}>\n </ifx-indicator>\n </span>}\n\n </div>\n }\n </a>\n {this.isExpandable && <ul class='expandable__submenu'></ul>}\n\n </div>\n );\n}\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["sidebarItemCss","SidebarItem","constructor","hostRef","this","icon","showIcon","showIconWrapper","href","internalHref","target","isExpandable","isNested","isSubMenuItem","active","isActionItem","indicatorVariant","internalActiveState","titleText","handleActiveChange","newValue","oldValue","labelElement","getNavItem","el","shadowRoot","handleClassList","handleNumberIndicatorChange","updateIndicatorVariant","handleConsoleError","event","detail","handleEventEmission","ifxSidebarMenu","emit","type","className","classList","contains","getExpandableMenu","expandableSubmenu","querySelector","getSidebarMenuItems","sidebarItems","querySelectorAll","length","getSidebarMenuItem","sidebarItem","toggleSubmenu","menuItem","expandableMenu","ifxSidebarActionItem","ifxSidebarNavigationItem","handleItemClick","handleExpandableMenu","sidebarExpandableMenu","forEach","li","document","createElement","appendChild","parentElementIsSidebar","parentElement","tagName","toUpperCase","checkIfMenuItemIsNested","parentIsSidebar","checkIfMenuItemIsSubMenu","navItem","isActive","iteratedComponent","activeAttributeValue","getAttribute","getParentSection","handleBorderIndicatorDisplacement","handleItem","item","isOpen","activeMenuItemSection","getActiveItemSection","children","child","topLevelItems","setHref","toLowerCase","trim","undefined","setActiveClasses","activeMenuItem","expandMenu","ac","isItemExpandable","handleActiveState","handleKeyDown","key","componentDidLoad","observeCollapsedState","extractTitleText","slotElement","assignedNodes","filter","node","nodeType","Node","TEXT_NODE","ELEMENT_NODE","map","_a","textContent","join","isCollapsed","hasAttribute","numberIndicator","observer","MutationObserver","observe","attributes","attributeFilter","componentWillLoad","setAttribute","componentWillUpdate","render","shouldHide","h","style","display","tabIndex","onKeyDown","onClick","class","title","isNaN","variant","number"],"sources":["src/components/navigation/sidebar/sidebar-item.scss?tag=ifx-sidebar-item&encapsulation=shadow","src/components/navigation/sidebar/sidebar-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../../global/font.scss\";\n\n:host {\n position: relative;\n display: block;\n}\n\n:host([data-has-icon=\"false\"]) {\n display: var(--ifx-sidebar-item-without-icon-display, block);\n}\n\n.sidebar__nav-item,\n.sidebar__nav-item.header__section {\n &:focus-visible {\n outline: none;\n box-shadow: 0 0 0 2px tokens.$ifxColorBaseWhite, 0 0 0 4px tokens.$ifxColorOcean500;\n\n & .sidebar__nav-item-icon-wrapper {\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-label {\n outline: none;\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n color: tokens.$ifxColorOcean600;\n }\n }\n }\n }\n\n\n\n &:hover {\n outline: none;\n\n & .sidebar__nav-item-icon-wrapper {\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-label {\n outline: none;\n color: tokens.$ifxColorOcean600;\n }\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n color: tokens.$ifxColorOcean600;\n }\n }\n }\n }\n}\n\n.sidebar__nav-item {\n display: flex;\n flex-direction: var(--ifx-sidebar-item-flex-direction, row);\n align-items: center;\n width: 100%;\n padding: 8px 0px;\n gap: 4px;\n flex: none;\n order: 0;\n flex-grow: 0;\n text-decoration: none;\n color: tokens.$ifxColorBaseBlack;\n cursor: pointer;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n\n\n &.extra-padding__bottom {\n padding: 8px 0px 16px 0px;\n }\n\n &.active {\n color: tokens.$ifxColorOcean500;\n }\n\n &.active-section {\n &::before {\n content: \"\";\n position: absolute;\n left: -32px;\n height: 40px;\n width: 2px;\n background: tokens.$ifxColorOcean500;\n }\n }\n\n\n &.open {\n padding: 8px 0px;\n\n & .sidebar__nav-item-label {\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 24px;\n }\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n transform: rotate(-180deg);\n }\n }\n }\n }\n\n &.header__section {\n box-sizing: padding-box;\n border-top: 1px solid tokens.$ifxColorEngineering200;\n padding: 16px 0px;\n display: -webkit-flex;\n -webkit-line-clamp: 1;\n -webkit-box-orient: horizontal;\n overflow: hidden;\n text-overflow: ellipsis;\n\n &.no-top-border {\n border-top: none;\n }\n\n &.active-section {\n &::before {\n content: \"\";\n position: absolute;\n left: -32px;\n height: 40px;\n width: 2px;\n background: tokens.$ifxColorOcean500;\n }\n }\n\n &.open {\n\n padding: 16px 0px 8px 0px;\n\n & .sidebar__nav-item-indicator {\n & .item__arrow-wrapper {\n & ifx-icon {\n transform: rotate(-180deg);\n }\n }\n }\n }\n\n & .sidebar__nav-item-label {\n color: tokens.$ifxColorBaseBlack;\n font-family: Source Sans 3;\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n }\n\n &.submenu__item {\n padding: 4px 0px;\n\n &.extra-padding__bottom {\n padding: 4px 0px 16px 0px;\n }\n }\n\n & .sidebar__nav-item-icon-wrapper {\n display: flex;\n width: tokens.$ifxSize300;\n height: tokens.$ifxSize300;\n justify-content: center;\n align-items: center;\n gap: tokens.$ifxSpace100;\n flex-shrink: 0;\n\n &.noIcon {\n display: none;\n }\n\n & ifx-icon {\n width: tokens.$ifxSize200;\n height: tokens.$ifxSize200;\n }\n }\n\n & .sidebar__nav-item-label {\n font-style: normal;\n font-weight: 400;\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n display: flex;\n align-items: center;\n flex: none;\n order: 1;\n flex-grow: 1;\n cursor: pointer;\n display: var(--ifx-sidebar-item-text-display, flex);\n }\n\n & .sidebar__nav-item-indicator {\n display: var(--ifx-sidebar-item-text-display, flex);\n flex-direction: row;\n justify-content: center;\n align-items: center;\n padding: 0px 4px;\n flex: none;\n order: 2;\n flex-grow: 0;\n position: relative;\n\n // Collapsed state styling - position indicator over icon\n :host([data-sidebar-collapsed]) & {\n position: absolute;\n top: 0;\n right: 0;\n z-index: 10;\n padding: 0;\n }\n }\n}\n\n.expandable__submenu {\n display: none;\n list-style-type: none;\n flex-direction: column;\n padding: 0;\n margin: 0;\n padding-left: 40px;\n\n &.open {\n display: flex;\n }\n}\n\n.header__section+.expandable__submenu {\n padding-left: 0;\n}","import { Component, h, Prop, Element, State, Listen, Watch, Event, EventEmitter, Method } from '@stencil/core';\n\n@Component({\n tag: 'ifx-sidebar-item',\n styleUrl: 'sidebar-item.scss',\n shadow: true\n})\nexport class SidebarItem {\n @Element() el;\n @Prop() icon: string = \"\"\n @State() showIcon: boolean = true;\n @State() showIconWrapper: boolean = false;\n @Prop() href: string = \"\";\n @State() internalHref: string = \"\";\n @Prop() target: string = \"_self\";\n @State() isExpandable: boolean = false;\n @State() isNested: boolean = true;\n @State() isSubMenuItem: boolean = false;\n @Prop() numberIndicator: number;\n @Prop() active: boolean = false; // set to true manually or by clicking on a navigation item\n @Prop() isActionItem: boolean = false; // if an item is an action item, it can not become active\n @State() indicatorVariant: 'number' | 'dot' = 'number';\n\n @State() internalActiveState: boolean = false;\n \n @Event({ bubbles: true, composed: true }) ifxSidebarMenu: EventEmitter;\n @Event({ bubbles: true, composed: true }) ifxSidebarNavigationItem: EventEmitter;\n @Event({ bubbles: true, composed: true }) ifxSidebarActionItem: EventEmitter;\n\n @Prop() handleItemClick: (item: HTMLElement) => void;\n\n private titleText: string = '';\n\n @Watch('active')\n handleActiveChange(newValue: boolean, oldValue: boolean) {\n // If the item is an action item, ignore the active prop\n if (this.isActionItem) {\n this.internalActiveState = false;\n return;\n }\n this.internalActiveState = newValue;\n if (newValue !== oldValue) {\n let labelElement = this.getNavItem(this.el.shadowRoot)\n if (!this.isExpandable && !newValue) {\n this.handleClassList(labelElement, 'remove', 'active');\n }\n if (!this.isExpandable && newValue) {\n this.handleClassList(labelElement, 'add', 'active');\n }\n }\n }\n\n @Watch('numberIndicator') \n handleNumberIndicatorChange() {\n this.updateIndicatorVariant();\n }\n\n @Listen('consoleError')\n handleConsoleError(event: CustomEvent<boolean>) {\n if (event.detail) {\n this.showIcon = false;\n } else {\n this.showIcon = true;\n }\n }\n\n handleEventEmission() {\n // Get the active item section\n this.ifxSidebarMenu.emit(this.el)\n }\n\n handleClassList(el, type, className) {\n el.classList[type](className)\n if (type === 'contains') {\n return el.classList.contains(className)\n }\n }\n\n getExpandableMenu() {\n const expandableSubmenu = this.el.shadowRoot.querySelector('.expandable__submenu')\n return expandableSubmenu\n }\n\n getNavItem(el) {\n return el?.querySelector('.sidebar__nav-item')\n }\n\n\n\n getSidebarMenuItems(el = this.el) {\n const sidebarItems = el.querySelectorAll('ifx-sidebar-item');\n if (sidebarItems.length === 0) {\n return el.shadowRoot.querySelectorAll('ifx-sidebar-item');\n }\n return sidebarItems;\n }\n\n getSidebarMenuItem() {\n const sidebarItem = this.el.shadowRoot.querySelector('.sidebar__nav-item')\n return sidebarItem;\n }\n\n\n toggleSubmenu() {\n if (this.isExpandable) {\n const menuItem = this.getSidebarMenuItem();\n const expandableMenu = this.getExpandableMenu();\n this.handleClassList(expandableMenu, 'toggle', 'open');\n this.handleClassList(menuItem, 'toggle', 'open');\n // Emit an event with the current component\n this.handleEventEmission();\n } else {\n // If the sidebar item is not expandable, it's a leaf item without a submenu.\n // Emit an event to the parent `ifx-sidebar` component to notify it that a leaf item has been clicked.\n if (this.isActionItem) { //its an action item that eg opens an overlay etc and should not influence the active state of the item\n this.ifxSidebarActionItem.emit(this.el); // emit new event if isActionItem is true\n return;\n } else { //its a navigation item which becomes active after clicking it\n this.handleActiveChange(true, this.internalActiveState)\n this.ifxSidebarNavigationItem.emit(this.el);\n }\n // If the sidebar item is selectable (not expandable), then call the handler function with the current element.\n if (this.handleItemClick) {\n this.handleItemClick(this.el);\n }\n }\n // // Emit an event with the current component\n // this.handleEventEmission();\n }\n\n\n\n handleExpandableMenu(sidebarItems) {\n const sidebarExpandableMenu = this.getExpandableMenu();\n sidebarItems.forEach((el: HTMLElement) => {\n const li = document.createElement('li')\n li.appendChild(el)\n sidebarExpandableMenu.appendChild(li)\n })\n }\n\n parentElementIsSidebar() {\n const parentElement = this.el.parentElement;\n if (parentElement.tagName.toUpperCase() === 'IFX-SIDEBAR') {\n return true;\n } else return false;\n }\n\n checkIfMenuItemIsNested() {\n const parentIsSidebar = this.parentElementIsSidebar()\n if (parentIsSidebar) {\n this.isNested = false;\n }\n }\n\n checkIfMenuItemIsSubMenu() {\n const parentElement = this.el.parentElement;\n const navItem = this.getNavItem(parentElement.shadowRoot);\n if(parentElement.tagName.toUpperCase() === 'IFX-SIDEBAR-ITEM' && !this.handleClassList(navItem, 'contains', 'header__section')) {\n this.isSubMenuItem = true;\n }else {\n this.isSubMenuItem = false;\n }\n }\n\n isActive(iteratedComponent) {\n const activeAttributeValue = iteratedComponent.getAttribute('active');\n const isActive = activeAttributeValue === 'true';\n return isActive\n }\n\n getParentSection(el: HTMLElement) {\n let parentElement = el.parentElement;\n\n while (parentElement && parentElement.tagName.toUpperCase() !== 'IFX-SIDEBAR') {\n if (parentElement.tagName.toUpperCase() === 'IFX-SIDEBAR-ITEM') {\n return parentElement;\n }\n parentElement = parentElement.parentElement;\n }\n\n return null;\n }\n\n\n\n handleBorderIndicatorDisplacement(menuItem) {\n // Recursive function to handle each item\n const handleItem = (item, menuItem) => {\n const isActive = this.isActive(item);\n if (isActive) {\n const isOpen = this.handleClassList(menuItem, 'contains', 'open');\n const activeMenuItemSection = this.getActiveItemSection();\n if (!isOpen) {\n this.handleClassList(activeMenuItemSection, 'add', 'active-section');\n } else {\n this.handleClassList(activeMenuItemSection, 'remove', 'active-section');\n }\n }\n\n // Process each child item\n const children = this.getSidebarMenuItems(item);\n children.forEach((child) => handleItem(child, menuItem));\n }\n\n // Start with the top-level items\n const topLevelItems = this.getSidebarMenuItems();\n topLevelItems.forEach((item) => handleItem(item, menuItem));\n }\n\n\n setHref() {\n if (this.href.toLowerCase().trim() === \"\") {\n this.internalHref = undefined;\n } else this.internalHref = this.href;\n }\n\n getActiveItemSection() {\n const parentIsSidebar = this.parentElementIsSidebar()\n if (parentIsSidebar) {\n const labelElement = this.getNavItem(this.el.shadowRoot)\n return labelElement;\n } else {\n const labelElement = this.getNavItem(this.el.shadowRoot)\n return labelElement;\n }\n }\n\n @Method()\n async setActiveClasses() {\n const activeMenuItem = this.getNavItem(this.el.shadowRoot)\n this.handleClassList(activeMenuItem, 'add', 'active')\n }\n\n @Method()\n async expandMenu(ac: boolean){\n const menuItem = this.getSidebarMenuItem();\n const expandableMenu = this.getExpandableMenu();\n this.handleClassList(expandableMenu, 'add', 'open');\n this.handleClassList(menuItem, 'add', 'open');\n if(ac){\n this.handleClassList(expandableMenu, 'remove', 'active-section')\n this.handleClassList(menuItem, 'remove', 'active-section')\n }\n }\n\n @Method()\n async isItemExpandable(){\n return this.isExpandable;\n }\n\n handleActiveState() {\n if (this.internalActiveState) {\n this.setActiveClasses()\n }\n }\n\n handleKeyDown(event: KeyboardEvent) {\n if (event.key === 'Enter') {\n this.toggleSubmenu()\n }\n }\n\n componentDidLoad() {\n this.handleActiveState();\n if (this.isExpandable) {\n const sidebarItems = this.getSidebarMenuItems();\n this.handleExpandableMenu(sidebarItems)\n }\n // Listen for collapsed state changes\n this.updateIndicatorVariant();\n // Set up MutationObserver to watch for CSS custom property changes\n this.observeCollapsedState();\n // Extract text content for title attribute\n this.extractTitleText();\n }\n\n private extractTitleText() {\n // Get the text content from the slot\n const slotElement = this.el.shadowRoot.querySelector('slot');\n if (slotElement) {\n const assignedNodes = slotElement.assignedNodes();\n this.titleText = assignedNodes\n .filter(node => node.nodeType === Node.TEXT_NODE || node.nodeType === Node.ELEMENT_NODE)\n .map(node => node.textContent?.trim() || '')\n .join(' ')\n .trim();\n }\n }\n\n private updateIndicatorVariant() {\n // Check the data attribute on this element\n const isCollapsed = this.el.hasAttribute('data-sidebar-collapsed');\n //this.indicatorVariant = isCollapsed ? 'dot' : 'number';\n if (this.numberIndicator > 0) {\n this.indicatorVariant = isCollapsed ? 'dot' : 'number';\n }\n }\n\n private observeCollapsedState() {\n // Create a MutationObserver to watch for data-sidebar-collapsed attribute changes\n const observer = new MutationObserver(() => {\n this.updateIndicatorVariant();\n });\n\n observer.observe(this.el, {\n attributes: true,\n attributeFilter: ['data-sidebar-collapsed']\n });\n }\n\n componentWillLoad() {\n this.internalActiveState = this.active;\n this.checkIfMenuItemIsNested();\n this.checkIfMenuItemIsSubMenu();\n this.setHref()\n\n // Set attribute to track if item has icon\n this.el.setAttribute('data-has-icon', this.icon ? 'true' : 'false');\n\n const sidebarItems = this.getSidebarMenuItems();\n if (sidebarItems.length !== 0) {\n this.isExpandable = true;\n } else {\n this.isExpandable = false;\n }\n }\n\n componentWillUpdate() {\n // If the active prop has been set to true and the internalActiveState has not been set to true yet\n if (this.active && !this.internalActiveState) {\n // Set the internal active state to true\n this.internalActiveState = this.active;\n\n // Emit the event to notify the parent Sidebar\n this.ifxSidebarNavigationItem.emit(this.el);\n }\n }\n\n\nrender() {\n const isCollapsed = this.el.hasAttribute('data-sidebar-collapsed');\n const shouldHide = this.el.hasAttribute('data-hide-in-collapsed');\n\n return (\n <div style={{ display: shouldHide ? 'none' : 'block' }}>\n <a\n tabIndex={1}\n onKeyDown={(event) => this.handleKeyDown(event)}\n href={this.internalHref}\n onClick={() => this.toggleSubmenu()}\n target={this.target}\n class={`sidebar__nav-item ${!this.isNested && this.isExpandable ? 'header__section' : \"\"} ${this.isSubMenuItem ? 'submenu__item' : \"\"}`}\n title={this.titleText}\n >\n {this.icon &&\n <div class={`sidebar__nav-item-icon-wrapper ${!this.showIcon && !isCollapsed ? 'noIcon' : \"\"}`}>\n <ifx-icon icon={this.icon}></ifx-icon>\n </div>}\n <div class=\"sidebar__nav-item-label\">\n <slot />\n </div>\n {\n (this.isExpandable || !isNaN(this.numberIndicator)) &&\n <div class=\"sidebar__nav-item-indicator\" style={{\n display: (!isCollapsed || this.icon) ? 'flex' : 'none'\n }}>\n {this.isExpandable &&\n <span class='item__arrow-wrapper'>\n <ifx-icon icon=\"chevron-down-16\" />\n </span>\n }\n\n {this.numberIndicator > 0 && !this.isExpandable && !this.isNested &&\n <span class=\"item__number-indicator\">\n <ifx-indicator\n variant={this.indicatorVariant}\n number={this.numberIndicator}>\n </ifx-indicator>\n </span>}\n\n </div>\n }\n </a>\n {this.isExpandable && <ul class='expandable__submenu'></ul>}\n\n </div>\n );\n}\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,2 +1,2 @@
1
- import{r as e,h as t,d as o}from"./p-DtIEDtZ8.js";const r=".ifx-content-switcher-item{all:unset;height:36px;box-sizing:border-box;border-radius:9999px;border:3px solid transparent;padding:7px 20px;font-family:var(--ifx-font-family);font-weight:600;font-size:14px;line-height:20px;display:flex;justify-content:center;align-items:center;gap:8px;background-color:transparent}.ifx-content-switcher-item.selected{color:#0A8276;background-color:#FFFFFF;border:3px solid #0A8276}.ifx-content-switcher-item:hover{color:#08665C;background-color:#FFFFFF;border:3px solid #08665C;cursor:pointer}.ifx-content-switcher-item:active{color:#08665C;background-color:#FFFFFF;border:3px solid #06534B}.ifx-content-switcher-item:focus{color:#08665C;background-color:#FFFFFF;border:3px solid #08665C}";const c=class{constructor(t){e(this,t);this.selected=false}render(){return t(o,{key:"844da0fa26ea37b9b53d16f70f982fc4daf3bed1"},t("button",{key:"ed5ec4be1c0cd301db79a078fe28f36967a55d85",class:"ifx-content-switcher-item"+(this.selected?" selected":"")},t("slot",{key:"6469c05327408244756a8af3f555c32bae66ace1"})))}};c.style=r;export{c as ifx_content_switcher_item};
2
- //# sourceMappingURL=p-dfd77261.entry.js.map
1
+ import{r as e,h as t,d as o}from"./p-PqnYwNKt.js";const r=".ifx-content-switcher-item{all:unset;height:36px;box-sizing:border-box;border-radius:9999px;border:3px solid transparent;padding:7px 20px;font-family:var(--ifx-font-family);font-weight:600;font-size:14px;line-height:20px;display:flex;justify-content:center;align-items:center;gap:8px;background-color:transparent}.ifx-content-switcher-item.selected{color:#0A8276;background-color:#FFFFFF;border:3px solid #0A8276}.ifx-content-switcher-item:hover{color:#08665C;background-color:#FFFFFF;border:3px solid #08665C;cursor:pointer}.ifx-content-switcher-item:active{color:#08665C;background-color:#FFFFFF;border:3px solid #06534B}.ifx-content-switcher-item:focus{color:#08665C;background-color:#FFFFFF;border:3px solid #08665C}";const c=class{constructor(t){e(this,t);this.selected=false}render(){return t(o,{key:"844da0fa26ea37b9b53d16f70f982fc4daf3bed1"},t("button",{key:"ed5ec4be1c0cd301db79a078fe28f36967a55d85",class:"ifx-content-switcher-item"+(this.selected?" selected":"")},t("slot",{key:"6469c05327408244756a8af3f555c32bae66ace1"})))}};c.style=r;export{c as ifx_content_switcher_item};
2
+ //# sourceMappingURL=p-0fb9f42b.entry.js.map
@@ -1,2 +1,2 @@
1
- import{r as t,c as e,h as i,d as s,a}from"./p-DtIEDtZ8.js";const l=":host{display:block;width:100%}.search-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-start;margin-bottom:16px}.components-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-end;align-content:flex-end;flex-wrap:wrap;gap:16px}.filter-slot-wrapper{flex-grow:1;flex-basis:100%;max-width:100%}@media (max-width: 1024px){.more-filters-wrapper{order:3;width:100%;display:flex;justify-content:center;padding-top:16px;}}@media (min-width: 720px) and (max-width: 1024px){.filter-slot-wrapper{flex-basis:calc((100% - 16px) / 2);max-width:calc((100% - 16px) / 2)}}@media (min-width: 1025px){.filter-slot-wrapper{flex-basis:auto;max-width:200px}::slotted([slot=filter-search]){max-width:828px}}::slotted([slot=filter-search]){flex-grow:1;flex-basis:100%;width:100%}";const r=class{constructor(i){t(this,i);this.ifxTopbarFilterChange=e(this,"ifxTopbarFilterChange",7);this.selectedOptions=[];this.showAllFilters=false;this.maxShownFilters=4;this.showMoreFiltersButton=true;this.handleMoreFiltersClick=()=>{this.showAllFilters=true;this.updateVisibleSlots()};this.handleResetEvent=()=>{var t;const e=(t=this.el.shadowRoot)===null||t===void 0?void 0:t.querySelector('slot[name="filter-search"]');if(e instanceof HTMLSlotElement){const t=e.assignedElements({flatten:true});t.forEach((t=>{const e=t.querySelector("ifx-filter-search");const i=e.shadowRoot.querySelectorAll("ifx-search-field");if(i.length>0){i.forEach((t=>{t.value=""}))}}))}this.selectedOptions=[];this.ifxTopbarFilterChange.emit(this.selectedOptions)};this.handleSearchChange=t=>{this.handleTopbarFilterChange(t)};this.handleFilterSelect=t=>{this.handleTopbarFilterChange(t)};this.handleTopbarFilterChange=t=>{const e=[...this.selectedOptions];if(t.type==="ifxFilterSearchChange"){const{filterName:i,filterValue:s}=t.detail;const a=e.findIndex((t=>t.filterName===i));if(a!==-1){e[a].filterValues=[s]}else{e.push({filterName:i,filterValues:[s],type:"text"})}}else if(t.type==="ifxFilterSelect"){const{filterName:i,filterValues:s,type:a}=t.detail;const l=e.findIndex((t=>t.filterName===i));if(l!==-1){e[l].filterValues=s;e[l].type=a}else{e.push({filterName:i,filterValues:s,type:a})}}this.selectedOptions=e;this.ifxTopbarFilterChange.emit(this.selectedOptions)}}connectedCallback(){this.el.addEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.addEventListener("ifxFilterSearchChange",this.handleSearchChange);window.addEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentWillUnload(){this.el.removeEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.removeEventListener("ifxFilterSearchChange",this.handleSearchChange);window.removeEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentWillLoad(){this.updateVisibleSlots()}updateVisibleSlots(){this.visibleSlots=this.showAllFilters?Number.MAX_SAFE_INTEGER:this.maxShownFilters}render(){const t=Math.max(0,this.visibleSlots);const e=this.el.querySelectorAll("ifx-set-filter").length;const a=Math.min(t,e,Number.MAX_SAFE_INTEGER);const l=Array.from({length:a},((t,e)=>i("div",{class:"filter-slot-wrapper"},i("slot",{name:`filter-component-${e+1}`}))));return i(s,{key:"2b4927cc61d5e9c566f85544f47b8f3a4305be4e"},i("div",{key:"dc3fc02769297cfea89e54f7403bd811ad4cf952",class:"search-container"},i("slot",{key:"9ec9fe23bd4d14de1d2795d0d2dd21622c93eb76",name:"filter-search"})," "),i("div",{key:"c4ea12c884a69fc6905cb178de6da350648821e0",class:"components-container"},l.length>0?l:i("slot",{name:"filter-component"}),this.showMoreFiltersButton&&!this.showAllFilters&&i("div",{key:"d99f66f19f88a1788b9bfdb86b5ceacbe2fd3fad",class:"more-filters-wrapper",onClick:this.handleMoreFiltersClick},i("ifx-button",{key:"fbf09d84fc2ea71ece0a6440fc808ddf89b78f65",type:"button",disabled:false,variant:"tertiary",size:"m",target:"_blank",theme:"default","full-width":"false"},i("ifx-icon",{key:"930c10fd594a70b820249134cbbb320e17ebf8a7",icon:"filter-16"}),"More filters"))))}get el(){return a(this)}};r.style=l;export{r as ifx_filter_bar};
2
- //# sourceMappingURL=p-d3a6bbf7.entry.js.map
1
+ import{r as t,c as e,h as i,d as s,a}from"./p-PqnYwNKt.js";const l=":host{display:block;width:100%}.search-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-start;margin-bottom:16px}.components-container{display:flex;width:calc(100% - 48px);padding-left:24px;padding-right:24px;flex-direction:row;align-items:flex-end;align-content:flex-end;flex-wrap:wrap;gap:16px}.filter-slot-wrapper{flex-grow:1;flex-basis:100%;max-width:100%}@media (max-width: 1024px){.more-filters-wrapper{order:3;width:100%;display:flex;justify-content:center;padding-top:16px;}}@media (min-width: 720px) and (max-width: 1024px){.filter-slot-wrapper{flex-basis:calc((100% - 16px) / 2);max-width:calc((100% - 16px) / 2)}}@media (min-width: 1025px){.filter-slot-wrapper{flex-basis:auto;max-width:200px}::slotted([slot=filter-search]){max-width:828px}}::slotted([slot=filter-search]){flex-grow:1;flex-basis:100%;width:100%}";const r=class{constructor(i){t(this,i);this.ifxTopbarFilterChange=e(this,"ifxTopbarFilterChange",7);this.selectedOptions=[];this.showAllFilters=false;this.maxShownFilters=4;this.showMoreFiltersButton=true;this.handleMoreFiltersClick=()=>{this.showAllFilters=true;this.updateVisibleSlots()};this.handleResetEvent=()=>{var t;const e=(t=this.el.shadowRoot)===null||t===void 0?void 0:t.querySelector('slot[name="filter-search"]');if(e instanceof HTMLSlotElement){const t=e.assignedElements({flatten:true});t.forEach((t=>{const e=t.querySelector("ifx-filter-search");const i=e.shadowRoot.querySelectorAll("ifx-search-field");if(i.length>0){i.forEach((t=>{t.value=""}))}}))}this.selectedOptions=[];this.ifxTopbarFilterChange.emit(this.selectedOptions)};this.handleSearchChange=t=>{this.handleTopbarFilterChange(t)};this.handleFilterSelect=t=>{this.handleTopbarFilterChange(t)};this.handleTopbarFilterChange=t=>{const e=[...this.selectedOptions];if(t.type==="ifxFilterSearchChange"){const{filterName:i,filterValue:s}=t.detail;const a=e.findIndex((t=>t.filterName===i));if(a!==-1){e[a].filterValues=[s]}else{e.push({filterName:i,filterValues:[s],type:"text"})}}else if(t.type==="ifxFilterSelect"){const{filterName:i,filterValues:s,type:a}=t.detail;const l=e.findIndex((t=>t.filterName===i));if(l!==-1){e[l].filterValues=s;e[l].type=a}else{e.push({filterName:i,filterValues:s,type:a})}}this.selectedOptions=e;this.ifxTopbarFilterChange.emit(this.selectedOptions)}}connectedCallback(){this.el.addEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.addEventListener("ifxFilterSearchChange",this.handleSearchChange);window.addEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentWillUnload(){this.el.removeEventListener("ifxFilterSelect",this.handleTopbarFilterChange);this.el.removeEventListener("ifxFilterSearchChange",this.handleSearchChange);window.removeEventListener("ifxResetFiltersEvent",this.handleResetEvent)}componentWillLoad(){this.updateVisibleSlots()}updateVisibleSlots(){this.visibleSlots=this.showAllFilters?Number.MAX_SAFE_INTEGER:this.maxShownFilters}render(){const t=Math.max(0,this.visibleSlots);const e=this.el.querySelectorAll("ifx-set-filter").length;const a=Math.min(t,e,Number.MAX_SAFE_INTEGER);const l=Array.from({length:a},((t,e)=>i("div",{class:"filter-slot-wrapper"},i("slot",{name:`filter-component-${e+1}`}))));return i(s,{key:"2b4927cc61d5e9c566f85544f47b8f3a4305be4e"},i("div",{key:"dc3fc02769297cfea89e54f7403bd811ad4cf952",class:"search-container"},i("slot",{key:"9ec9fe23bd4d14de1d2795d0d2dd21622c93eb76",name:"filter-search"})," "),i("div",{key:"c4ea12c884a69fc6905cb178de6da350648821e0",class:"components-container"},l.length>0?l:i("slot",{name:"filter-component"}),this.showMoreFiltersButton&&!this.showAllFilters&&i("div",{key:"d99f66f19f88a1788b9bfdb86b5ceacbe2fd3fad",class:"more-filters-wrapper",onClick:this.handleMoreFiltersClick},i("ifx-button",{key:"fbf09d84fc2ea71ece0a6440fc808ddf89b78f65",type:"button",disabled:false,variant:"tertiary",size:"m",target:"_blank",theme:"default","full-width":"false"},i("ifx-icon",{key:"930c10fd594a70b820249134cbbb320e17ebf8a7",icon:"filter-16"}),"More filters"))))}get el(){return a(this)}};r.style=l;export{r as ifx_filter_bar};
2
+ //# sourceMappingURL=p-116c853e.entry.js.map
@@ -0,0 +1,2 @@
1
+ import{r as i,c as t,h as s,a as e}from"./p-PqnYwNKt.js";import{c as n}from"./p-DMLRPGid.js";import"./p-B85MJLTf.js";const o=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}.action-list-item{display:flex;align-items:center;padding:8px 16px;background:#FFFFFF;transition:background-color 0.2s ease;cursor:default}.action-list-item--clickable{cursor:pointer}.action-list-item--clickable:hover:not(.action-list-item--disabled){background:#F7F7F7}.action-list-item--clickable:focus:not(.action-list-item--disabled){outline:none;background:#F7F7F7}.action-list-item--clickable:active:not(.action-list-item--disabled){background:#EEEDED}.action-list-item--disabled ::slotted(ifx-icon){color:#BFBBBB}.action-list-item--disabled ::slotted(*) ifx-icon{color:#BFBBBB}.action-list-item__leading{display:flex;align-items:center;justify-content:center;margin-right:16px;flex-shrink:0}.action-list-item__content{flex:1;min-width:0}.action-list-item__title{font-weight:600;font-size:1rem;line-height:1.5rem;color:#1D1D1D;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.action-list-item--disabled .action-list-item__title{color:#BFBBBB}.action-list-item__description{font-size:0.875rem;line-height:1.25rem;color:#575352;margin-top:2px}.action-list-item--disabled .action-list-item__description{color:#BFBBBB}.action-list-item__trailing{display:flex;align-items:center;justify-content:center;margin-left:16px;flex-shrink:0;gap:16px}';const l=class{constructor(s){i(this,s);this.ifxActionListItemClick=t(this,"ifxActionListItemClick",7);this.target="_self";this.disabled=false;this.handleMainClick=i=>{var t,s;if(this.disabled){i.preventDefault();i.stopPropagation();return}const e=(t=this.host.shadowRoot)===null||t===void 0?void 0:t.querySelector(".action-list-item__leading");const n=(s=this.host.shadowRoot)===null||s===void 0?void 0:s.querySelector(".action-list-item__trailing");if((e===null||e===void 0?void 0:e.contains(i.target))||(n===null||n===void 0?void 0:n.contains(i.target))){return}this.ifxActionListItemClick.emit({value:this.value,href:this.href,target:this.target,component:this});if(this.href){if(this.target==="_blank"){window.open(this.href,this.target)}else{window.location.href=this.href}}};this.handleLeadingClick=i=>{if(this.disabled){i.preventDefault();i.stopPropagation();return}const t=i.target;let s=t;while(s&&s!==this.host){if(this.isInteractiveElement(s)){i.stopPropagation();return}s=s.parentElement}i.stopPropagation();this.ifxActionListItemClick.emit({value:this.value,href:this.href,target:this.target,component:this});if(this.href){if(this.target==="_blank"){window.open(this.href,this.target)}else{window.location.href=this.href}}};this.handleTrailingClick=i=>{if(this.disabled){i.preventDefault();i.stopPropagation();return}const t=i.target;let s=t;while(s&&s!==this.host){if(this.isInteractiveElement(s)){i.stopPropagation();return}s=s.parentElement}i.stopPropagation();this.ifxActionListItemClick.emit({value:this.value,href:this.href,target:this.target,component:this});if(this.href){if(this.target==="_blank"){window.open(this.href,this.target)}else{window.location.href=this.href}}};this.isInteractiveElement=i=>{const t=i.tagName.toUpperCase();const s=["IFX-BUTTON","IFX-CHECKBOX","IFX-SWITCH"];return s.includes(t)};this.handleMainKeyDown=i=>{if(this.disabled)return;if(i.key==="Enter"||i.key===" "){i.preventDefault();this.handleMainClick(i)}};this.handleLeadingKeyDown=i=>{var t;if(this.disabled)return;if(i.key==="Enter"||i.key===" "){i.preventDefault();const s=(t=this.host.shadowRoot)===null||t===void 0?void 0:t.querySelector('slot[name="leading"]');const e=(s===null||s===void 0?void 0:s.assignedElements())||[];const n=e.find((i=>this.isInteractiveElement(i)));if(n){n.focus();n.click()}}};this.handleTrailingKeyDown=i=>{var t;if(this.disabled)return;if(i.key==="Enter"||i.key===" "){i.preventDefault();const s=(t=this.host.shadowRoot)===null||t===void 0?void 0:t.querySelector('slot[name="trailing"]');const e=(s===null||s===void 0?void 0:s.assignedElements())||[];const n=e.find((i=>this.isInteractiveElement(i)));if(n){n.focus();n.click()}}};this.updateSlotElementsDisabledState=()=>{const i=["ifx-checkbox","ifx-switch","ifx-button"];const t=this.host.querySelectorAll("[slot]");t.forEach((t=>{if(i.includes(t.tagName.toLowerCase())){this.setElementDisabledState(t)}i.forEach((i=>{const s=t.querySelectorAll(i);s.forEach((i=>{this.setElementDisabledState(i)}))}))}))};this.setElementDisabledState=i=>{if(this.disabled){i.setAttribute("disabled","true")}else{i.removeAttribute("disabled")}}}onDisabledChange(){this.updateSlotElementsDisabledState()}hasSlotContent(i){const t=this.host.querySelector(`[slot="${i}"]`);return!!t}componentDidLoad(){this.updateSlotElementsDisabledState()}componentDidUpdate(){this.updateSlotElementsDisabledState()}render(){const i=!this.disabled&&(this.href||this.value);const t=this.itemAriaLabel||`${this.itemTitle}${this.description?` - ${this.description}`:""}`;const e=this.hasSlotContent("leading");const o=this.hasSlotContent("trailing");return s("div",{key:"afc03036455ceb23a99e893ebdc36c052fcc2e64",class:n("action-list-item",this.disabled&&"action-list-item--disabled",i&&"action-list-item--clickable"),role:"listitem",tabIndex:i?0:-1,"aria-label":t,"aria-disabled":this.disabled?"true":undefined,onClick:this.handleMainClick,onKeyDown:this.handleMainKeyDown},e&&s("div",{key:"fbc09a625f124bdcf9137cde295838592925cc93",class:"action-list-item__leading",onClick:this.handleLeadingClick,onKeyDown:this.handleLeadingKeyDown},s("slot",{key:"915fb5467635e391ca3713def64ee031095e784d",name:"leading"})),s("div",{key:"589bd17dcd1f2de8ac7ac1c86db677c9b8eac35e",class:"action-list-item__content"},s("div",{key:"4b0ac3d7e1439cbe8682f9d14411acc4683b2ffe",class:"action-list-item__title"},this.itemTitle),this.description&&s("div",{key:"e5a0481505f637db1f7672fca5e1800a934d4270",class:"action-list-item__description"},this.description)),o&&s("div",{key:"c855aff75b5e1ddba37456c2225f46be3ae17429",class:"action-list-item__trailing",onClick:this.handleTrailingClick,onKeyDown:this.handleTrailingKeyDown},s("slot",{key:"68ff1e04f0bdf90894fa729619c7b7a6f896bad8",name:"trailing"})))}get host(){return e(this)}static get watchers(){return{disabled:["onDisabledChange"]}}};l.style=o;export{l as ifx_action_list_item};
2
+ //# sourceMappingURL=p-169f26ae.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["actionListItemCss","ActionListItem","constructor","hostRef","this","target","disabled","handleMainClick","event","preventDefault","stopPropagation","leadingElement","_a","host","shadowRoot","querySelector","trailingElement","_b","contains","ifxActionListItemClick","emit","value","href","component","window","open","location","handleLeadingClick","currentElement","isInteractiveElement","parentElement","handleTrailingClick","element","tagName","toUpperCase","interactiveInfineonComponents","includes","handleMainKeyDown","key","handleLeadingKeyDown","leadingSlot","assignedElements","firstInteractive","find","el","focus","click","handleTrailingKeyDown","trailingSlot","updateSlotElementsDisabledState","interactiveComponents","slots","querySelectorAll","forEach","slottedElement","toLowerCase","setElementDisabledState","componentTag","nestedElements","nestedElement","setAttribute","removeAttribute","onDisabledChange","hasSlotContent","slotName","slot","componentDidLoad","componentDidUpdate","render","isClickable","ariaLabel","itemAriaLabel","itemTitle","description","hasLeadingContent","hasTrailingContent","h","class","classNames","role","tabIndex","undefined","onClick","onKeyDown","name"],"sources":["src/components/action-list/action-list-item.scss?tag=ifx-action-list-item&encapsulation=shadow","src/components/action-list/action-list-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n.action-list-item {\n display: flex;\n align-items: center;\n padding: tokens.$ifxSpace100 tokens.$ifxSpace200;\n background: tokens.$ifxColorBaseWhite;\n transition: background-color 0.2s ease;\n cursor: default;\n\n &--clickable {\n cursor: pointer;\n\n &:hover:not(.action-list-item--disabled) {\n background: tokens.$ifxColorEngineering100;\n }\n\n &:focus:not(.action-list-item--disabled) {\n outline: none;\n //outline: 2px solid tokens.$ifxColorOcean500;\n //outline-offset: -2px;\n background: tokens.$ifxColorEngineering100;\n }\n\n &:active:not(.action-list-item--disabled) {\n background: tokens.$ifxColorEngineering200;\n }\n }\n\n &--disabled {\n // Apply disabled color to all slotted icons\n ::slotted(ifx-icon) {\n color: tokens.$ifxColorEngineering300;\n }\n\n // Also apply to nested icons within slotted elements\n ::slotted(*) {\n ifx-icon {\n color: tokens.$ifxColorEngineering300;\n }\n }\n }\n\n &__leading {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-right: tokens.$ifxSpace200;\n flex-shrink: 0;\n }\n\n &__content {\n flex: 1;\n min-width: 0; // Allows text to truncate\n }\n\n &__title {\n font-weight: tokens.$ifxFontWeightSemibold;\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n color: tokens.$ifxColorBaseBlack;\n\n // Truncate long titles\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n\n // Disabled state\n .action-list-item--disabled & {\n color: tokens.$ifxColorEngineering300;\n }\n }\n\n &__description {\n font-size: tokens.$ifxFontSizeS;\n line-height: tokens.$ifxLineHeightS;\n color: tokens.$ifxColorEngineering500;\n margin-top: tokens.$ifxSpace25;\n\n // Disabled state\n .action-list-item--disabled & {\n color: tokens.$ifxColorEngineering300;\n }\n }\n\n &__trailing {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-left: tokens.$ifxSpace200;\n flex-shrink: 0;\n gap: 16px;\n }\n}","import { Component, h, Prop, Element, Event, EventEmitter, Watch } from '@stencil/core';\nimport classNames from 'classnames';\n\nexport interface ActionListItemClickEvent {\n value?: string;\n href?: string;\n target?: string;\n component?: ActionListItem;\n}\n\n@Component({\n tag: 'ifx-action-list-item',\n styleUrl: 'action-list-item.scss',\n shadow: true,\n})\nexport class ActionListItem {\n @Element() host: HTMLElement;\n\n /**\n * The title text displayed in the item\n */\n @Prop() itemTitle: string;\n\n /**\n * The description text displayed below the title\n */\n @Prop() description?: string;\n\n /**\n * Value associated with this item\n */\n @Prop() value?: string;\n\n /**\n * URL to navigate to when item is clicked\n */\n @Prop() href?: string;\n\n /**\n * Target for the link navigation\n * @default '_self'\n */\n @Prop() target: string = '_self';\n\n /**\n * Controls whether the item is disabled\n * @default false\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Aria label for accessibility support\n */\n @Prop() itemAriaLabel?: string;\n\n /**\n * Event emitted when the main item area is clicked\n */\n @Event() ifxActionListItemClick: EventEmitter<ActionListItemClickEvent>;\n\n @Watch('disabled')\n onDisabledChange() {\n // Update interactive elements when disabled state changes\n this.updateSlotElementsDisabledState();\n }\n\n private handleMainClick = (event: MouseEvent) => {\n if (this.disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n // Check if clicked element is inside leading or trailing areas\n const leadingElement = this.host.shadowRoot?.querySelector('.action-list-item__leading');\n const trailingElement = this.host.shadowRoot?.querySelector('.action-list-item__trailing');\n\n if (leadingElement?.contains(event.target as Node) || trailingElement?.contains(event.target as Node)) {\n return; // Don't trigger main click if clicking on leading/trailing areas\n }\n\n // Always emit main event when clicking on content area (text), regardless of interactive elements\n this.ifxActionListItemClick.emit({\n value: this.value,\n href: this.href,\n target: this.target,\n component: this,\n });\n\n // If href is provided, automatically navigate (Link mode)\n // If no href is provided, only the event is emitted (Event mode)\n if (this.href) {\n if (this.target === '_blank') {\n window.open(this.href, this.target);\n } else {\n window.location.href = this.href;\n }\n }\n };\n\n private handleLeadingClick = (event: MouseEvent) => {\n if (this.disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n const target = event.target as HTMLElement;\n\n // Check if the clicked element or any of its parents is an interactive component\n let currentElement = target;\n while (currentElement && currentElement !== this.host) {\n if (this.isInteractiveElement(currentElement)) {\n // Interactive element clicked - stop propagation to prevent main event\n event.stopPropagation();\n return;\n }\n currentElement = currentElement.parentElement;\n }\n\n // Non-interactive element clicked - trigger main action\n event.stopPropagation();\n this.ifxActionListItemClick.emit({\n value: this.value,\n href: this.href,\n target: this.target,\n component: this,\n });\n\n // If href is provided, automatically navigate\n if (this.href) {\n if (this.target === '_blank') {\n window.open(this.href, this.target);\n } else {\n window.location.href = this.href;\n }\n }\n };\n\n private handleTrailingClick = (event: MouseEvent) => {\n if (this.disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n const target = event.target as HTMLElement;\n\n // Check if the clicked element or any of its parents is an interactive component\n let currentElement = target;\n while (currentElement && currentElement !== this.host) {\n if (this.isInteractiveElement(currentElement)) {\n // Interactive element clicked - stop propagation to prevent main event\n event.stopPropagation();\n return;\n }\n currentElement = currentElement.parentElement;\n }\n\n // Non-interactive element clicked - trigger main action\n event.stopPropagation();\n this.ifxActionListItemClick.emit({\n value: this.value,\n href: this.href,\n target: this.target,\n component: this,\n });\n\n // If href is provided, automatically navigate\n if (this.href) {\n if (this.target === '_blank') {\n window.open(this.href, this.target);\n } else {\n window.location.href = this.href;\n }\n }\n };\n\n private isInteractiveElement = (element: HTMLElement): boolean => {\n // Get the tag name, handling both custom elements and standard HTML\n const tagName = element.tagName.toUpperCase();\n\n // List of Infineon components that should block main event\n const interactiveInfineonComponents = [\n 'IFX-BUTTON',\n 'IFX-CHECKBOX',\n 'IFX-SWITCH'\n ];\n\n // Check if it's an interactive Infineon component\n return interactiveInfineonComponents.includes(tagName);\n };\n\n private handleMainKeyDown = (event: KeyboardEvent) => {\n if (this.disabled) return;\n\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n\n // Always trigger main action via keyboard, regardless of interactive elements\n this.handleMainClick(event as any);\n }\n };\n\n private handleLeadingKeyDown = (event: KeyboardEvent) => {\n if (this.disabled) return;\n\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n\n const leadingSlot = this.host.shadowRoot?.querySelector('slot[name=\"leading\"]') as HTMLSlotElement;\n const assignedElements = leadingSlot?.assignedElements() || [];\n\n // Find first interactive element and activate it\n const firstInteractive = assignedElements.find(el =>\n this.isInteractiveElement(el as HTMLElement)\n ) as HTMLElement;\n\n if (firstInteractive) {\n firstInteractive.focus();\n firstInteractive.click();\n }\n }\n };\n\n private handleTrailingKeyDown = (event: KeyboardEvent) => {\n if (this.disabled) return;\n\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n\n const trailingSlot = this.host.shadowRoot?.querySelector('slot[name=\"trailing\"]') as HTMLSlotElement;\n const assignedElements = trailingSlot?.assignedElements() || [];\n\n // Find first interactive element and activate it\n const firstInteractive = assignedElements.find(el =>\n this.isInteractiveElement(el as HTMLElement)\n ) as HTMLElement;\n\n if (firstInteractive) {\n firstInteractive.focus();\n firstInteractive.click();\n }\n }\n };\n\n private hasSlotContent(slotName: string): boolean {\n const slot = this.host.querySelector(`[slot=\"${slotName}\"]`);\n return !!slot;\n }\n\n componentDidLoad() {\n // Apply disabled state to interactive elements in slots\n this.updateSlotElementsDisabledState();\n }\n\n componentDidUpdate() {\n // Apply disabled state to interactive elements in slots when disabled prop changes\n this.updateSlotElementsDisabledState();\n }\n\n private updateSlotElementsDisabledState = () => {\n // Only handle interactive components that should be disabled\n const interactiveComponents = ['ifx-checkbox', 'ifx-switch', 'ifx-button'];\n\n // Get all slotted elements\n const slots = this.host.querySelectorAll('[slot]');\n\n slots.forEach(slottedElement => {\n // Check if the slotted element itself is an interactive component\n if (interactiveComponents.includes(slottedElement.tagName.toLowerCase())) {\n this.setElementDisabledState(slottedElement as HTMLElement);\n }\n\n // Also check for nested interactive components within the slotted element\n interactiveComponents.forEach(componentTag => {\n const nestedElements = slottedElement.querySelectorAll(componentTag);\n nestedElements.forEach(nestedElement => {\n this.setElementDisabledState(nestedElement as HTMLElement);\n });\n });\n });\n };\n\n private setElementDisabledState = (element: HTMLElement) => {\n if (this.disabled) {\n element.setAttribute('disabled', 'true');\n } else {\n element.removeAttribute('disabled');\n }\n }; render() {\n const isClickable = !this.disabled && (this.href || this.value);\n const ariaLabel = this.itemAriaLabel || `${this.itemTitle}${this.description ? ` - ${this.description}` : ''}`;\n const hasLeadingContent = this.hasSlotContent('leading');\n const hasTrailingContent = this.hasSlotContent('trailing');\n\n return (\n <div\n class={classNames(\n 'action-list-item',\n this.disabled && 'action-list-item--disabled',\n isClickable && 'action-list-item--clickable'\n )}\n role=\"listitem\"\n tabIndex={isClickable ? 0 : -1}\n aria-label={ariaLabel}\n aria-disabled={this.disabled ? 'true' : undefined}\n onClick={this.handleMainClick}\n onKeyDown={this.handleMainKeyDown}\n >\n {/* Leading Item Container - only render if content exists */}\n {hasLeadingContent && (\n <div\n class=\"action-list-item__leading\"\n onClick={this.handleLeadingClick}\n onKeyDown={this.handleLeadingKeyDown}\n >\n <slot name=\"leading\"></slot>\n </div>\n )}\n\n {/* Text Container */}\n <div class=\"action-list-item__content\">\n <div class=\"action-list-item__title\">\n {this.itemTitle}\n </div>\n {this.description && (\n <div class=\"action-list-item__description\">\n {this.description}\n </div>\n )}\n </div>\n\n {/* Trailing Item Container - only render if content exists */}\n {hasTrailingContent && (\n <div\n class=\"action-list-item__trailing\"\n onClick={this.handleTrailingClick}\n onKeyDown={this.handleTrailingKeyDown}\n >\n <slot name=\"trailing\"></slot>\n </div>\n )}\n </div>\n );\n }\n}"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["actionListItemCss","ActionListItem","constructor","hostRef","this","target","disabled","handleMainClick","event","preventDefault","stopPropagation","leadingElement","_a","host","shadowRoot","querySelector","trailingElement","_b","contains","ifxActionListItemClick","emit","value","href","component","window","open","location","handleLeadingClick","currentElement","isInteractiveElement","parentElement","handleTrailingClick","element","tagName","toUpperCase","interactiveInfineonComponents","includes","handleMainKeyDown","key","handleLeadingKeyDown","leadingSlot","assignedElements","firstInteractive","find","el","focus","click","handleTrailingKeyDown","trailingSlot","updateSlotElementsDisabledState","interactiveComponents","slots","querySelectorAll","forEach","slottedElement","toLowerCase","setElementDisabledState","componentTag","nestedElements","nestedElement","setAttribute","removeAttribute","onDisabledChange","hasSlotContent","slotName","slot","componentDidLoad","componentDidUpdate","render","isClickable","ariaLabel","itemAriaLabel","itemTitle","description","hasLeadingContent","hasTrailingContent","h","class","classNames","role","tabIndex","undefined","onClick","onKeyDown","name"],"sources":["src/components/action-list/action-list-item.scss?tag=ifx-action-list-item&encapsulation=shadow","src/components/action-list/action-list-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n.action-list-item {\n display: flex;\n align-items: center;\n padding: tokens.$ifxSpace100 tokens.$ifxSpace200;\n background: tokens.$ifxColorBaseWhite;\n transition: background-color 0.2s ease;\n cursor: default;\n\n &--clickable {\n cursor: pointer;\n\n &:hover:not(.action-list-item--disabled) {\n background: tokens.$ifxColorEngineering100;\n }\n\n &:focus:not(.action-list-item--disabled) {\n outline: none;\n //outline: 2px solid tokens.$ifxColorOcean500;\n //outline-offset: -2px;\n background: tokens.$ifxColorEngineering100;\n }\n\n &:active:not(.action-list-item--disabled) {\n background: tokens.$ifxColorEngineering200;\n }\n }\n\n &--disabled {\n // Apply disabled color to all slotted icons\n ::slotted(ifx-icon) {\n color: tokens.$ifxColorEngineering300;\n }\n\n // Also apply to nested icons within slotted elements\n ::slotted(*) {\n ifx-icon {\n color: tokens.$ifxColorEngineering300;\n }\n }\n }\n\n &__leading {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-right: tokens.$ifxSpace200;\n flex-shrink: 0;\n }\n\n &__content {\n flex: 1;\n min-width: 0; // Allows text to truncate\n }\n\n &__title {\n font-weight: tokens.$ifxFontWeightSemibold;\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n color: tokens.$ifxColorBaseBlack;\n\n // Truncate long titles\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n\n // Disabled state\n .action-list-item--disabled & {\n color: tokens.$ifxColorEngineering300;\n }\n }\n\n &__description {\n font-size: tokens.$ifxFontSizeS;\n line-height: tokens.$ifxLineHeightS;\n color: tokens.$ifxColorEngineering500;\n margin-top: tokens.$ifxSpace25;\n\n // Disabled state\n .action-list-item--disabled & {\n color: tokens.$ifxColorEngineering300;\n }\n }\n\n &__trailing {\n display: flex;\n align-items: center;\n justify-content: center;\n margin-left: tokens.$ifxSpace200;\n flex-shrink: 0;\n gap: 16px;\n }\n}","import { Component, h, Prop, Element, Event, EventEmitter, Watch } from '@stencil/core';\nimport classNames from 'classnames';\n\nexport interface ActionListItemClickEvent {\n value?: string;\n href?: string;\n target?: string;\n component?: ActionListItem;\n}\n\n@Component({\n tag: 'ifx-action-list-item',\n styleUrl: 'action-list-item.scss',\n shadow: true,\n})\nexport class ActionListItem {\n @Element() host: HTMLElement;\n\n /**\n * The title text displayed in the item\n */\n @Prop() itemTitle: string;\n\n /**\n * The description text displayed below the title\n */\n @Prop() description?: string;\n\n /**\n * Value associated with this item\n */\n @Prop() value?: string;\n\n /**\n * URL to navigate to when item is clicked\n */\n @Prop() href?: string;\n\n /**\n * Target for the link navigation\n * @default '_self'\n */\n @Prop() target: string = '_self';\n\n /**\n * Controls whether the item is disabled\n * @default false\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Aria label for accessibility support\n */\n @Prop() itemAriaLabel?: string;\n\n /**\n * Event emitted when the main item area is clicked\n */\n @Event() ifxActionListItemClick: EventEmitter<ActionListItemClickEvent>;\n\n @Watch('disabled')\n onDisabledChange() {\n // Update interactive elements when disabled state changes\n this.updateSlotElementsDisabledState();\n }\n\n private handleMainClick = (event: MouseEvent) => {\n if (this.disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n // Check if clicked element is inside leading or trailing areas\n const leadingElement = this.host.shadowRoot?.querySelector('.action-list-item__leading');\n const trailingElement = this.host.shadowRoot?.querySelector('.action-list-item__trailing');\n\n if (leadingElement?.contains(event.target as Node) || trailingElement?.contains(event.target as Node)) {\n return; // Don't trigger main click if clicking on leading/trailing areas\n }\n\n // Always emit main event when clicking on content area (text), regardless of interactive elements\n this.ifxActionListItemClick.emit({\n value: this.value,\n href: this.href,\n target: this.target,\n component: this,\n });\n\n // If href is provided, automatically navigate (Link mode)\n // If no href is provided, only the event is emitted (Event mode)\n if (this.href) {\n if (this.target === '_blank') {\n window.open(this.href, this.target);\n } else {\n window.location.href = this.href;\n }\n }\n };\n\n private handleLeadingClick = (event: MouseEvent) => {\n if (this.disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n const target = event.target as HTMLElement;\n\n // Check if the clicked element or any of its parents is an interactive component\n let currentElement = target;\n while (currentElement && currentElement !== this.host) {\n if (this.isInteractiveElement(currentElement)) {\n // Interactive element clicked - stop propagation to prevent main event\n event.stopPropagation();\n return;\n }\n currentElement = currentElement.parentElement;\n }\n\n // Non-interactive element clicked - trigger main action\n event.stopPropagation();\n this.ifxActionListItemClick.emit({\n value: this.value,\n href: this.href,\n target: this.target,\n component: this,\n });\n\n // If href is provided, automatically navigate\n if (this.href) {\n if (this.target === '_blank') {\n window.open(this.href, this.target);\n } else {\n window.location.href = this.href;\n }\n }\n };\n\n private handleTrailingClick = (event: MouseEvent) => {\n if (this.disabled) {\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n const target = event.target as HTMLElement;\n\n // Check if the clicked element or any of its parents is an interactive component\n let currentElement = target;\n while (currentElement && currentElement !== this.host) {\n if (this.isInteractiveElement(currentElement)) {\n // Interactive element clicked - stop propagation to prevent main event\n event.stopPropagation();\n return;\n }\n currentElement = currentElement.parentElement;\n }\n\n // Non-interactive element clicked - trigger main action\n event.stopPropagation();\n this.ifxActionListItemClick.emit({\n value: this.value,\n href: this.href,\n target: this.target,\n component: this,\n });\n\n // If href is provided, automatically navigate\n if (this.href) {\n if (this.target === '_blank') {\n window.open(this.href, this.target);\n } else {\n window.location.href = this.href;\n }\n }\n };\n\n private isInteractiveElement = (element: HTMLElement): boolean => {\n // Get the tag name, handling both custom elements and standard HTML\n const tagName = element.tagName.toUpperCase();\n\n // List of Infineon components that should block main event\n const interactiveInfineonComponents = [\n 'IFX-BUTTON',\n 'IFX-CHECKBOX',\n 'IFX-SWITCH'\n ];\n\n // Check if it's an interactive Infineon component\n return interactiveInfineonComponents.includes(tagName);\n };\n\n private handleMainKeyDown = (event: KeyboardEvent) => {\n if (this.disabled) return;\n\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n\n // Always trigger main action via keyboard, regardless of interactive elements\n this.handleMainClick(event as any);\n }\n };\n\n private handleLeadingKeyDown = (event: KeyboardEvent) => {\n if (this.disabled) return;\n\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n\n const leadingSlot = this.host.shadowRoot?.querySelector('slot[name=\"leading\"]') as HTMLSlotElement;\n const assignedElements = leadingSlot?.assignedElements() || [];\n\n // Find first interactive element and activate it\n const firstInteractive = assignedElements.find(el =>\n this.isInteractiveElement(el as HTMLElement)\n ) as HTMLElement;\n\n if (firstInteractive) {\n firstInteractive.focus();\n firstInteractive.click();\n }\n }\n };\n\n private handleTrailingKeyDown = (event: KeyboardEvent) => {\n if (this.disabled) return;\n\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n\n const trailingSlot = this.host.shadowRoot?.querySelector('slot[name=\"trailing\"]') as HTMLSlotElement;\n const assignedElements = trailingSlot?.assignedElements() || [];\n\n // Find first interactive element and activate it\n const firstInteractive = assignedElements.find(el =>\n this.isInteractiveElement(el as HTMLElement)\n ) as HTMLElement;\n\n if (firstInteractive) {\n firstInteractive.focus();\n firstInteractive.click();\n }\n }\n };\n\n private hasSlotContent(slotName: string): boolean {\n const slot = this.host.querySelector(`[slot=\"${slotName}\"]`);\n return !!slot;\n }\n\n componentDidLoad() {\n // Apply disabled state to interactive elements in slots\n this.updateSlotElementsDisabledState();\n }\n\n componentDidUpdate() {\n // Apply disabled state to interactive elements in slots when disabled prop changes\n this.updateSlotElementsDisabledState();\n }\n\n private updateSlotElementsDisabledState = () => {\n // Only handle interactive components that should be disabled\n const interactiveComponents = ['ifx-checkbox', 'ifx-switch', 'ifx-button'];\n\n // Get all slotted elements\n const slots = this.host.querySelectorAll('[slot]');\n\n slots.forEach(slottedElement => {\n // Check if the slotted element itself is an interactive component\n if (interactiveComponents.includes(slottedElement.tagName.toLowerCase())) {\n this.setElementDisabledState(slottedElement as HTMLElement);\n }\n\n // Also check for nested interactive components within the slotted element\n interactiveComponents.forEach(componentTag => {\n const nestedElements = slottedElement.querySelectorAll(componentTag);\n nestedElements.forEach(nestedElement => {\n this.setElementDisabledState(nestedElement as HTMLElement);\n });\n });\n });\n };\n\n private setElementDisabledState = (element: HTMLElement) => {\n if (this.disabled) {\n element.setAttribute('disabled', 'true');\n } else {\n element.removeAttribute('disabled');\n }\n }; render() {\n const isClickable = !this.disabled && (this.href || this.value);\n const ariaLabel = this.itemAriaLabel || `${this.itemTitle}${this.description ? ` - ${this.description}` : ''}`;\n const hasLeadingContent = this.hasSlotContent('leading');\n const hasTrailingContent = this.hasSlotContent('trailing');\n\n return (\n <div\n class={classNames(\n 'action-list-item',\n this.disabled && 'action-list-item--disabled',\n isClickable && 'action-list-item--clickable'\n )}\n role=\"listitem\"\n tabIndex={isClickable ? 0 : -1}\n aria-label={ariaLabel}\n aria-disabled={this.disabled ? 'true' : undefined}\n onClick={this.handleMainClick}\n onKeyDown={this.handleMainKeyDown}\n >\n {/* Leading Item Container - only render if content exists */}\n {hasLeadingContent && (\n <div\n class=\"action-list-item__leading\"\n onClick={this.handleLeadingClick}\n onKeyDown={this.handleLeadingKeyDown}\n >\n <slot name=\"leading\"></slot>\n </div>\n )}\n\n {/* Text Container */}\n <div class=\"action-list-item__content\">\n <div class=\"action-list-item__title\">\n {this.itemTitle}\n </div>\n {this.description && (\n <div class=\"action-list-item__description\">\n {this.description}\n </div>\n )}\n </div>\n\n {/* Trailing Item Container - only render if content exists */}\n {hasTrailingContent && (\n <div\n class=\"action-list-item__trailing\"\n onClick={this.handleTrailingClick}\n onKeyDown={this.handleTrailingKeyDown}\n >\n <slot name=\"trailing\"></slot>\n </div>\n )}\n </div>\n );\n }\n}"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as i,c as o,h as t,a as e}from"./p-PqnYwNKt.js";const n=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}.dropdown-item{text-decoration:none;color:#1D1D1D;display:flex;align-items:center;padding:8px 16px;gap:8px;font-family:var(--ifx-font-family)}.dropdown-item:focus{outline:none;box-shadow:0 0 0 2px #FFFFFF, 0 0 0 4px #0A8276}.dropdown-item.hide{display:none}.dropdown-item span{color:#1D1D1D;font-size:16px;font-style:normal;font-weight:400;line-height:24px;}.dropdown-item.small span{font-size:14px}.dropdown-item:hover{cursor:pointer;background-color:#EEEDED}.dropdown-item:active{background-color:#BFBBBB}.icon{margin-right:4px}';const s=class{constructor(t){i(this,t);this.ifxDropdownItem=o(this,"ifxDropdownItem",7);this.href="";this.target="_self";this.hide=false;this.size="l"}handleMenuSize(i){this.size=i.detail}handleEventEmission(){this.ifxDropdownItem.emit(this.el.textContent)}render(){const i=this.href!==undefined&&this.href!==null&&this.href!=="";const o={class:`dropdown-item ${this.size==="s"?"small":""} ${this.hide?"hide":""}`,onClick:()=>this.handleEventEmission(),role:"menuitem"};if(!i)o.tabIndex=0;return t("a",Object.assign({key:"0fa61b25ba8f7f8dec6828def32fca24c753970b"},o,i?{href:this.href,target:this.target}:{}),this.icon&&t("ifx-icon",{key:"7676baff54e17a8ac7a3de6a47fb00e773b80718",class:"icon",icon:this.icon}),t("span",{key:"a2b3213b15b3e0d0b40c12cf7863158f5233c400"},t("slot",{key:"b0c64b7c89c088900c65736450ebb366fcccad3c"})))}get el(){return e(this)}};s.style=n;export{s as ifx_dropdown_item};
2
+ //# sourceMappingURL=p-1c1b1a1f.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["dropdownItemCss","DropdownItem","constructor","hostRef","this","href","target","hide","size","handleMenuSize","event","detail","handleEventEmission","ifxDropdownItem","emit","el","textContent","render","hasHref","undefined","common","class","onClick","role","tabIndex","h","Object","assign","key","icon"],"sources":["src/components/dropdown/dropdown-item/dropdown-item.scss?tag=ifx-dropdown-item&encapsulation=shadow","src/components/dropdown/dropdown-item/dropdown-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../../global/font.scss\";\n\n.dropdown-item {\n text-decoration: none;\n color: tokens.$ifxColorBaseBlack;\n display: flex;\n align-items: center;\n padding: 8px 16px;\n gap: tokens.$ifxSize100;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n &:focus{\n outline: none;\n box-shadow: 0 0 0 2px tokens.$ifxColorBaseWhite, 0 0 0 4px tokens.$ifxColorOcean500;\n }\n\n &.hide {\n display: none;\n }\n\n & span {\n color: tokens.$ifxColorBaseBlack;\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 24px;\n /* 150% */\n }\n\n &.small {\n & span {\n font-size: 14px;\n }\n }\n\n &:hover {\n cursor: pointer;\n background-color: tokens.$ifxColorEngineering200;\n }\n\n &:active {\n background-color: tokens.$ifxColorEngineering300;\n }\n}\n\n.icon {\n margin-right: 4px;\n}","import { Component, Prop, h, Listen, State, Event, EventEmitter, Element } from \"@stencil/core\";\n\n@Component({\n tag: 'ifx-dropdown-item',\n styleUrl: 'dropdown-item.scss',\n shadow: true\n})\n\nexport class DropdownItem {\n @Prop() icon: string;\n @Prop() href: string = \"\"\n @Prop() target: string = \"_self\"\n @Prop() hide: boolean = false;\n @State() size: string = 'l'\n @Event() ifxDropdownItem: EventEmitter;\n @Element() el;\n\n @Listen('menuSize', { target: 'body' })\n handleMenuSize(event: CustomEvent) {\n this.size = event.detail;\n }\n\n handleEventEmission() {\n this.ifxDropdownItem.emit(this.el.textContent)\n }\n\n render() {\n const hasHref = this.href !== undefined && this.href !== null && this.href !== '';\n const common = {\n class: `dropdown-item ${this.size === 's' ? 'small' : \"\"} ${this.hide ? 'hide' : \"\"}`,\n onClick: () => this.handleEventEmission(),\n role: 'menuitem'\n } as any;\n\n if (!hasHref) common.tabIndex = 0;\n\n return (\n <a {...common} {...(hasHref ? { href: this.href, target: this.target } : {})}>\n {this.icon && <ifx-icon class=\"icon\" icon={this.icon}></ifx-icon>}\n <span><slot /></span>\n </a>\n );\n }\n}\n"],"mappings":"yDAAA,MAAMA,EAAkB,olB,MCQXC,EAAY,MANzB,WAAAC,CAAAC,G,2DAQUC,KAAIC,KAAW,GACfD,KAAME,OAAW,QACjBF,KAAIG,KAAY,MACfH,KAAII,KAAW,GA8BzB,CAzBC,cAAAC,CAAeC,GACbN,KAAKI,KAAOE,EAAMC,M,CAGpB,mBAAAC,GACER,KAAKS,gBAAgBC,KAAKV,KAAKW,GAAGC,Y,CAGpC,MAAAC,GACE,MAAMC,EAAUd,KAAKC,OAASc,WAAaf,KAAKC,OAAS,MAAQD,KAAKC,OAAS,GAC/E,MAAMe,EAAS,CACbC,MAAO,iBAAiBjB,KAAKI,OAAS,IAAM,QAAU,MAAMJ,KAAKG,KAAO,OAAS,KACjFe,QAAS,IAAMlB,KAAKQ,sBACpBW,KAAM,YAGR,IAAKL,EAASE,EAAOI,SAAW,EAEhC,OACEC,EAAO,IAAAC,OAAAC,OAAA,CAAAC,IAAA,4CAAAR,EAAaF,EAAU,CAAEb,KAAMD,KAAKC,KAAMC,OAAQF,KAAKE,QAAW,IACtEF,KAAKyB,MAAQJ,EAAA,YAAAG,IAAA,2CAAUP,MAAM,OAAOQ,KAAMzB,KAAKyB,OAChDJ,EAAA,QAAAG,IAAA,4CAAMH,EAAQ,QAAAG,IAAA,8C","ignoreList":[]}
1
+ {"version":3,"names":["dropdownItemCss","DropdownItem","constructor","hostRef","this","href","target","hide","size","handleMenuSize","event","detail","handleEventEmission","ifxDropdownItem","emit","el","textContent","render","hasHref","undefined","common","class","onClick","role","tabIndex","h","Object","assign","key","icon"],"sources":["src/components/dropdown/dropdown-item/dropdown-item.scss?tag=ifx-dropdown-item&encapsulation=shadow","src/components/dropdown/dropdown-item/dropdown-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../../global/font.scss\";\n\n.dropdown-item {\n text-decoration: none;\n color: tokens.$ifxColorBaseBlack;\n display: flex;\n align-items: center;\n padding: 8px 16px;\n gap: tokens.$ifxSize100;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n &:focus{\n outline: none;\n box-shadow: 0 0 0 2px tokens.$ifxColorBaseWhite, 0 0 0 4px tokens.$ifxColorOcean500;\n }\n\n &.hide {\n display: none;\n }\n\n & span {\n color: tokens.$ifxColorBaseBlack;\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 24px;\n /* 150% */\n }\n\n &.small {\n & span {\n font-size: 14px;\n }\n }\n\n &:hover {\n cursor: pointer;\n background-color: tokens.$ifxColorEngineering200;\n }\n\n &:active {\n background-color: tokens.$ifxColorEngineering300;\n }\n}\n\n.icon {\n margin-right: 4px;\n}","import { Component, Prop, h, Listen, State, Event, EventEmitter, Element } from \"@stencil/core\";\n\n@Component({\n tag: 'ifx-dropdown-item',\n styleUrl: 'dropdown-item.scss',\n shadow: true\n})\n\nexport class DropdownItem {\n @Prop() icon: string;\n @Prop() href: string = \"\"\n @Prop() target: string = \"_self\"\n @Prop() hide: boolean = false;\n @State() size: string = 'l'\n @Event() ifxDropdownItem: EventEmitter;\n @Element() el;\n\n @Listen('menuSize', { target: 'body' })\n handleMenuSize(event: CustomEvent) {\n this.size = event.detail;\n }\n\n handleEventEmission() {\n this.ifxDropdownItem.emit(this.el.textContent)\n }\n\n render() {\n const hasHref = this.href !== undefined && this.href !== null && this.href !== '';\n const common = {\n class: `dropdown-item ${this.size === 's' ? 'small' : \"\"} ${this.hide ? 'hide' : \"\"}`,\n onClick: () => this.handleEventEmission(),\n role: 'menuitem'\n } as any;\n\n if (!hasHref) common.tabIndex = 0;\n\n return (\n <a {...common} {...(hasHref ? { href: this.href, target: this.target } : {})}>\n {this.icon && <ifx-icon class=\"icon\" icon={this.icon}></ifx-icon>}\n <span><slot /></span>\n </a>\n );\n }\n}\n"],"mappings":"yDAAA,MAAMA,EAAkB,klB,MCQXC,EAAY,MANzB,WAAAC,CAAAC,G,2DAQUC,KAAIC,KAAW,GACfD,KAAME,OAAW,QACjBF,KAAIG,KAAY,MACfH,KAAII,KAAW,GA8BzB,CAzBC,cAAAC,CAAeC,GACbN,KAAKI,KAAOE,EAAMC,M,CAGpB,mBAAAC,GACER,KAAKS,gBAAgBC,KAAKV,KAAKW,GAAGC,Y,CAGpC,MAAAC,GACE,MAAMC,EAAUd,KAAKC,OAASc,WAAaf,KAAKC,OAAS,MAAQD,KAAKC,OAAS,GAC/E,MAAMe,EAAS,CACbC,MAAO,iBAAiBjB,KAAKI,OAAS,IAAM,QAAU,MAAMJ,KAAKG,KAAO,OAAS,KACjFe,QAAS,IAAMlB,KAAKQ,sBACpBW,KAAM,YAGR,IAAKL,EAASE,EAAOI,SAAW,EAEhC,OACEC,EAAO,IAAAC,OAAAC,OAAA,CAAAC,IAAA,4CAAAR,EAAaF,EAAU,CAAEb,KAAMD,KAAKC,KAAMC,OAAQF,KAAKE,QAAW,IACtEF,KAAKyB,MAAQJ,EAAA,YAAAG,IAAA,2CAAUP,MAAM,OAAOQ,KAAMzB,KAAKyB,OAChDJ,EAAA,QAAAG,IAAA,4CAAMH,EAAQ,QAAAG,IAAA,8C","ignoreList":[]}