@infineon/infineon-design-system-stencil 39.4.4-canary.0 → 39.5.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 (1210) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +452 -452
  3. package/dist/cjs/dom-utils-dykhxr-_.js.map +1 -1
  4. package/dist/cjs/framework-detection-C_6nNXcS.js.map +1 -1
  5. package/dist/cjs/ifx-accordion.ifx-accordion-item.entry.cjs.js.map +1 -1
  6. package/dist/cjs/ifx-accordion_2.cjs.entry.js +2 -2
  7. package/dist/cjs/ifx-accordion_2.cjs.entry.js.map +1 -1
  8. package/dist/cjs/ifx-action-list-item.cjs.entry.js +1 -1
  9. package/dist/cjs/ifx-action-list-item.cjs.entry.js.map +1 -1
  10. package/dist/cjs/ifx-action-list-item.entry.cjs.js.map +1 -1
  11. package/dist/cjs/ifx-action-list.cjs.entry.js +1 -1
  12. package/dist/cjs/ifx-action-list.cjs.entry.js.map +1 -1
  13. package/dist/cjs/ifx-action-list.entry.cjs.js.map +1 -1
  14. package/dist/cjs/ifx-alert.ifx-template.entry.cjs.js.map +1 -1
  15. package/dist/cjs/ifx-alert_2.cjs.entry.js +1 -1
  16. package/dist/cjs/ifx-alert_2.cjs.entry.js.map +1 -1
  17. package/dist/cjs/ifx-basic-table.cjs.entry.js +7 -7
  18. package/dist/cjs/ifx-basic-table.cjs.entry.js.map +1 -1
  19. package/dist/cjs/ifx-basic-table.entry.cjs.js.map +1 -1
  20. package/dist/cjs/ifx-breadcrumb-item-label.cjs.entry.js +1 -1
  21. package/dist/cjs/ifx-breadcrumb-item-label.cjs.entry.js.map +1 -1
  22. package/dist/cjs/ifx-breadcrumb-item-label.entry.cjs.js.map +1 -1
  23. package/dist/cjs/ifx-breadcrumb-item.cjs.entry.js +1 -1
  24. package/dist/cjs/ifx-breadcrumb-item.cjs.entry.js.map +1 -1
  25. package/dist/cjs/ifx-breadcrumb-item.entry.cjs.js.map +1 -1
  26. package/dist/cjs/ifx-breadcrumb.cjs.entry.js +1 -1
  27. package/dist/cjs/ifx-breadcrumb.cjs.entry.js.map +1 -1
  28. package/dist/cjs/ifx-breadcrumb.entry.cjs.js.map +1 -1
  29. package/dist/cjs/ifx-button.cjs.entry.js +1 -1
  30. package/dist/cjs/ifx-button.cjs.entry.js.map +1 -1
  31. package/dist/cjs/ifx-button.entry.cjs.js.map +1 -1
  32. package/dist/cjs/ifx-card-headline.cjs.entry.js +1 -1
  33. package/dist/cjs/ifx-card-headline.cjs.entry.js.map +1 -1
  34. package/dist/cjs/ifx-card-headline.entry.cjs.js.map +1 -1
  35. package/dist/cjs/ifx-card-image.cjs.entry.js +1 -1
  36. package/dist/cjs/ifx-card-image.cjs.entry.js.map +1 -1
  37. package/dist/cjs/ifx-card-image.entry.cjs.js.map +1 -1
  38. package/dist/cjs/ifx-card-links.cjs.entry.js +1 -1
  39. package/dist/cjs/ifx-card-links.cjs.entry.js.map +1 -1
  40. package/dist/cjs/ifx-card-links.entry.cjs.js.map +1 -1
  41. package/dist/cjs/ifx-card-overline.cjs.entry.js +1 -1
  42. package/dist/cjs/ifx-card-overline.cjs.entry.js.map +1 -1
  43. package/dist/cjs/ifx-card-overline.entry.cjs.js.map +1 -1
  44. package/dist/cjs/ifx-card-text.cjs.entry.js +1 -1
  45. package/dist/cjs/ifx-card-text.cjs.entry.js.map +1 -1
  46. package/dist/cjs/ifx-card-text.entry.cjs.js.map +1 -1
  47. package/dist/cjs/ifx-card.cjs.entry.js +5 -5
  48. package/dist/cjs/ifx-card.cjs.entry.js.map +1 -1
  49. package/dist/cjs/ifx-card.entry.cjs.js.map +1 -1
  50. package/dist/cjs/ifx-checkbox-group.cjs.entry.js +1 -1
  51. package/dist/cjs/ifx-checkbox-group.cjs.entry.js.map +1 -1
  52. package/dist/cjs/ifx-checkbox-group.entry.cjs.js.map +1 -1
  53. package/dist/cjs/ifx-checkbox.cjs.entry.js +6 -6
  54. package/dist/cjs/ifx-checkbox.cjs.entry.js.map +1 -1
  55. package/dist/cjs/ifx-checkbox.entry.cjs.js.map +1 -1
  56. package/dist/cjs/ifx-chip.ifx-chip-item.ifx-pagination.entry.cjs.js.map +1 -1
  57. package/dist/cjs/ifx-chip_3.cjs.entry.js +15 -15
  58. package/dist/cjs/ifx-chip_3.cjs.entry.js.map +1 -1
  59. package/dist/cjs/ifx-content-switcher-item.cjs.entry.js +1 -1
  60. package/dist/cjs/ifx-content-switcher-item.cjs.entry.js.map +1 -1
  61. package/dist/cjs/ifx-content-switcher-item.entry.cjs.js.map +1 -1
  62. package/dist/cjs/ifx-content-switcher.cjs.entry.js +1 -1
  63. package/dist/cjs/ifx-content-switcher.cjs.entry.js.map +1 -1
  64. package/dist/cjs/ifx-content-switcher.entry.cjs.js.map +1 -1
  65. package/dist/cjs/ifx-date-picker.cjs.entry.js +2 -2
  66. package/dist/cjs/ifx-date-picker.cjs.entry.js.map +1 -1
  67. package/dist/cjs/ifx-date-picker.entry.cjs.js.map +1 -1
  68. package/dist/cjs/ifx-download.cjs.entry.js +2 -2
  69. package/dist/cjs/ifx-download.cjs.entry.js.map +1 -1
  70. package/dist/cjs/ifx-download.entry.cjs.js.map +1 -1
  71. package/dist/cjs/ifx-dropdown-header.cjs.entry.js +1 -1
  72. package/dist/cjs/ifx-dropdown-header.cjs.entry.js.map +1 -1
  73. package/dist/cjs/ifx-dropdown-header.entry.cjs.js.map +1 -1
  74. package/dist/cjs/ifx-dropdown-item.cjs.entry.js +1 -1
  75. package/dist/cjs/ifx-dropdown-item.cjs.entry.js.map +1 -1
  76. package/dist/cjs/ifx-dropdown-item.entry.cjs.js.map +1 -1
  77. package/dist/cjs/ifx-dropdown-menu.cjs.entry.js +4 -4
  78. package/dist/cjs/ifx-dropdown-menu.cjs.entry.js.map +1 -1
  79. package/dist/cjs/ifx-dropdown-menu.entry.cjs.js.map +1 -1
  80. package/dist/cjs/ifx-dropdown-separator.cjs.entry.js +1 -1
  81. package/dist/cjs/ifx-dropdown-separator.cjs.entry.js.map +1 -1
  82. package/dist/cjs/ifx-dropdown-separator.entry.cjs.js.map +1 -1
  83. package/dist/cjs/ifx-dropdown-trigger-button.cjs.entry.js +2 -2
  84. package/dist/cjs/ifx-dropdown-trigger-button.cjs.entry.js.map +1 -1
  85. package/dist/cjs/ifx-dropdown-trigger-button.entry.cjs.js.map +1 -1
  86. package/dist/cjs/ifx-dropdown-trigger.cjs.entry.js +1 -1
  87. package/dist/cjs/ifx-dropdown-trigger.cjs.entry.js.map +1 -1
  88. package/dist/cjs/ifx-dropdown-trigger.entry.cjs.js.map +1 -1
  89. package/dist/cjs/ifx-dropdown.cjs.entry.js +1 -1
  90. package/dist/cjs/ifx-dropdown.cjs.entry.js.map +1 -1
  91. package/dist/cjs/ifx-dropdown.entry.cjs.js.map +1 -1
  92. package/dist/cjs/ifx-faq.cjs.entry.js +1 -1
  93. package/dist/cjs/ifx-faq.cjs.entry.js.map +1 -1
  94. package/dist/cjs/ifx-faq.entry.cjs.js.map +1 -1
  95. package/dist/cjs/ifx-file-upload.cjs.entry.js +2 -2
  96. package/dist/cjs/ifx-file-upload.cjs.entry.js.map +1 -1
  97. package/dist/cjs/ifx-file-upload.entry.cjs.js.map +1 -1
  98. package/dist/cjs/ifx-filter-accordion.cjs.entry.js +2 -2
  99. package/dist/cjs/ifx-filter-accordion.cjs.entry.js.map +1 -1
  100. package/dist/cjs/ifx-filter-accordion.entry.cjs.js.map +1 -1
  101. package/dist/cjs/ifx-filter-bar.cjs.entry.js +1 -1
  102. package/dist/cjs/ifx-filter-bar.cjs.entry.js.map +1 -1
  103. package/dist/cjs/ifx-filter-bar.entry.cjs.js.map +1 -1
  104. package/dist/cjs/ifx-filter-search.cjs.entry.js +1 -1
  105. package/dist/cjs/ifx-filter-search.cjs.entry.js.map +1 -1
  106. package/dist/cjs/ifx-filter-search.entry.cjs.js.map +1 -1
  107. package/dist/cjs/ifx-filter-type-group.cjs.entry.js +1 -1
  108. package/dist/cjs/ifx-filter-type-group.cjs.entry.js.map +1 -1
  109. package/dist/cjs/ifx-filter-type-group.entry.cjs.js.map +1 -1
  110. package/dist/cjs/ifx-footer-column.cjs.entry.js +1 -1
  111. package/dist/cjs/ifx-footer-column.cjs.entry.js.map +1 -1
  112. package/dist/cjs/ifx-footer-column.entry.cjs.js.map +1 -1
  113. package/dist/cjs/ifx-footer.cjs.entry.js +4 -4
  114. package/dist/cjs/ifx-footer.cjs.entry.js.map +1 -1
  115. package/dist/cjs/ifx-footer.entry.cjs.js.map +1 -1
  116. package/dist/cjs/ifx-icon-button.cjs.entry.js +1 -1
  117. package/dist/cjs/ifx-icon-button.cjs.entry.js.map +1 -1
  118. package/dist/cjs/ifx-icon-button.entry.cjs.js.map +1 -1
  119. package/dist/cjs/ifx-icon.cjs.entry.js +1 -1
  120. package/dist/cjs/ifx-icon.cjs.entry.js.map +1 -1
  121. package/dist/cjs/ifx-icon.entry.cjs.js.map +1 -1
  122. package/dist/cjs/ifx-icons-preview.cjs.entry.js +1 -1
  123. package/dist/cjs/ifx-icons-preview.cjs.entry.js.map +1 -1
  124. package/dist/cjs/ifx-icons-preview.entry.cjs.js.map +1 -1
  125. package/dist/cjs/ifx-indicator.cjs.entry.js +2 -2
  126. package/dist/cjs/ifx-indicator.cjs.entry.js.map +1 -1
  127. package/dist/cjs/ifx-indicator.entry.cjs.js.map +1 -1
  128. package/dist/cjs/ifx-link.cjs.entry.js +1 -1
  129. package/dist/cjs/ifx-link.cjs.entry.js.map +1 -1
  130. package/dist/cjs/ifx-link.entry.cjs.js.map +1 -1
  131. package/dist/cjs/ifx-list-entry.cjs.entry.js +1 -1
  132. package/dist/cjs/ifx-list-entry.cjs.entry.js.map +1 -1
  133. package/dist/cjs/ifx-list-entry.entry.cjs.js.map +1 -1
  134. package/dist/cjs/ifx-list.cjs.entry.js.map +1 -1
  135. package/dist/cjs/ifx-list.entry.cjs.js.map +1 -1
  136. package/dist/cjs/ifx-modal.cjs.entry.js +2 -2
  137. package/dist/cjs/ifx-modal.cjs.entry.js.map +1 -1
  138. package/dist/cjs/ifx-modal.entry.cjs.js.map +1 -1
  139. package/dist/cjs/ifx-multiselect.ifx-multiselect-option.entry.cjs.js.map +1 -1
  140. package/dist/cjs/ifx-multiselect_2.cjs.entry.js +14 -14
  141. package/dist/cjs/ifx-multiselect_2.cjs.entry.js.map +1 -1
  142. package/dist/cjs/ifx-navbar-item.cjs.entry.js +5 -5
  143. package/dist/cjs/ifx-navbar-item.cjs.entry.js.map +1 -1
  144. package/dist/cjs/ifx-navbar-item.entry.cjs.js.map +1 -1
  145. package/dist/cjs/ifx-navbar-profile.cjs.entry.js +6 -6
  146. package/dist/cjs/ifx-navbar-profile.cjs.entry.js.map +1 -1
  147. package/dist/cjs/ifx-navbar-profile.entry.cjs.js.map +1 -1
  148. package/dist/cjs/ifx-navbar.cjs.entry.js +3 -3
  149. package/dist/cjs/ifx-navbar.cjs.entry.js.map +1 -1
  150. package/dist/cjs/ifx-navbar.entry.cjs.js.map +1 -1
  151. package/dist/cjs/ifx-notification.cjs.entry.js +2 -2
  152. package/dist/cjs/ifx-notification.cjs.entry.js.map +1 -1
  153. package/dist/cjs/ifx-notification.entry.cjs.js.map +1 -1
  154. package/dist/cjs/ifx-overview-table.cjs.entry.js +1 -1
  155. package/dist/cjs/ifx-overview-table.cjs.entry.js.map +1 -1
  156. package/dist/cjs/ifx-overview-table.entry.cjs.js.map +1 -1
  157. package/dist/cjs/ifx-progress-bar.cjs.entry.js +1 -1
  158. package/dist/cjs/ifx-progress-bar.cjs.entry.js.map +1 -1
  159. package/dist/cjs/ifx-progress-bar.entry.cjs.js.map +1 -1
  160. package/dist/cjs/ifx-radio-button-group.cjs.entry.js +1 -1
  161. package/dist/cjs/ifx-radio-button-group.cjs.entry.js.map +1 -1
  162. package/dist/cjs/ifx-radio-button-group.entry.cjs.js.map +1 -1
  163. package/dist/cjs/ifx-radio-button.cjs.entry.js +10 -10
  164. package/dist/cjs/ifx-radio-button.cjs.entry.js.map +1 -1
  165. package/dist/cjs/ifx-radio-button.entry.cjs.js.map +1 -1
  166. package/dist/cjs/ifx-search-bar.cjs.entry.js +1 -1
  167. package/dist/cjs/ifx-search-bar.cjs.entry.js.map +1 -1
  168. package/dist/cjs/ifx-search-bar.entry.cjs.js.map +1 -1
  169. package/dist/cjs/ifx-search-field.cjs.entry.js +2 -2
  170. package/dist/cjs/ifx-search-field.cjs.entry.js.map +1 -1
  171. package/dist/cjs/ifx-search-field.entry.cjs.js.map +1 -1
  172. package/dist/cjs/ifx-segment.cjs.entry.js +1 -1
  173. package/dist/cjs/ifx-segment.cjs.entry.js.map +1 -1
  174. package/dist/cjs/ifx-segment.entry.cjs.js.map +1 -1
  175. package/dist/cjs/ifx-segmented-control.cjs.entry.js +2 -2
  176. package/dist/cjs/ifx-segmented-control.cjs.entry.js.map +1 -1
  177. package/dist/cjs/ifx-segmented-control.entry.cjs.js.map +1 -1
  178. package/dist/cjs/ifx-select.cjs.entry.js +38 -38
  179. package/dist/cjs/ifx-select.cjs.entry.js.map +1 -1
  180. package/dist/cjs/ifx-select.entry.cjs.js.map +1 -1
  181. package/dist/cjs/ifx-set-filter.cjs.entry.js.map +1 -1
  182. package/dist/cjs/ifx-set-filter.entry.cjs.js.map +1 -1
  183. package/dist/cjs/ifx-sidebar-item.cjs.entry.js +5 -5
  184. package/dist/cjs/ifx-sidebar-item.cjs.entry.js.map +1 -1
  185. package/dist/cjs/ifx-sidebar-item.entry.cjs.js.map +1 -1
  186. package/dist/cjs/ifx-sidebar-title.cjs.entry.js +1 -1
  187. package/dist/cjs/ifx-sidebar-title.cjs.entry.js.map +1 -1
  188. package/dist/cjs/ifx-sidebar-title.entry.cjs.js.map +1 -1
  189. package/dist/cjs/ifx-sidebar.cjs.entry.js +5 -5
  190. package/dist/cjs/ifx-sidebar.cjs.entry.js.map +1 -1
  191. package/dist/cjs/ifx-sidebar.entry.cjs.js.map +1 -1
  192. package/dist/cjs/ifx-slider.cjs.entry.js +2 -2
  193. package/dist/cjs/ifx-slider.cjs.entry.js.map +1 -1
  194. package/dist/cjs/ifx-slider.entry.cjs.js.map +1 -1
  195. package/dist/cjs/ifx-spinner.ifx-text-field.entry.cjs.js.map +1 -1
  196. package/dist/cjs/ifx-spinner_2.cjs.entry.js +7 -7
  197. package/dist/cjs/ifx-spinner_2.cjs.entry.js.map +1 -1
  198. package/dist/cjs/ifx-status.cjs.entry.js +1 -1
  199. package/dist/cjs/ifx-status.cjs.entry.js.map +1 -1
  200. package/dist/cjs/ifx-status.entry.cjs.js.map +1 -1
  201. package/dist/cjs/ifx-step.cjs.entry.js +11 -11
  202. package/dist/cjs/ifx-step.cjs.entry.js.map +1 -1
  203. package/dist/cjs/ifx-step.entry.cjs.js.map +1 -1
  204. package/dist/cjs/ifx-stepper.cjs.entry.js +2 -2
  205. package/dist/cjs/ifx-stepper.cjs.entry.js.map +1 -1
  206. package/dist/cjs/ifx-stepper.entry.cjs.js.map +1 -1
  207. package/dist/cjs/ifx-switch.cjs.entry.js +1 -1
  208. package/dist/cjs/ifx-switch.cjs.entry.js.map +1 -1
  209. package/dist/cjs/ifx-switch.entry.cjs.js.map +1 -1
  210. package/dist/cjs/ifx-tab.cjs.entry.js +1 -1
  211. package/dist/cjs/ifx-tab.cjs.entry.js.map +1 -1
  212. package/dist/cjs/ifx-tab.entry.cjs.js.map +1 -1
  213. package/dist/cjs/ifx-table.cjs.entry.js +143 -48
  214. package/dist/cjs/ifx-table.cjs.entry.js.map +1 -1
  215. package/dist/cjs/ifx-table.entry.cjs.js.map +1 -1
  216. package/dist/cjs/ifx-tabs.cjs.entry.js +2 -2
  217. package/dist/cjs/ifx-tabs.cjs.entry.js.map +1 -1
  218. package/dist/cjs/ifx-tabs.entry.cjs.js.map +1 -1
  219. package/dist/cjs/ifx-templates-ui.cjs.entry.js +1 -1
  220. package/dist/cjs/ifx-templates-ui.cjs.entry.js.map +1 -1
  221. package/dist/cjs/ifx-templates-ui.entry.cjs.js.map +1 -1
  222. package/dist/cjs/ifx-textarea.cjs.entry.js +2 -2
  223. package/dist/cjs/ifx-textarea.cjs.entry.js.map +1 -1
  224. package/dist/cjs/ifx-textarea.entry.cjs.js.map +1 -1
  225. package/dist/cjs/ifx-tooltip.cjs.entry.js +4 -4
  226. package/dist/cjs/ifx-tooltip.cjs.entry.js.map +1 -1
  227. package/dist/cjs/ifx-tooltip.entry.cjs.js.map +1 -1
  228. package/dist/cjs/ifx-tree-view-item.cjs.entry.js +2 -2
  229. package/dist/cjs/ifx-tree-view-item.cjs.entry.js.map +1 -1
  230. package/dist/cjs/ifx-tree-view-item.entry.cjs.js.map +1 -1
  231. package/dist/cjs/ifx-tree-view.cjs.entry.js +1 -1
  232. package/dist/cjs/ifx-tree-view.cjs.entry.js.map +1 -1
  233. package/dist/cjs/ifx-tree-view.entry.cjs.js.map +1 -1
  234. package/dist/cjs/infineon-design-system-stencil.cjs.js +1 -1
  235. package/dist/cjs/loader.cjs.js +1 -1
  236. package/dist/collection/collection-manifest.json +6 -6
  237. package/dist/collection/components/accordion/accordion.js +1 -1
  238. package/dist/collection/components/accordion/accordion.js.map +1 -1
  239. package/dist/collection/components/accordion/accordion.stories.js +14 -14
  240. package/dist/collection/components/accordion/accordion.stories.js.map +1 -1
  241. package/dist/collection/components/accordion/accordionItem.js +1 -1
  242. package/dist/collection/components/accordion/accordionItem.js.map +1 -1
  243. package/dist/collection/components/action-list/action-list-item.js +2 -2
  244. package/dist/collection/components/action-list/action-list-item.js.map +1 -1
  245. package/dist/collection/components/action-list/action-list.js +1 -1
  246. package/dist/collection/components/action-list/action-list.js.map +1 -1
  247. package/dist/collection/components/action-list/action-list.stories.js +175 -175
  248. package/dist/collection/components/action-list/action-list.stories.js.map +1 -1
  249. package/dist/collection/components/alert/alert.js.map +1 -1
  250. package/dist/collection/components/alert/alert.stories.js +5 -5
  251. package/dist/collection/components/alert/alert.stories.js.map +1 -1
  252. package/dist/collection/components/breadcrumb/breadcrumb-item-label.js +1 -1
  253. package/dist/collection/components/breadcrumb/breadcrumb-item-label.js.map +1 -1
  254. package/dist/collection/components/breadcrumb/breadcrumb-item.js +1 -1
  255. package/dist/collection/components/breadcrumb/breadcrumb-item.js.map +1 -1
  256. package/dist/collection/components/breadcrumb/breadcrumb.js +1 -1
  257. package/dist/collection/components/breadcrumb/breadcrumb.js.map +1 -1
  258. package/dist/collection/components/breadcrumb/breadcrumb.stories.js +24 -24
  259. package/dist/collection/components/breadcrumb/breadcrumb.stories.js.map +1 -1
  260. package/dist/collection/components/button/button.js +1 -1
  261. package/dist/collection/components/button/button.js.map +1 -1
  262. package/dist/collection/components/button/button.stories.js +2 -2
  263. package/dist/collection/components/button/button.stories.js.map +1 -1
  264. package/dist/collection/components/card/card-headline/card-headline.js +1 -1
  265. package/dist/collection/components/card/card-headline/card-headline.js.map +1 -1
  266. package/dist/collection/components/card/card-image/card-image.js +1 -1
  267. package/dist/collection/components/card/card-image/card-image.js.map +1 -1
  268. package/dist/collection/components/card/card-links/card-links.js +1 -1
  269. package/dist/collection/components/card/card-links/card-links.js.map +1 -1
  270. package/dist/collection/components/card/card-overline/card-overline.js +1 -1
  271. package/dist/collection/components/card/card-overline/card-overline.js.map +1 -1
  272. package/dist/collection/components/card/card-text/card-text.js +1 -1
  273. package/dist/collection/components/card/card-text/card-text.js.map +1 -1
  274. package/dist/collection/components/card/card.js +5 -5
  275. package/dist/collection/components/card/card.js.map +1 -1
  276. package/dist/collection/components/card/card.stories.js +50 -50
  277. package/dist/collection/components/card/card.stories.js.map +1 -1
  278. package/dist/collection/components/checkbox/checkbox.js +6 -6
  279. package/dist/collection/components/checkbox/checkbox.js.map +1 -1
  280. package/dist/collection/components/checkbox/checkbox.stories.js.map +1 -1
  281. package/dist/collection/components/checkbox-group/checkbox-group.js +1 -1
  282. package/dist/collection/components/checkbox-group/checkbox-group.js.map +1 -1
  283. package/dist/collection/components/checkbox-group/checkbox-group.stories.js +3 -3
  284. package/dist/collection/components/checkbox-group/checkbox-group.stories.js.map +1 -1
  285. package/dist/collection/components/chip/chip-item/chip-item.js +2 -2
  286. package/dist/collection/components/chip/chip-item/chip-item.js.map +1 -1
  287. package/dist/collection/components/chip/chip.js +12 -12
  288. package/dist/collection/components/chip/chip.js.map +1 -1
  289. package/dist/collection/components/chip/chip.stories.js +16 -16
  290. package/dist/collection/components/chip/chip.stories.js.map +1 -1
  291. package/dist/collection/components/chip/interfaces.js.map +1 -1
  292. package/dist/collection/components/content-switcher/content-switcher-item.js +1 -1
  293. package/dist/collection/components/content-switcher/content-switcher-item.js.map +1 -1
  294. package/dist/collection/components/content-switcher/content-switcher.js +2 -2
  295. package/dist/collection/components/content-switcher/content-switcher.js.map +1 -1
  296. package/dist/collection/components/content-switcher/content-switcher.stories.js +2 -2
  297. package/dist/collection/components/content-switcher/content-switcher.stories.js.map +1 -1
  298. package/dist/collection/components/date-picker/date-picker.js +2 -2
  299. package/dist/collection/components/date-picker/date-picker.js.map +1 -1
  300. package/dist/collection/components/date-picker/date-picker.stories.js.map +1 -1
  301. package/dist/collection/components/download/download.js +2 -2
  302. package/dist/collection/components/download/download.js.map +1 -1
  303. package/dist/collection/components/download/download.stories.js.map +1 -1
  304. package/dist/collection/components/dropdown/IOpenable.js.map +1 -1
  305. package/dist/collection/components/dropdown/dropdown-header/dropdown-header.js +1 -1
  306. package/dist/collection/components/dropdown/dropdown-header/dropdown-header.js.map +1 -1
  307. package/dist/collection/components/dropdown/dropdown-item/dropdown-item.js +1 -1
  308. package/dist/collection/components/dropdown/dropdown-item/dropdown-item.js.map +1 -1
  309. package/dist/collection/components/dropdown/dropdown-menu/dropdown-menu.js +4 -4
  310. package/dist/collection/components/dropdown/dropdown-menu/dropdown-menu.js.map +1 -1
  311. package/dist/collection/components/dropdown/dropdown-seperator/dropdown-separator.js +1 -1
  312. package/dist/collection/components/dropdown/dropdown-seperator/dropdown-separator.js.map +1 -1
  313. package/dist/collection/components/dropdown/dropdown-trigger/dropdown-trigger.js +1 -1
  314. package/dist/collection/components/dropdown/dropdown-trigger/dropdown-trigger.js.map +1 -1
  315. package/dist/collection/components/dropdown/dropdown-trigger-button/dropdown-trigger-button.js +2 -2
  316. package/dist/collection/components/dropdown/dropdown-trigger-button/dropdown-trigger-button.js.map +1 -1
  317. package/dist/collection/components/dropdown/dropdown.js +2 -2
  318. package/dist/collection/components/dropdown/dropdown.js.map +1 -1
  319. package/dist/collection/components/dropdown/dropdown.stories.js +90 -90
  320. package/dist/collection/components/dropdown/dropdown.stories.js.map +1 -1
  321. package/dist/collection/components/file-upload/file-upload.js +2 -2
  322. package/dist/collection/components/file-upload/file-upload.js.map +1 -1
  323. package/dist/collection/components/file-upload/file-upload.stories.js.map +1 -1
  324. package/dist/collection/components/footer/footer-column.js +1 -1
  325. package/dist/collection/components/footer/footer-column.js.map +1 -1
  326. package/dist/collection/components/footer/footer.js +4 -4
  327. package/dist/collection/components/footer/footer.js.map +1 -1
  328. package/dist/collection/components/footer/footer.stories.js +89 -89
  329. package/dist/collection/components/footer/footer.stories.js.map +1 -1
  330. package/dist/collection/components/icon/infineonIconStencil.js +1 -1
  331. package/dist/collection/components/icon/infineonIconStencil.js.map +1 -1
  332. package/dist/collection/components/icon/infineonIconStencil.stories.js.map +1 -1
  333. package/dist/collection/components/icon-button/icon-button.js +1 -1
  334. package/dist/collection/components/icon-button/icon-button.js.map +1 -1
  335. package/dist/collection/components/icon-button/icon-button.stories.js +1 -1
  336. package/dist/collection/components/icon-button/icon-button.stories.js.map +1 -1
  337. package/dist/collection/components/icons-preview/icons-preview.js +1 -1
  338. package/dist/collection/components/icons-preview/icons-preview.js.map +1 -1
  339. package/dist/collection/components/icons-preview/icons-preview.stories.js.map +1 -1
  340. package/dist/collection/components/indicator/indicator.js +2 -2
  341. package/dist/collection/components/indicator/indicator.js.map +1 -1
  342. package/dist/collection/components/indicator/indicator.stories.js.map +1 -1
  343. package/dist/collection/components/link/link.js +1 -1
  344. package/dist/collection/components/link/link.js.map +1 -1
  345. package/dist/collection/components/link/link.stories.js +5 -5
  346. package/dist/collection/components/link/link.stories.js.map +1 -1
  347. package/dist/collection/components/modal/modal.js +2 -2
  348. package/dist/collection/components/modal/modal.js.map +1 -1
  349. package/dist/collection/components/modal/modal.stories.js +2 -2
  350. package/dist/collection/components/modal/modal.stories.js.map +1 -1
  351. package/dist/collection/components/navigation/navbar/navbar-item.js +5 -5
  352. package/dist/collection/components/navigation/navbar/navbar-item.js.map +1 -1
  353. package/dist/collection/components/navigation/navbar/navbar-profile.js +6 -6
  354. package/dist/collection/components/navigation/navbar/navbar-profile.js.map +1 -1
  355. package/dist/collection/components/navigation/navbar/navbar.js +3 -3
  356. package/dist/collection/components/navigation/navbar/navbar.js.map +1 -1
  357. package/dist/collection/components/navigation/navbar/navbar.stories.js +51 -51
  358. package/dist/collection/components/navigation/navbar/navbar.stories.js.map +1 -1
  359. package/dist/collection/components/navigation/sidebar/sidebar-item.js +5 -5
  360. package/dist/collection/components/navigation/sidebar/sidebar-item.js.map +1 -1
  361. package/dist/collection/components/navigation/sidebar/sidebar-title.js +1 -1
  362. package/dist/collection/components/navigation/sidebar/sidebar-title.js.map +1 -1
  363. package/dist/collection/components/navigation/sidebar/sidebar.js +5 -5
  364. package/dist/collection/components/navigation/sidebar/sidebar.js.map +1 -1
  365. package/dist/collection/components/navigation/sidebar/sidebar.stories.js +117 -117
  366. package/dist/collection/components/navigation/sidebar/sidebar.stories.js.map +1 -1
  367. package/dist/collection/components/notification/notification.js +3 -3
  368. package/dist/collection/components/notification/notification.js.map +1 -1
  369. package/dist/collection/components/notification/notification.stories.js +7 -7
  370. package/dist/collection/components/notification/notification.stories.js.map +1 -1
  371. package/dist/collection/components/overview-table/overview-table.js +1 -1
  372. package/dist/collection/components/overview-table/overview-table.js.map +1 -1
  373. package/dist/collection/components/overview-table/overview-table.stories.js.map +1 -1
  374. package/dist/collection/components/pagination/pagination.js +1 -1
  375. package/dist/collection/components/pagination/pagination.js.map +1 -1
  376. package/dist/collection/components/pagination/pagination.stories.js.map +1 -1
  377. package/dist/collection/components/progress-bar/progress-bar.js +1 -1
  378. package/dist/collection/components/progress-bar/progress-bar.js.map +1 -1
  379. package/dist/collection/components/progress-bar/progress-bar.stories.js +6 -6
  380. package/dist/collection/components/progress-bar/progress-bar.stories.js.map +1 -1
  381. package/dist/collection/components/radio-button/radio-button.js +10 -10
  382. package/dist/collection/components/radio-button/radio-button.js.map +1 -1
  383. package/dist/collection/components/radio-button/radio-button.stories.js.map +1 -1
  384. package/dist/collection/components/radio-button-group/radio-button-group.js +1 -1
  385. package/dist/collection/components/radio-button-group/radio-button-group.js.map +1 -1
  386. package/dist/collection/components/radio-button-group/radio-button-group.stories.js +3 -3
  387. package/dist/collection/components/radio-button-group/radio-button-group.stories.js.map +1 -1
  388. package/dist/collection/components/search-bar/search-bar.js +1 -1
  389. package/dist/collection/components/search-bar/search-bar.js.map +1 -1
  390. package/dist/collection/components/search-bar/search-bar.stories.js.map +1 -1
  391. package/dist/collection/components/search-field/search-field.js +4 -4
  392. package/dist/collection/components/search-field/search-field.js.map +1 -1
  393. package/dist/collection/components/search-field/search-field.stories.js.map +1 -1
  394. package/dist/collection/components/segmented-control/segment/segment.js +1 -1
  395. package/dist/collection/components/segmented-control/segment/segment.js.map +1 -1
  396. package/dist/collection/components/segmented-control/segmented-control.js +2 -2
  397. package/dist/collection/components/segmented-control/segmented-control.js.map +1 -1
  398. package/dist/collection/components/segmented-control/segmented-control.stories.js +14 -14
  399. package/dist/collection/components/segmented-control/segmented-control.stories.js.map +1 -1
  400. package/dist/collection/components/select/multi-select/interfaces.js.map +1 -1
  401. package/dist/collection/components/select/multi-select/multiselect-option.js +4 -4
  402. package/dist/collection/components/select/multi-select/multiselect-option.js.map +1 -1
  403. package/dist/collection/components/select/multi-select/multiselect.js +10 -10
  404. package/dist/collection/components/select/multi-select/multiselect.js.map +1 -1
  405. package/dist/collection/components/select/multi-select/multiselect.stories.js +156 -156
  406. package/dist/collection/components/select/multi-select/multiselect.stories.js.map +1 -1
  407. package/dist/collection/components/select/single-select/interfaces.js.map +1 -1
  408. package/dist/collection/components/select/single-select/select.js +38 -38
  409. package/dist/collection/components/select/single-select/select.js.map +1 -1
  410. package/dist/collection/components/select/single-select/select.stories.js +13 -13
  411. package/dist/collection/components/select/single-select/select.stories.js.map +1 -1
  412. package/dist/collection/components/select/single-select/utils.js.map +1 -1
  413. package/dist/collection/components/slider/slider.js +2 -2
  414. package/dist/collection/components/slider/slider.js.map +1 -1
  415. package/dist/collection/components/slider/slider.stories.js.map +1 -1
  416. package/dist/collection/components/spinner/spinner.js +2 -2
  417. package/dist/collection/components/spinner/spinner.js.map +1 -1
  418. package/dist/collection/components/spinner/spinner.stories.js.map +1 -1
  419. package/dist/collection/components/status/status.js +1 -1
  420. package/dist/collection/components/status/status.js.map +1 -1
  421. package/dist/collection/components/status/status.stories.js.map +1 -1
  422. package/dist/collection/components/stepper/interfaces.js.map +1 -1
  423. package/dist/collection/components/stepper/step/step.js +12 -12
  424. package/dist/collection/components/stepper/step/step.js.map +1 -1
  425. package/dist/collection/components/stepper/stepper.js +2 -2
  426. package/dist/collection/components/stepper/stepper.js.map +1 -1
  427. package/dist/collection/components/stepper/stepper.stories.js +13 -13
  428. package/dist/collection/components/stepper/stepper.stories.js.map +1 -1
  429. package/dist/collection/components/switch/switch.js +1 -1
  430. package/dist/collection/components/switch/switch.js.map +1 -1
  431. package/dist/collection/components/switch/switch.stories.js.map +1 -1
  432. package/dist/collection/components/table-advanced-version/buttonCellRenderer.js.map +1 -1
  433. package/dist/collection/components/table-advanced-version/checkboxCellRenderer.js.map +1 -1
  434. package/dist/collection/components/table-advanced-version/checkboxHeaderRenderer.js.map +1 -1
  435. package/dist/collection/components/table-advanced-version/customLoadingOverlay.js +2 -2
  436. package/dist/collection/components/table-advanced-version/customLoadingOverlay.js.map +1 -1
  437. package/dist/collection/components/table-advanced-version/customNoRowsOverlay.js +4 -4
  438. package/dist/collection/components/table-advanced-version/customNoRowsOverlay.js.map +1 -1
  439. package/dist/collection/components/table-advanced-version/filter-bar/filter-bar.js +1 -1
  440. package/dist/collection/components/table-advanced-version/filter-bar/filter-bar.js.map +1 -1
  441. package/dist/collection/components/table-advanced-version/filter-type-group/filter-accordion/filter-accordion.js +2 -2
  442. package/dist/collection/components/table-advanced-version/filter-type-group/filter-accordion/filter-accordion.js.map +1 -1
  443. package/dist/collection/components/table-advanced-version/filter-type-group/filter-search/filter-search.js +1 -1
  444. package/dist/collection/components/table-advanced-version/filter-type-group/filter-search/filter-search.js.map +1 -1
  445. package/dist/collection/components/table-advanced-version/filter-type-group/filter-type-group.js +1 -1
  446. package/dist/collection/components/table-advanced-version/filter-type-group/filter-type-group.js.map +1 -1
  447. package/dist/collection/components/table-advanced-version/filter-type-group/filter-type-group.stories.js +17 -17
  448. package/dist/collection/components/table-advanced-version/filter-type-group/filter-type-group.stories.js.map +1 -1
  449. package/dist/collection/components/table-advanced-version/filter-type-group/utils.js.map +1 -1
  450. package/dist/collection/components/table-advanced-version/iconButtonCellRenderer.js.map +1 -1
  451. package/dist/collection/components/table-advanced-version/interfaces.js.map +1 -1
  452. package/dist/collection/components/table-advanced-version/linkCellRenderer.js.map +1 -1
  453. package/dist/collection/components/table-advanced-version/list/list-entry/list-entry.js +1 -1
  454. package/dist/collection/components/table-advanced-version/list/list-entry/list-entry.js.map +1 -1
  455. package/dist/collection/components/table-advanced-version/list/list.js.map +1 -1
  456. package/dist/collection/components/table-advanced-version/list/list.stories.js.map +1 -1
  457. package/dist/collection/components/table-advanced-version/set-filter/setFilter.js.map +1 -1
  458. package/dist/collection/components/table-advanced-version/statusCellRenderer.js.map +1 -1
  459. package/dist/collection/components/table-advanced-version/table.js +139 -43
  460. package/dist/collection/components/table-advanced-version/table.js.map +1 -1
  461. package/dist/collection/components/table-advanced-version/table.stories.js +84 -84
  462. package/dist/collection/components/table-advanced-version/table.stories.js.map +1 -1
  463. package/dist/collection/components/table-basic-version/customLoadingOverlay.js +2 -2
  464. package/dist/collection/components/table-basic-version/customLoadingOverlay.js.map +1 -1
  465. package/dist/collection/components/table-basic-version/customNoRowsOverlay.js +4 -4
  466. package/dist/collection/components/table-basic-version/customNoRowsOverlay.js.map +1 -1
  467. package/dist/collection/components/table-basic-version/interfaces.js.map +1 -1
  468. package/dist/collection/components/table-basic-version/table.js +1 -1
  469. package/dist/collection/components/table-basic-version/table.js.map +1 -1
  470. package/dist/collection/components/table-basic-version/table.stories.js +6 -6
  471. package/dist/collection/components/table-basic-version/table.stories.js.map +1 -1
  472. package/dist/collection/components/tabs/tab.js +1 -1
  473. package/dist/collection/components/tabs/tab.js.map +1 -1
  474. package/dist/collection/components/tabs/tabs.js +2 -2
  475. package/dist/collection/components/tabs/tabs.js.map +1 -1
  476. package/dist/collection/components/tabs/tabs.stories.js +4 -4
  477. package/dist/collection/components/tabs/tabs.stories.js.map +1 -1
  478. package/dist/collection/components/templates/template/template.js +1 -1
  479. package/dist/collection/components/templates/template/template.js.map +1 -1
  480. package/dist/collection/components/templates/templates-ui/templates-ui.js +1 -1
  481. package/dist/collection/components/templates/templates-ui/templates-ui.js.map +1 -1
  482. package/dist/collection/components/text-field/text-field.js +5 -5
  483. package/dist/collection/components/text-field/text-field.js.map +1 -1
  484. package/dist/collection/components/text-field/text-field.stories.js +1 -1
  485. package/dist/collection/components/text-field/text-field.stories.js.map +1 -1
  486. package/dist/collection/components/textarea/textarea.js +2 -2
  487. package/dist/collection/components/textarea/textarea.js.map +1 -1
  488. package/dist/collection/components/textarea/textarea.stories.js +23 -23
  489. package/dist/collection/components/textarea/textarea.stories.js.map +1 -1
  490. package/dist/collection/components/tooltip/tooltip.js +4 -4
  491. package/dist/collection/components/tooltip/tooltip.js.map +1 -1
  492. package/dist/collection/components/tooltip/tooltip.stories.js.map +1 -1
  493. package/dist/collection/components/tree-view/tree-view-item.js +5 -5
  494. package/dist/collection/components/tree-view/tree-view-item.js.map +1 -1
  495. package/dist/collection/components/tree-view/tree-view.js +1 -1
  496. package/dist/collection/components/tree-view/tree-view.js.map +1 -1
  497. package/dist/collection/components/tree-view/tree-view.stories.js +76 -76
  498. package/dist/collection/components/tree-view/tree-view.stories.js.map +1 -1
  499. package/dist/collection/global/font-import.js.map +1 -1
  500. package/dist/collection/global/utils/animation.js.map +1 -1
  501. package/dist/collection/global/utils/dom-ready.js.map +1 -1
  502. package/dist/collection/global/utils/dom-utils.js.map +1 -1
  503. package/dist/collection/global/utils/focus-trap.js.map +1 -1
  504. package/dist/collection/global/utils/framework-detection.js.map +1 -1
  505. package/dist/collection/global/utils/tracking.js.map +1 -1
  506. package/dist/collection/index.js.map +1 -1
  507. package/dist/collection/stories/setup-and-installation/faq/faq.js +1 -1
  508. package/dist/collection/stories/setup-and-installation/faq/faq.js.map +1 -1
  509. package/dist/collection/test-setup.js.map +1 -1
  510. package/dist/components/ifx-accordion-item.js +1 -1
  511. package/dist/components/ifx-accordion.js +1 -1
  512. package/dist/components/ifx-action-list-item.js +1 -1
  513. package/dist/components/ifx-action-list-item.js.map +1 -1
  514. package/dist/components/ifx-action-list.js +1 -1
  515. package/dist/components/ifx-action-list.js.map +1 -1
  516. package/dist/components/ifx-alert.js +1 -1
  517. package/dist/components/ifx-basic-table.js +7 -7
  518. package/dist/components/ifx-basic-table.js.map +1 -1
  519. package/dist/components/ifx-breadcrumb-item-label.js +2 -2
  520. package/dist/components/ifx-breadcrumb-item-label.js.map +1 -1
  521. package/dist/components/ifx-breadcrumb-item.js +1 -1
  522. package/dist/components/ifx-breadcrumb-item.js.map +1 -1
  523. package/dist/components/ifx-breadcrumb.js +1 -1
  524. package/dist/components/ifx-breadcrumb.js.map +1 -1
  525. package/dist/components/ifx-button.js +1 -1
  526. package/dist/components/ifx-card-headline.js +1 -1
  527. package/dist/components/ifx-card-headline.js.map +1 -1
  528. package/dist/components/ifx-card-image.js +1 -1
  529. package/dist/components/ifx-card-image.js.map +1 -1
  530. package/dist/components/ifx-card-links.js +1 -1
  531. package/dist/components/ifx-card-links.js.map +1 -1
  532. package/dist/components/ifx-card-overline.js +1 -1
  533. package/dist/components/ifx-card-overline.js.map +1 -1
  534. package/dist/components/ifx-card-text.js +1 -1
  535. package/dist/components/ifx-card-text.js.map +1 -1
  536. package/dist/components/ifx-card.js +5 -5
  537. package/dist/components/ifx-card.js.map +1 -1
  538. package/dist/components/ifx-checkbox-group.js +2 -2
  539. package/dist/components/ifx-checkbox-group.js.map +1 -1
  540. package/dist/components/ifx-checkbox.js +1 -1
  541. package/dist/components/ifx-chip-item.js +1 -1
  542. package/dist/components/ifx-chip.js +1 -1
  543. package/dist/components/ifx-content-switcher-item.js +1 -1
  544. package/dist/components/ifx-content-switcher-item.js.map +1 -1
  545. package/dist/components/ifx-content-switcher.js +1 -1
  546. package/dist/components/ifx-content-switcher.js.map +1 -1
  547. package/dist/components/ifx-date-picker.js +3 -3
  548. package/dist/components/ifx-date-picker.js.map +1 -1
  549. package/dist/components/ifx-download.js +3 -3
  550. package/dist/components/ifx-download.js.map +1 -1
  551. package/dist/components/ifx-dropdown-header.js +1 -1
  552. package/dist/components/ifx-dropdown-header.js.map +1 -1
  553. package/dist/components/ifx-dropdown-item.js +2 -2
  554. package/dist/components/ifx-dropdown-item.js.map +1 -1
  555. package/dist/components/ifx-dropdown-menu.js +4 -4
  556. package/dist/components/ifx-dropdown-menu.js.map +1 -1
  557. package/dist/components/ifx-dropdown-separator.js +1 -1
  558. package/dist/components/ifx-dropdown-separator.js.map +1 -1
  559. package/dist/components/ifx-dropdown-trigger-button.js +4 -4
  560. package/dist/components/ifx-dropdown-trigger-button.js.map +1 -1
  561. package/dist/components/ifx-dropdown-trigger.js +1 -1
  562. package/dist/components/ifx-dropdown-trigger.js.map +1 -1
  563. package/dist/components/ifx-dropdown.js +1 -1
  564. package/dist/components/ifx-dropdown.js.map +1 -1
  565. package/dist/components/ifx-faq.js +4 -4
  566. package/dist/components/ifx-faq.js.map +1 -1
  567. package/dist/components/ifx-file-upload.js +6 -6
  568. package/dist/components/ifx-file-upload.js.map +1 -1
  569. package/dist/components/ifx-filter-accordion.js +4 -4
  570. package/dist/components/ifx-filter-accordion.js.map +1 -1
  571. package/dist/components/ifx-filter-bar.js +3 -3
  572. package/dist/components/ifx-filter-bar.js.map +1 -1
  573. package/dist/components/ifx-filter-search.js +3 -3
  574. package/dist/components/ifx-filter-search.js.map +1 -1
  575. package/dist/components/ifx-filter-type-group.js +1 -1
  576. package/dist/components/ifx-filter-type-group.js.map +1 -1
  577. package/dist/components/ifx-footer-column.js +1 -1
  578. package/dist/components/ifx-footer-column.js.map +1 -1
  579. package/dist/components/ifx-footer.js +4 -4
  580. package/dist/components/ifx-footer.js.map +1 -1
  581. package/dist/components/ifx-icon-button.js +1 -1
  582. package/dist/components/ifx-icon.js +1 -1
  583. package/dist/components/ifx-icons-preview.js +5 -5
  584. package/dist/components/ifx-icons-preview.js.map +1 -1
  585. package/dist/components/ifx-indicator.js +1 -1
  586. package/dist/components/ifx-link.js +1 -1
  587. package/dist/components/ifx-list-entry.js +4 -4
  588. package/dist/components/ifx-list-entry.js.map +1 -1
  589. package/dist/components/ifx-list.js +2 -2
  590. package/dist/components/ifx-list.js.map +1 -1
  591. package/dist/components/ifx-modal.js +4 -4
  592. package/dist/components/ifx-modal.js.map +1 -1
  593. package/dist/components/ifx-multiselect-option.js +1 -1
  594. package/dist/components/ifx-multiselect.js +1 -1
  595. package/dist/components/ifx-navbar-item.js +7 -7
  596. package/dist/components/ifx-navbar-item.js.map +1 -1
  597. package/dist/components/ifx-navbar-profile.js +6 -6
  598. package/dist/components/ifx-navbar-profile.js.map +1 -1
  599. package/dist/components/ifx-navbar.js +4 -4
  600. package/dist/components/ifx-navbar.js.map +1 -1
  601. package/dist/components/ifx-notification.js +1 -1
  602. package/dist/components/ifx-overview-table.js +4 -4
  603. package/dist/components/ifx-overview-table.js.map +1 -1
  604. package/dist/components/ifx-pagination.js +1 -1
  605. package/dist/components/ifx-progress-bar.js +1 -1
  606. package/dist/components/ifx-radio-button-group.js +2 -2
  607. package/dist/components/ifx-radio-button-group.js.map +1 -1
  608. package/dist/components/ifx-radio-button.js +1 -1
  609. package/dist/components/ifx-search-bar.js +3 -3
  610. package/dist/components/ifx-search-bar.js.map +1 -1
  611. package/dist/components/ifx-search-field.js +1 -1
  612. package/dist/components/ifx-segment.js +2 -2
  613. package/dist/components/ifx-segment.js.map +1 -1
  614. package/dist/components/ifx-segmented-control.js +3 -3
  615. package/dist/components/ifx-segmented-control.js.map +1 -1
  616. package/dist/components/ifx-select.js +1 -1
  617. package/dist/components/ifx-set-filter.js +7 -7
  618. package/dist/components/ifx-set-filter.js.map +1 -1
  619. package/dist/components/ifx-sidebar-item.js +7 -7
  620. package/dist/components/ifx-sidebar-item.js.map +1 -1
  621. package/dist/components/ifx-sidebar-title.js +1 -1
  622. package/dist/components/ifx-sidebar-title.js.map +1 -1
  623. package/dist/components/ifx-sidebar.js +6 -6
  624. package/dist/components/ifx-sidebar.js.map +1 -1
  625. package/dist/components/ifx-slider.js +3 -3
  626. package/dist/components/ifx-slider.js.map +1 -1
  627. package/dist/components/ifx-spinner.js +1 -1
  628. package/dist/components/ifx-status.js +1 -1
  629. package/dist/components/ifx-status.js.map +1 -1
  630. package/dist/components/ifx-step.js +12 -12
  631. package/dist/components/ifx-step.js.map +1 -1
  632. package/dist/components/ifx-stepper.js +2 -2
  633. package/dist/components/ifx-stepper.js.map +1 -1
  634. package/dist/components/ifx-switch.js +1 -1
  635. package/dist/components/ifx-switch.js.map +1 -1
  636. package/dist/components/ifx-tab.js +1 -1
  637. package/dist/components/ifx-tab.js.map +1 -1
  638. package/dist/components/ifx-table.js +153 -57
  639. package/dist/components/ifx-table.js.map +1 -1
  640. package/dist/components/ifx-tabs.js +4 -4
  641. package/dist/components/ifx-tabs.js.map +1 -1
  642. package/dist/components/ifx-template.js +1 -1
  643. package/dist/components/ifx-templates-ui.js +9 -9
  644. package/dist/components/ifx-templates-ui.js.map +1 -1
  645. package/dist/components/ifx-text-field.js +1 -1
  646. package/dist/components/ifx-textarea.js +2 -2
  647. package/dist/components/ifx-textarea.js.map +1 -1
  648. package/dist/components/ifx-tooltip.js +5 -5
  649. package/dist/components/ifx-tooltip.js.map +1 -1
  650. package/dist/components/ifx-tree-view-item.js +4 -4
  651. package/dist/components/ifx-tree-view-item.js.map +1 -1
  652. package/dist/components/ifx-tree-view.js +1 -1
  653. package/dist/components/ifx-tree-view.js.map +1 -1
  654. package/dist/components/{p-BVontUD4.js → p-4wfkxGlJ.js} +6 -6
  655. package/dist/components/p-4wfkxGlJ.js.map +1 -0
  656. package/dist/components/{p-UJUcpUZI.js → p-BG0cmSVP.js} +6 -6
  657. package/dist/components/p-BG0cmSVP.js.map +1 -0
  658. package/dist/components/{p-DcAKq8Jr.js → p-BGgzlGhs.js} +12 -12
  659. package/dist/components/p-BGgzlGhs.js.map +1 -0
  660. package/dist/components/{p-B61ip_5M.js → p-BQj9WQQe.js} +9 -9
  661. package/dist/components/p-BQj9WQQe.js.map +1 -0
  662. package/dist/components/{p-B8O27fA1.js → p-BR9GBwm3.js} +3 -3
  663. package/dist/components/p-BR9GBwm3.js.map +1 -0
  664. package/dist/components/{p-rP_UHrBl.js → p-BxahGQyq.js} +4 -4
  665. package/dist/components/p-BxahGQyq.js.map +1 -0
  666. package/dist/components/{p-BODyHBnq.js → p-C12r4j5b.js} +3 -3
  667. package/dist/components/p-C12r4j5b.js.map +1 -0
  668. package/dist/components/{p-D3I_SqHt.js → p-CRSbKJxa.js} +5 -5
  669. package/dist/components/p-CRSbKJxa.js.map +1 -0
  670. package/dist/components/{p-B5v9D54X.js → p-CcGE_f9F.js} +15 -15
  671. package/dist/components/p-CcGE_f9F.js.map +1 -0
  672. package/dist/components/{p-TR-rcXLt.js → p-CnXEcTdH.js} +3 -3
  673. package/dist/components/p-CnXEcTdH.js.map +1 -0
  674. package/dist/components/{p-DzvIkH4S.js → p-DFInpODO.js} +8 -8
  675. package/dist/components/p-DFInpODO.js.map +1 -0
  676. package/dist/components/{p-C0oKAW62.js → p-DHLzWSzN.js} +41 -41
  677. package/dist/components/p-DHLzWSzN.js.map +1 -0
  678. package/dist/components/{p-sukt4tRE.js → p-DNZFFt4T.js} +16 -16
  679. package/dist/components/p-DNZFFt4T.js.map +1 -0
  680. package/dist/components/{p-y82FFfi8.js → p-DRqwZrk0.js} +4 -4
  681. package/dist/components/p-DRqwZrk0.js.map +1 -0
  682. package/dist/components/{p-BNfoBOb0.js → p-DdOsLLJc.js} +4 -4
  683. package/dist/components/p-DdOsLLJc.js.map +1 -0
  684. package/dist/components/{p-BnjY2AJX.js → p-DhNY6ZGA.js} +3 -3
  685. package/dist/components/{p-BnjY2AJX.js.map → p-DhNY6ZGA.js.map} +1 -1
  686. package/dist/components/{p-ncBPrnzY.js → p-Djr4amRx.js} +8 -8
  687. package/dist/components/p-Djr4amRx.js.map +1 -0
  688. package/dist/components/{p-BpoV3zpc.js → p-F-WOWp_H.js} +4 -4
  689. package/dist/components/p-F-WOWp_H.js.map +1 -0
  690. package/dist/components/{p-DrBheHJU.js → p-R79iWjuc.js} +3 -3
  691. package/dist/components/p-R79iWjuc.js.map +1 -0
  692. package/dist/components/{p-CIgjv3WT.js → p-RF9z92mE.js} +3 -3
  693. package/dist/components/p-RF9z92mE.js.map +1 -0
  694. package/dist/components/p-bqYaVeZb.js.map +1 -1
  695. package/dist/components/{p-DfhZt04W.js → p-esRQWwdS.js} +8 -8
  696. package/dist/components/p-esRQWwdS.js.map +1 -0
  697. package/dist/components/{p-T-OkJYup.js → p-v3vmQuAS.js} +6 -6
  698. package/dist/components/p-v3vmQuAS.js.map +1 -0
  699. package/dist/esm/dom-utils-Bw2fh5LT.js.map +1 -1
  700. package/dist/esm/framework-detection-DcmcuUOA.js.map +1 -1
  701. package/dist/esm/ifx-accordion.ifx-accordion-item.entry.js.map +1 -1
  702. package/dist/esm/ifx-accordion_2.entry.js +2 -2
  703. package/dist/esm/ifx-accordion_2.entry.js.map +1 -1
  704. package/dist/esm/ifx-action-list-item.entry.js +1 -1
  705. package/dist/esm/ifx-action-list-item.entry.js.map +1 -1
  706. package/dist/esm/ifx-action-list.entry.js +1 -1
  707. package/dist/esm/ifx-action-list.entry.js.map +1 -1
  708. package/dist/esm/ifx-alert.ifx-template.entry.js.map +1 -1
  709. package/dist/esm/ifx-alert_2.entry.js +1 -1
  710. package/dist/esm/ifx-alert_2.entry.js.map +1 -1
  711. package/dist/esm/ifx-basic-table.entry.js +7 -7
  712. package/dist/esm/ifx-basic-table.entry.js.map +1 -1
  713. package/dist/esm/ifx-breadcrumb-item-label.entry.js +1 -1
  714. package/dist/esm/ifx-breadcrumb-item-label.entry.js.map +1 -1
  715. package/dist/esm/ifx-breadcrumb-item.entry.js +1 -1
  716. package/dist/esm/ifx-breadcrumb-item.entry.js.map +1 -1
  717. package/dist/esm/ifx-breadcrumb.entry.js +1 -1
  718. package/dist/esm/ifx-breadcrumb.entry.js.map +1 -1
  719. package/dist/esm/ifx-button.entry.js +1 -1
  720. package/dist/esm/ifx-button.entry.js.map +1 -1
  721. package/dist/esm/ifx-card-headline.entry.js +1 -1
  722. package/dist/esm/ifx-card-headline.entry.js.map +1 -1
  723. package/dist/esm/ifx-card-image.entry.js +1 -1
  724. package/dist/esm/ifx-card-image.entry.js.map +1 -1
  725. package/dist/esm/ifx-card-links.entry.js +1 -1
  726. package/dist/esm/ifx-card-links.entry.js.map +1 -1
  727. package/dist/esm/ifx-card-overline.entry.js +1 -1
  728. package/dist/esm/ifx-card-overline.entry.js.map +1 -1
  729. package/dist/esm/ifx-card-text.entry.js +1 -1
  730. package/dist/esm/ifx-card-text.entry.js.map +1 -1
  731. package/dist/esm/ifx-card.entry.js +5 -5
  732. package/dist/esm/ifx-card.entry.js.map +1 -1
  733. package/dist/esm/ifx-checkbox-group.entry.js +1 -1
  734. package/dist/esm/ifx-checkbox-group.entry.js.map +1 -1
  735. package/dist/esm/ifx-checkbox.entry.js +6 -6
  736. package/dist/esm/ifx-checkbox.entry.js.map +1 -1
  737. package/dist/esm/ifx-chip.ifx-chip-item.ifx-pagination.entry.js.map +1 -1
  738. package/dist/esm/ifx-chip_3.entry.js +15 -15
  739. package/dist/esm/ifx-chip_3.entry.js.map +1 -1
  740. package/dist/esm/ifx-content-switcher-item.entry.js +1 -1
  741. package/dist/esm/ifx-content-switcher-item.entry.js.map +1 -1
  742. package/dist/esm/ifx-content-switcher.entry.js +1 -1
  743. package/dist/esm/ifx-content-switcher.entry.js.map +1 -1
  744. package/dist/esm/ifx-date-picker.entry.js +2 -2
  745. package/dist/esm/ifx-date-picker.entry.js.map +1 -1
  746. package/dist/esm/ifx-download.entry.js +2 -2
  747. package/dist/esm/ifx-download.entry.js.map +1 -1
  748. package/dist/esm/ifx-dropdown-header.entry.js +1 -1
  749. package/dist/esm/ifx-dropdown-header.entry.js.map +1 -1
  750. package/dist/esm/ifx-dropdown-item.entry.js +1 -1
  751. package/dist/esm/ifx-dropdown-item.entry.js.map +1 -1
  752. package/dist/esm/ifx-dropdown-menu.entry.js +4 -4
  753. package/dist/esm/ifx-dropdown-menu.entry.js.map +1 -1
  754. package/dist/esm/ifx-dropdown-separator.entry.js +1 -1
  755. package/dist/esm/ifx-dropdown-separator.entry.js.map +1 -1
  756. package/dist/esm/ifx-dropdown-trigger-button.entry.js +2 -2
  757. package/dist/esm/ifx-dropdown-trigger-button.entry.js.map +1 -1
  758. package/dist/esm/ifx-dropdown-trigger.entry.js +1 -1
  759. package/dist/esm/ifx-dropdown-trigger.entry.js.map +1 -1
  760. package/dist/esm/ifx-dropdown.entry.js +1 -1
  761. package/dist/esm/ifx-dropdown.entry.js.map +1 -1
  762. package/dist/esm/ifx-faq.entry.js +1 -1
  763. package/dist/esm/ifx-faq.entry.js.map +1 -1
  764. package/dist/esm/ifx-file-upload.entry.js +2 -2
  765. package/dist/esm/ifx-file-upload.entry.js.map +1 -1
  766. package/dist/esm/ifx-filter-accordion.entry.js +2 -2
  767. package/dist/esm/ifx-filter-accordion.entry.js.map +1 -1
  768. package/dist/esm/ifx-filter-bar.entry.js +1 -1
  769. package/dist/esm/ifx-filter-bar.entry.js.map +1 -1
  770. package/dist/esm/ifx-filter-search.entry.js +1 -1
  771. package/dist/esm/ifx-filter-search.entry.js.map +1 -1
  772. package/dist/esm/ifx-filter-type-group.entry.js +1 -1
  773. package/dist/esm/ifx-filter-type-group.entry.js.map +1 -1
  774. package/dist/esm/ifx-footer-column.entry.js +1 -1
  775. package/dist/esm/ifx-footer-column.entry.js.map +1 -1
  776. package/dist/esm/ifx-footer.entry.js +4 -4
  777. package/dist/esm/ifx-footer.entry.js.map +1 -1
  778. package/dist/esm/ifx-icon-button.entry.js +1 -1
  779. package/dist/esm/ifx-icon-button.entry.js.map +1 -1
  780. package/dist/esm/ifx-icon.entry.js +1 -1
  781. package/dist/esm/ifx-icon.entry.js.map +1 -1
  782. package/dist/esm/ifx-icons-preview.entry.js +1 -1
  783. package/dist/esm/ifx-icons-preview.entry.js.map +1 -1
  784. package/dist/esm/ifx-indicator.entry.js +2 -2
  785. package/dist/esm/ifx-indicator.entry.js.map +1 -1
  786. package/dist/esm/ifx-link.entry.js +1 -1
  787. package/dist/esm/ifx-link.entry.js.map +1 -1
  788. package/dist/esm/ifx-list-entry.entry.js +1 -1
  789. package/dist/esm/ifx-list-entry.entry.js.map +1 -1
  790. package/dist/esm/ifx-list.entry.js.map +1 -1
  791. package/dist/esm/ifx-modal.entry.js +2 -2
  792. package/dist/esm/ifx-modal.entry.js.map +1 -1
  793. package/dist/esm/ifx-multiselect.ifx-multiselect-option.entry.js.map +1 -1
  794. package/dist/esm/ifx-multiselect_2.entry.js +14 -14
  795. package/dist/esm/ifx-multiselect_2.entry.js.map +1 -1
  796. package/dist/esm/ifx-navbar-item.entry.js +5 -5
  797. package/dist/esm/ifx-navbar-item.entry.js.map +1 -1
  798. package/dist/esm/ifx-navbar-profile.entry.js +6 -6
  799. package/dist/esm/ifx-navbar-profile.entry.js.map +1 -1
  800. package/dist/esm/ifx-navbar.entry.js +3 -3
  801. package/dist/esm/ifx-navbar.entry.js.map +1 -1
  802. package/dist/esm/ifx-notification.entry.js +2 -2
  803. package/dist/esm/ifx-notification.entry.js.map +1 -1
  804. package/dist/esm/ifx-overview-table.entry.js +1 -1
  805. package/dist/esm/ifx-overview-table.entry.js.map +1 -1
  806. package/dist/esm/ifx-progress-bar.entry.js +1 -1
  807. package/dist/esm/ifx-progress-bar.entry.js.map +1 -1
  808. package/dist/esm/ifx-radio-button-group.entry.js +1 -1
  809. package/dist/esm/ifx-radio-button-group.entry.js.map +1 -1
  810. package/dist/esm/ifx-radio-button.entry.js +10 -10
  811. package/dist/esm/ifx-radio-button.entry.js.map +1 -1
  812. package/dist/esm/ifx-search-bar.entry.js +1 -1
  813. package/dist/esm/ifx-search-bar.entry.js.map +1 -1
  814. package/dist/esm/ifx-search-field.entry.js +2 -2
  815. package/dist/esm/ifx-search-field.entry.js.map +1 -1
  816. package/dist/esm/ifx-segment.entry.js +1 -1
  817. package/dist/esm/ifx-segment.entry.js.map +1 -1
  818. package/dist/esm/ifx-segmented-control.entry.js +2 -2
  819. package/dist/esm/ifx-segmented-control.entry.js.map +1 -1
  820. package/dist/esm/ifx-select.entry.js +38 -38
  821. package/dist/esm/ifx-select.entry.js.map +1 -1
  822. package/dist/esm/ifx-set-filter.entry.js.map +1 -1
  823. package/dist/esm/ifx-sidebar-item.entry.js +5 -5
  824. package/dist/esm/ifx-sidebar-item.entry.js.map +1 -1
  825. package/dist/esm/ifx-sidebar-title.entry.js +1 -1
  826. package/dist/esm/ifx-sidebar-title.entry.js.map +1 -1
  827. package/dist/esm/ifx-sidebar.entry.js +5 -5
  828. package/dist/esm/ifx-sidebar.entry.js.map +1 -1
  829. package/dist/esm/ifx-slider.entry.js +2 -2
  830. package/dist/esm/ifx-slider.entry.js.map +1 -1
  831. package/dist/esm/ifx-spinner.ifx-text-field.entry.js.map +1 -1
  832. package/dist/esm/ifx-spinner_2.entry.js +7 -7
  833. package/dist/esm/ifx-spinner_2.entry.js.map +1 -1
  834. package/dist/esm/ifx-status.entry.js +1 -1
  835. package/dist/esm/ifx-status.entry.js.map +1 -1
  836. package/dist/esm/ifx-step.entry.js +11 -11
  837. package/dist/esm/ifx-step.entry.js.map +1 -1
  838. package/dist/esm/ifx-stepper.entry.js +2 -2
  839. package/dist/esm/ifx-stepper.entry.js.map +1 -1
  840. package/dist/esm/ifx-switch.entry.js +1 -1
  841. package/dist/esm/ifx-switch.entry.js.map +1 -1
  842. package/dist/esm/ifx-tab.entry.js +1 -1
  843. package/dist/esm/ifx-tab.entry.js.map +1 -1
  844. package/dist/esm/ifx-table.entry.js +143 -48
  845. package/dist/esm/ifx-table.entry.js.map +1 -1
  846. package/dist/esm/ifx-tabs.entry.js +2 -2
  847. package/dist/esm/ifx-tabs.entry.js.map +1 -1
  848. package/dist/esm/ifx-templates-ui.entry.js +1 -1
  849. package/dist/esm/ifx-templates-ui.entry.js.map +1 -1
  850. package/dist/esm/ifx-textarea.entry.js +2 -2
  851. package/dist/esm/ifx-textarea.entry.js.map +1 -1
  852. package/dist/esm/ifx-tooltip.entry.js +4 -4
  853. package/dist/esm/ifx-tooltip.entry.js.map +1 -1
  854. package/dist/esm/ifx-tree-view-item.entry.js +2 -2
  855. package/dist/esm/ifx-tree-view-item.entry.js.map +1 -1
  856. package/dist/esm/ifx-tree-view.entry.js +1 -1
  857. package/dist/esm/ifx-tree-view.entry.js.map +1 -1
  858. package/dist/esm/infineon-design-system-stencil.js +1 -1
  859. package/dist/esm/loader.js +1 -1
  860. package/dist/infineon-design-system-stencil/ifx-accordion.ifx-accordion-item.entry.esm.js.map +1 -1
  861. package/dist/infineon-design-system-stencil/ifx-action-list-item.entry.esm.js.map +1 -1
  862. package/dist/infineon-design-system-stencil/ifx-action-list.entry.esm.js.map +1 -1
  863. package/dist/infineon-design-system-stencil/ifx-alert.ifx-template.entry.esm.js.map +1 -1
  864. package/dist/infineon-design-system-stencil/ifx-basic-table.entry.esm.js.map +1 -1
  865. package/dist/infineon-design-system-stencil/ifx-breadcrumb-item-label.entry.esm.js.map +1 -1
  866. package/dist/infineon-design-system-stencil/ifx-breadcrumb-item.entry.esm.js.map +1 -1
  867. package/dist/infineon-design-system-stencil/ifx-breadcrumb.entry.esm.js.map +1 -1
  868. package/dist/infineon-design-system-stencil/ifx-button.entry.esm.js.map +1 -1
  869. package/dist/infineon-design-system-stencil/ifx-card-headline.entry.esm.js.map +1 -1
  870. package/dist/infineon-design-system-stencil/ifx-card-image.entry.esm.js.map +1 -1
  871. package/dist/infineon-design-system-stencil/ifx-card-links.entry.esm.js.map +1 -1
  872. package/dist/infineon-design-system-stencil/ifx-card-overline.entry.esm.js.map +1 -1
  873. package/dist/infineon-design-system-stencil/ifx-card-text.entry.esm.js.map +1 -1
  874. package/dist/infineon-design-system-stencil/ifx-card.entry.esm.js.map +1 -1
  875. package/dist/infineon-design-system-stencil/ifx-checkbox-group.entry.esm.js.map +1 -1
  876. package/dist/infineon-design-system-stencil/ifx-checkbox.entry.esm.js.map +1 -1
  877. package/dist/infineon-design-system-stencil/ifx-chip.ifx-chip-item.ifx-pagination.entry.esm.js.map +1 -1
  878. package/dist/infineon-design-system-stencil/ifx-content-switcher-item.entry.esm.js.map +1 -1
  879. package/dist/infineon-design-system-stencil/ifx-content-switcher.entry.esm.js.map +1 -1
  880. package/dist/infineon-design-system-stencil/ifx-date-picker.entry.esm.js.map +1 -1
  881. package/dist/infineon-design-system-stencil/ifx-download.entry.esm.js.map +1 -1
  882. package/dist/infineon-design-system-stencil/ifx-dropdown-header.entry.esm.js.map +1 -1
  883. package/dist/infineon-design-system-stencil/ifx-dropdown-item.entry.esm.js.map +1 -1
  884. package/dist/infineon-design-system-stencil/ifx-dropdown-menu.entry.esm.js.map +1 -1
  885. package/dist/infineon-design-system-stencil/ifx-dropdown-separator.entry.esm.js.map +1 -1
  886. package/dist/infineon-design-system-stencil/ifx-dropdown-trigger-button.entry.esm.js.map +1 -1
  887. package/dist/infineon-design-system-stencil/ifx-dropdown-trigger.entry.esm.js.map +1 -1
  888. package/dist/infineon-design-system-stencil/ifx-dropdown.entry.esm.js.map +1 -1
  889. package/dist/infineon-design-system-stencil/ifx-faq.entry.esm.js.map +1 -1
  890. package/dist/infineon-design-system-stencil/ifx-file-upload.entry.esm.js.map +1 -1
  891. package/dist/infineon-design-system-stencil/ifx-filter-accordion.entry.esm.js.map +1 -1
  892. package/dist/infineon-design-system-stencil/ifx-filter-bar.entry.esm.js.map +1 -1
  893. package/dist/infineon-design-system-stencil/ifx-filter-search.entry.esm.js.map +1 -1
  894. package/dist/infineon-design-system-stencil/ifx-filter-type-group.entry.esm.js.map +1 -1
  895. package/dist/infineon-design-system-stencil/ifx-footer-column.entry.esm.js.map +1 -1
  896. package/dist/infineon-design-system-stencil/ifx-footer.entry.esm.js.map +1 -1
  897. package/dist/infineon-design-system-stencil/ifx-icon-button.entry.esm.js.map +1 -1
  898. package/dist/infineon-design-system-stencil/ifx-icon.entry.esm.js.map +1 -1
  899. package/dist/infineon-design-system-stencil/ifx-icons-preview.entry.esm.js.map +1 -1
  900. package/dist/infineon-design-system-stencil/ifx-indicator.entry.esm.js.map +1 -1
  901. package/dist/infineon-design-system-stencil/ifx-link.entry.esm.js.map +1 -1
  902. package/dist/infineon-design-system-stencil/ifx-list-entry.entry.esm.js.map +1 -1
  903. package/dist/infineon-design-system-stencil/ifx-list.entry.esm.js.map +1 -1
  904. package/dist/infineon-design-system-stencil/ifx-modal.entry.esm.js.map +1 -1
  905. package/dist/infineon-design-system-stencil/ifx-multiselect.ifx-multiselect-option.entry.esm.js.map +1 -1
  906. package/dist/infineon-design-system-stencil/ifx-navbar-item.entry.esm.js.map +1 -1
  907. package/dist/infineon-design-system-stencil/ifx-navbar-profile.entry.esm.js.map +1 -1
  908. package/dist/infineon-design-system-stencil/ifx-navbar.entry.esm.js.map +1 -1
  909. package/dist/infineon-design-system-stencil/ifx-notification.entry.esm.js.map +1 -1
  910. package/dist/infineon-design-system-stencil/ifx-overview-table.entry.esm.js.map +1 -1
  911. package/dist/infineon-design-system-stencil/ifx-progress-bar.entry.esm.js.map +1 -1
  912. package/dist/infineon-design-system-stencil/ifx-radio-button-group.entry.esm.js.map +1 -1
  913. package/dist/infineon-design-system-stencil/ifx-radio-button.entry.esm.js.map +1 -1
  914. package/dist/infineon-design-system-stencil/ifx-search-bar.entry.esm.js.map +1 -1
  915. package/dist/infineon-design-system-stencil/ifx-search-field.entry.esm.js.map +1 -1
  916. package/dist/infineon-design-system-stencil/ifx-segment.entry.esm.js.map +1 -1
  917. package/dist/infineon-design-system-stencil/ifx-segmented-control.entry.esm.js.map +1 -1
  918. package/dist/infineon-design-system-stencil/ifx-select.entry.esm.js.map +1 -1
  919. package/dist/infineon-design-system-stencil/ifx-set-filter.entry.esm.js.map +1 -1
  920. package/dist/infineon-design-system-stencil/ifx-sidebar-item.entry.esm.js.map +1 -1
  921. package/dist/infineon-design-system-stencil/ifx-sidebar-title.entry.esm.js.map +1 -1
  922. package/dist/infineon-design-system-stencil/ifx-sidebar.entry.esm.js.map +1 -1
  923. package/dist/infineon-design-system-stencil/ifx-slider.entry.esm.js.map +1 -1
  924. package/dist/infineon-design-system-stencil/ifx-spinner.ifx-text-field.entry.esm.js.map +1 -1
  925. package/dist/infineon-design-system-stencil/ifx-status.entry.esm.js.map +1 -1
  926. package/dist/infineon-design-system-stencil/ifx-step.entry.esm.js.map +1 -1
  927. package/dist/infineon-design-system-stencil/ifx-stepper.entry.esm.js.map +1 -1
  928. package/dist/infineon-design-system-stencil/ifx-switch.entry.esm.js.map +1 -1
  929. package/dist/infineon-design-system-stencil/ifx-tab.entry.esm.js.map +1 -1
  930. package/dist/infineon-design-system-stencil/ifx-table.entry.esm.js.map +1 -1
  931. package/dist/infineon-design-system-stencil/ifx-tabs.entry.esm.js.map +1 -1
  932. package/dist/infineon-design-system-stencil/ifx-templates-ui.entry.esm.js.map +1 -1
  933. package/dist/infineon-design-system-stencil/ifx-textarea.entry.esm.js.map +1 -1
  934. package/dist/infineon-design-system-stencil/ifx-tooltip.entry.esm.js.map +1 -1
  935. package/dist/infineon-design-system-stencil/ifx-tree-view-item.entry.esm.js.map +1 -1
  936. package/dist/infineon-design-system-stencil/ifx-tree-view.entry.esm.js.map +1 -1
  937. package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js +1 -1
  938. package/dist/infineon-design-system-stencil/{p-6c41a04b.entry.js → p-05f66dcb.entry.js} +2 -2
  939. package/dist/infineon-design-system-stencil/p-05f66dcb.entry.js.map +1 -0
  940. package/dist/infineon-design-system-stencil/{p-edda61ad.entry.js → p-060845fd.entry.js} +2 -2
  941. package/dist/infineon-design-system-stencil/p-060845fd.entry.js.map +1 -0
  942. package/dist/infineon-design-system-stencil/{p-fd3e81ea.entry.js → p-06d2f85b.entry.js} +2 -2
  943. package/dist/infineon-design-system-stencil/p-06d2f85b.entry.js.map +1 -0
  944. package/dist/infineon-design-system-stencil/{p-56c892b7.entry.js → p-0929589d.entry.js} +2 -2
  945. package/dist/infineon-design-system-stencil/p-0929589d.entry.js.map +1 -0
  946. package/dist/infineon-design-system-stencil/{p-a3feab7d.entry.js → p-0be8f0c9.entry.js} +2 -2
  947. package/dist/infineon-design-system-stencil/p-0be8f0c9.entry.js.map +1 -0
  948. package/dist/infineon-design-system-stencil/{p-99700497.entry.js → p-0fb9f42b.entry.js} +2 -2
  949. package/dist/infineon-design-system-stencil/p-0fb9f42b.entry.js.map +1 -0
  950. package/dist/infineon-design-system-stencil/{p-52c43df7.entry.js → p-116c853e.entry.js} +2 -2
  951. package/dist/infineon-design-system-stencil/p-116c853e.entry.js.map +1 -0
  952. package/dist/infineon-design-system-stencil/{p-9469fe88.entry.js → p-169f26ae.entry.js} +2 -2
  953. package/dist/infineon-design-system-stencil/p-169f26ae.entry.js.map +1 -0
  954. package/dist/infineon-design-system-stencil/{p-5e6dc7d8.entry.js → p-1c1b1a1f.entry.js} +2 -2
  955. package/dist/infineon-design-system-stencil/p-1c1b1a1f.entry.js.map +1 -0
  956. package/dist/infineon-design-system-stencil/p-1d494424.entry.js +2 -0
  957. package/dist/infineon-design-system-stencil/p-1d494424.entry.js.map +1 -0
  958. package/dist/infineon-design-system-stencil/{p-c8a488bb.entry.js → p-22e9960d.entry.js} +2 -2
  959. package/dist/infineon-design-system-stencil/p-22e9960d.entry.js.map +1 -0
  960. package/dist/infineon-design-system-stencil/{p-e6254813.entry.js → p-2503d869.entry.js} +2 -2
  961. package/dist/infineon-design-system-stencil/p-2503d869.entry.js.map +1 -0
  962. package/dist/infineon-design-system-stencil/{p-80672b31.entry.js → p-273907cb.entry.js} +2 -2
  963. package/dist/infineon-design-system-stencil/p-273907cb.entry.js.map +1 -0
  964. package/dist/infineon-design-system-stencil/{p-210b1849.entry.js → p-2813423a.entry.js} +2 -2
  965. package/dist/infineon-design-system-stencil/p-2813423a.entry.js.map +1 -0
  966. package/dist/infineon-design-system-stencil/{p-694aa84a.entry.js → p-2b4b2b06.entry.js} +2 -2
  967. package/dist/infineon-design-system-stencil/p-2b4b2b06.entry.js.map +1 -0
  968. package/dist/infineon-design-system-stencil/{p-18c6d719.entry.js → p-2e172019.entry.js} +2 -2
  969. package/dist/infineon-design-system-stencil/p-2e172019.entry.js.map +1 -0
  970. package/dist/infineon-design-system-stencil/p-307e6a72.entry.js +2 -0
  971. package/dist/infineon-design-system-stencil/p-307e6a72.entry.js.map +1 -0
  972. package/dist/infineon-design-system-stencil/{p-0f35aeb6.entry.js → p-35d2266a.entry.js} +2 -2
  973. package/dist/infineon-design-system-stencil/p-35d2266a.entry.js.map +1 -0
  974. package/dist/infineon-design-system-stencil/{p-57f89e06.entry.js → p-380368ca.entry.js} +2 -2
  975. package/dist/infineon-design-system-stencil/p-380368ca.entry.js.map +1 -0
  976. package/dist/infineon-design-system-stencil/{p-2d3e3eea.entry.js → p-39561a49.entry.js} +2 -2
  977. package/dist/infineon-design-system-stencil/p-39561a49.entry.js.map +1 -0
  978. package/dist/infineon-design-system-stencil/{p-cc748b24.entry.js → p-39e3ee45.entry.js} +2 -2
  979. package/dist/infineon-design-system-stencil/p-39e3ee45.entry.js.map +1 -0
  980. package/dist/infineon-design-system-stencil/{p-501cf224.entry.js → p-3d77ef02.entry.js} +2 -2
  981. package/dist/infineon-design-system-stencil/p-3d77ef02.entry.js.map +1 -0
  982. package/dist/infineon-design-system-stencil/p-3eeacac9.entry.js +2 -0
  983. package/dist/infineon-design-system-stencil/p-3eeacac9.entry.js.map +1 -0
  984. package/dist/infineon-design-system-stencil/{p-4a0ae909.entry.js → p-45dad0d1.entry.js} +2 -2
  985. package/dist/infineon-design-system-stencil/p-45dad0d1.entry.js.map +1 -0
  986. package/dist/infineon-design-system-stencil/p-4669e01f.entry.js.map +1 -1
  987. package/dist/infineon-design-system-stencil/{p-30af152b.entry.js → p-4da5a2a5.entry.js} +2 -2
  988. package/dist/infineon-design-system-stencil/p-4da5a2a5.entry.js.map +1 -0
  989. package/dist/infineon-design-system-stencil/{p-db796fec.entry.js → p-4fba0543.entry.js} +2 -2
  990. package/dist/infineon-design-system-stencil/p-4fba0543.entry.js.map +1 -0
  991. package/dist/infineon-design-system-stencil/p-5367db9d.entry.js +2 -0
  992. package/dist/infineon-design-system-stencil/p-5367db9d.entry.js.map +1 -0
  993. package/dist/infineon-design-system-stencil/p-58dd6f5c.entry.js +2 -0
  994. package/dist/infineon-design-system-stencil/p-58dd6f5c.entry.js.map +1 -0
  995. package/dist/infineon-design-system-stencil/{p-961940f9.entry.js → p-5b571505.entry.js} +2 -2
  996. package/dist/infineon-design-system-stencil/p-5b571505.entry.js.map +1 -0
  997. package/dist/infineon-design-system-stencil/{p-af2c2c1f.entry.js → p-5e3d0ff0.entry.js} +2 -2
  998. package/dist/infineon-design-system-stencil/p-5e3d0ff0.entry.js.map +1 -0
  999. package/dist/infineon-design-system-stencil/{p-5e2e0f37.entry.js → p-5fb3eb8b.entry.js} +2 -2
  1000. package/dist/infineon-design-system-stencil/p-5fb3eb8b.entry.js.map +1 -0
  1001. package/dist/infineon-design-system-stencil/{p-3ffb4e39.entry.js → p-6a07106e.entry.js} +2 -2
  1002. package/dist/infineon-design-system-stencil/p-6a07106e.entry.js.map +1 -0
  1003. package/dist/infineon-design-system-stencil/{p-b2e514e5.entry.js → p-6e115707.entry.js} +2 -2
  1004. package/dist/infineon-design-system-stencil/p-6e115707.entry.js.map +1 -0
  1005. package/dist/infineon-design-system-stencil/p-6eb6af05.entry.js +2 -0
  1006. package/dist/infineon-design-system-stencil/p-6eb6af05.entry.js.map +1 -0
  1007. package/dist/infineon-design-system-stencil/{p-ee8900a5.entry.js → p-744c1c8e.entry.js} +2 -2
  1008. package/dist/infineon-design-system-stencil/p-744c1c8e.entry.js.map +1 -0
  1009. package/dist/infineon-design-system-stencil/p-760cfc7e.entry.js +2 -0
  1010. package/dist/infineon-design-system-stencil/p-760cfc7e.entry.js.map +1 -0
  1011. package/dist/infineon-design-system-stencil/{p-228e8272.entry.js → p-8a58c2be.entry.js} +2 -2
  1012. package/dist/infineon-design-system-stencil/p-8a58c2be.entry.js.map +1 -0
  1013. package/dist/infineon-design-system-stencil/{p-e8a60f3b.entry.js → p-8ceb2ccc.entry.js} +2 -2
  1014. package/dist/infineon-design-system-stencil/p-8ceb2ccc.entry.js.map +1 -0
  1015. package/dist/infineon-design-system-stencil/p-92ee6f73.entry.js.map +1 -1
  1016. package/dist/infineon-design-system-stencil/p-94dfe026.entry.js +2 -0
  1017. package/dist/infineon-design-system-stencil/p-94dfe026.entry.js.map +1 -0
  1018. package/dist/infineon-design-system-stencil/{p-7cf9f8a3.entry.js → p-9517d1b0.entry.js} +2 -2
  1019. package/dist/infineon-design-system-stencil/p-9517d1b0.entry.js.map +1 -0
  1020. package/dist/infineon-design-system-stencil/{p-81289e5f.entry.js → p-97b2ac42.entry.js} +2 -2
  1021. package/dist/infineon-design-system-stencil/p-97b2ac42.entry.js.map +1 -0
  1022. package/dist/infineon-design-system-stencil/{p-9f1ec0af.entry.js → p-9b06df76.entry.js} +2 -2
  1023. package/dist/infineon-design-system-stencil/p-9b06df76.entry.js.map +1 -0
  1024. package/dist/infineon-design-system-stencil/p-9ba730bb.entry.js +2 -0
  1025. package/dist/infineon-design-system-stencil/p-9ba730bb.entry.js.map +1 -0
  1026. package/dist/infineon-design-system-stencil/{p-e66a51e4.entry.js → p-9deaa65e.entry.js} +2 -2
  1027. package/dist/infineon-design-system-stencil/p-9deaa65e.entry.js.map +1 -0
  1028. package/dist/infineon-design-system-stencil/p-Bw2fh5LT.js.map +1 -1
  1029. package/dist/infineon-design-system-stencil/p-DcmcuUOA.js.map +1 -1
  1030. package/dist/infineon-design-system-stencil/{p-5251b206.entry.js → p-a4dd2fe1.entry.js} +2 -2
  1031. package/dist/infineon-design-system-stencil/p-a4dd2fe1.entry.js.map +1 -0
  1032. package/dist/infineon-design-system-stencil/{p-08316f9f.entry.js → p-a85754a5.entry.js} +2 -2
  1033. package/dist/infineon-design-system-stencil/{p-08316f9f.entry.js.map → p-a85754a5.entry.js.map} +1 -1
  1034. package/dist/infineon-design-system-stencil/{p-f6b4c091.entry.js → p-ab326703.entry.js} +2 -2
  1035. package/dist/infineon-design-system-stencil/p-ab326703.entry.js.map +1 -0
  1036. package/dist/infineon-design-system-stencil/{p-01754b50.entry.js → p-b7672947.entry.js} +2 -2
  1037. package/dist/infineon-design-system-stencil/p-b7672947.entry.js.map +1 -0
  1038. package/dist/infineon-design-system-stencil/{p-27a7a852.entry.js → p-bd8c6834.entry.js} +2 -2
  1039. package/dist/infineon-design-system-stencil/p-bd8c6834.entry.js.map +1 -0
  1040. package/dist/infineon-design-system-stencil/p-beaba918.entry.js +2 -0
  1041. package/dist/infineon-design-system-stencil/p-beaba918.entry.js.map +1 -0
  1042. package/dist/infineon-design-system-stencil/{p-e8f801be.entry.js → p-c578a728.entry.js} +2 -2
  1043. package/dist/infineon-design-system-stencil/p-c578a728.entry.js.map +1 -0
  1044. package/dist/infineon-design-system-stencil/{p-c896414e.entry.js → p-c6826c1e.entry.js} +2 -2
  1045. package/dist/infineon-design-system-stencil/p-c6826c1e.entry.js.map +1 -0
  1046. package/dist/infineon-design-system-stencil/{p-0b0f2040.entry.js → p-ca312cbb.entry.js} +2 -2
  1047. package/dist/infineon-design-system-stencil/p-ca312cbb.entry.js.map +1 -0
  1048. package/dist/infineon-design-system-stencil/{p-962821bc.entry.js → p-ca870353.entry.js} +2 -2
  1049. package/dist/infineon-design-system-stencil/p-ca870353.entry.js.map +1 -0
  1050. package/dist/infineon-design-system-stencil/{p-4b41a66f.entry.js → p-ce799b3d.entry.js} +2 -2
  1051. package/dist/infineon-design-system-stencil/p-ce799b3d.entry.js.map +1 -0
  1052. package/dist/infineon-design-system-stencil/{p-acd3359f.entry.js → p-d267f6d2.entry.js} +2 -2
  1053. package/dist/infineon-design-system-stencil/p-d267f6d2.entry.js.map +1 -0
  1054. package/dist/infineon-design-system-stencil/{p-eb0e4967.entry.js → p-d2b076fe.entry.js} +2 -2
  1055. package/dist/infineon-design-system-stencil/p-d2b076fe.entry.js.map +1 -0
  1056. package/dist/infineon-design-system-stencil/p-d4373c36.entry.js +2 -0
  1057. package/dist/infineon-design-system-stencil/p-d4373c36.entry.js.map +1 -0
  1058. package/dist/infineon-design-system-stencil/{p-c6013ced.entry.js → p-d65a334c.entry.js} +2 -2
  1059. package/dist/infineon-design-system-stencil/p-d65a334c.entry.js.map +1 -0
  1060. package/dist/infineon-design-system-stencil/p-dac7d817.entry.js +2 -0
  1061. package/dist/infineon-design-system-stencil/p-dac7d817.entry.js.map +1 -0
  1062. package/dist/infineon-design-system-stencil/{p-252e292d.entry.js → p-dbc6ae20.entry.js} +2 -2
  1063. package/dist/infineon-design-system-stencil/p-dbc6ae20.entry.js.map +1 -0
  1064. package/dist/infineon-design-system-stencil/{p-9a3be43a.entry.js → p-dcd0af23.entry.js} +2 -2
  1065. package/dist/infineon-design-system-stencil/p-dcd0af23.entry.js.map +1 -0
  1066. package/dist/infineon-design-system-stencil/{p-ac371faa.entry.js → p-e3c11b6c.entry.js} +2 -2
  1067. package/dist/infineon-design-system-stencil/p-e3c11b6c.entry.js.map +1 -0
  1068. package/dist/infineon-design-system-stencil/p-e6c4c4cf.entry.js +2 -0
  1069. package/dist/infineon-design-system-stencil/p-e6c4c4cf.entry.js.map +1 -0
  1070. package/dist/infineon-design-system-stencil/{p-f2bcdd91.entry.js → p-e78ffc43.entry.js} +2 -2
  1071. package/dist/infineon-design-system-stencil/p-e78ffc43.entry.js.map +1 -0
  1072. package/dist/infineon-design-system-stencil/{p-4b8ff4cb.entry.js → p-e7c656cd.entry.js} +2 -2
  1073. package/dist/infineon-design-system-stencil/p-e7c656cd.entry.js.map +1 -0
  1074. package/dist/infineon-design-system-stencil/{p-f3b42bba.entry.js → p-edbfa46e.entry.js} +2 -2
  1075. package/dist/infineon-design-system-stencil/p-edbfa46e.entry.js.map +1 -0
  1076. package/dist/infineon-design-system-stencil/{p-72a516f9.entry.js → p-ee04eb6e.entry.js} +2 -2
  1077. package/dist/infineon-design-system-stencil/p-ee04eb6e.entry.js.map +1 -0
  1078. package/dist/infineon-design-system-stencil/{p-f1c5b005.entry.js → p-f06b0ae3.entry.js} +2 -2
  1079. package/dist/infineon-design-system-stencil/p-f06b0ae3.entry.js.map +1 -0
  1080. package/dist/infineon-design-system-stencil/{p-a423e08f.entry.js → p-f1ba768a.entry.js} +2 -2
  1081. package/dist/infineon-design-system-stencil/p-f1ba768a.entry.js.map +1 -0
  1082. package/dist/infineon-design-system-stencil/{p-8f90cc75.entry.js → p-f2c8c7a6.entry.js} +2 -2
  1083. package/dist/infineon-design-system-stencil/p-f2c8c7a6.entry.js.map +1 -0
  1084. package/dist/infineon-design-system-stencil/{p-5b7a11f2.entry.js → p-fb92000d.entry.js} +2 -2
  1085. package/dist/infineon-design-system-stencil/p-fb92000d.entry.js.map +1 -0
  1086. package/dist/infineon-design-system-stencil/p-fc359efa.entry.js +2 -0
  1087. package/dist/infineon-design-system-stencil/p-fc359efa.entry.js.map +1 -0
  1088. package/dist/infineon-design-system-stencil/{p-8cc6cd75.entry.js → p-fcae5dc1.entry.js} +2 -2
  1089. package/dist/infineon-design-system-stencil/p-fcae5dc1.entry.js.map +1 -0
  1090. package/dist/infineon-design-system-stencil/{p-a8632f44.entry.js → p-ff4cc197.entry.js} +2 -2
  1091. package/dist/infineon-design-system-stencil/p-ff4cc197.entry.js.map +1 -0
  1092. package/dist/types/components/checkbox/checkbox.d.ts +1 -1
  1093. package/dist/types/components/link/link.d.ts +1 -1
  1094. package/dist/types/components/navigation/navbar/navbar-item.d.ts +1 -1
  1095. package/dist/types/components/select/single-select/types/choices.d.ts +2 -2
  1096. package/dist/types/components/table-advanced-version/list/list.d.ts +1 -1
  1097. package/dist/types/components/table-advanced-version/table.d.ts +1 -0
  1098. package/dist/types/components/tooltip/tooltip.d.ts +1 -1
  1099. package/dist/types/global.d.ts +3 -3
  1100. package/dist/types/loader.d.ts +1 -1
  1101. package/package.json +111 -111
  1102. package/dist/components/p-B5v9D54X.js.map +0 -1
  1103. package/dist/components/p-B61ip_5M.js.map +0 -1
  1104. package/dist/components/p-B8O27fA1.js.map +0 -1
  1105. package/dist/components/p-BNfoBOb0.js.map +0 -1
  1106. package/dist/components/p-BODyHBnq.js.map +0 -1
  1107. package/dist/components/p-BVontUD4.js.map +0 -1
  1108. package/dist/components/p-BpoV3zpc.js.map +0 -1
  1109. package/dist/components/p-C0oKAW62.js.map +0 -1
  1110. package/dist/components/p-CIgjv3WT.js.map +0 -1
  1111. package/dist/components/p-D3I_SqHt.js.map +0 -1
  1112. package/dist/components/p-DcAKq8Jr.js.map +0 -1
  1113. package/dist/components/p-DfhZt04W.js.map +0 -1
  1114. package/dist/components/p-DrBheHJU.js.map +0 -1
  1115. package/dist/components/p-DzvIkH4S.js.map +0 -1
  1116. package/dist/components/p-T-OkJYup.js.map +0 -1
  1117. package/dist/components/p-TR-rcXLt.js.map +0 -1
  1118. package/dist/components/p-UJUcpUZI.js.map +0 -1
  1119. package/dist/components/p-ncBPrnzY.js.map +0 -1
  1120. package/dist/components/p-rP_UHrBl.js.map +0 -1
  1121. package/dist/components/p-sukt4tRE.js.map +0 -1
  1122. package/dist/components/p-y82FFfi8.js.map +0 -1
  1123. package/dist/infineon-design-system-stencil/p-01754b50.entry.js.map +0 -1
  1124. package/dist/infineon-design-system-stencil/p-0b0f2040.entry.js.map +0 -1
  1125. package/dist/infineon-design-system-stencil/p-0f35aeb6.entry.js.map +0 -1
  1126. package/dist/infineon-design-system-stencil/p-18c6d719.entry.js.map +0 -1
  1127. package/dist/infineon-design-system-stencil/p-210b1849.entry.js.map +0 -1
  1128. package/dist/infineon-design-system-stencil/p-228e8272.entry.js.map +0 -1
  1129. package/dist/infineon-design-system-stencil/p-252e292d.entry.js.map +0 -1
  1130. package/dist/infineon-design-system-stencil/p-27a7a852.entry.js.map +0 -1
  1131. package/dist/infineon-design-system-stencil/p-2d3e3eea.entry.js.map +0 -1
  1132. package/dist/infineon-design-system-stencil/p-30af152b.entry.js.map +0 -1
  1133. package/dist/infineon-design-system-stencil/p-356425ec.entry.js +0 -2
  1134. package/dist/infineon-design-system-stencil/p-356425ec.entry.js.map +0 -1
  1135. package/dist/infineon-design-system-stencil/p-3ffb4e39.entry.js.map +0 -1
  1136. package/dist/infineon-design-system-stencil/p-46b370da.entry.js +0 -2
  1137. package/dist/infineon-design-system-stencil/p-46b370da.entry.js.map +0 -1
  1138. package/dist/infineon-design-system-stencil/p-4a0ae909.entry.js.map +0 -1
  1139. package/dist/infineon-design-system-stencil/p-4b41a66f.entry.js.map +0 -1
  1140. package/dist/infineon-design-system-stencil/p-4b8ff4cb.entry.js.map +0 -1
  1141. package/dist/infineon-design-system-stencil/p-501cf224.entry.js.map +0 -1
  1142. package/dist/infineon-design-system-stencil/p-5251b206.entry.js.map +0 -1
  1143. package/dist/infineon-design-system-stencil/p-52b7ca57.entry.js +0 -2
  1144. package/dist/infineon-design-system-stencil/p-52b7ca57.entry.js.map +0 -1
  1145. package/dist/infineon-design-system-stencil/p-52c43df7.entry.js.map +0 -1
  1146. package/dist/infineon-design-system-stencil/p-56c892b7.entry.js.map +0 -1
  1147. package/dist/infineon-design-system-stencil/p-57f89e06.entry.js.map +0 -1
  1148. package/dist/infineon-design-system-stencil/p-5b7a11f2.entry.js.map +0 -1
  1149. package/dist/infineon-design-system-stencil/p-5e2e0f37.entry.js.map +0 -1
  1150. package/dist/infineon-design-system-stencil/p-5e6dc7d8.entry.js.map +0 -1
  1151. package/dist/infineon-design-system-stencil/p-5e7e0b40.entry.js +0 -2
  1152. package/dist/infineon-design-system-stencil/p-5e7e0b40.entry.js.map +0 -1
  1153. package/dist/infineon-design-system-stencil/p-5f28de7f.entry.js +0 -2
  1154. package/dist/infineon-design-system-stencil/p-5f28de7f.entry.js.map +0 -1
  1155. package/dist/infineon-design-system-stencil/p-694aa84a.entry.js.map +0 -1
  1156. package/dist/infineon-design-system-stencil/p-6c41a04b.entry.js.map +0 -1
  1157. package/dist/infineon-design-system-stencil/p-72a516f9.entry.js.map +0 -1
  1158. package/dist/infineon-design-system-stencil/p-7cf9f8a3.entry.js.map +0 -1
  1159. package/dist/infineon-design-system-stencil/p-80672b31.entry.js.map +0 -1
  1160. package/dist/infineon-design-system-stencil/p-81289e5f.entry.js.map +0 -1
  1161. package/dist/infineon-design-system-stencil/p-8872ee5c.entry.js +0 -2
  1162. package/dist/infineon-design-system-stencil/p-8872ee5c.entry.js.map +0 -1
  1163. package/dist/infineon-design-system-stencil/p-8cc6cd75.entry.js.map +0 -1
  1164. package/dist/infineon-design-system-stencil/p-8f90cc75.entry.js.map +0 -1
  1165. package/dist/infineon-design-system-stencil/p-9469fe88.entry.js.map +0 -1
  1166. package/dist/infineon-design-system-stencil/p-961940f9.entry.js.map +0 -1
  1167. package/dist/infineon-design-system-stencil/p-962821bc.entry.js.map +0 -1
  1168. package/dist/infineon-design-system-stencil/p-99700497.entry.js.map +0 -1
  1169. package/dist/infineon-design-system-stencil/p-9a3be43a.entry.js.map +0 -1
  1170. package/dist/infineon-design-system-stencil/p-9f1ec0af.entry.js.map +0 -1
  1171. package/dist/infineon-design-system-stencil/p-9f51c51a.entry.js +0 -2
  1172. package/dist/infineon-design-system-stencil/p-9f51c51a.entry.js.map +0 -1
  1173. package/dist/infineon-design-system-stencil/p-a3feab7d.entry.js.map +0 -1
  1174. package/dist/infineon-design-system-stencil/p-a423e08f.entry.js.map +0 -1
  1175. package/dist/infineon-design-system-stencil/p-a8632f44.entry.js.map +0 -1
  1176. package/dist/infineon-design-system-stencil/p-aa79ab02.entry.js +0 -2
  1177. package/dist/infineon-design-system-stencil/p-aa79ab02.entry.js.map +0 -1
  1178. package/dist/infineon-design-system-stencil/p-ac371faa.entry.js.map +0 -1
  1179. package/dist/infineon-design-system-stencil/p-acd3359f.entry.js.map +0 -1
  1180. package/dist/infineon-design-system-stencil/p-af2c2c1f.entry.js.map +0 -1
  1181. package/dist/infineon-design-system-stencil/p-b2e514e5.entry.js.map +0 -1
  1182. package/dist/infineon-design-system-stencil/p-b83f33e2.entry.js +0 -2
  1183. package/dist/infineon-design-system-stencil/p-b83f33e2.entry.js.map +0 -1
  1184. package/dist/infineon-design-system-stencil/p-c5d6762c.entry.js +0 -2
  1185. package/dist/infineon-design-system-stencil/p-c5d6762c.entry.js.map +0 -1
  1186. package/dist/infineon-design-system-stencil/p-c6013ced.entry.js.map +0 -1
  1187. package/dist/infineon-design-system-stencil/p-c896414e.entry.js.map +0 -1
  1188. package/dist/infineon-design-system-stencil/p-c8a488bb.entry.js.map +0 -1
  1189. package/dist/infineon-design-system-stencil/p-cc748b24.entry.js.map +0 -1
  1190. package/dist/infineon-design-system-stencil/p-d1be48d9.entry.js +0 -2
  1191. package/dist/infineon-design-system-stencil/p-d1be48d9.entry.js.map +0 -1
  1192. package/dist/infineon-design-system-stencil/p-da112045.entry.js +0 -2
  1193. package/dist/infineon-design-system-stencil/p-da112045.entry.js.map +0 -1
  1194. package/dist/infineon-design-system-stencil/p-db796fec.entry.js.map +0 -1
  1195. package/dist/infineon-design-system-stencil/p-e6254813.entry.js.map +0 -1
  1196. package/dist/infineon-design-system-stencil/p-e66a51e4.entry.js.map +0 -1
  1197. package/dist/infineon-design-system-stencil/p-e759a91a.entry.js +0 -2
  1198. package/dist/infineon-design-system-stencil/p-e759a91a.entry.js.map +0 -1
  1199. package/dist/infineon-design-system-stencil/p-e8a60f3b.entry.js.map +0 -1
  1200. package/dist/infineon-design-system-stencil/p-e8f801be.entry.js.map +0 -1
  1201. package/dist/infineon-design-system-stencil/p-e9381c81.entry.js +0 -2
  1202. package/dist/infineon-design-system-stencil/p-e9381c81.entry.js.map +0 -1
  1203. package/dist/infineon-design-system-stencil/p-eb0e4967.entry.js.map +0 -1
  1204. package/dist/infineon-design-system-stencil/p-edda61ad.entry.js.map +0 -1
  1205. package/dist/infineon-design-system-stencil/p-ee8900a5.entry.js.map +0 -1
  1206. package/dist/infineon-design-system-stencil/p-f1c5b005.entry.js.map +0 -1
  1207. package/dist/infineon-design-system-stencil/p-f2bcdd91.entry.js.map +0 -1
  1208. package/dist/infineon-design-system-stencil/p-f3b42bba.entry.js.map +0 -1
  1209. package/dist/infineon-design-system-stencil/p-f6b4c091.entry.js.map +0 -1
  1210. package/dist/infineon-design-system-stencil/p-fd3e81ea.entry.js.map +0 -1
@@ -1,2 +1,2 @@
1
- import{r as i,c as e,h as t,a as s}from"./p-PqnYwNKt.js";import{d as l,t as a}from"./p-DcmcuUOA.js";import{i as o}from"./p-Bw2fh5LT.js";const r=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{font-family:var(--ifx-font-family, sans-serif)}.file-upload-wrapper{display:flex;flex-direction:column}.file-upload-wrapper.disabled{pointer-events:none}.file-upload-wrapper.disabled label,.file-upload-wrapper.disabled .file-upload-info{color:#575352}.file-upload-label{font-style:normal;font-weight:400;font-size:1rem;line-height:1.5rem;color:#1D1D1D}.file-upload-label .required{display:inline-block;margin-left:4px}.file-upload-label .required.error{color:#CD002F}.upload-dropzone{border:1px dashed #BFBBBB;padding:40px;text-align:center;cursor:pointer;color:#1D1D1D;transition:border-color 0.3s ease;border-radius:1px;background:#FFFFFF}.upload-dropzone ifx-icon{color:#0A8276}.upload-dropzone:hover{border:1px dashed #8D8786}.upload-dropzone.drag-over{border:1px solid #0A8276;background:#F7F7F7}.upload-dropzone.drag-over.error{border:1px solid #0A8276}.upload-dropzone.error{border-color:#CD002F}.disabled .upload-dropzone{pointer-events:none;border-color:#BFBBBB;color:#BFBBBB}.disabled .upload-dropzone ifx-icon{color:#BFBBBB}.upload-dropzone input{display:none}.file-upload-info{font-style:normal;font-weight:400;font-size:0.75rem;line-height:1rem;letter-spacing:0em;color:#1D1D1D;margin:0;margin-top:4px}.file-upload-status{font-style:normal;font-weight:400;font-size:0.75rem;line-height:1rem;letter-spacing:0.2px;margin-top:8px}.file-upload-status.file-upload-status__error{display:flex;align-items:center;color:#CD002F}.file-upload-status.file-upload-status__error ifx-icon{position:relative;top:-1px;color:#CD002F;margin-right:8px}.upload-heading{font:600 1.125rem/1.625rem "Source Sans 3";margin-bottom:8px}.file-list-wrapper{margin-top:16px}.file-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.file-item{border:1px solid #BFBBBB;padding-top:12px;padding-right:16px;padding-bottom:8px;padding-left:16px;display:flex;gap:8px}.file-info{width:100%;min-width:0}.file-top-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:-8px}.file-top-row ifx-icon{flex-shrink:0}.file-name-wrapper{display:flex;min-width:0;max-width:100%;white-space:nowrap;overflow:hidden;font-weight:400;font-size:0.875rem}.file-name-base{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0}.file-name-ext{flex-shrink:0;margin-left:0}.file-middle-row{display:flex;align-items:center;font-size:0.75rem;line-height:1rem;flex-wrap:wrap;color:#575352}.file-middle-row .file-status{margin-left:12px}.file-middle-row .file-status ifx-icon{margin-right:8px}.file-progress-row{margin-top:4px}.file-progress-row ifx-progress-bar{width:100%}.upload-success{border-color:#0A8276}.upload-success .file-status ifx-icon{position:relative;top:1px;color:#4CA460}.upload-failed{border-color:#CD002F}.upload-failed .file-status{color:#CD002F;margin-left:0}';const n=class{constructor(t){i(this,t);this.ifxFileUploadAdd=e(this,"ifxFileUploadAdd",7);this.ifxFileUploadRemove=e(this,"ifxFileUploadRemove",7);this.ifxFileUploadChange=e(this,"ifxFileUploadChange",7);this.ifxFileUploadError=e(this,"ifxFileUploadError",7);this.ifxFileUploadInvalid=e(this,"ifxFileUploadInvalid",7);this.ifxFileUploadStart=e(this,"ifxFileUploadStart",7);this.ifxFileUploadComplete=e(this,"ifxFileUploadComplete",7);this.ifxFileUploadAllComplete=e(this,"ifxFileUploadAllComplete",7);this.ifxFileUploadAbort=e(this,"ifxFileUploadAbort",7);this.ifxFileUploadDrop=e(this,"ifxFileUploadDrop",7);this.ifxFileUploadClick=e(this,"ifxFileUploadClick",7);this.ifxFileUploadMaxFilesExceeded=e(this,"ifxFileUploadMaxFilesExceeded",7);this.ifxFileUploadValidation=e(this,"ifxFileUploadValidation",7);this.ifxFileUploadRetry=e(this,"ifxFileUploadRetry",7);this.dragAndDrop=false;this.required=false;this.disabled=false;this.maxFileSizeMB=7;this.allowedFileTypes=undefined;this.additionalAllowedFileTypes=[];this.allowAnyFileType=false;this.allowedFileExtensions=[];this.label="Label";this.labelRequiredError="At least one file must be uploaded";this.labelBrowseFiles="Browse files";this.labelDragAndDrop="Drag & Drop or browse files to upload";this.labelUploadedFilesHeading="Uploaded files";this.labelFileTooLarge="Upload failed. Max file size: {{size}}MB.";this.labelUnsupportedFileType="Unsupported file type.";this.labelUploaded="Successfully uploaded";this.labelUploadFailed="Upload failed. Please try again.";this.labelSupportedFormatsTemplate="Supported file formats: {{types}}. Max file size: {{size}}MB.";this.labelFileSingular="file";this.labelFilePlural="files";this.labelMaxFilesInfo="Up to {{count}} {{files}}.";this.labelMaxFilesExceeded="Upload limit exceeded. Only {{count}} {{files}} allowed.";this.ariaLabelBrowseFiles="Browse files";this.ariaLabelDropzone="Upload area. Click to browse or drag and drop files.";this.ariaLabelFileInput="Upload file";this.ariaLabelRemoveFile="Remove file";this.ariaLabelCancelUpload="Cancel upload";this.ariaLabelRetryUpload="Retry upload";this.ariaLabelUploadingStatus="Upload in progress";this.ariaLabelUploadedStatus="Upload completed";this.ariaLabelUploadFailedStatus="Upload failed";this.internalId=`ifx-file-upload-${Math.random().toString(36).substr(2,9)}`;this.isDragOver=false;this.files=[];this.uploadTasks=[];this.rejectedSizeFiles=[];this.rejectedTypeFiles=[];this.requiredError=false;this.statusMessage=null;this.fileInputEl=null;this.extensionToMimeMap={jpg:"image/jpeg",jpeg:"image/jpeg",png:"image/png",gif:"image/gif",svg:"image/svg+xml",webp:"image/webp",pdf:"application/pdf",doc:"application/msword",docx:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",xls:"application/vnd.ms-excel",xlsx:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",ppt:"application/vnd.ms-powerpoint",pptx:"application/vnd.openxmlformats-officedocument.presentationml.presentation",txt:"text/plain",csv:"text/csv",json:"application/json",mp3:"audio/mpeg",wav:"audio/wav",mp4:"video/mp4",mov:"video/quicktime",webm:"video/webm",zip:"application/zip",rar:"application/vnd.rar",tar:"application/x-tar",gz:"application/gzip",xml:"application/xml",html:"text/html",css:"text/css",js:"application/javascript"}}get maxFiles(){return this._maxFiles}set maxFiles(i){if(typeof i==="number"&&i<1){console.warn("Invalid `maxFiles` value. Must be >= 1. Value ignored.");this._maxFiles=undefined}else{this._maxFiles=i}}validateRequired(){var i,e;if(this.required&&this.files.length===0){this.requiredError=true;if(((i=this.statusMessage)===null||i===void 0?void 0:i.text)!==this.labelRequiredError){this.statusMessage={type:"error",text:this.labelRequiredError}}this.ifxFileUploadValidation.emit({valid:false})}else{this.requiredError=false;if(((e=this.statusMessage)===null||e===void 0?void 0:e.text)===this.labelRequiredError){this.statusMessage=null}this.ifxFileUploadValidation.emit({valid:true})}}pluralize(i){if(this.allowAnyFileType){return i===1?"file":"files"}return i===1?this.labelFileSingular:this.labelFilePlural}getNormalizedFileTypes(){if(!this.allowedFileTypes&&this.allowedFileExtensions&&this.getNormalizedFileExtensions().length>0){return[]}if(!this.allowedFileTypes){return["jpg","jpeg","png","pdf","mov","mp3","mp4"]}if(Array.isArray(this.allowedFileTypes)){return this.allowedFileTypes}try{return JSON.parse(this.allowedFileTypes)}catch(i){return this.allowedFileTypes.split(",").map((i=>i.trim()))}}getNormalizedFileExtensions(){if(!this.allowedFileExtensions)return[];if(Array.isArray(this.allowedFileExtensions)){return this.allowedFileExtensions}try{return JSON.parse(this.allowedFileExtensions)}catch(i){return this.allowedFileExtensions.split(",").map((i=>i.trim()))}}isFileTypeAllowed(i){if(this.allowAnyFileType){return true}const e=this.getFileExtension(i.name);const t=this.getNormalizedFileTypes();const s=t.map((i=>this.extensionToMimeMap[i.toLowerCase()])).filter(Boolean);if(s.includes(i.type)){return true}const l=this.getAdditionalMimeTypes();if(l.includes(i.type)){return true}const a=this.getNormalizedFileExtensions();if(a.length>0&&e){for(const i of a){const t=i.startsWith(".")?i.substring(1).toLowerCase():i.toLowerCase();if(e===t){return true}}}return false}getFileExtension(i){const e=i.lastIndexOf(".");if(e===-1||e===i.length-1){return null}return i.substring(e+1).toLowerCase()}getLabelFromMimeType(i){for(const[e,t]of Object.entries(this.extensionToMimeMap)){if(t===i){return e.toUpperCase()}}return i}handleFileChange(i){const e=i.target;if(!e.files)return;this.processFiles(e.files)}handleDrop(i){var e;if(this.disabled)return;i.preventDefault();i.stopPropagation();this.isDragOver=false;if((e=i.dataTransfer)===null||e===void 0?void 0:e.files){const e=Array.from(i.dataTransfer.files);const t=[];const s=[];e.forEach((i=>{const e=this.isFileTypeAllowed(i);const l=i.size<=this.maxFileSizeMB*1024*1024;if(e&&l)t.push(i);else s.push(i)}));this.ifxFileUploadDrop.emit({droppedFiles:e,acceptedFiles:t,rejectedFiles:s});this.processFiles(i.dataTransfer.files)}}handleDragOver(i){if(this.disabled)return;i.preventDefault();this.isDragOver=true}handleDragLeave(i){if(this.disabled)return;i.preventDefault();this.isDragOver=false}processFiles(i){const e=Array.from(i);const t=[];const s=[];const l=[];e.forEach((i=>{const e=this.isFileTypeAllowed(i);const a=i.size<=this.maxFileSizeMB*1024*1024;const o=this.files.some((e=>e.name===i.name&&e.size===i.size));if(o){this.ifxFileUploadInvalid.emit({file:i,reason:"duplicate"});this.ifxFileUploadError.emit({file:i,errorType:"duplicate",message:`File "${i.name}" is already added`,reason:"duplicate"});return}if(e&&a){t.push(i)}else{if(!e){l.push(i.name);this.ifxFileUploadInvalid.emit({file:i,reason:"invalid-type"})}if(!a){s.push(i.name);this.ifxFileUploadInvalid.emit({file:i,reason:"invalid-size"})}this.ifxFileUploadError.emit({file:i,errorType:!e?"invalid-type":"file-too-large",message:"Invalid file rejected",reason:!e?"unsupported-type":"file-too-large"})}}));this.rejectedSizeFiles=[...this.rejectedSizeFiles,...s];this.rejectedTypeFiles=[...this.rejectedTypeFiles,...l];if(this.maxFiles&&this.files.length+t.length>this.maxFiles){const i=this.maxFiles-this.files.length;const e=t.slice(0,Math.max(i,0));const s=t.slice(i);this.files=[...this.files,...e];e.forEach((i=>this.startUpload(i)));if(e.length>0){this.ifxFileUploadAdd.emit({addedFiles:e,files:this.files});this.ifxFileUploadChange.emit({files:this.files})}s.forEach((i=>{this.ifxFileUploadInvalid.emit({file:i,reason:"too-many-files"});this.ifxFileUploadError.emit({file:i,errorType:"too-many-files",message:`Upload limit exceeded. Max ${this.maxFiles} files allowed.`,reason:"too-many-files"})}));if(s.length>0){this.statusMessage={type:"error",text:this.labelMaxFilesExceeded.replace("{{count}}",this.maxFiles.toString()).replace("{{files}}",this.pluralize(this.maxFiles))};this.ifxFileUploadMaxFilesExceeded.emit({maxFiles:this.maxFiles,attempted:this.files.length+t.length})}return}t.forEach((i=>this.startUpload(i)));this.files=[...this.files,...t];if(t.length>0){this.ifxFileUploadAdd.emit({addedFiles:t,files:this.files});this.ifxFileUploadChange.emit({files:this.files})}this.validateRequired()}retryUpload(i){const e=this.uploadTasks.findIndex((e=>e.file.name===i.name));if(e!==-1){this.uploadTasks.splice(e,1);this.uploadTasks=[...this.uploadTasks]}this.ifxFileUploadRetry.emit({file:i});this.startUpload(i)}checkAndEmitAllComplete(){if(this.uploadTasks.every((i=>i.completed||i.error))){const i=this.uploadTasks.some((i=>i.completed&&!i.error));if(i){const i=this.uploadTasks.filter((i=>i.completed&&!i.error)).map((i=>i.file));this.ifxFileUploadAllComplete.emit({files:i})}}}resetFileInput(){if(this.fileInputEl){this.fileInputEl.value=""}}updateTaskProgress(i,e){const t=this.uploadTasks.find((e=>e.file===i));if(t){const i=Math.max(t.progress,Math.min(100,e));if(i!==t.progress){t.progress=i;this.uploadTasks=[...this.uploadTasks]}}}startUpload(i){this.ifxFileUploadStart.emit({file:i});const e={file:i,progress:3,intervalId:null,completed:false};this.uploadTasks=[...this.uploadTasks,e];if(this.uploadHandler){this.uploadHandler(i,(e=>{this.updateTaskProgress(i,e)})).then((()=>{e.progress=100;e.completed=true;this.uploadTasks=[...this.uploadTasks];this.ifxFileUploadComplete.emit({file:i});this.ifxFileUploadChange.emit({files:this.files});this.checkAndEmitAllComplete()})).catch((()=>{e.error=true;this.uploadTasks=[...this.uploadTasks];this.ifxFileUploadError.emit({file:i,errorType:"upload-failed",message:"Upload handler rejected file",reason:"custom"});this.checkAndEmitAllComplete()}))}else{const t=i.size;const s=1e5;let l=0;e.intervalId=window.setInterval((()=>{l+=s/5;const a=Math.min(100,Math.round(l/t*100));this.updateTaskProgress(i,a);if(a>=100){clearInterval(e.intervalId);e.completed=true;e.intervalId=null;this.uploadTasks=[...this.uploadTasks];this.ifxFileUploadComplete.emit({file:i});this.ifxFileUploadChange.emit({files:this.files});this.checkAndEmitAllComplete()}}),200)}}cancelUpload(i){const e=this.uploadTasks.findIndex((e=>e.file.name===i.name));if(e!==-1){const i=this.uploadTasks[e];if((i===null||i===void 0?void 0:i.intervalId)!==null){clearInterval(i.intervalId)}this.uploadTasks=this.uploadTasks.filter(((i,t)=>t!==e))}this.files=this.files.filter((e=>e.name!==i.name));this.ifxFileUploadAbort.emit({file:i});this.ifxFileUploadChange.emit({files:this.files});this.resetFileInput();this.validateRequired()}removeFile(i){var e;this.uploadTasks=this.uploadTasks.filter((e=>e.file.name!==i.name));this.files=this.files.filter((e=>e.name!==i.name));this.ifxFileUploadRemove.emit({removedFile:i,files:this.files});this.ifxFileUploadChange.emit({files:this.files});this.validateRequired();this.resetFileInput();if(this.maxFiles&&this.files.length<this.maxFiles&&((e=this.statusMessage)===null||e===void 0?void 0:e.text)!==this.labelRequiredError){this.statusMessage=null}}clearRejectedFile(i,e){if(e==="size"){this.rejectedSizeFiles=this.rejectedSizeFiles.filter((e=>e!==i))}else{this.rejectedTypeFiles=this.rejectedTypeFiles.filter((e=>e!==i))}this.resetFileInput();if(this.maxFiles&&this.files.length<this.maxFiles){this.statusMessage=null}this.validateRequired()}splitFileNameParts(i){const e=i.name;const t=e.lastIndexOf(".");if(t===-1)return{base:e,ext:""};return{base:e.substring(0,t),ext:e.substring(t)}}getFileIcon(i){var e;const t=(e=i.name.split(".").pop())===null||e===void 0?void 0:e.toLowerCase();switch(t){case"pdf":return"file-pdf-16";case"jpg":case"jpeg":return"file-jpg-16";case"png":return"file-png-16";case"mov":return"file-mov-16";case"mp3":return"file-mp3-16";case"mp4":return"file-mp4-16";default:return"file-16"}}formatSize(i){if(i>=1024*1024*1024){return`${(i/(1024*1024*1024)).toFixed(1)} GB`}else if(i>=1024*1024){return`${(i/(1024*1024)).toFixed(1)} MB`}else if(i>=1024){return`${(i/1024).toFixed(0)} KB`}else{return`${i} B`}}getAcceptAttribute(){if(this.allowAnyFileType){return""}const i=[];const e=this.getNormalizedFileTypes().map((i=>"."+i.toLowerCase()));i.push(...e);const t=this.getAdditionalMimeTypes();i.push(...t);const s=this.getNormalizedFileExtensions();s.forEach((e=>{const t=e.startsWith(".")?e:"."+e;i.push(t)}));return i.join(",")}getFormattedProgressText(i){const e=Math.round(i.progress/100*i.file.size);const t=this.formatSize(e);const s=this.formatSize(i.file.size);return`${t} / ${s} uploaded`}getAdditionalMimeTypes(){if(!this.additionalAllowedFileTypes)return[];if(Array.isArray(this.additionalAllowedFileTypes))return this.additionalAllowedFileTypes;return this.additionalAllowedFileTypes.split(",").map((i=>i.trim()))}getSupportedFileText(){if(this.allowAnyFileType){let i=`All file types allowed. Max file size: ${this.maxFileSizeMB}MB.`;if(this.labelMaxFilesInfo&&this.maxFiles){const e=this.pluralize(this.maxFiles);const t=this.labelMaxFilesInfo.replace("{{count}}",this.maxFiles.toString()).replace("{{files}}",e);i+=` ${t}`}return i}const i=[];const e=this.getNormalizedFileTypes().map((i=>i.toUpperCase()));i.push(...e);const t=this.getAdditionalMimeTypes().map((i=>this.getLabelFromMimeType(i)));i.push(...t);const s=this.getNormalizedFileExtensions().map((i=>{const e=i.startsWith(".")?i.substring(1):i;return e.toUpperCase()}));i.push(...s);const l=i.join(", ");let a=this.labelSupportedFormatsTemplate.replace("{{types}}",l).replace("{{size}}",this.maxFileSizeMB.toString());if(this.labelMaxFilesInfo&&this.maxFiles){const i=this.pluralize(this.maxFiles);const e=this.labelMaxFilesInfo.replace("{{count}}",this.maxFiles.toString()).replace("{{files}}",i);a+=` ${e}`}return a}getFormattedFileTooLargeText(){return this.labelFileTooLarge.replace("{{size}}",this.maxFileSizeMB.toString())}renderStatusMessage(){if(!this.statusMessage)return null;return t("div",{class:`file-upload-status file-upload-status__${this.statusMessage.type}`},this.statusMessage.type==="error"&&t("ifx-icon",{icon:"c-warning-16"}),this.statusMessage.text)}isInputDisabled(){return this.disabled||this.maxFiles!==undefined&&this.files.length>=this.maxFiles}async componentDidLoad(){if(!o(this.hostElement)){const i=l();a("ifx-file-upload",await i)}if(this.hostElement.hasAttribute("show-demo-states")){this.showDemoStates=true}if(this.showDemoStates){this.injectDemoState()}}async injectDemoState(){const i=new Array(5e4).fill("a").join("");const e=i+i;const t=new File([i],"Image.jpg",{type:"image/jpeg"});const s=new File([e],"File.pdf",{type:"application/pdf"});const l=new File([i],"Text.docx",{type:"application/vnd.openxmlformats-officedocument.wordprocessingml.document"});const a=new File([e+e+e],"Video.mp4",{type:"video/mp4"});const o=new File(["demo"],"Script.exe",{type:"application/x-msdownload"});this.files=[s,t,l];this.uploadTasks=[{file:s,progress:100,intervalId:null,completed:true},{file:t,progress:40,intervalId:null,completed:false},{file:l,progress:80,intervalId:null,completed:false,error:true}];this.rejectedSizeFiles=[a.name];this.rejectedTypeFiles=[o.name]}async triggerDemoValidation(){this.validateRequired()}render(){return t("div",{key:"1f124f8353f9792779c45c93c69ada515a98e5da",class:{"file-upload-wrapper":true,disabled:this.disabled}},this.label&&t("label",{key:"978f9239732d695dd2423808c7f693425f57234f",class:"file-upload-label",htmlFor:this.internalId},this.label,this.required&&t("span",{key:"244a6645265dcfceba6b4a4a6ccc99b2c91725f9",class:`required ${this.requiredError?"error":""}`},"*")),this.dragAndDrop?this.renderDragAndDropArea():this.renderUploadArea(),(this.files.length>0||this.rejectedSizeFiles.length>0||this.rejectedTypeFiles.length>0)&&t("div",{key:"2f2f116d633310829185149787ad207027b79141",class:"file-list-wrapper"},t("div",{key:"9d572976ac747a7a6a50be2d8d097a2e896c55fb",class:"upload-heading"},this.labelUploadedFilesHeading),t("ul",{key:"223220ed67180059f08025543d7d46ff76b84308",class:"file-list"},this.rejectedSizeFiles.map((i=>t("li",{class:"file-item upload-failed",key:`rejected-size-${i}`},t("div",{class:"file-icon"},t("ifx-icon",{icon:"file-16"})),t("div",{class:"file-info"},t("div",{class:"file-top-row"},t("span",{class:"file-name-wrapper"},t("span",{class:"file-name-base"},this.splitFileNameParts({name:i}).base),t("span",{class:"file-name-ext"},this.splitFileNameParts({name:i}).ext)),t("div",{class:"file-actions"},t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"delete-forever-16",size:"s","aria-label":this.ariaLabelRemoveFile,onClick:()=>this.clearRejectedFile(i,"size")}))),t("div",{class:"file-middle-row"},t("span",{class:"file-status","aria-label":this.labelFileTooLarge.replace("{{size}}",this.maxFileSizeMB.toString())},this.getFormattedFileTooLargeText())))))),this.rejectedTypeFiles.map((i=>t("li",{class:"file-item upload-failed",key:`rejected-type-${i}`},t("div",{class:"file-icon"},t("ifx-icon",{icon:"file-16"})),t("div",{class:"file-info"},t("div",{class:"file-top-row"},t("span",{class:"file-name-wrapper"},t("span",{class:"file-name-base"},this.splitFileNameParts({name:i}).base),t("span",{class:"file-name-ext"},this.splitFileNameParts({name:i}).ext)),t("div",{class:"file-actions"},t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"delete-forever-16",size:"s","aria-label":this.ariaLabelRemoveFile,onClick:()=>this.clearRejectedFile(i,"type")}))),t("div",{class:"file-middle-row"},t("span",{class:"file-status","aria-label":this.labelUnsupportedFileType},this.labelUnsupportedFileType)))))),this.files.map((i=>{var e;const s=this.uploadTasks.find((e=>e.file.name===i.name));const l=(e=s===null||s===void 0?void 0:s.progress)!==null&&e!==void 0?e:100;const a=s&&!s.completed;const o=(s===null||s===void 0?void 0:s.error)===true;const r=o?"file-item upload-failed":a?"file-item uploading":"file-item upload-success";const n=`${i.name}-${i.size}`;const{base:h,ext:d}=this.splitFileNameParts(i);return t("li",{class:r,key:n},t("div",{class:"file-icon"},t("ifx-icon",{icon:this.getFileIcon(i)})),t("div",{class:"file-info"},t("div",{class:"file-top-row"},t("span",{class:"file-name-wrapper"},t("span",{class:"file-name-base"},h),t("span",{class:"file-name-ext"},d)),t("div",{class:"file-actions"},t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"refresh-16",size:"s","aria-label":this.ariaLabelRetryUpload,onClick:()=>this.retryUpload(i),style:{display:o?"inline-flex":"none"}}),t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"cross-16",size:"s","aria-label":this.ariaLabelCancelUpload,onClick:()=>this.cancelUpload(i),style:{display:a?"inline-flex":"none"}}),t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"delete-forever-16",size:"s","aria-label":this.ariaLabelRemoveFile,onClick:()=>this.removeFile(i),style:{display:!a?"inline-flex":"none"}}))),t("div",{class:"file-middle-row"},a&&s&&!s.error&&t("span",{class:"file-uploading","aria-label":this.ariaLabelUploadingStatus},this.getFormattedProgressText(s)),!a&&!o&&t("span",null,t("span",{class:"file-size"},this.formatSize(i.size)),t("span",{class:"file-status","aria-label":this.ariaLabelUploadedStatus},t("ifx-icon",{icon:"check-16"}),this.labelUploaded)),o&&t("span",{class:"file-status","aria-label":this.ariaLabelUploadFailedStatus},this.labelUploadFailed)),a&&s&&!s.error&&t("div",{class:"file-progress-row"},t("ifx-progress-bar",{size:"s",value:l,"show-label":"true"}))))})))))}renderUploadArea(){const i=i=>{this.fileInputEl=i};return t("div",{class:{"upload-button":true}},t("ifx-button",{variant:"secondary",onClick:()=>{var i;return(i=this.fileInputEl)===null||i===void 0?void 0:i.click()},disabled:this.isInputDisabled(),"aria-label":this.ariaLabelBrowseFiles},t("ifx-icon",{icon:"upload-16"}),this.labelBrowseFiles),t("input",{id:this.internalId,ref:i,type:"file",accept:this.getAcceptAttribute(),multiple:true,onChange:i=>this.handleFileChange(i),style:{display:"none"},disabled:this.isInputDisabled(),"aria-label":this.ariaLabelFileInput}),t("p",{class:"file-upload-info"},this.getSupportedFileText()),this.renderStatusMessage())}renderDragAndDropArea(){const i=i=>{this.fileInputEl=i};const e=()=>{if(this.fileInputEl){this.fileInputEl.click()}};return t("div",{class:{disabled:this.isInputDisabled()}},t("div",{class:{"upload-dropzone":true,"drag-over":this.isDragOver,error:this.requiredError},onClick:e,onDragOver:i=>this.handleDragOver(i),onDragLeave:i=>this.handleDragLeave(i),onDrop:i=>this.handleDrop(i),role:"button",tabIndex:0,"aria-label":this.ariaLabelDropzone},t("ifx-icon",{icon:"upload-16",class:"custom-icon"}),t("p",null,this.labelDragAndDrop),t("p",{class:"file-upload-info"},this.getSupportedFileText()),t("div",{style:{height:"0px",overflow:"hidden"}},t("input",{id:this.internalId,ref:i,type:"file",accept:this.getAcceptAttribute(),multiple:true,onChange:i=>this.handleFileChange(i),disabled:this.isInputDisabled(),"aria-label":this.ariaLabelFileInput}))),this.renderStatusMessage())}get hostElement(){return s(this)}};n.style=r;export{n as ifx_file_upload};
2
- //# sourceMappingURL=p-3ffb4e39.entry.js.map
1
+ import{r as i,c as e,h as t,a as s}from"./p-PqnYwNKt.js";import{d as l,t as a}from"./p-DcmcuUOA.js";import{i as o}from"./p-Bw2fh5LT.js";const r=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{font-family:var(--ifx-font-family, sans-serif)}.file-upload-wrapper{display:flex;flex-direction:column}.file-upload-wrapper.disabled{pointer-events:none}.file-upload-wrapper.disabled label,.file-upload-wrapper.disabled .file-upload-info{color:#575352}.file-upload-label{font-style:normal;font-weight:400;font-size:1rem;line-height:1.5rem;color:#1D1D1D}.file-upload-label .required{display:inline-block;margin-left:4px}.file-upload-label .required.error{color:#CD002F}.upload-dropzone{border:1px dashed #BFBBBB;padding:40px;text-align:center;cursor:pointer;color:#1D1D1D;transition:border-color 0.3s ease;border-radius:1px;background:#FFFFFF}.upload-dropzone ifx-icon{color:#0A8276}.upload-dropzone:hover{border:1px dashed #8D8786}.upload-dropzone.drag-over{border:1px solid #0A8276;background:#F7F7F7}.upload-dropzone.drag-over.error{border:1px solid #0A8276}.upload-dropzone.error{border-color:#CD002F}.disabled .upload-dropzone{pointer-events:none;border-color:#BFBBBB;color:#BFBBBB}.disabled .upload-dropzone ifx-icon{color:#BFBBBB}.upload-dropzone input{display:none}.file-upload-info{font-style:normal;font-weight:400;font-size:0.75rem;line-height:1rem;letter-spacing:0em;color:#1D1D1D;margin:0;margin-top:4px}.file-upload-status{font-style:normal;font-weight:400;font-size:0.75rem;line-height:1rem;letter-spacing:0.2px;margin-top:8px}.file-upload-status.file-upload-status__error{display:flex;align-items:center;color:#CD002F}.file-upload-status.file-upload-status__error ifx-icon{position:relative;top:-1px;color:#CD002F;margin-right:8px}.upload-heading{font:600 1.125rem/1.625rem "Source Sans 3";margin-bottom:8px}.file-list-wrapper{margin-top:16px}.file-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}.file-item{border:1px solid #BFBBBB;padding-top:12px;padding-right:16px;padding-bottom:8px;padding-left:16px;display:flex;gap:8px}.file-info{width:100%;min-width:0}.file-top-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:-8px}.file-top-row ifx-icon{flex-shrink:0}.file-name-wrapper{display:flex;min-width:0;max-width:100%;white-space:nowrap;overflow:hidden;font-weight:400;font-size:0.875rem}.file-name-base{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0}.file-name-ext{flex-shrink:0;margin-left:0}.file-middle-row{display:flex;align-items:center;font-size:0.75rem;line-height:1rem;flex-wrap:wrap;color:#575352}.file-middle-row .file-status{margin-left:12px}.file-middle-row .file-status ifx-icon{margin-right:8px}.file-progress-row{margin-top:4px}.file-progress-row ifx-progress-bar{width:100%}.upload-success{border-color:#0A8276}.upload-success .file-status ifx-icon{position:relative;top:1px;color:#4CA460}.upload-failed{border-color:#CD002F}.upload-failed .file-status{color:#CD002F;margin-left:0}';const n=class{constructor(t){i(this,t);this.ifxFileUploadAdd=e(this,"ifxFileUploadAdd",7);this.ifxFileUploadRemove=e(this,"ifxFileUploadRemove",7);this.ifxFileUploadChange=e(this,"ifxFileUploadChange",7);this.ifxFileUploadError=e(this,"ifxFileUploadError",7);this.ifxFileUploadInvalid=e(this,"ifxFileUploadInvalid",7);this.ifxFileUploadStart=e(this,"ifxFileUploadStart",7);this.ifxFileUploadComplete=e(this,"ifxFileUploadComplete",7);this.ifxFileUploadAllComplete=e(this,"ifxFileUploadAllComplete",7);this.ifxFileUploadAbort=e(this,"ifxFileUploadAbort",7);this.ifxFileUploadDrop=e(this,"ifxFileUploadDrop",7);this.ifxFileUploadClick=e(this,"ifxFileUploadClick",7);this.ifxFileUploadMaxFilesExceeded=e(this,"ifxFileUploadMaxFilesExceeded",7);this.ifxFileUploadValidation=e(this,"ifxFileUploadValidation",7);this.ifxFileUploadRetry=e(this,"ifxFileUploadRetry",7);this.dragAndDrop=false;this.required=false;this.disabled=false;this.maxFileSizeMB=7;this.allowedFileTypes=undefined;this.additionalAllowedFileTypes=[];this.allowAnyFileType=false;this.allowedFileExtensions=[];this.label="Label";this.labelRequiredError="At least one file must be uploaded";this.labelBrowseFiles="Browse files";this.labelDragAndDrop="Drag & Drop or browse files to upload";this.labelUploadedFilesHeading="Uploaded files";this.labelFileTooLarge="Upload failed. Max file size: {{size}}MB.";this.labelUnsupportedFileType="Unsupported file type.";this.labelUploaded="Successfully uploaded";this.labelUploadFailed="Upload failed. Please try again.";this.labelSupportedFormatsTemplate="Supported file formats: {{types}}. Max file size: {{size}}MB.";this.labelFileSingular="file";this.labelFilePlural="files";this.labelMaxFilesInfo="Up to {{count}} {{files}}.";this.labelMaxFilesExceeded="Upload limit exceeded. Only {{count}} {{files}} allowed.";this.ariaLabelBrowseFiles="Browse files";this.ariaLabelDropzone="Upload area. Click to browse or drag and drop files.";this.ariaLabelFileInput="Upload file";this.ariaLabelRemoveFile="Remove file";this.ariaLabelCancelUpload="Cancel upload";this.ariaLabelRetryUpload="Retry upload";this.ariaLabelUploadingStatus="Upload in progress";this.ariaLabelUploadedStatus="Upload completed";this.ariaLabelUploadFailedStatus="Upload failed";this.internalId=`ifx-file-upload-${Math.random().toString(36).substr(2,9)}`;this.isDragOver=false;this.files=[];this.uploadTasks=[];this.rejectedSizeFiles=[];this.rejectedTypeFiles=[];this.requiredError=false;this.statusMessage=null;this.fileInputEl=null;this.extensionToMimeMap={jpg:"image/jpeg",jpeg:"image/jpeg",png:"image/png",gif:"image/gif",svg:"image/svg+xml",webp:"image/webp",pdf:"application/pdf",doc:"application/msword",docx:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",xls:"application/vnd.ms-excel",xlsx:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",ppt:"application/vnd.ms-powerpoint",pptx:"application/vnd.openxmlformats-officedocument.presentationml.presentation",txt:"text/plain",csv:"text/csv",json:"application/json",mp3:"audio/mpeg",wav:"audio/wav",mp4:"video/mp4",mov:"video/quicktime",webm:"video/webm",zip:"application/zip",rar:"application/vnd.rar",tar:"application/x-tar",gz:"application/gzip",xml:"application/xml",html:"text/html",css:"text/css",js:"application/javascript"}}get maxFiles(){return this._maxFiles}set maxFiles(i){if(typeof i==="number"&&i<1){console.warn("Invalid `maxFiles` value. Must be >= 1. Value ignored.");this._maxFiles=undefined}else{this._maxFiles=i}}validateRequired(){var i,e;if(this.required&&this.files.length===0){this.requiredError=true;if(((i=this.statusMessage)===null||i===void 0?void 0:i.text)!==this.labelRequiredError){this.statusMessage={type:"error",text:this.labelRequiredError}}this.ifxFileUploadValidation.emit({valid:false})}else{this.requiredError=false;if(((e=this.statusMessage)===null||e===void 0?void 0:e.text)===this.labelRequiredError){this.statusMessage=null}this.ifxFileUploadValidation.emit({valid:true})}}pluralize(i){if(this.allowAnyFileType){return i===1?"file":"files"}return i===1?this.labelFileSingular:this.labelFilePlural}getNormalizedFileTypes(){if(!this.allowedFileTypes&&this.allowedFileExtensions&&this.getNormalizedFileExtensions().length>0){return[]}if(!this.allowedFileTypes){return["jpg","jpeg","png","pdf","mov","mp3","mp4"]}if(Array.isArray(this.allowedFileTypes)){return this.allowedFileTypes}try{return JSON.parse(this.allowedFileTypes)}catch(i){return this.allowedFileTypes.split(",").map((i=>i.trim()))}}getNormalizedFileExtensions(){if(!this.allowedFileExtensions)return[];if(Array.isArray(this.allowedFileExtensions)){return this.allowedFileExtensions}try{return JSON.parse(this.allowedFileExtensions)}catch(i){return this.allowedFileExtensions.split(",").map((i=>i.trim()))}}isFileTypeAllowed(i){if(this.allowAnyFileType){return true}const e=this.getFileExtension(i.name);const t=this.getNormalizedFileTypes();const s=t.map((i=>this.extensionToMimeMap[i.toLowerCase()])).filter(Boolean);if(s.includes(i.type)){return true}const l=this.getAdditionalMimeTypes();if(l.includes(i.type)){return true}const a=this.getNormalizedFileExtensions();if(a.length>0&&e){for(const i of a){const t=i.startsWith(".")?i.substring(1).toLowerCase():i.toLowerCase();if(e===t){return true}}}return false}getFileExtension(i){const e=i.lastIndexOf(".");if(e===-1||e===i.length-1){return null}return i.substring(e+1).toLowerCase()}getLabelFromMimeType(i){for(const[e,t]of Object.entries(this.extensionToMimeMap)){if(t===i){return e.toUpperCase()}}return i}handleFileChange(i){const e=i.target;if(!e.files)return;this.processFiles(e.files)}handleDrop(i){var e;if(this.disabled)return;i.preventDefault();i.stopPropagation();this.isDragOver=false;if((e=i.dataTransfer)===null||e===void 0?void 0:e.files){const e=Array.from(i.dataTransfer.files);const t=[];const s=[];e.forEach((i=>{const e=this.isFileTypeAllowed(i);const l=i.size<=this.maxFileSizeMB*1024*1024;if(e&&l)t.push(i);else s.push(i)}));this.ifxFileUploadDrop.emit({droppedFiles:e,acceptedFiles:t,rejectedFiles:s});this.processFiles(i.dataTransfer.files)}}handleDragOver(i){if(this.disabled)return;i.preventDefault();this.isDragOver=true}handleDragLeave(i){if(this.disabled)return;i.preventDefault();this.isDragOver=false}processFiles(i){const e=Array.from(i);const t=[];const s=[];const l=[];e.forEach((i=>{const e=this.isFileTypeAllowed(i);const a=i.size<=this.maxFileSizeMB*1024*1024;const o=this.files.some((e=>e.name===i.name&&e.size===i.size));if(o){this.ifxFileUploadInvalid.emit({file:i,reason:"duplicate"});this.ifxFileUploadError.emit({file:i,errorType:"duplicate",message:`File "${i.name}" is already added`,reason:"duplicate"});return}if(e&&a){t.push(i)}else{if(!e){l.push(i.name);this.ifxFileUploadInvalid.emit({file:i,reason:"invalid-type"})}if(!a){s.push(i.name);this.ifxFileUploadInvalid.emit({file:i,reason:"invalid-size"})}this.ifxFileUploadError.emit({file:i,errorType:!e?"invalid-type":"file-too-large",message:"Invalid file rejected",reason:!e?"unsupported-type":"file-too-large"})}}));this.rejectedSizeFiles=[...this.rejectedSizeFiles,...s];this.rejectedTypeFiles=[...this.rejectedTypeFiles,...l];if(this.maxFiles&&this.files.length+t.length>this.maxFiles){const i=this.maxFiles-this.files.length;const e=t.slice(0,Math.max(i,0));const s=t.slice(i);this.files=[...this.files,...e];e.forEach((i=>this.startUpload(i)));if(e.length>0){this.ifxFileUploadAdd.emit({addedFiles:e,files:this.files});this.ifxFileUploadChange.emit({files:this.files})}s.forEach((i=>{this.ifxFileUploadInvalid.emit({file:i,reason:"too-many-files"});this.ifxFileUploadError.emit({file:i,errorType:"too-many-files",message:`Upload limit exceeded. Max ${this.maxFiles} files allowed.`,reason:"too-many-files"})}));if(s.length>0){this.statusMessage={type:"error",text:this.labelMaxFilesExceeded.replace("{{count}}",this.maxFiles.toString()).replace("{{files}}",this.pluralize(this.maxFiles))};this.ifxFileUploadMaxFilesExceeded.emit({maxFiles:this.maxFiles,attempted:this.files.length+t.length})}return}t.forEach((i=>this.startUpload(i)));this.files=[...this.files,...t];if(t.length>0){this.ifxFileUploadAdd.emit({addedFiles:t,files:this.files});this.ifxFileUploadChange.emit({files:this.files})}this.validateRequired()}retryUpload(i){const e=this.uploadTasks.findIndex((e=>e.file.name===i.name));if(e!==-1){this.uploadTasks.splice(e,1);this.uploadTasks=[...this.uploadTasks]}this.ifxFileUploadRetry.emit({file:i});this.startUpload(i)}checkAndEmitAllComplete(){if(this.uploadTasks.every((i=>i.completed||i.error))){const i=this.uploadTasks.some((i=>i.completed&&!i.error));if(i){const i=this.uploadTasks.filter((i=>i.completed&&!i.error)).map((i=>i.file));this.ifxFileUploadAllComplete.emit({files:i})}}}resetFileInput(){if(this.fileInputEl){this.fileInputEl.value=""}}updateTaskProgress(i,e){const t=this.uploadTasks.find((e=>e.file===i));if(t){const i=Math.max(t.progress,Math.min(100,e));if(i!==t.progress){t.progress=i;this.uploadTasks=[...this.uploadTasks]}}}startUpload(i){this.ifxFileUploadStart.emit({file:i});const e={file:i,progress:3,intervalId:null,completed:false};this.uploadTasks=[...this.uploadTasks,e];if(this.uploadHandler){this.uploadHandler(i,(e=>{this.updateTaskProgress(i,e)})).then((()=>{e.progress=100;e.completed=true;this.uploadTasks=[...this.uploadTasks];this.ifxFileUploadComplete.emit({file:i});this.ifxFileUploadChange.emit({files:this.files});this.checkAndEmitAllComplete()})).catch((()=>{e.error=true;this.uploadTasks=[...this.uploadTasks];this.ifxFileUploadError.emit({file:i,errorType:"upload-failed",message:"Upload handler rejected file",reason:"custom"});this.checkAndEmitAllComplete()}))}else{const t=i.size;const s=1e5;let l=0;e.intervalId=window.setInterval((()=>{l+=s/5;const a=Math.min(100,Math.round(l/t*100));this.updateTaskProgress(i,a);if(a>=100){clearInterval(e.intervalId);e.completed=true;e.intervalId=null;this.uploadTasks=[...this.uploadTasks];this.ifxFileUploadComplete.emit({file:i});this.ifxFileUploadChange.emit({files:this.files});this.checkAndEmitAllComplete()}}),200)}}cancelUpload(i){const e=this.uploadTasks.findIndex((e=>e.file.name===i.name));if(e!==-1){const i=this.uploadTasks[e];if((i===null||i===void 0?void 0:i.intervalId)!==null){clearInterval(i.intervalId)}this.uploadTasks=this.uploadTasks.filter(((i,t)=>t!==e))}this.files=this.files.filter((e=>e.name!==i.name));this.ifxFileUploadAbort.emit({file:i});this.ifxFileUploadChange.emit({files:this.files});this.resetFileInput();this.validateRequired()}removeFile(i){var e;this.uploadTasks=this.uploadTasks.filter((e=>e.file.name!==i.name));this.files=this.files.filter((e=>e.name!==i.name));this.ifxFileUploadRemove.emit({removedFile:i,files:this.files});this.ifxFileUploadChange.emit({files:this.files});this.validateRequired();this.resetFileInput();if(this.maxFiles&&this.files.length<this.maxFiles&&((e=this.statusMessage)===null||e===void 0?void 0:e.text)!==this.labelRequiredError){this.statusMessage=null}}clearRejectedFile(i,e){if(e==="size"){this.rejectedSizeFiles=this.rejectedSizeFiles.filter((e=>e!==i))}else{this.rejectedTypeFiles=this.rejectedTypeFiles.filter((e=>e!==i))}this.resetFileInput();if(this.maxFiles&&this.files.length<this.maxFiles){this.statusMessage=null}this.validateRequired()}splitFileNameParts(i){const e=i.name;const t=e.lastIndexOf(".");if(t===-1)return{base:e,ext:""};return{base:e.substring(0,t),ext:e.substring(t)}}getFileIcon(i){var e;const t=(e=i.name.split(".").pop())===null||e===void 0?void 0:e.toLowerCase();switch(t){case"pdf":return"file-pdf-16";case"jpg":case"jpeg":return"file-jpg-16";case"png":return"file-png-16";case"mov":return"file-mov-16";case"mp3":return"file-mp3-16";case"mp4":return"file-mp4-16";default:return"file-16"}}formatSize(i){if(i>=1024*1024*1024){return`${(i/(1024*1024*1024)).toFixed(1)} GB`}else if(i>=1024*1024){return`${(i/(1024*1024)).toFixed(1)} MB`}else if(i>=1024){return`${(i/1024).toFixed(0)} KB`}else{return`${i} B`}}getAcceptAttribute(){if(this.allowAnyFileType){return""}const i=[];const e=this.getNormalizedFileTypes().map((i=>"."+i.toLowerCase()));i.push(...e);const t=this.getAdditionalMimeTypes();i.push(...t);const s=this.getNormalizedFileExtensions();s.forEach((e=>{const t=e.startsWith(".")?e:"."+e;i.push(t)}));return i.join(",")}getFormattedProgressText(i){const e=Math.round(i.progress/100*i.file.size);const t=this.formatSize(e);const s=this.formatSize(i.file.size);return`${t} / ${s} uploaded`}getAdditionalMimeTypes(){if(!this.additionalAllowedFileTypes)return[];if(Array.isArray(this.additionalAllowedFileTypes))return this.additionalAllowedFileTypes;return this.additionalAllowedFileTypes.split(",").map((i=>i.trim()))}getSupportedFileText(){if(this.allowAnyFileType){let i=`All file types allowed. Max file size: ${this.maxFileSizeMB}MB.`;if(this.labelMaxFilesInfo&&this.maxFiles){const e=this.pluralize(this.maxFiles);const t=this.labelMaxFilesInfo.replace("{{count}}",this.maxFiles.toString()).replace("{{files}}",e);i+=` ${t}`}return i}const i=[];const e=this.getNormalizedFileTypes().map((i=>i.toUpperCase()));i.push(...e);const t=this.getAdditionalMimeTypes().map((i=>this.getLabelFromMimeType(i)));i.push(...t);const s=this.getNormalizedFileExtensions().map((i=>{const e=i.startsWith(".")?i.substring(1):i;return e.toUpperCase()}));i.push(...s);const l=i.join(", ");let a=this.labelSupportedFormatsTemplate.replace("{{types}}",l).replace("{{size}}",this.maxFileSizeMB.toString());if(this.labelMaxFilesInfo&&this.maxFiles){const i=this.pluralize(this.maxFiles);const e=this.labelMaxFilesInfo.replace("{{count}}",this.maxFiles.toString()).replace("{{files}}",i);a+=` ${e}`}return a}getFormattedFileTooLargeText(){return this.labelFileTooLarge.replace("{{size}}",this.maxFileSizeMB.toString())}renderStatusMessage(){if(!this.statusMessage)return null;return t("div",{class:`file-upload-status file-upload-status__${this.statusMessage.type}`},this.statusMessage.type==="error"&&t("ifx-icon",{icon:"c-warning-16"}),this.statusMessage.text)}isInputDisabled(){return this.disabled||this.maxFiles!==undefined&&this.files.length>=this.maxFiles}async componentDidLoad(){if(!o(this.hostElement)){const i=l();a("ifx-file-upload",await i)}if(this.hostElement.hasAttribute("show-demo-states")){this.showDemoStates=true}if(this.showDemoStates){this.injectDemoState()}}async injectDemoState(){const i=new Array(5e4).fill("a").join("");const e=i+i;const t=new File([i],"Image.jpg",{type:"image/jpeg"});const s=new File([e],"File.pdf",{type:"application/pdf"});const l=new File([i],"Text.docx",{type:"application/vnd.openxmlformats-officedocument.wordprocessingml.document"});const a=new File([e+e+e],"Video.mp4",{type:"video/mp4"});const o=new File(["demo"],"Script.exe",{type:"application/x-msdownload"});this.files=[s,t,l];this.uploadTasks=[{file:s,progress:100,intervalId:null,completed:true},{file:t,progress:40,intervalId:null,completed:false},{file:l,progress:80,intervalId:null,completed:false,error:true}];this.rejectedSizeFiles=[a.name];this.rejectedTypeFiles=[o.name]}async triggerDemoValidation(){this.validateRequired()}render(){return t("div",{key:"ef6b20aec846cdb005bbf42292a6d38a6ed1a503",class:{"file-upload-wrapper":true,disabled:this.disabled}},this.label&&t("label",{key:"91b547b30348f765a3542c88c50790d84affaa8a",class:"file-upload-label",htmlFor:this.internalId},this.label,this.required&&t("span",{key:"bef4e9628b629bacfc729a962b37a009185eb374",class:`required ${this.requiredError?"error":""}`},"*")),this.dragAndDrop?this.renderDragAndDropArea():this.renderUploadArea(),(this.files.length>0||this.rejectedSizeFiles.length>0||this.rejectedTypeFiles.length>0)&&t("div",{key:"0bbe459c523c0a9077f23c458fb59e03b5ae0134",class:"file-list-wrapper"},t("div",{key:"e01f3966e8a3d5697da4d57ea7eb711d026177b9",class:"upload-heading"},this.labelUploadedFilesHeading),t("ul",{key:"7c3c8ce0f8a4ebdac12c843b120482140adf93c2",class:"file-list"},this.rejectedSizeFiles.map((i=>t("li",{class:"file-item upload-failed",key:`rejected-size-${i}`},t("div",{class:"file-icon"},t("ifx-icon",{icon:"file-16"})),t("div",{class:"file-info"},t("div",{class:"file-top-row"},t("span",{class:"file-name-wrapper"},t("span",{class:"file-name-base"},this.splitFileNameParts({name:i}).base),t("span",{class:"file-name-ext"},this.splitFileNameParts({name:i}).ext)),t("div",{class:"file-actions"},t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"delete-forever-16",size:"s","aria-label":this.ariaLabelRemoveFile,onClick:()=>this.clearRejectedFile(i,"size")}))),t("div",{class:"file-middle-row"},t("span",{class:"file-status","aria-label":this.labelFileTooLarge.replace("{{size}}",this.maxFileSizeMB.toString())},this.getFormattedFileTooLargeText())))))),this.rejectedTypeFiles.map((i=>t("li",{class:"file-item upload-failed",key:`rejected-type-${i}`},t("div",{class:"file-icon"},t("ifx-icon",{icon:"file-16"})),t("div",{class:"file-info"},t("div",{class:"file-top-row"},t("span",{class:"file-name-wrapper"},t("span",{class:"file-name-base"},this.splitFileNameParts({name:i}).base),t("span",{class:"file-name-ext"},this.splitFileNameParts({name:i}).ext)),t("div",{class:"file-actions"},t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"delete-forever-16",size:"s","aria-label":this.ariaLabelRemoveFile,onClick:()=>this.clearRejectedFile(i,"type")}))),t("div",{class:"file-middle-row"},t("span",{class:"file-status","aria-label":this.labelUnsupportedFileType},this.labelUnsupportedFileType)))))),this.files.map((i=>{var e;const s=this.uploadTasks.find((e=>e.file.name===i.name));const l=(e=s===null||s===void 0?void 0:s.progress)!==null&&e!==void 0?e:100;const a=s&&!s.completed;const o=(s===null||s===void 0?void 0:s.error)===true;const r=o?"file-item upload-failed":a?"file-item uploading":"file-item upload-success";const n=`${i.name}-${i.size}`;const{base:h,ext:d}=this.splitFileNameParts(i);return t("li",{class:r,key:n},t("div",{class:"file-icon"},t("ifx-icon",{icon:this.getFileIcon(i)})),t("div",{class:"file-info"},t("div",{class:"file-top-row"},t("span",{class:"file-name-wrapper"},t("span",{class:"file-name-base"},h),t("span",{class:"file-name-ext"},d)),t("div",{class:"file-actions"},t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"refresh-16",size:"s","aria-label":this.ariaLabelRetryUpload,onClick:()=>this.retryUpload(i),style:{display:o?"inline-flex":"none"}}),t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"cross-16",size:"s","aria-label":this.ariaLabelCancelUpload,onClick:()=>this.cancelUpload(i),style:{display:a?"inline-flex":"none"}}),t("ifx-icon-button",{shape:"square",variant:"tertiary",icon:"delete-forever-16",size:"s","aria-label":this.ariaLabelRemoveFile,onClick:()=>this.removeFile(i),style:{display:!a?"inline-flex":"none"}}))),t("div",{class:"file-middle-row"},a&&s&&!s.error&&t("span",{class:"file-uploading","aria-label":this.ariaLabelUploadingStatus},this.getFormattedProgressText(s)),!a&&!o&&t("span",null,t("span",{class:"file-size"},this.formatSize(i.size)),t("span",{class:"file-status","aria-label":this.ariaLabelUploadedStatus},t("ifx-icon",{icon:"check-16"}),this.labelUploaded)),o&&t("span",{class:"file-status","aria-label":this.ariaLabelUploadFailedStatus},this.labelUploadFailed)),a&&s&&!s.error&&t("div",{class:"file-progress-row"},t("ifx-progress-bar",{size:"s",value:l,"show-label":"true"}))))})))))}renderUploadArea(){const i=i=>{this.fileInputEl=i};return t("div",{class:{"upload-button":true}},t("ifx-button",{variant:"secondary",onClick:()=>{var i;return(i=this.fileInputEl)===null||i===void 0?void 0:i.click()},disabled:this.isInputDisabled(),"aria-label":this.ariaLabelBrowseFiles},t("ifx-icon",{icon:"upload-16"}),this.labelBrowseFiles),t("input",{id:this.internalId,ref:i,type:"file",accept:this.getAcceptAttribute(),multiple:true,onChange:i=>this.handleFileChange(i),style:{display:"none"},disabled:this.isInputDisabled(),"aria-label":this.ariaLabelFileInput}),t("p",{class:"file-upload-info"},this.getSupportedFileText()),this.renderStatusMessage())}renderDragAndDropArea(){const i=i=>{this.fileInputEl=i};const e=()=>{if(this.fileInputEl){this.fileInputEl.click()}};return t("div",{class:{disabled:this.isInputDisabled()}},t("div",{class:{"upload-dropzone":true,"drag-over":this.isDragOver,error:this.requiredError},onClick:e,onDragOver:i=>this.handleDragOver(i),onDragLeave:i=>this.handleDragLeave(i),onDrop:i=>this.handleDrop(i),role:"button",tabIndex:0,"aria-label":this.ariaLabelDropzone},t("ifx-icon",{icon:"upload-16",class:"custom-icon"}),t("p",null,this.labelDragAndDrop),t("p",{class:"file-upload-info"},this.getSupportedFileText()),t("div",{style:{height:"0px",overflow:"hidden"}},t("input",{id:this.internalId,ref:i,type:"file",accept:this.getAcceptAttribute(),multiple:true,onChange:i=>this.handleFileChange(i),disabled:this.isInputDisabled(),"aria-label":this.ariaLabelFileInput}))),this.renderStatusMessage())}get hostElement(){return s(this)}};n.style=r;export{n as ifx_file_upload};
2
+ //# sourceMappingURL=p-6a07106e.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["fileUploadCss","FileUpload","constructor","hostRef","this","dragAndDrop","required","disabled","maxFileSizeMB","allowedFileTypes","undefined","additionalAllowedFileTypes","allowAnyFileType","allowedFileExtensions","label","labelRequiredError","labelBrowseFiles","labelDragAndDrop","labelUploadedFilesHeading","labelFileTooLarge","labelUnsupportedFileType","labelUploaded","labelUploadFailed","labelSupportedFormatsTemplate","labelFileSingular","labelFilePlural","labelMaxFilesInfo","labelMaxFilesExceeded","ariaLabelBrowseFiles","ariaLabelDropzone","ariaLabelFileInput","ariaLabelRemoveFile","ariaLabelCancelUpload","ariaLabelRetryUpload","ariaLabelUploadingStatus","ariaLabelUploadedStatus","ariaLabelUploadFailedStatus","internalId","Math","random","toString","substr","isDragOver","files","uploadTasks","rejectedSizeFiles","rejectedTypeFiles","requiredError","statusMessage","fileInputEl","extensionToMimeMap","jpg","jpeg","png","gif","svg","webp","pdf","doc","docx","xls","xlsx","ppt","pptx","txt","csv","json","mp3","wav","mp4","mov","webm","zip","rar","tar","gz","xml","html","css","js","maxFiles","_maxFiles","value","console","warn","validateRequired","length","_a","text","type","ifxFileUploadValidation","emit","valid","_b","pluralize","count","getNormalizedFileTypes","getNormalizedFileExtensions","Array","isArray","JSON","parse","split","map","t","trim","isFileTypeAllowed","file","fileExtension","getFileExtension","name","normalizedTypes","allowedMimes","ext","toLowerCase","filter","Boolean","includes","additionalMimeTypes","getAdditionalMimeTypes","customExtensions","normalizedExt","startsWith","substring","filename","lastDotIndex","lastIndexOf","getLabelFromMimeType","mime","knownMime","Object","entries","toUpperCase","handleFileChange","event","input","target","processFiles","handleDrop","preventDefault","stopPropagation","dataTransfer","droppedFiles","from","acceptedFiles","rejectedFiles","forEach","isValidType","isValidSize","size","push","ifxFileUploadDrop","handleDragOver","handleDragLeave","fileList","selectedFiles","validFiles","rejectedSize","rejectedType","isDuplicate","some","existing","ifxFileUploadInvalid","reason","ifxFileUploadError","errorType","message","availableSlots","limitedFiles","slice","max","overflowFiles","startUpload","ifxFileUploadAdd","addedFiles","ifxFileUploadChange","replace","ifxFileUploadMaxFilesExceeded","attempted","retryUpload","taskIndex","findIndex","splice","ifxFileUploadRetry","checkAndEmitAllComplete","every","completed","error","hasSuccessfulUploads","successfulFiles","ifxFileUploadAllComplete","resetFileInput","updateTaskProgress","progress","task","find","newProgress","min","ifxFileUploadStart","intervalId","uploadHandler","percent","then","ifxFileUploadComplete","catch","totalSize","fakeUploadSpeed","uploaded","window","setInterval","round","clearInterval","cancelUpload","_","i","f","ifxFileUploadAbort","removeFile","ifxFileUploadRemove","removedFile","clearRejectedFile","fileName","splitFileNameParts","dotIndex","base","getFileIcon","extension","pop","formatSize","bytes","toFixed","getAcceptAttribute","acceptValues","extensionTypes","mimeTypes","join","getFormattedProgressText","uploadedSize","uploadedText","totalText","getSupportedFileText","fileWord","maxFilesText","allTypes","extensions","cleanExt","typesLabel","getFormattedFileTooLargeText","renderStatusMessage","h","class","icon","isInputDisabled","componentDidLoad","isNestedInIfxComponent","hostElement","framework","detectFramework","trackComponent","hasAttribute","showDemoStates","injectDemoState","dummyContent","fill","bigContent","uploading","File","failed","tooLarge","unsupported","triggerDemoValidation","render","key","htmlFor","renderDragAndDropArea","renderUploadArea","shape","variant","onClick","isUploading","isError","itemClass","uniqueKey","style","display","handleInputRef","el","click","id","ref","accept","multiple","onChange","e","triggerInputClick","onDragOver","onDragLeave","onDrop","role","tabIndex","height","overflow"],"sources":["src/components/file-upload/file-upload.scss?tag=ifx-file-upload&encapsulation=shadow","src/components/file-upload/file-upload.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n:host {\n // TODO remove\n font-family: var(--ifx-font-family, sans-serif);\n}\n\n.file-upload-wrapper {\n display: flex;\n flex-direction: column;\n\n &.disabled {\n pointer-events: none;\n\n label,\n .file-upload-info {\n color: tokens.$ifxColorEngineering500;\n }\n }\n}\n\n.file-upload-label {\n font-style: normal;\n font-weight: 400;\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n color: tokens.$ifxColorBaseBlack;\n\n .required {\n display: inline-block;\n margin-left: 4px;\n\n &.error {\n color: tokens.$ifxColorRed500;\n }\n }\n}\n\n.upload-dropzone {\n border: 1px dashed tokens.$ifxColorEngineering300;\n padding: tokens.$ifxSpace500;\n text-align: center;\n cursor: pointer;\n color: tokens.$ifxColorBaseBlack;\n transition: border-color 0.3s ease;\n border-radius: tokens.$ifxBorderRadius12;\n background: tokens.$ifxColorBaseWhite;\n\n ifx-icon {\n color: tokens.$ifxColorOcean500;\n }\n\n &:hover {\n border: 1px dashed tokens.$ifxColorEngineering400;\n }\n\n &.drag-over {\n border: 1px solid tokens.$ifxColorOcean500;\n background: tokens.$ifxColorEngineering100;\n\n &.error {\n border: 1px solid tokens.$ifxColorOcean500;\n }\n }\n\n &.error {\n border-color: tokens.$ifxColorRed500;\n }\n\n .disabled & {\n pointer-events: none;\n border-color: tokens.$ifxColorEngineering300;\n color: tokens.$ifxColorEngineering300;\n\n ifx-icon {\n color: tokens.$ifxColorEngineering300;\n }\n }\n}\n\n.upload-dropzone input {\n display: none;\n}\n\n.file-upload-info {\n font-style: normal;\n font-weight: tokens.$ifxFontWeightRegular;\n font-size: tokens.$ifxFontSizeXs;\n line-height: tokens.$ifxLineHeightXs;\n letter-spacing: tokens.$ifxLetterSpacingDefault;\n color: tokens.$ifxColorBaseBlack;\n margin: 0;\n margin-top: tokens.$ifxSpace50;\n}\n\n.file-upload-status {\n font-style: normal;\n font-weight: 400;\n font-size: tokens.$ifxFontSizeXs;\n line-height: tokens.$ifxLineHeightXs;\n letter-spacing: 0.2px;\n margin-top: tokens.$ifxSpace100;\n\n &.file-upload-status__error {\n display: flex;\n align-items: center;\n color: tokens.$ifxColorRed500;\n\n ifx-icon {\n position: relative;\n top: - tokens.$ifxSpace12;\n color: tokens.$ifxColorRed500;\n margin-right: tokens.$ifxSpace100;\n }\n }\n}\n\n.upload-heading {\n font: tokens.$ifxHeadingHeading06;\n margin-bottom: tokens.$ifxSpace100;\n}\n\n.file-list-wrapper {\n margin-top: tokens.$ifxSpace200;\n}\n\n.file-list {\n list-style: none;\n padding: 0;\n margin: 0;\n display: flex;\n flex-direction: column;\n gap: tokens.$ifxSpace200;\n}\n\n.file-item {\n border: 1px solid tokens.$ifxColorEngineering300;\n padding-top: tokens.$ifxSpace150;\n padding-right: tokens.$ifxSpace200;\n padding-bottom: tokens.$ifxSpace100;\n padding-left: tokens.$ifxSpace200;\n display: flex;\n gap: tokens.$ifxSpace100;\n}\n\n.file-info {\n width: 100%;\n min-width: 0;\n}\n\n.file-top-row {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: tokens.$ifxSpace200;\n margin-top: - tokens.$ifxSpace100;\n}\n\n.file-top-row ifx-icon {\n flex-shrink: 0;\n}\n\n.file-name-wrapper {\n display: flex;\n min-width: 0;\n max-width: 100%;\n white-space: nowrap;\n overflow: hidden;\n font-weight: tokens.$ifxFontWeightRegular;\n font-size: tokens.$ifxFontSizeS;\n}\n\n.file-name-base {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n flex-shrink: 1;\n min-width: 0;\n}\n\n.file-name-ext {\n flex-shrink: 0;\n margin-left: 0;\n}\n\n.file-middle-row {\n display: flex;\n align-items: center;\n font-size: tokens.$ifxFontSizeXs;\n line-height: tokens.$ifxLineHeightXs;\n flex-wrap: wrap;\n color: tokens.$ifxColorEngineering500;\n\n .file-status {\n margin-left: tokens.$ifxSpace150;\n\n ifx-icon {\n margin-right: tokens.$ifxSpace100;\n }\n }\n}\n\n.file-progress-row {\n margin-top: tokens.$ifxSpace50;\n}\n\n.file-progress-row ifx-progress-bar {\n width: 100%;\n}\n\n.upload-success {\n border-color: tokens.$ifxColorOcean500;\n\n .file-status {\n ifx-icon {\n position: relative;\n top: tokens.$ifxSpace12;\n color: tokens.$ifxColorGreen500;\n }\n }\n}\n\n.upload-failed {\n border-color: tokens.$ifxColorRed500;\n\n .file-status {\n color: tokens.$ifxColorRed500;\n margin-left: 0;\n }\n}\n","import { Component, h, State, Event, EventEmitter, Prop, Method, 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\ninterface UploadTask {\n file: File;\n progress: number;\n intervalId: number | null;\n completed: boolean;\n error?: boolean;\n}\n\nexport type FileUploadErrorReason = 'network-error' | 'timeout' | 'file-too-large' | 'unsupported-type' | 'invalid-type' | 'custom' | (string & {});\n\n@Component({\n tag: 'ifx-file-upload',\n styleUrl: 'file-upload.scss',\n shadow: true,\n})\nexport class FileUpload {\n @Element() hostElement: HTMLElement;\n\n @Prop() dragAndDrop: boolean = false;\n @Prop() required: boolean = false;\n @Prop() disabled: boolean = false;\n @Prop() maxFileSizeMB: number = 7;\n /** Default set of allowed file extensions (used internally). Can be extended using `additionalAllowedFileTypes`. */\n @Prop() allowedFileTypes?: string | string[] = undefined;\n @Prop() additionalAllowedFileTypes?: string | string[] = [];\n /** When set to true, allows any file type to be uploaded (no file type restrictions). */\n @Prop() allowAnyFileType: boolean = false;\n /** Custom file extensions to allow (e.g., 'xml', 'asc', 'cfg'). Recommended format: without dots. Also accepts format with dots like '.xml'. Do not use wildcards like '*.xml'. */\n @Prop() allowedFileExtensions?: string | string[] = [];\n @Prop() uploadHandler?: (file: File, onProgress?: (progress: number) => void) => Promise<void>;\n\n private _maxFiles?: number;\n @Prop()\n get maxFiles(): number | undefined {\n return this._maxFiles;\n }\n set maxFiles(value: number | undefined) {\n if (typeof value === 'number' && value < 1) {\n console.warn('Invalid `maxFiles` value. Must be >= 1. Value ignored.');\n this._maxFiles = undefined;\n } else {\n this._maxFiles = value;\n }\n }\n\n @Prop() label: string = 'Label';\n @Prop() labelRequiredError: string = 'At least one file must be uploaded';\n @Prop() labelBrowseFiles: string = 'Browse files';\n @Prop() labelDragAndDrop: string = 'Drag & Drop or browse files to upload';\n @Prop() labelUploadedFilesHeading: string = 'Uploaded files';\n @Prop() labelFileTooLarge: string = 'Upload failed. Max file size: {{size}}MB.';\n @Prop() labelUnsupportedFileType: string = 'Unsupported file type.';\n @Prop() labelUploaded: string = 'Successfully uploaded';\n @Prop() labelUploadFailed: string = 'Upload failed. Please try again.';\n @Prop() labelSupportedFormatsTemplate: string = 'Supported file formats: {{types}}. Max file size: {{size}}MB.';\n @Prop() labelFileSingular: string = 'file';\n @Prop() labelFilePlural: string = 'files';\n @Prop() labelMaxFilesInfo?: string = 'Up to {{count}} {{files}}.';\n @Prop() labelMaxFilesExceeded: string = 'Upload limit exceeded. Only {{count}} {{files}} allowed.';\n\n @Prop() ariaLabelBrowseFiles: string = 'Browse files';\n @Prop() ariaLabelDropzone: string = 'Upload area. Click to browse or drag and drop files.';\n @Prop() ariaLabelFileInput: string = 'Upload file';\n @Prop() ariaLabelRemoveFile: string = 'Remove file';\n @Prop() ariaLabelCancelUpload: string = 'Cancel upload';\n @Prop() ariaLabelRetryUpload: string = 'Retry upload';\n @Prop() ariaLabelUploadingStatus: string = 'Upload in progress';\n @Prop() ariaLabelUploadedStatus: string = 'Upload completed';\n @Prop() ariaLabelUploadFailedStatus: string = 'Upload failed';\n\n private showDemoStates?: boolean;\n private internalId = `ifx-file-upload-${Math.random().toString(36).substr(2, 9)}`;\n\n @State() isDragOver: boolean = false;\n @State() files: File[] = [];\n @State() uploadTasks: UploadTask[] = [];\n @State() rejectedSizeFiles: string[] = [];\n @State() rejectedTypeFiles: string[] = [];\n @State() requiredError: boolean = false;\n @State() statusMessage: { type: 'error' | 'info' | 'success'; text: string } | null = null;\n\n @Event() ifxFileUploadAdd: EventEmitter<{ addedFiles: File[]; files: File[] }>;\n @Event() ifxFileUploadRemove: EventEmitter<{ removedFile: File; files: File[] }>;\n @Event() ifxFileUploadChange: EventEmitter<{ files: File[] }>;\n @Event() ifxFileUploadError: EventEmitter<{ errorType: string; file: File; message: string; reason?: string }>;\n @Event() ifxFileUploadInvalid: EventEmitter<{ file: File; reason: string }>;\n @Event() ifxFileUploadStart: EventEmitter<{ file: File }>;\n @Event() ifxFileUploadComplete: EventEmitter<{ file: File }>;\n @Event() ifxFileUploadAllComplete: EventEmitter<{ files: File[] }>;\n @Event() ifxFileUploadAbort: EventEmitter<{ file: File }>;\n @Event() ifxFileUploadDrop: EventEmitter<{ droppedFiles: File[]; acceptedFiles: File[]; rejectedFiles: File[] }>;\n @Event() ifxFileUploadClick: EventEmitter<void>;\n @Event() ifxFileUploadMaxFilesExceeded: EventEmitter<{ maxFiles: number; attempted: number }>;\n @Event() ifxFileUploadValidation: EventEmitter<{ valid: boolean }>;\n @Event() ifxFileUploadRetry: EventEmitter<{ file: File }>;\n\n private fileInputEl: HTMLInputElement | null = null;\n\n private extensionToMimeMap: Record<string, string> = {\n /**\n * Maps file extensions to MIME types.\n * This is only used for translating `allowedFileTypes` (extensions) into MIME types,\n * and for labeling in the UI. It does NOT define which files are globally allowed.\n */\n\n // Images\n jpg: 'image/jpeg',\n jpeg: 'image/jpeg',\n png: 'image/png',\n gif: 'image/gif',\n svg: 'image/svg+xml',\n webp: 'image/webp',\n\n // Documents\n pdf: 'application/pdf',\n doc: 'application/msword',\n docx: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n xls: 'application/vnd.ms-excel',\n xlsx: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n ppt: 'application/vnd.ms-powerpoint',\n pptx: 'application/vnd.openxmlformats-officedocument.presentationml.presentation',\n txt: 'text/plain',\n csv: 'text/csv',\n json: 'application/json',\n\n // Audio/Video\n mp3: 'audio/mpeg',\n wav: 'audio/wav',\n mp4: 'video/mp4',\n mov: 'video/quicktime',\n webm: 'video/webm',\n\n // Archive / Code\n zip: 'application/zip',\n rar: 'application/vnd.rar',\n tar: 'application/x-tar',\n gz: 'application/gzip',\n\n // Sonstiges\n xml: 'application/xml',\n html: 'text/html',\n css: 'text/css',\n js: 'application/javascript',\n };\n\n private validateRequired(): void {\n if (this.required && this.files.length === 0) {\n this.requiredError = true;\n\n if (this.statusMessage?.text !== this.labelRequiredError) {\n this.statusMessage = {\n type: 'error',\n text: this.labelRequiredError,\n };\n }\n\n this.ifxFileUploadValidation.emit({ valid: false });\n } else {\n this.requiredError = false;\n\n if (this.statusMessage?.text === this.labelRequiredError) {\n this.statusMessage = null;\n }\n\n this.ifxFileUploadValidation.emit({ valid: true });\n }\n }\n\n private pluralize(count: number): string {\n // If allowAnyFileType is true, use generic terms\n if (this.allowAnyFileType) {\n return count === 1 ? 'file' : 'files';\n }\n return count === 1 ? this.labelFileSingular : this.labelFilePlural;\n }\n\n private getNormalizedFileTypes(): string[] {\n // If allowedFileTypes is not set and allowedFileExtensions is set, return empty array\n if (!this.allowedFileTypes && this.allowedFileExtensions && this.getNormalizedFileExtensions().length > 0) {\n return [];\n }\n\n // If allowedFileTypes is not set and no allowedFileExtensions, use defaults\n if (!this.allowedFileTypes) {\n return ['jpg', 'jpeg', 'png', 'pdf', 'mov', 'mp3', 'mp4'];\n }\n\n if (Array.isArray(this.allowedFileTypes)) {\n return this.allowedFileTypes;\n }\n try {\n return JSON.parse(this.allowedFileTypes);\n } catch {\n return this.allowedFileTypes.split(',').map(t => t.trim());\n }\n }\n\n private getNormalizedFileExtensions(): string[] {\n if (!this.allowedFileExtensions) return [];\n if (Array.isArray(this.allowedFileExtensions)) {\n return this.allowedFileExtensions;\n }\n try {\n return JSON.parse(this.allowedFileExtensions);\n } catch {\n return this.allowedFileExtensions.split(',').map(t => t.trim());\n }\n }\n\n /**\n * Enhanced file type validation that supports:\n * - allowAnyFileType flag for unrestricted uploads (overrides all restrictions)\n * - allowedFileTypes (predefined extensions mapped to MIME types) - if not set and allowedFileExtensions is set, ignored\n * - additionalAllowedFileTypes (MIME types)\n * - allowedFileExtensions (custom extensions) - if only this is set, only these extensions are allowed\n */\n private isFileTypeAllowed(file: File): boolean {\n // If allowAnyFileType is true, accept all files (overrides all restrictions)\n if (this.allowAnyFileType) {\n return true;\n }\n\n const fileExtension = this.getFileExtension(file.name);\n\n // Check against allowedFileTypes (predefined extensions)\n const normalizedTypes = this.getNormalizedFileTypes();\n const allowedMimes = normalizedTypes.map(ext => this.extensionToMimeMap[ext.toLowerCase()]).filter(Boolean);\n\n if (allowedMimes.includes(file.type)) {\n return true;\n }\n\n // Check against additionalAllowedFileTypes (MIME types)\n const additionalMimeTypes = this.getAdditionalMimeTypes();\n if (additionalMimeTypes.includes(file.type)) {\n return true;\n }\n\n // Check against allowedFileExtensions (custom extensions)\n const customExtensions = this.getNormalizedFileExtensions();\n if (customExtensions.length > 0 && fileExtension) {\n for (const ext of customExtensions) {\n const normalizedExt = ext.startsWith('.') ? ext.substring(1).toLowerCase() : ext.toLowerCase();\n if (fileExtension === normalizedExt) {\n return true;\n }\n }\n }\n\n return false;\n }\n\n /**\n * Extracts file extension from filename (without dot)\n */\n private getFileExtension(filename: string): string | null {\n const lastDotIndex = filename.lastIndexOf('.');\n if (lastDotIndex === -1 || lastDotIndex === filename.length - 1) {\n return null;\n }\n return filename.substring(lastDotIndex + 1).toLowerCase();\n }\n\n private getLabelFromMimeType(mime: string): string {\n for (const [ext, knownMime] of Object.entries(this.extensionToMimeMap)) {\n if (knownMime === mime) {\n return ext.toUpperCase();\n }\n }\n return mime; // fallback: show raw MIME\n }\n\n handleFileChange(event: Event) {\n const input = event.target as HTMLInputElement;\n if (!input.files) return;\n this.processFiles(input.files);\n }\n\n handleDrop(event: DragEvent) {\n if (this.disabled) return;\n event.preventDefault();\n event.stopPropagation();\n this.isDragOver = false;\n if (event.dataTransfer?.files) {\n const droppedFiles = Array.from(event.dataTransfer.files);\n\n const acceptedFiles: File[] = [];\n const rejectedFiles: File[] = [];\n\n droppedFiles.forEach(file => {\n const isValidType = this.isFileTypeAllowed(file);\n const isValidSize = file.size <= this.maxFileSizeMB * 1024 * 1024;\n if (isValidType && isValidSize) acceptedFiles.push(file);\n else rejectedFiles.push(file);\n });\n\n this.ifxFileUploadDrop.emit({\n droppedFiles,\n acceptedFiles,\n rejectedFiles,\n });\n\n this.processFiles(event.dataTransfer.files);\n }\n }\n\n handleDragOver(event: DragEvent) {\n if (this.disabled) return;\n event.preventDefault();\n this.isDragOver = true;\n }\n\n handleDragLeave(event: DragEvent) {\n if (this.disabled) return;\n event.preventDefault();\n this.isDragOver = false;\n }\n\n processFiles(fileList: FileList) {\n const selectedFiles = Array.from(fileList);\n\n const validFiles: File[] = [];\n const rejectedSize: string[] = [];\n const rejectedType: string[] = [];\n\n selectedFiles.forEach(file => {\n const isValidType = this.isFileTypeAllowed(file);\n const isValidSize = file.size <= this.maxFileSizeMB * 1024 * 1024;\n const isDuplicate = this.files.some(existing => existing.name === file.name && existing.size === file.size);\n\n if (isDuplicate) {\n this.ifxFileUploadInvalid.emit({ file, reason: 'duplicate' });\n this.ifxFileUploadError.emit({\n file,\n errorType: 'duplicate',\n message: `File \"${file.name}\" is already added`,\n reason: 'duplicate',\n });\n return;\n }\n\n if (isValidType && isValidSize) {\n validFiles.push(file);\n } else {\n if (!isValidType) {\n rejectedType.push(file.name);\n this.ifxFileUploadInvalid.emit({ file, reason: 'invalid-type' });\n }\n if (!isValidSize) {\n rejectedSize.push(file.name);\n this.ifxFileUploadInvalid.emit({ file, reason: 'invalid-size' });\n }\n this.ifxFileUploadError.emit({\n file,\n errorType: !isValidType ? 'invalid-type' : 'file-too-large',\n message: 'Invalid file rejected',\n reason: !isValidType ? 'unsupported-type' : 'file-too-large',\n });\n }\n });\n\n this.rejectedSizeFiles = [...this.rejectedSizeFiles, ...rejectedSize];\n this.rejectedTypeFiles = [...this.rejectedTypeFiles, ...rejectedType];\n\n if (this.maxFiles && this.files.length + validFiles.length > this.maxFiles) {\n const availableSlots = this.maxFiles - this.files.length;\n const limitedFiles = validFiles.slice(0, Math.max(availableSlots, 0));\n const overflowFiles = validFiles.slice(availableSlots);\n\n this.files = [...this.files, ...limitedFiles];\n\n limitedFiles.forEach(file => this.startUpload(file));\n\n if (limitedFiles.length > 0) {\n this.ifxFileUploadAdd.emit({ addedFiles: limitedFiles, files: this.files });\n this.ifxFileUploadChange.emit({ files: this.files });\n }\n\n overflowFiles.forEach(file => {\n this.ifxFileUploadInvalid.emit({ file, reason: 'too-many-files' });\n this.ifxFileUploadError.emit({\n file,\n errorType: 'too-many-files',\n message: `Upload limit exceeded. Max ${this.maxFiles} files allowed.`,\n reason: 'too-many-files',\n });\n });\n\n if (overflowFiles.length > 0) {\n this.statusMessage = {\n type: 'error',\n text: this.labelMaxFilesExceeded.replace('{{count}}', this.maxFiles.toString()).replace('{{files}}', this.pluralize(this.maxFiles)),\n };\n this.ifxFileUploadMaxFilesExceeded.emit({\n maxFiles: this.maxFiles,\n attempted: this.files.length + validFiles.length,\n });\n }\n\n return;\n }\n\n validFiles.forEach(file => this.startUpload(file));\n this.files = [...this.files, ...validFiles];\n\n if (validFiles.length > 0) {\n this.ifxFileUploadAdd.emit({ addedFiles: validFiles, files: this.files });\n this.ifxFileUploadChange.emit({ files: this.files });\n }\n\n this.validateRequired();\n }\n\n retryUpload(file: File) {\n const taskIndex = this.uploadTasks.findIndex(t => t.file.name === file.name);\n if (taskIndex !== -1) {\n this.uploadTasks.splice(taskIndex, 1);\n this.uploadTasks = [...this.uploadTasks];\n }\n this.ifxFileUploadRetry.emit({ file });\n this.startUpload(file);\n }\n\n private checkAndEmitAllComplete(): void {\n if (this.uploadTasks.every(t => t.completed || t.error)) {\n const hasSuccessfulUploads = this.uploadTasks.some(t => t.completed && !t.error);\n if (hasSuccessfulUploads) {\n const successfulFiles = this.uploadTasks.filter(t => t.completed && !t.error).map(t => t.file);\n this.ifxFileUploadAllComplete.emit({ files: successfulFiles });\n }\n }\n }\n\n private resetFileInput(): void {\n if (this.fileInputEl) {\n this.fileInputEl.value = '';\n }\n }\n\n private updateTaskProgress(file: File, progress: number): void {\n const task = this.uploadTasks.find(t => t.file === file);\n if (task) {\n const newProgress = Math.max(task.progress, Math.min(100, progress));\n if (newProgress !== task.progress) {\n task.progress = newProgress;\n this.uploadTasks = [...this.uploadTasks];\n }\n }\n }\n\n startUpload(file: File) {\n this.ifxFileUploadStart.emit({ file });\n const task: UploadTask = {\n file,\n progress: 3, // Start with initial progress for better UX\n intervalId: null,\n completed: false,\n };\n this.uploadTasks = [...this.uploadTasks, task];\n\n if (this.uploadHandler) {\n this.uploadHandler(file, (percent: number) => {\n this.updateTaskProgress(file, percent);\n })\n .then(() => {\n task.progress = 100;\n task.completed = true;\n this.uploadTasks = [...this.uploadTasks];\n this.ifxFileUploadComplete.emit({ file });\n this.ifxFileUploadChange.emit({ files: this.files });\n this.checkAndEmitAllComplete();\n })\n .catch(() => {\n task.error = true;\n this.uploadTasks = [...this.uploadTasks];\n this.ifxFileUploadError.emit({\n file,\n errorType: 'upload-failed',\n message: 'Upload handler rejected file',\n reason: 'custom',\n });\n this.checkAndEmitAllComplete();\n });\n } else {\n const totalSize = file.size;\n const fakeUploadSpeed = 100000;\n let uploaded = 0;\n task.intervalId = window.setInterval(() => {\n uploaded += fakeUploadSpeed / 5;\n const progress = Math.min(100, Math.round((uploaded / totalSize) * 100));\n this.updateTaskProgress(file, progress);\n\n if (progress >= 100) {\n clearInterval(task.intervalId!);\n task.completed = true;\n task.intervalId = null;\n this.uploadTasks = [...this.uploadTasks];\n this.ifxFileUploadComplete.emit({ file });\n this.ifxFileUploadChange.emit({ files: this.files });\n this.checkAndEmitAllComplete();\n }\n }, 200);\n }\n }\n\n cancelUpload(file: File) {\n const taskIndex = this.uploadTasks.findIndex(t => t.file.name === file.name);\n if (taskIndex !== -1) {\n const task = this.uploadTasks[taskIndex];\n if (task?.intervalId !== null) {\n clearInterval(task.intervalId);\n }\n this.uploadTasks = this.uploadTasks.filter((_, i) => i !== taskIndex);\n }\n this.files = this.files.filter(f => f.name !== file.name);\n this.ifxFileUploadAbort.emit({ file });\n this.ifxFileUploadChange.emit({ files: this.files });\n this.resetFileInput();\n this.validateRequired();\n }\n\n removeFile(file: File) {\n this.uploadTasks = this.uploadTasks.filter(task => task.file.name !== file.name);\n this.files = this.files.filter(f => f.name !== file.name);\n this.ifxFileUploadRemove.emit({ removedFile: file, files: this.files });\n this.ifxFileUploadChange.emit({ files: this.files });\n this.validateRequired();\n\n this.resetFileInput();\n\n if (this.maxFiles && this.files.length < this.maxFiles && this.statusMessage?.text !== this.labelRequiredError) {\n this.statusMessage = null;\n }\n }\n\n clearRejectedFile(fileName: string, type: 'size' | 'type') {\n if (type === 'size') {\n this.rejectedSizeFiles = this.rejectedSizeFiles.filter(f => f !== fileName);\n } else {\n this.rejectedTypeFiles = this.rejectedTypeFiles.filter(f => f !== fileName);\n }\n\n this.resetFileInput();\n\n if (this.maxFiles && this.files.length < this.maxFiles) {\n this.statusMessage = null;\n }\n\n this.validateRequired();\n }\n\n splitFileNameParts(file: File): { base: string; ext: string } {\n const name = file.name;\n const dotIndex = name.lastIndexOf('.');\n if (dotIndex === -1) return { base: name, ext: '' };\n return {\n base: name.substring(0, dotIndex),\n ext: name.substring(dotIndex),\n };\n }\n\n getFileIcon(file: File): string {\n const extension = file.name.split('.').pop()?.toLowerCase();\n switch (extension) {\n case 'pdf':\n return 'file-pdf-16';\n case 'jpg':\n case 'jpeg':\n return 'file-jpg-16';\n case 'png':\n return 'file-png-16';\n case 'mov':\n return 'file-mov-16';\n case 'mp3':\n return 'file-mp3-16';\n case 'mp4':\n return 'file-mp4-16';\n default:\n return 'file-16';\n }\n }\n\n formatSize(bytes: number): string {\n if (bytes >= 1024 * 1024 * 1024) {\n return `${(bytes / (1024 * 1024 * 1024)).toFixed(1)} GB`;\n } else if (bytes >= 1024 * 1024) {\n return `${(bytes / (1024 * 1024)).toFixed(1)} MB`;\n } else if (bytes >= 1024) {\n return `${(bytes / 1024).toFixed(0)} KB`;\n } else {\n return `${bytes} B`;\n }\n }\n\n getAcceptAttribute(): string {\n // If allowAnyFileType is true, don't restrict the input\n if (this.allowAnyFileType) {\n return '';\n }\n\n const acceptValues: string[] = [];\n\n // Add extensions from allowedFileTypes\n const extensionTypes = this.getNormalizedFileTypes().map(ext => '.' + ext.toLowerCase());\n acceptValues.push(...extensionTypes);\n\n // Add MIME types from additionalAllowedFileTypes\n const mimeTypes = this.getAdditionalMimeTypes();\n acceptValues.push(...mimeTypes);\n\n // Add custom file extensions\n const customExtensions = this.getNormalizedFileExtensions();\n customExtensions.forEach(ext => {\n const normalizedExt = ext.startsWith('.') ? ext : '.' + ext;\n acceptValues.push(normalizedExt);\n });\n\n return acceptValues.join(',');\n }\n\n private getFormattedProgressText(task: UploadTask): string {\n const uploadedSize = Math.round((task.progress / 100) * task.file.size);\n const uploadedText = this.formatSize(uploadedSize);\n const totalText = this.formatSize(task.file.size);\n return `${uploadedText} / ${totalText} uploaded`;\n }\n\n private getAdditionalMimeTypes(): string[] {\n if (!this.additionalAllowedFileTypes) return [];\n if (Array.isArray(this.additionalAllowedFileTypes)) return this.additionalAllowedFileTypes;\n return this.additionalAllowedFileTypes.split(',').map(t => t.trim());\n }\n\n private getSupportedFileText(): string {\n if (this.allowAnyFileType) {\n let text = `All file types allowed. Max file size: ${this.maxFileSizeMB}MB.`;\n if (this.labelMaxFilesInfo && this.maxFiles) {\n const fileWord = this.pluralize(this.maxFiles);\n const maxFilesText = this.labelMaxFilesInfo.replace('{{count}}', this.maxFiles.toString()).replace('{{files}}', fileWord);\n text += ` ${maxFilesText}`;\n }\n return text;\n }\n\n const allTypes: string[] = [];\n\n // Add extensions from allowedFileTypes\n const extensions = this.getNormalizedFileTypes().map(ext => ext.toUpperCase());\n allTypes.push(...extensions);\n\n // Add MIME types from additionalAllowedFileTypes\n const mimeTypes = this.getAdditionalMimeTypes().map(mime => this.getLabelFromMimeType(mime));\n allTypes.push(...mimeTypes);\n\n // Add custom file extensions\n const customExtensions = this.getNormalizedFileExtensions().map(ext => {\n const cleanExt = ext.startsWith('.') ? ext.substring(1) : ext;\n return cleanExt.toUpperCase();\n });\n allTypes.push(...customExtensions);\n\n const typesLabel = allTypes.join(', ');\n\n let text = this.labelSupportedFormatsTemplate.replace('{{types}}', typesLabel).replace('{{size}}', this.maxFileSizeMB.toString());\n\n if (this.labelMaxFilesInfo && this.maxFiles) {\n const fileWord = this.pluralize(this.maxFiles);\n const maxFilesText = this.labelMaxFilesInfo.replace('{{count}}', this.maxFiles.toString()).replace('{{files}}', fileWord);\n text += ` ${maxFilesText}`;\n }\n\n return text;\n }\n\n private getFormattedFileTooLargeText(): string {\n return this.labelFileTooLarge.replace('{{size}}', this.maxFileSizeMB.toString());\n }\n\n private renderStatusMessage() {\n if (!this.statusMessage) return null;\n\n return (\n <div class={`file-upload-status file-upload-status__${this.statusMessage.type}`}>\n {this.statusMessage.type === 'error' && <ifx-icon icon=\"c-warning-16\"></ifx-icon>}\n {this.statusMessage.text}\n </div>\n );\n }\n\n private isInputDisabled(): boolean {\n return this.disabled || (this.maxFiles !== undefined && this.files.length >= this.maxFiles);\n }\n\n async componentDidLoad() {\n if (!isNestedInIfxComponent(this.hostElement)) {\n const framework = detectFramework();\n trackComponent('ifx-file-upload', await framework);\n }\n\n if (this.hostElement.hasAttribute('show-demo-states')) {\n this.showDemoStates = true;\n }\n\n if (this.showDemoStates) {\n this.injectDemoState();\n }\n }\n\n // Storybook Demo\n @Method()\n async injectDemoState() {\n const dummyContent = new Array(50000).fill('a').join(''); // ~50 KB\n const bigContent = dummyContent + dummyContent; // ~100 KB\n\n const uploading = new File([dummyContent], 'Image.jpg', { type: 'image/jpeg' }); // ~50 KB\n const uploaded = new File([bigContent], 'File.pdf', { type: 'application/pdf' }); // ~100 KB\n const failed = new File([dummyContent], 'Text.docx', { type: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' }); // ~50 KB\n const tooLarge = new File([bigContent + bigContent + bigContent], 'Video.mp4', { type: 'video/mp4' }); // ~300 KB\n const unsupported = new File(['demo'], 'Script.exe', { type: 'application/x-msdownload' }); // very small\n\n this.files = [uploaded, uploading, failed];\n this.uploadTasks = [\n { file: uploaded, progress: 100, intervalId: null, completed: true },\n { file: uploading, progress: 40, intervalId: null, completed: false },\n { file: failed, progress: 80, intervalId: null, completed: false, error: true },\n ];\n this.rejectedSizeFiles = [tooLarge.name];\n this.rejectedTypeFiles = [unsupported.name];\n }\n\n // Storybook Demo\n @Method()\n async triggerDemoValidation(): Promise<void> {\n this.validateRequired();\n }\n\n render() {\n return (\n <div\n class={{\n 'file-upload-wrapper': true,\n 'disabled': this.disabled,\n }}\n >\n {this.label && (\n <label class=\"file-upload-label\" htmlFor={this.internalId}>\n {this.label}\n {this.required && <span class={`required ${this.requiredError ? 'error' : ''}`}>*</span>}\n </label>\n )}\n\n {this.dragAndDrop ? this.renderDragAndDropArea() : this.renderUploadArea()}\n\n {(this.files.length > 0 || this.rejectedSizeFiles.length > 0 || this.rejectedTypeFiles.length > 0) && (\n <div class=\"file-list-wrapper\">\n <div class=\"upload-heading\">{this.labelUploadedFilesHeading}</div>\n <ul class=\"file-list\">\n {this.rejectedSizeFiles.map(fileName => (\n <li class=\"file-item upload-failed\" key={`rejected-size-${fileName}`}>\n <div class=\"file-icon\">\n <ifx-icon icon=\"file-16\"></ifx-icon>\n </div>\n <div class=\"file-info\">\n <div class=\"file-top-row\">\n <span class=\"file-name-wrapper\">\n <span class=\"file-name-base\">{this.splitFileNameParts({ name: fileName } as File).base}</span>\n <span class=\"file-name-ext\">{this.splitFileNameParts({ name: fileName } as File).ext}</span>\n </span>\n <div class=\"file-actions\">\n <ifx-icon-button\n shape=\"square\"\n variant=\"tertiary\"\n icon=\"delete-forever-16\"\n size=\"s\"\n aria-label={this.ariaLabelRemoveFile}\n onClick={() => this.clearRejectedFile(fileName, 'size')}\n ></ifx-icon-button>\n </div>\n </div>\n <div class=\"file-middle-row\">\n <span class=\"file-status\" aria-label={this.labelFileTooLarge.replace('{{size}}', this.maxFileSizeMB.toString())}>\n {this.getFormattedFileTooLargeText()}\n </span>\n </div>\n </div>\n </li>\n ))}\n\n {this.rejectedTypeFiles.map(fileName => (\n <li class=\"file-item upload-failed\" key={`rejected-type-${fileName}`}>\n <div class=\"file-icon\">\n <ifx-icon icon=\"file-16\"></ifx-icon>\n </div>\n <div class=\"file-info\">\n <div class=\"file-top-row\">\n <span class=\"file-name-wrapper\">\n <span class=\"file-name-base\">{this.splitFileNameParts({ name: fileName } as File).base}</span>\n <span class=\"file-name-ext\">{this.splitFileNameParts({ name: fileName } as File).ext}</span>\n </span>\n <div class=\"file-actions\">\n <ifx-icon-button\n shape=\"square\"\n variant=\"tertiary\"\n icon=\"delete-forever-16\"\n size=\"s\"\n aria-label={this.ariaLabelRemoveFile}\n onClick={() => this.clearRejectedFile(fileName, 'type')}\n ></ifx-icon-button>\n </div>\n </div>\n <div class=\"file-middle-row\">\n <span class=\"file-status\" aria-label={this.labelUnsupportedFileType}>\n {this.labelUnsupportedFileType}\n </span>\n </div>\n </div>\n </li>\n ))}\n\n {this.files.map(file => {\n const task = this.uploadTasks.find(t => t.file.name === file.name);\n const progress = task?.progress ?? 100;\n const isUploading = task && !task.completed;\n const isError = task?.error === true;\n const itemClass = isError ? 'file-item upload-failed' : isUploading ? 'file-item uploading' : 'file-item upload-success';\n const uniqueKey = `${file.name}-${file.size}`;\n const { base, ext } = this.splitFileNameParts(file);\n\n return (\n <li class={itemClass} key={uniqueKey}>\n <div class=\"file-icon\">\n <ifx-icon icon={this.getFileIcon(file)}></ifx-icon>\n </div>\n <div class=\"file-info\">\n <div class=\"file-top-row\">\n <span class=\"file-name-wrapper\">\n <span class=\"file-name-base\">{base}</span>\n <span class=\"file-name-ext\">{ext}</span>\n </span>\n <div class=\"file-actions\">\n <ifx-icon-button\n shape=\"square\"\n variant=\"tertiary\"\n icon=\"refresh-16\"\n size=\"s\"\n aria-label={this.ariaLabelRetryUpload}\n onClick={() => this.retryUpload(file)}\n style={{ display: isError ? 'inline-flex' : 'none' }}\n ></ifx-icon-button>\n <ifx-icon-button\n shape=\"square\"\n variant=\"tertiary\"\n icon=\"cross-16\"\n size=\"s\"\n aria-label={this.ariaLabelCancelUpload}\n onClick={() => this.cancelUpload(file)}\n style={{ display: isUploading ? 'inline-flex' : 'none' }}\n ></ifx-icon-button>\n <ifx-icon-button\n shape=\"square\"\n variant=\"tertiary\"\n icon=\"delete-forever-16\"\n size=\"s\"\n aria-label={this.ariaLabelRemoveFile}\n onClick={() => this.removeFile(file)}\n style={{ display: !isUploading ? 'inline-flex' : 'none' }}\n ></ifx-icon-button>\n </div>\n </div>\n\n <div class=\"file-middle-row\">\n {isUploading && task && !task.error && (\n <span class=\"file-uploading\" aria-label={this.ariaLabelUploadingStatus}>\n {this.getFormattedProgressText(task)}\n </span>\n )}\n {!isUploading && !isError && (\n <span>\n <span class=\"file-size\">{this.formatSize(file.size)}</span>\n <span class=\"file-status\" aria-label={this.ariaLabelUploadedStatus}>\n <ifx-icon icon=\"check-16\"></ifx-icon>\n {this.labelUploaded}\n </span>\n </span>\n )}\n {isError && (\n <span class=\"file-status\" aria-label={this.ariaLabelUploadFailedStatus}>\n {this.labelUploadFailed}\n </span>\n )}\n </div>\n\n {isUploading && task && !task.error && (\n <div class=\"file-progress-row\">\n <ifx-progress-bar size=\"s\" value={progress} show-label=\"true\"></ifx-progress-bar>\n </div>\n )}\n </div>\n </li>\n );\n })}\n </ul>\n </div>\n )}\n </div>\n );\n }\n\n renderUploadArea() {\n const handleInputRef = (el: HTMLInputElement | null) => {\n this.fileInputEl = el;\n };\n\n return (\n <div class={{ 'upload-button': true }}>\n <ifx-button variant=\"secondary\" onClick={() => this.fileInputEl?.click()} disabled={this.isInputDisabled()} aria-label={this.ariaLabelBrowseFiles}>\n <ifx-icon icon=\"upload-16\"></ifx-icon>\n {this.labelBrowseFiles}\n </ifx-button>\n <input\n id={this.internalId}\n ref={handleInputRef}\n type=\"file\"\n accept={this.getAcceptAttribute()}\n multiple\n onChange={e => this.handleFileChange(e)}\n style={{ display: 'none' }}\n disabled={this.isInputDisabled()}\n aria-label={this.ariaLabelFileInput}\n />\n <p class=\"file-upload-info\">{this.getSupportedFileText()}</p>\n {this.renderStatusMessage()}\n </div>\n );\n }\n\n renderDragAndDropArea() {\n const handleInputRef = (el: HTMLInputElement | null) => {\n this.fileInputEl = el;\n };\n\n const triggerInputClick = () => {\n if (this.fileInputEl) {\n this.fileInputEl.click();\n }\n };\n\n return (\n <div class={{ disabled: this.isInputDisabled() }}>\n <div\n class={{ 'upload-dropzone': true, 'drag-over': this.isDragOver, 'error': this.requiredError }}\n onClick={triggerInputClick}\n onDragOver={e => this.handleDragOver(e)}\n onDragLeave={e => this.handleDragLeave(e)}\n onDrop={e => this.handleDrop(e)}\n role=\"button\"\n tabIndex={0}\n aria-label={this.ariaLabelDropzone}\n >\n <ifx-icon icon=\"upload-16\" class=\"custom-icon\"></ifx-icon>\n <p>{this.labelDragAndDrop}</p>\n <p class=\"file-upload-info\">{this.getSupportedFileText()}</p>\n <div style={{ height: '0px', overflow: 'hidden' }}>\n <input\n id={this.internalId}\n ref={handleInputRef}\n type=\"file\"\n accept={this.getAcceptAttribute()}\n multiple\n onChange={e => this.handleFileChange(e)}\n disabled={this.isInputDisabled()}\n aria-label={this.ariaLabelFileInput}\n />\n </div>\n </div>\n {this.renderStatusMessage()}\n </div>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,2 +1,2 @@
1
- import{r as t,h as e,a as o,c as i}from"./p-PqnYwNKt.js";import{d as n,t as r}from"./p-DcmcuUOA.js";import{i as a}from"./p-Bw2fh5LT.js";import{c as s}from"./p-DMLRPGid.js";import"./p-B85MJLTf.js";const p=":host{display:inline-block}.spinner{position:relative;width:40px;height:40px}.spinner.s{width:24px;height:24px}.border{box-sizing:border-box;position:absolute;width:100%;height:100%;border:4px solid transparent;border-top-color:#0A8276;border-left-color:#0A8276;border-right-color:#0A8276;border-top-left-radius:1px;border-top-right-radius:1px;border-radius:50%;animation:spin 2s linear infinite}.border.inverted{border-top-color:#FFFFFF;border-left-color:#FFFFFF;border-right-color:#FFFFFF}.semiconductor{width:100%;height:100%;animation:spin 2s linear infinite}.semiconductor svg{fill:#0A8276}.semiconductor.inverted svg{fill:#FFFFFF}.semiconductor.s svg{width:24px;height:24px}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}";const l=class{constructor(e){t(this,e);this.inverted=false}async componentDidLoad(){if(!a(this.el)){const t=n();r("ifx-spinner",await t)}}render(){return e("div",{key:"3494b108576459cad2c7d1c9796c32486df2049f",role:"status","aria-label":this.ariaLabel||"Loading",class:this.getClassNames()},e("div",{key:"4c38429b38606bbfa4886e1c5a356b567961726d",class:`${this.variant!=="brand"?"border":""} ${this.inverted?"inverted":""}`}),this.variant==="brand"&&e("div",{key:"9c76d02a9a93eb20882b89875fc18b15ff7219d3",class:`semiconductor ${this.inverted?"inverted":""} ${this.getSizeClass()}`},e("svg",{key:"7b09ca8942f361fed1e5c4af040e2facc7ae9044",width:"40",height:"40",viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e("g",{key:"28fff6e48621daf10ba79f86975b6c11860a9d6f",id:"spinner/conductor"},e("path",{key:"31a4c0c243b82b3c3f0c870f6990b5d41e7c5ef2",id:"Vector",d:"M38.75 18.75C39.4375 18.75 40 19.3125 40 20C40 20.6875 39.4409 21.25 38.75 21.25H35V26.25H38.75C39.4375 26.25 40 26.8125 40 27.5C40 28.1875 39.4409 28.75 38.75 28.75H35V30C35 32.7617 32.7617 35 30 35H28.75V38.75C28.75 39.4409 28.1875 40 27.5 40C26.8125 40 26.25 39.4409 26.25 38.75V35H21.25V38.75C21.25 39.4409 20.6875 40 20 40C19.3125 40 18.75 39.4409 18.75 38.75V35H13.75V38.75C13.75 39.4409 13.1875 40 12.5 40C11.8125 40 11.25 39.4409 11.25 38.75V35H10C7.23828 35 5 32.7617 5 30V28.75H1.25C0.559062 28.75 0 28.1875 0 27.5C0 26.8125 0.559062 26.25 1.25 26.25H5V21.25H1.25C0.559062 21.25 0 20.6875 0 20C0 19.3125 0.559062 18.75 1.25 18.75H5V13.75H1.25C0.559062 13.75 0 13.1875 0 12.5C0 11.8125 0.559062 11.25 1.25 11.25H5V10C5 7.23828 7.23828 5 10 5H11.25V1.25C11.25 0.5625 11.8125 0 12.5 0C13.1875 0 13.75 0.559063 13.75 1.25V5H18.75V1.25C18.75 0.559063 19.3091 0 20 0C20.6909 0 21.25 0.559063 21.25 1.25V5H26.25V1.25C26.25 0.559063 26.8091 0 27.5 0C28.1909 0 28.75 0.559063 28.75 1.25V5H30C32.7617 5 35 7.23828 35 10V11.25H38.75C39.4409 11.25 40 11.8091 40 12.5C40 13.1909 39.4409 13.75 38.75 13.75H35V18.75H38.75ZM32.5 10C32.5 8.62188 31.3781 7.5 30 7.5H10C8.62187 7.5 7.5 8.62188 7.5 10V30C7.5 31.3781 8.62187 32.5 10 32.5H30C31.3781 32.5 32.5 31.3781 32.5 30V10Z"})))))}getSizeClass(){return`${this.size}`==="s"?"s":""}getClassNames(){return s("spinner",this.size&&`spinner ${this.getSizeClass()}`)}get el(){return o(this)}};l.style=p;const c=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{display:flex}.textInput__container{display:flex;flex-direction:column;align-items:flex-start;padding:0px;width:100%;flex:none;order:0;align-self:stretch;flex-grow:0;font-family:var(--ifx-font-family)}.textInput__container .delete-icon{position:absolute;right:16px}.textInput__container:not(.readonly,.disabled) .delete-icon:hover{cursor:pointer}.textInput__container.disabled:not(.readonly) #text-field{color:#FFFFFF}.textInput__container.disabled:not(.readonly) .delete-icon{color:#FFFFFF}.textInput__container.disabled:not(.readonly) .textInput__top-wrapper label{color:#BFBBBB}.textInput__container.disabled:not(.readonly) .textInput__top-wrapper .required{color:#BFBBBB}.textInput__container.disabled:not(.readonly) .textInput__bottom-wrapper input{border:1px solid #BFBBBB;background-color:#BFBBBB}.textInput__container.disabled:not(.readonly) .textInput__bottom-wrapper input::placeholder{font-size:1rem;color:#FFFFFF}.textInput__container .textInput__top-wrapper{display:flex;flex-direction:row;align-items:flex-start;padding:0px;gap:4px;flex:none;order:0;align-self:stretch;flex-grow:0}.textInput__container .textInput__top-wrapper label{font-style:normal;font-weight:400;font-size:1rem;line-height:1.5rem;display:flex;align-items:center;color:#1D1D1D;flex:none;order:0;flex-grow:0}.textInput__container .textInput__top-wrapper label .optional-required{margin-left:4px}.textInput__container .textInput__top-wrapper label .optional{margin-left:4px}.textInput__container .textInput__top-wrapper label .required{color:#575352;margin-left:4px}.textInput__container .textInput__top-wrapper label .required.error{color:#CD002F}.textInput__container .input-container{position:relative;display:flex;align-items:center;width:100%}.textInput__container .textInput__bottom-wrapper{flex-grow:1;position:relative;display:flex;flex-direction:column;align-items:flex-start;padding:0px;gap:4px;flex:none;order:1;align-self:stretch;flex-grow:0}.textInput__container .textInput__bottom-wrapper input{width:100%;box-sizing:border-box;display:flex;flex-direction:row;align-items:center;padding:8px 16px;gap:8px;height:40px;background-color:#FFFFFF;color:#1D1D1D;font-family:var(--ifx-font-family);font-size:1rem;line-height:1.5rem;border:1px solid #8D8786;border-radius:1px;flex:none;order:0;align-self:stretch;flex-grow:0;text-overflow:ellipsis}.textInput__container .textInput__bottom-wrapper input.input-s{height:36px;font-size:0.875rem;line-height:1.25rem}.textInput__container .textInput__bottom-wrapper input.input-s::placeholder{font-size:1rem;line-height:1.25rem}.textInput__container .textInput__bottom-wrapper input.icon{padding-left:40px}.textInput__container .textInput__bottom-wrapper input.error{border:1px solid #CD002F}.textInput__container .textInput__bottom-wrapper input.error:focus{outline:none}.textInput__container .textInput__bottom-wrapper input.readonly{border:none;border-radius:var(--borderRadius-12, 1px);border-bottom:1px solid var(--color-engineering-300, #bfbbbb);background:var(--color-base-white, #fff);padding-left:0}.textInput__container .textInput__bottom-wrapper input.readonly::placeholder{color:#1D1D1D}.textInput__container .textInput__bottom-wrapper input.success{border:1px solid #4CA460}.textInput__container .textInput__bottom-wrapper input.success:focus{outline:none}.textInput__container .textInput__bottom-wrapper input:focus:not(.error,.success):not(.readonly){outline:none;border:1px solid #0A8276}.textInput__container .textInput__bottom-wrapper input.readonly:focus,.textInput__container .textInput__bottom-wrapper input[readonly]:focus{outline:none;box-shadow:none;border:none;border-bottom:1px solid var(--color-engineering-300, #bfbbbb)}.textInput__container .textInput__bottom-wrapper input:hover:not(:disabled,:focus,.error,.success):not(.readonly){border:1px solid #575352}.textInput__container .textInput__bottom-wrapper .input-icon{position:absolute;top:50%;transform:translateY(-50%);left:16px;transition:0.3s;color:#8D8786}.textInput__container .textInput__bottom-wrapper .textInput__bottom-wrapper-caption{font-style:normal;font-weight:400;font-size:0.75rem;line-height:1rem;color:#1D1D1D;flex:none;order:1;align-self:stretch;flex-grow:0}.textInput__container .textInput__bottom-wrapper .textInput__bottom-wrapper-caption.error{color:#CD002F}.textInput__container .textInput__bottom-wrapper .textInput__bottom-wrapper-caption.disabled{color:#BFBBBB}';const d=class{constructor(e){t(this,e);this.ifxInput=i(this,"ifxInput",7);if(e.$hostElement$["s-ei"]){this.internals=e.$hostElement$["s-ei"]}else{this.internals=e.$hostElement$.attachInternals();e.$hostElement$["s-ei"]=this.internals}this.placeholder="Placeholder";this.value="";this.error=false;this.label="";this.icon="";this.caption="";this.size="m";this.required=false;this.success=false;this.disabled=false;this.readOnly=false;this.showDeleteIcon=false;this.autocomplete="on";this.type="text";this.internalId="text-field"}valueWatcher(t){if(t!==this.inputElement.value){this.inputElement.value=t}}async reset(){this.value="";this.inputElement.value=""}handleDeleteContent(){if(!this.disabled&&!this.readOnly){this.reset();this.ifxInput.emit(this.value)}}handleInput(){const t=this.inputElement.value;this.value=t;this.ifxInput.emit(this.value)}handleTypeProp(){this.internalType=this.type==="text"||this.type==="password"?this.type:"text"}componentWillLoad(){this.handleTypeProp()}async componentDidLoad(){if(!a(this.el)){const t=n();r("ifx-text-field",await t)}}render(){return e("div",{key:"d67359eb3f5b01ca82f3d7e100c932b394f5dd72","aria-label":"a text field for user input","aria-value":this.value,"aria-disabled":this.disabled,class:`textInput__container ${this.readOnly?"readonly":""} ${this.disabled&&!this.error?"disabled":""}`},e("div",{key:"984feba03b24e932834781c8f816e79817fbec7f",class:"textInput__top-wrapper"},this.label&&e("label",{key:"02c23276205f851ee2c8807d2b67bccc11fb4350",htmlFor:this.internalId},e("span",{key:"8473ccc62f76dad8aa84b5f98b36caacaa5c3fb2"},this.label),this.required&&e("span",{key:"60b25e7269a034b0d4fa7fd63e25151c1e0b8de0",class:`required ${this.error&&!this.readOnly?"error":""}`},"*"))),e("div",{key:"f9e0d1caa7c5f8774132fbed4857e84af4dbb5a2",class:"textInput__bottom-wrapper"},e("div",{key:"10ae27bf8edb9a9fc1a35b9e79db46dc07272a76",class:"input-container"},this.icon&&e("ifx-icon",{key:"e78ef7ef5c27a8366fcc87148112c3f2fd5c6432",class:"input-icon",icon:this.icon}),e("input",{key:"f384201d840524143d8e9e75dd25e7d09b64ab52",ref:t=>this.inputElement=t,disabled:this.disabled&&!this.error,autocomplete:this.autocomplete,type:this.internalType,id:this.internalId,value:this.value,onInput:()=>this.handleInput(),placeholder:this.placeholder,readonly:this.readOnly,maxlength:this.maxlength,class:`${this.icon?"icon":""}\n ${this.error?"error":""} \n ${this.readOnly?"readonly":""} \n ${this.size==="s"?"input-s":""}\n ${this.success?"success":""}`}),this.showDeleteIcon&&this.value&&e("ifx-icon",{key:"b2e4e802c696d38c22975c09c1e2737187bf51f6",class:"delete-icon",icon:"cRemove16",onClick:()=>this.handleDeleteContent()})),this.caption&&e("div",{key:"870558a1ab7766ffc694ae7e0fcb1b6ba95e5f6b",class:`textInput__bottom-wrapper-caption ${this.error&&!this.readOnly?"error":""} ${this.disabled&&!this.readOnly&&!this.error?"disabled":""}`},this.caption)))}get el(){return o(this)}static get watchers(){return{value:["valueWatcher"]}}};d.style=c;export{l as ifx_spinner,d as ifx_text_field};
2
- //# sourceMappingURL=p-b2e514e5.entry.js.map
1
+ import{r as t,h as e,a as o,c as i}from"./p-PqnYwNKt.js";import{d as n,t as r}from"./p-DcmcuUOA.js";import{i as a}from"./p-Bw2fh5LT.js";import{c as s}from"./p-DMLRPGid.js";import"./p-B85MJLTf.js";const p=":host{display:inline-block}.spinner{position:relative;width:40px;height:40px}.spinner.s{width:24px;height:24px}.border{box-sizing:border-box;position:absolute;width:100%;height:100%;border:4px solid transparent;border-top-color:#0A8276;border-left-color:#0A8276;border-right-color:#0A8276;border-top-left-radius:1px;border-top-right-radius:1px;border-radius:50%;animation:spin 2s linear infinite}.border.inverted{border-top-color:#FFFFFF;border-left-color:#FFFFFF;border-right-color:#FFFFFF}.semiconductor{width:100%;height:100%;animation:spin 2s linear infinite}.semiconductor svg{fill:#0A8276}.semiconductor.inverted svg{fill:#FFFFFF}.semiconductor.s svg{width:24px;height:24px}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}";const l=class{constructor(e){t(this,e);this.inverted=false}async componentDidLoad(){if(!a(this.el)){const t=n();r("ifx-spinner",await t)}}render(){return e("div",{key:"dcb5fa927ad5ad53c34eb4c47a115cf3ae9958cd",role:"status","aria-label":this.ariaLabel||"Loading",class:this.getClassNames()},e("div",{key:"490dd918800c9ae2dad8289cc5b7adaefeff8ab7",class:`${this.variant!=="brand"?"border":""} ${this.inverted?"inverted":""}`}),this.variant==="brand"&&e("div",{key:"4da8f91e1154a482b8f196e7a8c972db546ca16a",class:`semiconductor ${this.inverted?"inverted":""} ${this.getSizeClass()}`},e("svg",{key:"d1e37b9d383892fc9528588184fb3af7c76934de",width:"40",height:"40",viewBox:"0 0 40 40",fill:"none",xmlns:"http://www.w3.org/2000/svg"},e("g",{key:"f750eebbab8e00e9f1b6913d8f229ad13f1b94a2",id:"spinner/conductor"},e("path",{key:"c96fa1feb182affde75eabf4a4cc834f2f3d3dcc",id:"Vector",d:"M38.75 18.75C39.4375 18.75 40 19.3125 40 20C40 20.6875 39.4409 21.25 38.75 21.25H35V26.25H38.75C39.4375 26.25 40 26.8125 40 27.5C40 28.1875 39.4409 28.75 38.75 28.75H35V30C35 32.7617 32.7617 35 30 35H28.75V38.75C28.75 39.4409 28.1875 40 27.5 40C26.8125 40 26.25 39.4409 26.25 38.75V35H21.25V38.75C21.25 39.4409 20.6875 40 20 40C19.3125 40 18.75 39.4409 18.75 38.75V35H13.75V38.75C13.75 39.4409 13.1875 40 12.5 40C11.8125 40 11.25 39.4409 11.25 38.75V35H10C7.23828 35 5 32.7617 5 30V28.75H1.25C0.559062 28.75 0 28.1875 0 27.5C0 26.8125 0.559062 26.25 1.25 26.25H5V21.25H1.25C0.559062 21.25 0 20.6875 0 20C0 19.3125 0.559062 18.75 1.25 18.75H5V13.75H1.25C0.559062 13.75 0 13.1875 0 12.5C0 11.8125 0.559062 11.25 1.25 11.25H5V10C5 7.23828 7.23828 5 10 5H11.25V1.25C11.25 0.5625 11.8125 0 12.5 0C13.1875 0 13.75 0.559063 13.75 1.25V5H18.75V1.25C18.75 0.559063 19.3091 0 20 0C20.6909 0 21.25 0.559063 21.25 1.25V5H26.25V1.25C26.25 0.559063 26.8091 0 27.5 0C28.1909 0 28.75 0.559063 28.75 1.25V5H30C32.7617 5 35 7.23828 35 10V11.25H38.75C39.4409 11.25 40 11.8091 40 12.5C40 13.1909 39.4409 13.75 38.75 13.75H35V18.75H38.75ZM32.5 10C32.5 8.62188 31.3781 7.5 30 7.5H10C8.62187 7.5 7.5 8.62188 7.5 10V30C7.5 31.3781 8.62187 32.5 10 32.5H30C31.3781 32.5 32.5 31.3781 32.5 30V10Z"})))))}getSizeClass(){return`${this.size}`==="s"?"s":""}getClassNames(){return s("spinner",this.size&&`spinner ${this.getSizeClass()}`)}get el(){return o(this)}};l.style=p;const d=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}:host{display:flex}.textInput__container{display:flex;flex-direction:column;align-items:flex-start;padding:0px;width:100%;flex:none;order:0;align-self:stretch;flex-grow:0;font-family:var(--ifx-font-family)}.textInput__container .delete-icon{position:absolute;right:16px}.textInput__container:not(.readonly,.disabled) .delete-icon:hover{cursor:pointer}.textInput__container.disabled:not(.readonly) #text-field{color:#FFFFFF}.textInput__container.disabled:not(.readonly) .delete-icon{color:#FFFFFF}.textInput__container.disabled:not(.readonly) .textInput__top-wrapper label{color:#BFBBBB}.textInput__container.disabled:not(.readonly) .textInput__top-wrapper .required{color:#BFBBBB}.textInput__container.disabled:not(.readonly) .textInput__bottom-wrapper input{border:1px solid #BFBBBB;background-color:#BFBBBB}.textInput__container.disabled:not(.readonly) .textInput__bottom-wrapper input::placeholder{font-size:1rem;color:#FFFFFF}.textInput__container .textInput__top-wrapper{display:flex;flex-direction:row;align-items:flex-start;padding:0px;gap:4px;flex:none;order:0;align-self:stretch;flex-grow:0}.textInput__container .textInput__top-wrapper label{font-style:normal;font-weight:400;font-size:1rem;line-height:1.5rem;display:flex;align-items:center;color:#1D1D1D;flex:none;order:0;flex-grow:0}.textInput__container .textInput__top-wrapper label .optional-required{margin-left:4px}.textInput__container .textInput__top-wrapper label .optional{margin-left:4px}.textInput__container .textInput__top-wrapper label .required{color:#575352;margin-left:4px}.textInput__container .textInput__top-wrapper label .required.error{color:#CD002F}.textInput__container .input-container{position:relative;display:flex;align-items:center;width:100%}.textInput__container .textInput__bottom-wrapper{flex-grow:1;position:relative;display:flex;flex-direction:column;align-items:flex-start;padding:0px;gap:4px;flex:none;order:1;align-self:stretch;flex-grow:0}.textInput__container .textInput__bottom-wrapper input{width:100%;box-sizing:border-box;display:flex;flex-direction:row;align-items:center;padding:8px 16px;gap:8px;height:40px;background-color:#FFFFFF;color:#1D1D1D;font-family:var(--ifx-font-family);font-size:1rem;line-height:1.5rem;border:1px solid #8D8786;border-radius:1px;flex:none;order:0;align-self:stretch;flex-grow:0;text-overflow:ellipsis}.textInput__container .textInput__bottom-wrapper input.input-s{height:36px;font-size:0.875rem;line-height:1.25rem}.textInput__container .textInput__bottom-wrapper input.input-s::placeholder{font-size:1rem;line-height:1.25rem}.textInput__container .textInput__bottom-wrapper input.icon{padding-left:40px}.textInput__container .textInput__bottom-wrapper input.error{border:1px solid #CD002F}.textInput__container .textInput__bottom-wrapper input.error:focus{outline:none}.textInput__container .textInput__bottom-wrapper input.readonly{border:none;border-radius:var(--borderRadius-12, 1px);border-bottom:1px solid var(--color-engineering-300, #bfbbbb);background:var(--color-base-white, #fff);padding-left:0}.textInput__container .textInput__bottom-wrapper input.readonly::placeholder{color:#1D1D1D}.textInput__container .textInput__bottom-wrapper input.success{border:1px solid #4CA460}.textInput__container .textInput__bottom-wrapper input.success:focus{outline:none}.textInput__container .textInput__bottom-wrapper input:focus:not(.error,.success):not(.readonly){outline:none;border:1px solid #0A8276}.textInput__container .textInput__bottom-wrapper input.readonly:focus,.textInput__container .textInput__bottom-wrapper input[readonly]:focus{outline:none;box-shadow:none;border:none;border-bottom:1px solid var(--color-engineering-300, #bfbbbb)}.textInput__container .textInput__bottom-wrapper input:hover:not(:disabled,:focus,.error,.success):not(.readonly){border:1px solid #575352}.textInput__container .textInput__bottom-wrapper .input-icon{position:absolute;top:50%;transform:translateY(-50%);left:16px;transition:0.3s;color:#8D8786}.textInput__container .textInput__bottom-wrapper .textInput__bottom-wrapper-caption{font-style:normal;font-weight:400;font-size:0.75rem;line-height:1rem;color:#1D1D1D;flex:none;order:1;align-self:stretch;flex-grow:0}.textInput__container .textInput__bottom-wrapper .textInput__bottom-wrapper-caption.error{color:#CD002F}.textInput__container .textInput__bottom-wrapper .textInput__bottom-wrapper-caption.disabled{color:#BFBBBB}';const c=class{constructor(e){t(this,e);this.ifxInput=i(this,"ifxInput",7);if(e.$hostElement$["s-ei"]){this.internals=e.$hostElement$["s-ei"]}else{this.internals=e.$hostElement$.attachInternals();e.$hostElement$["s-ei"]=this.internals}this.placeholder="Placeholder";this.value="";this.error=false;this.label="";this.icon="";this.caption="";this.size="m";this.required=false;this.success=false;this.disabled=false;this.readOnly=false;this.showDeleteIcon=false;this.autocomplete="on";this.type="text";this.internalId="text-field"}valueWatcher(t){if(t!==this.inputElement.value){this.inputElement.value=t}}async reset(){this.value="";this.inputElement.value=""}handleDeleteContent(){if(!this.disabled&&!this.readOnly){this.reset();this.ifxInput.emit(this.value)}}handleInput(){const t=this.inputElement.value;this.value=t;this.ifxInput.emit(this.value)}handleTypeProp(){this.internalType=this.type==="text"||this.type==="password"?this.type:"text"}componentWillLoad(){this.handleTypeProp()}async componentDidLoad(){if(!a(this.el)){const t=n();r("ifx-text-field",await t)}}render(){return e("div",{key:"fde8ba65931e70265b84ddd75143a78627cbbba7","aria-label":"a text field for user input","aria-value":this.value,"aria-disabled":this.disabled,class:`textInput__container ${this.readOnly?"readonly":""} ${this.disabled&&!this.error?"disabled":""}`},e("div",{key:"662198ca46ff5a6d568589b5d0ebb4b6117a6205",class:"textInput__top-wrapper"},this.label&&e("label",{key:"be2ec4dec1d869c891f8defac11181ca18f06053",htmlFor:this.internalId},e("span",{key:"46d77c5682c4ed8ac8cfb41a4ef676bc061236a8"},this.label),this.required&&e("span",{key:"28ddfeee2b30168c4c755bdc822fec0ef98c529a",class:`required ${this.error&&!this.readOnly?"error":""}`},"*"))),e("div",{key:"20457f5caf1857c5e7259763a885ed7c7a9df636",class:"textInput__bottom-wrapper"},e("div",{key:"7e9a0bfc6a2f590d741ece4639d5f38e4c712085",class:"input-container"},this.icon&&e("ifx-icon",{key:"ebdc52fb4dcca7912fd6ac428f1f42442fbb2313",class:"input-icon",icon:this.icon}),e("input",{key:"4760819b300477cbac4da643c41b3dfb97d62285",ref:t=>this.inputElement=t,disabled:this.disabled&&!this.error,autocomplete:this.autocomplete,type:this.internalType,id:this.internalId,value:this.value,onInput:()=>this.handleInput(),placeholder:this.placeholder,readonly:this.readOnly,maxlength:this.maxlength,class:`${this.icon?"icon":""}\n ${this.error?"error":""} \n ${this.readOnly?"readonly":""} \n ${this.size==="s"?"input-s":""}\n ${this.success?"success":""}`}),this.showDeleteIcon&&this.value&&e("ifx-icon",{key:"34d4b05f44f3b5a0f4afddf40b2d3a0384482a57",class:"delete-icon",icon:"cRemove16",onClick:()=>this.handleDeleteContent()})),this.caption&&e("div",{key:"da655fe4c12336e535e9f1be649136ce9344c115",class:`textInput__bottom-wrapper-caption ${this.error&&!this.readOnly?"error":""} ${this.disabled&&!this.readOnly&&!this.error?"disabled":""}`},this.caption)))}get el(){return o(this)}static get watchers(){return{value:["valueWatcher"]}}};c.style=d;export{l as ifx_spinner,c as ifx_text_field};
2
+ //# sourceMappingURL=p-6e115707.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["spinnerCss","Spinner","constructor","hostRef","this","inverted","componentDidLoad","isNestedInIfxComponent","el","framework","detectFramework","trackComponent","render","h","key","role","ariaLabel","class","getClassNames","variant","getSizeClass","width","height","viewBox","fill","xmlns","id","d","size","classNames","textFieldCss","TextField","placeholder","value","error","label","icon","caption","required","success","disabled","readOnly","showDeleteIcon","autocomplete","type","internalId","valueWatcher","newValue","inputElement","reset","handleDeleteContent","ifxInput","emit","handleInput","query","handleTypeProp","internalType","componentWillLoad","htmlFor","ref","onInput","readonly","maxlength","onClick"],"sources":["src/components/spinner/spinner.scss?tag=ifx-spinner&encapsulation=shadow","src/components/spinner/spinner.tsx","src/components/text-field/text-field.scss?tag=ifx-text-field&encapsulation=shadow","src/components/text-field/text-field.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n:host {\n display: inline-block;\n\n}\n\n.spinner {\n position: relative;\n width: tokens.$ifxSize500;\n height: tokens.$ifxSize500;\n\n}\n\n.spinner.s {\n width: tokens.$ifxSize300;\n height: tokens.$ifxSize300;\n}\n\n.border {\n box-sizing: border-box;\n position: absolute;\n width: 100%;\n height: 100%;\n border: 4px solid transparent;\n border-top-color: tokens.$ifxColorOcean500;\n border-left-color: tokens.$ifxColorOcean500;\n border-right-color: tokens.$ifxColorOcean500;\n border-top-left-radius: 1px;\n border-top-right-radius: 1px;\n border-radius: 50%;\n animation: spin 2s linear infinite;\n\n &.inverted {\n border-top-color: tokens.$ifxColorBaseWhite;\n border-left-color: tokens.$ifxColorBaseWhite;\n border-right-color: tokens.$ifxColorBaseWhite;\n }\n}\n\n.semiconductor {\n width: 100%;\n height: 100%;\n animation: spin 2s linear infinite;\n\n & svg {\n fill: tokens.$ifxColorOcean500;\n }\n\n &.inverted {\n & svg {\n fill: tokens.$ifxColorBaseWhite;\n }\n }\n\n &.s {\n & svg {\n width: tokens.$ifxSize300;\n height: tokens.$ifxSize300;\n }\n }\n}\n\n\n@keyframes spin {\n 0% {\n transform: rotate(0deg);\n }\n\n 100% {\n transform: rotate(360deg);\n }\n}","import { Component, h, Prop, Element } from '@stencil/core';\nimport { trackComponent } from '../../global/utils/tracking';\nimport { isNestedInIfxComponent } from '../../global/utils/dom-utils';\nimport { detectFramework } from '../../global/utils/framework-detection';\nimport classNames from 'classnames';\n \n@Component({\n tag: 'ifx-spinner',\n styleUrl: 'spinner.scss',\n shadow: true,\n})\nexport class Spinner {\n @Element() el;\n @Prop() size: string;\n @Prop() variant: string;\n @Prop() inverted: boolean = false;\n @Prop() ariaLabel: string | null;\n\n async componentDidLoad() { \n if(!isNestedInIfxComponent(this.el)) { \n const framework = detectFramework();\n trackComponent('ifx-spinner', await framework)\n }\n }\n\n render() {\n return (\n <div role=\"status\" \n aria-label={this.ariaLabel || \"Loading\"}\n class={this.getClassNames()}>\n <div class={`${this.variant !== 'brand' ? 'border' : \"\"} ${this.inverted ? 'inverted' : \"\"}`}></div>\n {this.variant === 'brand'\n && <div class={`semiconductor ${this.inverted ? 'inverted' : \"\"} ${this.getSizeClass()}`}>\n <svg width='40' height='40' viewBox=\"0 0 40 40\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"spinner/conductor\">\n <path id=\"Vector\" d=\"M38.75 18.75C39.4375 18.75 40 19.3125 40 20C40 20.6875 39.4409 21.25 38.75 21.25H35V26.25H38.75C39.4375 26.25 40 26.8125 40 27.5C40 28.1875 39.4409 28.75 38.75 28.75H35V30C35 32.7617 32.7617 35 30 35H28.75V38.75C28.75 39.4409 28.1875 40 27.5 40C26.8125 40 26.25 39.4409 26.25 38.75V35H21.25V38.75C21.25 39.4409 20.6875 40 20 40C19.3125 40 18.75 39.4409 18.75 38.75V35H13.75V38.75C13.75 39.4409 13.1875 40 12.5 40C11.8125 40 11.25 39.4409 11.25 38.75V35H10C7.23828 35 5 32.7617 5 30V28.75H1.25C0.559062 28.75 0 28.1875 0 27.5C0 26.8125 0.559062 26.25 1.25 26.25H5V21.25H1.25C0.559062 21.25 0 20.6875 0 20C0 19.3125 0.559062 18.75 1.25 18.75H5V13.75H1.25C0.559062 13.75 0 13.1875 0 12.5C0 11.8125 0.559062 11.25 1.25 11.25H5V10C5 7.23828 7.23828 5 10 5H11.25V1.25C11.25 0.5625 11.8125 0 12.5 0C13.1875 0 13.75 0.559063 13.75 1.25V5H18.75V1.25C18.75 0.559063 19.3091 0 20 0C20.6909 0 21.25 0.559063 21.25 1.25V5H26.25V1.25C26.25 0.559063 26.8091 0 27.5 0C28.1909 0 28.75 0.559063 28.75 1.25V5H30C32.7617 5 35 7.23828 35 10V11.25H38.75C39.4409 11.25 40 11.8091 40 12.5C40 13.1909 39.4409 13.75 38.75 13.75H35V18.75H38.75ZM32.5 10C32.5 8.62188 31.3781 7.5 30 7.5H10C8.62187 7.5 7.5 8.62188 7.5 10V30C7.5 31.3781 8.62187 32.5 10 32.5H30C31.3781 32.5 32.5 31.3781 32.5 30V10Z\" />\n </g>\n </svg>\n </div>}\n </div>\n );\n }\n\n getSizeClass() {\n return `${this.size}` === \"s\"\n ? \"s\"\n : \"\";\n }\n\n getClassNames() {\n return classNames(\n 'spinner',\n this.size && `spinner ${this.getSizeClass()}`\n );\n }\n}\n","@use '~@infineon/design-system-tokens/dist/tokens';\n@use '../../global/font.scss';\n\n:host {\n display: flex;\n}\n\n.textInput__container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n padding: 0px;\n width: 100%;\n flex: none;\n order: 0;\n align-self: stretch;\n flex-grow: 0;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n & .delete-icon {\n position: absolute;\n right: tokens.$ifxSpace200;\n }\n\n &:not(.readonly, .disabled) .delete-icon {\n &:hover {\n cursor: pointer;\n }\n }\n\n &.disabled:not(.readonly) {\n\n & #text-field { \n color: tokens.$ifxColorBaseWhite;\n }\n\n & .delete-icon { \n color: tokens.$ifxColorBaseWhite;\n }\n \n & .textInput__top-wrapper {\n & label {\n color: tokens.$ifxColorEngineering300;\n }\n\n & .required {\n color: tokens.$ifxColorEngineering300;\n }\n }\n\n & .textInput__bottom-wrapper {\n input {\n border: 1px solid tokens.$ifxColorEngineering300;\n background-color: tokens.$ifxColorEngineering300;\n\n &::placeholder {\n font-size: tokens.$ifxFontSizeM;\n color: tokens.$ifxColorBaseWhite;\n }\n }\n }\n }\n\n & .textInput__top-wrapper {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n padding: 0px;\n gap: tokens.$ifxSpace50;\n flex: none;\n order: 0;\n align-self: stretch;\n flex-grow: 0;\n\n & label {\n font-style: normal;\n font-weight: tokens.$ifxFontWeightRegular;\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n display: flex;\n align-items: center;\n color: tokens.$ifxColorBaseBlack;\n flex: none;\n order: 0;\n flex-grow: 0;\n\n & .optional-required {\n margin-left: tokens.$ifxSpace50;\n }\n\n & .optional {\n margin-left: tokens.$ifxSpace50;\n }\n\n & .required {\n color: tokens.$ifxColorEngineering500;\n margin-left: tokens.$ifxSpace50;\n\n &.error {\n color: tokens.$ifxColorRed500;\n }\n }\n }\n }\n\n .input-container {\n position: relative;\n display: flex;\n align-items: center;\n width: 100%;\n }\n\n & .textInput__bottom-wrapper {\n flex-grow: 1;\n position: relative;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n padding: 0px;\n gap: tokens.$ifxSpace50;\n flex: none;\n order: 1;\n align-self: stretch;\n flex-grow: 0;\n\n & input {\n width: 100%;\n box-sizing: border-box;\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: tokens.$ifxSpace100 tokens.$ifxSpace200;\n gap: tokens.$ifxSpace100;\n height: tokens.$ifxSize500;\n background-color: tokens.$ifxColorBaseWhite;\n color: tokens.$ifxColorBaseBlack;\n font-family: var(--ifx-font-family); // tokens.$ifxFontFamilyBody;\n\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightM;\n border: 1px solid tokens.$ifxColorEngineering400;\n border-radius: tokens.$ifxBorderRadius12;\n flex: none;\n order: 0;\n align-self: stretch;\n flex-grow: 0;\n text-overflow: ellipsis;\n\n &.input-s {\n height: tokens.$ifxSize450;\n font-size: tokens.$ifxFontSizeS;\n line-height: tokens.$ifxLineHeightS;\n\n &::placeholder {\n font-size: tokens.$ifxFontSizeM;\n line-height: tokens.$ifxLineHeightS;\n }\n }\n\n &.icon {\n padding-left: tokens.$ifxSpace500;\n }\n\n &.error {\n border: 1px solid tokens.$ifxColorRed500;\n\n &:focus {\n outline: none;\n }\n }\n\n &.readonly {\n border: none;\n border-radius: var(--borderRadius-12, 1px);\n border-bottom: 1px solid var(--color-engineering-300, #bfbbbb);\n background: var(--color-base-white, #fff);\n padding-left: 0;\n\n &::placeholder {\n color: tokens.$ifxColorBaseBlack;\n }\n }\n\n &.success {\n border: 1px solid tokens.$ifxColorGreen500;\n\n &:focus {\n outline: none;\n }\n }\n\n &:focus:not(.error, .success):not(.readonly) {\n outline: none;\n border: 1px solid tokens.$ifxColorOcean500;\n }\n\n &.readonly:focus,\n &[readonly]:focus {\n outline: none;\n box-shadow: none;\n border: none;\n border-bottom: 1px solid var(--color-engineering-300, #bfbbbb);\n }\n\n &:hover:not(:disabled, :focus, .error, .success):not(.readonly) {\n border: 1px solid tokens.$ifxColorEngineering500;\n }\n }\n\n & .input-icon {\n // Position the icon within the icon container\n // Adjust the positioning as needed\n position: absolute;\n top: 50%;\n transform: translateY(-50%);\n left: tokens.$ifxSpace200;\n /* Adjust this value to control the icon's left offset */\n transition: 0.3s;\n color: tokens.$ifxColorEngineering400;\n }\n\n & .textInput__bottom-wrapper-caption {\n font-style: normal;\n font-weight: tokens.$ifxFontWeightRegular;\n font-size: tokens.$ifxFontSizeXs;\n line-height: tokens.$ifxLineHeightXs;\n color: tokens.$ifxColorBaseBlack;\n flex: none;\n order: 1;\n align-self: stretch;\n flex-grow: 0;\n\n &.error {\n color: tokens.$ifxColorRed500;\n }\n\n &.disabled {\n color: tokens.$ifxColorEngineering300;\n }\n }\n }\n}","import { Component, h, Event, Element, Prop, EventEmitter, Watch, Method, AttachInternals, State } 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-text-field',\n styleUrl: 'text-field.scss',\n shadow: true,\n // formAssociated: true\n})\nexport class TextField {\n private inputElement: HTMLInputElement;\n @Element() el;\n @Prop() placeholder: string = 'Placeholder';\n @Prop({ mutable: true }) value: string = '';\n @Prop() error: boolean = false;\n @Prop() label: string = '';\n @Prop() icon: string = '';\n @Prop() caption: string = '';\n @Prop() size: string = 'm';\n @Prop() required: boolean = false;\n @Prop() success: boolean = false;\n @Prop() disabled: boolean = false;\n @Prop() readOnly: boolean = false;\n @Prop() maxlength?: number;\n @Prop() showDeleteIcon: boolean = false;\n @Prop() autocomplete: string = 'on';\n @Prop() type: 'text' | 'password' = 'text';\n @Prop() internalId: string = 'text-field';\n @State() internalType: string;\n @Event() ifxInput: EventEmitter<String>;\n // @Prop({ reflect: true })\n // resetOnSubmit: boolean = false;\n\n @AttachInternals() internals: ElementInternals;\n\n @Watch('value')\n valueWatcher(newValue: string) {\n if (newValue !== this.inputElement.value) {\n this.inputElement.value = newValue;\n }\n }\n\n @Method()\n async reset() {\n this.value = '';\n this.inputElement.value = '';\n }\n\n handleDeleteContent() {\n if (!this.disabled && !this.readOnly) {\n this.reset();\n this.ifxInput.emit(this.value);\n }\n }\n\n handleInput() {\n const query = this.inputElement.value;\n this.value = query;\n //this.internals.setFormValue(query) // update form value\n this.ifxInput.emit(this.value);\n }\n\n handleTypeProp() {\n this.internalType = this.type === 'text' || this.type === 'password' ? this.type : 'text';\n }\n\n // formResetCallback() {\n // this.internals.setValidity({});\n // this.internals.setFormValue(\"\");\n // }\n\n componentWillLoad() {\n this.handleTypeProp();\n }\n\n async componentDidLoad() {\n if (!isNestedInIfxComponent(this.el)) {\n const framework = detectFramework();\n trackComponent('ifx-text-field', await framework);\n }\n }\n\n render() {\n return (\n <div\n aria-label=\"a text field for user input\"\n aria-value={this.value}\n aria-disabled={this.disabled}\n class={`textInput__container ${this.readOnly ? 'readonly' : ''} ${this.disabled && !this.error ? 'disabled' : ''}`}\n >\n <div class=\"textInput__top-wrapper\">\n {this.label && (\n <label htmlFor={this.internalId}>\n <span>{this.label}</span>\n {this.required && <span class={`required ${this.error && !this.readOnly ? 'error' : ''}`}>*</span>}\n </label>\n )}\n </div>\n\n <div class=\"textInput__bottom-wrapper\">\n <div class=\"input-container\">\n {this.icon && <ifx-icon class=\"input-icon\" icon={this.icon} />}\n <input\n ref={el => (this.inputElement = el)}\n disabled={this.disabled && !this.error}\n autocomplete={this.autocomplete}\n type={this.internalType}\n id={this.internalId}\n value={this.value}\n onInput={() => this.handleInput()}\n placeholder={this.placeholder}\n readonly={this.readOnly}\n maxlength={this.maxlength}\n class={`${this.icon ? 'icon' : ''}\n ${this.error ? 'error' : ''} \n ${this.readOnly ? 'readonly' : ''} \n ${this.size === 's' ? 'input-s' : ''}\n ${this.success ? 'success' : ''}`}\n />\n\n {this.showDeleteIcon && this.value && <ifx-icon class=\"delete-icon\" icon=\"cRemove16\" onClick={() => this.handleDeleteContent()}></ifx-icon>}\n </div>\n {this.caption && (\n <div class={`textInput__bottom-wrapper-caption ${this.error && !this.readOnly ? 'error' : ''} ${this.disabled && !this.readOnly && !this.error ? 'disabled' : ''}`}>\n {this.caption}\n </div>\n )}\n </div>\n </div>\n );\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as e,h as i,a as t}from"./p-PqnYwNKt.js";import{i as a}from"./p-CmdmgBUp.js";const n='.container{display:flex;flex-direction:column;gap:10px}.alert__wrapper{margin-bottom:40px}.snippet__wrapper{display:flex;flex-direction:column;gap:5px;position:sticky;top:0;left:0;z-index:99;background-color:white}.html-wrapper{background:rgb(38, 38, 38);padding:20px;color:white;font-family:monospace}.html-wrapper button{position:absolute;right:0px;bottom:0px;background:rgba(0, 0, 0, 0.85);color:#C9CDCF;border:0 none;padding:4px 10px;font-size:0.75rem;font-family:"Nunito Sans";font-weight:700;border-top:1px solid rgba(255, 255, 255, 0.1);border-left:1px solid rgba(255, 255, 255, 0.1);margin-left:-1px;border-radius:4px 0 0 0;cursor:pointer}.html-wrapper .component-name{color:#A8FF60}.html-wrapper .attribute-name{color:rgb(150, 203, 254)}.html-wrapper .attribute-value{color:rgb(180, 116, 221)}.preview__container{box-sizing:border-box;display:flex;align-items:center;padding:2px;flex-wrap:wrap;gap:4px}.preview__container .no-results{width:100%;text-align:center}.preview__container .preview__container-item{display:flex;justify-content:center;align-items:center;border:1px solid #f1f1f1;padding:2px;width:50px;height:50px;position:relative}.preview__container .preview__container-item:active{border-color:#378375}.preview__container .preview__container-item:hover{cursor:pointer}.preview__container .preview__container-item.copied::after{z-index:50;content:"copied!";position:absolute;top:0;left:50px;background-color:#000;color:white;padding:3px;border-radius:4px}';const c=class{constructor(i){e(this,i);this.iconsArray=[];this.isCopied=false;this.copiedIcon=null;this.htmlTag='<ifx-icon icon="calendar-16"></ifx-icon>';this.iconName=`""`;this.searchTerm=""}handleCopiedText(){this.isCopied=true;setTimeout((()=>{this.isCopied=false}),2e3)}copyIconText(e){this.htmlTag=`<ifx-icon icon="${e}"></ifx-icon>`;this.iconName=`"${e}"`;this.copiedIcon=e}copyHtmlString(){const e=`<ifx-icon icon=${this.iconName}></ifx-icon>`;navigator.clipboard.writeText(e);this.handleCopiedText()}get filteredIcons(){const e=this.searchTerm.toLowerCase().trim();if(!e)return this.iconsArray;return this.iconsArray.filter((i=>i.toLowerCase().includes(e)))}getIconIndex(e){return this.iconsArray.indexOf(e)}handleIconFilter(){const e=this.el.shadowRoot.querySelector("#search__field");e.addEventListener("ifxInput",(e=>{this.searchTerm=e.detail}))}componentWillLoad(){this.iconsArray=Object.keys(a)}componentDidLoad(){this.handleIconFilter()}render(){return i("div",{key:"cad3f5516e9ff71983c1ab79b423db3d8ff4c046",class:"container"},i("div",{key:"bcaecb8c43b7415c7422293cd71db36dabe03fc7",class:"alert__wrapper"},i("ifx-notification",{key:"28fe835bd823d3b7ca753303b2ab7231f5aa0c47",icon:"c-check-16",variant:"neutral","link-text":"Figma icon library","link-href":"https://www.figma.com/design/yWwaLoqsWLWygDxXfvdym9/Infineon-DDS-%7C-UI-icon-library?node-id=13284-1289&p=f&t=SD6EdmXaSufsjPCv-0","link-target":"_blank"},"You can also find the UI icons in Figma for use in mockups.")),i("div",{key:"29db796fdc26758434eea3cb0662381e83931c81",class:"snippet__wrapper"},i("div",{key:"cae0df2cebf1499ad0febbe84c5734f7a1150c40",class:"search__wrapper"},i("ifx-search-field",{key:"5624bffdabb2ef12904145ed485d96a95f72e079",id:"search__field",size:"m","show-delete-icon":"true",value:"",autocomplete:"on",placeholder:"Search icon"})),i("div",{key:"f4ff80bdc97d3bf96dc4fbdbb85195ea2b0f1b7d",class:"html-wrapper"},i("span",{key:"11ce503b64564201aa64b37df12f2d7b44c495ff",class:"html-tag"},"<"),i("span",{key:"ff5dca010ee326d8558592300a7152596ff29065",class:"component-name"},"ifx-icon"),i("span",{key:"bee19150f951c80c6bdb2ceb81edb7af7c50c4f7",class:"attribute-name"}," icon"),"=",i("span",{key:"9451bd94d2b6e8122d7e60dcb2fcfd350a10a0eb",class:"attribute-value"},this.iconName),i("span",{key:"c074ba23a0ac267ada8c3b4ea701fd788e0ef047",class:"html-tag"},">"),i("span",{key:"df301dced95dc4003dad62d42fbc7a991e07aa7b",class:"html-tag"},"</"),i("span",{key:"e50e42d063fd5370594fb3a9ad264dcfa30272fc",class:"component-name"},"ifx-icon"),i("span",{key:"72e1e2869c4dd6a373c27949678012a4d17a5750",class:"html-tag"},">"),i("button",{key:"e065221a5f5e4fcd545287050effd8f301960b5e",onClick:()=>this.copyHtmlString()},this.isCopied?"Copied":"Copy"))),i("div",{key:"f5f0b51524f2f850a2151db2b0188dff1e4c3131",class:"preview__container"},this.filteredIcons.map((e=>i("div",{key:e,class:`preview__container-item ${this.isCopied&&this.copiedIcon===e?"copied":""}`,onClick:()=>this.copyIconText(e)},i("ifx-icon",{icon:e})))),this.filteredIcons.length===0&&i("div",{key:"bcc64909d726c6fe43fac93ba623cd643110e67c",class:"no-results"},'No icons found matching "',this.searchTerm,'"')))}get el(){return t(this)}};c.style=n;export{c as ifx_icons_preview};
2
+ //# sourceMappingURL=p-6eb6af05.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["iconsPreviewCss","IconsPreview","constructor","hostRef","this","iconsArray","isCopied","copiedIcon","htmlTag","iconName","searchTerm","handleCopiedText","setTimeout","copyIconText","icon","copyHtmlString","copiedTag","navigator","clipboard","writeText","filteredIcons","term","toLowerCase","trim","filter","includes","getIconIndex","indexOf","handleIconFilter","searchField","el","shadowRoot","querySelector","addEventListener","e","detail","componentWillLoad","Object","keys","icons","componentDidLoad","render","h","key","class","variant","id","size","value","autocomplete","placeholder","onClick","map","length"],"sources":["src/components/icons-preview/icons-preview.scss?tag=ifx-icons-preview&encapsulation=shadow","src/components/icons-preview/icons-preview.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n.container {\n display: flex;\n flex-direction: column;\n gap: 10px;\n}\n\n.alert__wrapper { \n margin-bottom: 40px;\n}\n\n.snippet__wrapper { \n display: flex;\n flex-direction: column;\n gap: 5px;\n position: sticky;\n top: 0;\n left: 0;\n z-index: 99;\n background-color: white;\n}\n\n.html-wrapper {\n background: rgb(38, 38, 38);\n padding: 20px;\n color: white;\n font-family: monospace;\n\n & button {\n position: absolute;\n right: 0px;\n bottom: 0px;\n background: rgba(0, 0, 0, 0.85);\n color: #C9CDCF;\n border: 0 none;\n padding: 4px 10px;\n font-size: tokens.$ifxFontSizeXs;\n font-family: \"Nunito Sans\";\n font-weight: 700;\n border-top: 1px solid rgba(255, 255, 255, .1);\n border-left: 1px solid rgba(255, 255, 255, .1);\n margin-left: -1px;\n border-radius: 4px 0 0 0;\n cursor: pointer;\n }\n\n & .component-name {\n color: #A8FF60;\n }\n\n & .attribute-name {\n color: rgb(150, 203, 254);\n }\n\n & .attribute-value {\n color: rgb(180, 116, 221);\n }\n\n\n}\n\n.preview__container {\n box-sizing: border-box;\n display: flex;\n align-items: center;\n padding: 2px;\n flex-wrap: wrap;\n gap: 4px;\n\n & .no-results { \n width: 100%;\n text-align: center;\n }\n\n & .preview__container-item {\n display: flex;\n justify-content: center;\n align-items: center;\n border: 1px solid #f1f1f1;\n padding: 2px;\n width: 50px;\n height: 50px;\n position: relative;\n\n &:active {\n border-color: #378375;\n }\n\n &:hover {\n cursor: pointer;\n }\n\n &.copied {\n &::after {\n z-index: 50;\n content: 'copied!';\n position: absolute;\n top: 0;\n left: 50px;\n background-color: #000;\n color: white;\n padding: 3px;\n border-radius: 4px;\n }\n }\n }\n}","import { Component, h, Element, State } from \"@stencil/core\";\nimport { icons } from '@infineon/infineon-icons';\n\n@Component({\n tag: 'ifx-icons-preview',\n styleUrl: './icons-preview.scss',\n shadow: true\n})\n\nexport class IconsPreview {\n @State() iconsArray: string[] = [];\n @State() isCopied: boolean = false;\n @State() copiedIndex: number;\n @State() copiedIcon: string | null = null;\n @State() htmlTag: string = '<ifx-icon icon=\"calendar-16\"></ifx-icon>';\n @State() iconName: string = `\"\"`;\n @State() searchTerm: string = '';\n @Element() el;\n\n handleCopiedText() { \n this.isCopied = true;\n setTimeout(() => {\n this.isCopied = false\n }, 2000);\n }\n\n copyIconText(icon: string) { \n this.htmlTag = `<ifx-icon icon=\"${icon}\"></ifx-icon>`;\n this.iconName = `\"${icon}\"`;\n this.copiedIcon = icon;\n }\n\n copyHtmlString() { \n const copiedTag = `<ifx-icon icon=${this.iconName}></ifx-icon>`;\n navigator.clipboard.writeText(copiedTag);\n this.handleCopiedText()\n }\n\n get filteredIcons() {\n const term = this.searchTerm.toLowerCase().trim();\n if (!term) return this.iconsArray;\n \n return this.iconsArray.filter(icon => \n icon.toLowerCase().includes(term)\n );\n }\n\n getIconIndex(icon: string): number {\n return this.iconsArray.indexOf(icon);\n }\n\n handleIconFilter() { \n const searchField = this.el.shadowRoot.querySelector('#search__field');\n searchField.addEventListener('ifxInput', (e) => { \n this.searchTerm = e.detail;\n })\n }\n\n componentWillLoad() { \n this.iconsArray = Object.keys(icons);\n }\n\n componentDidLoad() { \n this.handleIconFilter()\n }\n\n render() {\n return (\n <div class='container'>\n <div class=\"alert__wrapper\">\n <ifx-notification \n icon=\"c-check-16\" \n variant=\"neutral\" \n link-text=\"Figma icon library\" \n link-href=\"https://www.figma.com/design/yWwaLoqsWLWygDxXfvdym9/Infineon-DDS-%7C-UI-icon-library?node-id=13284-1289&p=f&t=SD6EdmXaSufsjPCv-0\"\n link-target=\"_blank\">\n You can also find the UI icons in Figma for use in mockups.\n </ifx-notification>\n </div>\n <div class=\"snippet__wrapper\">\n <div class=\"search__wrapper\">\n <ifx-search-field id=\"search__field\" size=\"m\" show-delete-icon=\"true\" value=\"\" autocomplete=\"on\" placeholder=\"Search icon\"></ifx-search-field>\n </div>\n <div class='html-wrapper'>\n <span class=\"html-tag\">&lt;</span>\n <span class=\"component-name\">ifx-icon</span>\n <span class=\"attribute-name\"> icon</span>=<span class=\"attribute-value\">{this.iconName}</span>\n <span class=\"html-tag\">&gt;</span>\n <span class=\"html-tag\">&lt;/</span>\n <span class=\"component-name\">ifx-icon</span>\n <span class=\"html-tag\">&gt;</span>\n <button onClick={() => this.copyHtmlString()}>{this.isCopied ? 'Copied' : 'Copy'}</button>\n </div>\n </div>\n <div class=\"preview__container\">\n {this.filteredIcons.map((icon) => (\n <div \n key={icon}\n class={`preview__container-item ${\n this.isCopied && this.copiedIcon === icon ? 'copied' : \"\"\n }`} \n onClick={() => this.copyIconText(icon)}\n >\n <ifx-icon icon={icon}></ifx-icon>\n </div>\n ))}\n {this.filteredIcons.length === 0 && (\n <div class=\"no-results\">No icons found matching \"{this.searchTerm}\"</div>\n )}\n </div>\n </div>\n )\n }\n}"],"mappings":"sFAAA,MAAMA,EAAkB,s8C,MCSXC,EAAY,MANzB,WAAAC,CAAAC,G,UAOWC,KAAUC,WAAa,GACvBD,KAAQE,SAAY,MAEpBF,KAAUG,WAAkB,KAC5BH,KAAOI,QAAW,2CAClBJ,KAAQK,SAAW,KACnBL,KAAUM,WAAW,EAiG/B,CA9FC,gBAAAC,GACEP,KAAKE,SAAW,KAChBM,YAAW,KACTR,KAAKE,SAAW,KAAK,GACpB,I,CAGJ,YAAAO,CAAaC,GACZV,KAAKI,QAAU,mBAAmBM,iBAClCV,KAAKK,SAAW,IAAIK,KACpBV,KAAKG,WAAaO,C,CAGpB,cAAAC,GACE,MAAMC,EAAY,kBAAkBZ,KAAKK,uBACzCQ,UAAUC,UAAUC,UAAUH,GAC9BZ,KAAKO,kB,CAGL,iBAAIS,GACJ,MAAMC,EAAOjB,KAAKM,WAAWY,cAAcC,OAC3C,IAAKF,EAAM,OAAOjB,KAAKC,WAEvB,OAAOD,KAAKC,WAAWmB,QAAOV,GAC5BA,EAAKQ,cAAcG,SAASJ,I,CAIhC,YAAAK,CAAaZ,GACX,OAAOV,KAAKC,WAAWsB,QAAQb,E,CAGjC,gBAAAc,GACE,MAAMC,EAAczB,KAAK0B,GAAGC,WAAWC,cAAc,kBACrDH,EAAYI,iBAAiB,YAAaC,IACxC9B,KAAKM,WAAawB,EAAEC,MAAM,G,CAI9B,iBAAAC,GACEhC,KAAKC,WAAagC,OAAOC,KAAKC,E,CAGhC,gBAAAC,GACEpC,KAAKwB,kB,CAGP,MAAAa,GACE,OACEC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,aACTF,EAAK,OAAAC,IAAA,2CAAAC,MAAM,kBACPF,EAAA,oBAAAC,IAAA,2CACE7B,KAAK,aACL+B,QAAQ,UACE,iCACA,+IACE,wBAAQ,gEAI1BH,EAAK,OAAAC,IAAA,2CAAAC,MAAM,oBACTF,EAAK,OAAAC,IAAA,2CAAAC,MAAM,mBACTF,EAAkB,oBAAAC,IAAA,2CAAAG,GAAG,gBAAgBC,KAAK,IAAqB,0BAAOC,MAAM,GAAGC,aAAa,KAAKC,YAAY,iBAE/GR,EAAK,OAAAC,IAAA,2CAAAC,MAAM,gBACTF,EAAM,QAAAC,IAAA,2CAAAC,MAAM,YAAsB,KAClCF,EAAM,QAAAC,IAAA,2CAAAC,MAAM,kBAAgC,YAC5CF,EAAM,QAAAC,IAAA,2CAAAC,MAAM,kBAA6B,aAACF,EAAA,QAAAC,IAAA,2CAAMC,MAAM,mBAAmBxC,KAAKK,UAC9EiC,EAAM,QAAAC,IAAA,2CAAAC,MAAM,YAAsB,KAClCF,EAAM,QAAAC,IAAA,2CAAAC,MAAM,YAAuB,MACnCF,EAAM,QAAAC,IAAA,2CAAAC,MAAM,kBAAgC,YAC5CF,EAAM,QAAAC,IAAA,2CAAAC,MAAM,YAAsB,KAClCF,EAAQ,UAAAC,IAAA,2CAAAQ,QAAS,IAAM/C,KAAKW,kBAAmBX,KAAKE,SAAW,SAAW,UAG9EoC,EAAK,OAAAC,IAAA,2CAAAC,MAAM,sBACXxC,KAAKgB,cAAcgC,KAAKtC,GACpB4B,EAAA,OACEC,IAAK7B,EACL8B,MAAO,2BACLxC,KAAKE,UAAYF,KAAKG,aAAeO,EAAO,SAAW,KAEzDqC,QAAS,IAAM/C,KAAKS,aAAaC,IAEjC4B,EAAA,YAAU5B,KAAMA,OAGnBV,KAAKgB,cAAciC,SAAW,GAC/BX,EAAA,OAAAC,IAAA,2CAAKC,MAAM,cAAY,4BAA2BxC,KAAKM,WAAU,M","ignoreList":[]}
@@ -1,2 +1,2 @@
1
- import{r as e,h as o}from"./p-PqnYwNKt.js";const n=".container{padding-top:10px}";const t=class{constructor(o){e(this,o)}render(){return o("div",{key:"750ba5457073ee26c2a0ec5e0ffea950569bd5ef",class:"container"},o("ifx-accordion",{key:"f02cfd45ebad962c7f852395c777d67fd9378d46"},o("ifx-accordion-item",{key:"296d3f7bd6bbc528a0b1a7a7f23ae0556ab2dd8f",caption:"What is the Infineon DDS?"},"The Infineon Digital Design System consists of code components, design principles, tools and guidelines as well as a dedicated interdisciplinary team. Its purpose is to support internal and external colleagues create digital user interfaces with a high level of usability as well as a consistent expression of the Infineon brand. The DDS does not focus on the content of a web application but it describes how the design of the application’s structure should be."),o("ifx-accordion-item",{key:"a1418c2859c7a0406beea37f280e6805c44edcc7",caption:"How do I get access to the DDS?"},"You can use the provided Figma file as a foundation for mockups and prototypes, use Storybook to view what UI components and variants are available and use code components provided via Storybook or Github."),o("ifx-accordion-item",{key:"d0387e97694ea01953d8411882d44a64ca01bfbc",caption:"Can I integrate the Infineon DDS into my project?"},"Yes, you can. We are happy to discuss with you which point in time and which scope of integration is bestsuited for updating your interface to the Infineon DDS. (To avoid that users get confused by a mixture of UI components, we recommend choosing larger updates or technology changes as opportunity to integrate the Infineon DDS.)"),o("ifx-accordion-item",{key:"09516365adaa86dcf74018f6eee9e71481da5822",caption:"Are Infineon DDS components accessable?"},"We have taken WCAG 2.0 Level AA as baseline level for all design decisions inside the Infineon Digital Design System. To make an online experience truly accessible you have to implement the specific code, content, and visual design according to the accessibility standard. Find an introduction to this topic here."),o("ifx-accordion-item",{key:"4da90ebc551c090670bf0bac1a89fb0ef8c584db",caption:"How to request a new component?"},"Please contact us like described in the contribution section! We are planning to expand the number of components continually. If your component is also usable for multiple other projects, there is a good chance we might work together with you.")))}};t.style=n;export{t as ifx_faq};
2
- //# sourceMappingURL=p-ee8900a5.entry.js.map
1
+ import{r as e,h as o}from"./p-PqnYwNKt.js";const n=".container{padding-top:10px}";const t=class{constructor(o){e(this,o)}render(){return o("div",{key:"adeafa17925f9102d39715eab6909d46770960d4",class:"container"},o("ifx-accordion",{key:"84efcea4b3a9b58049fe21d325306cba1f433396"},o("ifx-accordion-item",{key:"fd1d00d722e76a84a0d8175aea9135f1fda63bee",caption:"What is the Infineon DDS?"},"The Infineon Digital Design System consists of code components, design principles, tools and guidelines as well as a dedicated interdisciplinary team. Its purpose is to support internal and external colleagues create digital user interfaces with a high level of usability as well as a consistent expression of the Infineon brand. The DDS does not focus on the content of a web application but it describes how the design of the application’s structure should be."),o("ifx-accordion-item",{key:"274463b3f960e8e0e588fd312f6295461ed0a3a3",caption:"How do I get access to the DDS?"},"You can use the provided Figma file as a foundation for mockups and prototypes, use Storybook to view what UI components and variants are available and use code components provided via Storybook or Github."),o("ifx-accordion-item",{key:"d3baafb7c0dd648fdb03f53f8a962122c373cc13",caption:"Can I integrate the Infineon DDS into my project?"},"Yes, you can. We are happy to discuss with you which point in time and which scope of integration is bestsuited for updating your interface to the Infineon DDS. (To avoid that users get confused by a mixture of UI components, we recommend choosing larger updates or technology changes as opportunity to integrate the Infineon DDS.)"),o("ifx-accordion-item",{key:"989bd8527ebe9935475c0bdda083869a1853e1bc",caption:"Are Infineon DDS components accessable?"},"We have taken WCAG 2.0 Level AA as baseline level for all design decisions inside the Infineon Digital Design System. To make an online experience truly accessible you have to implement the specific code, content, and visual design according to the accessibility standard. Find an introduction to this topic here."),o("ifx-accordion-item",{key:"bcc207308c52cdbbc3f36c5024834276de5207fd",caption:"How to request a new component?"},"Please contact us like described in the contribution section! We are planning to expand the number of components continually. If your component is also usable for multiple other projects, there is a good chance we might work together with you.")))}};t.style=n;export{t as ifx_faq};
2
+ //# sourceMappingURL=p-744c1c8e.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["faqCss","Faq","render","h","key","class","caption"],"sources":["src/stories/setup-and-installation/faq/faq.scss?tag=ifx-faq&encapsulation=shadow","src/stories/setup-and-installation/faq/faq.tsx"],"sourcesContent":[".container { \n padding-top: 10px;\n}","import { Component, h } from '@stencil/core';\n\n@Component({\n tag: 'ifx-faq',\n styleUrl: './faq.scss',\n shadow: true,\n})\nexport class Faq {\n\n render() {\n return (\n <div class='container'>\n <ifx-accordion>\n <ifx-accordion-item caption=\"What is the Infineon DDS?\">\n The Infineon Digital Design System consists of code components, design principles, tools and guidelines as well as a dedicated interdisciplinary team. Its purpose is to support internal and external colleagues create digital user interfaces with a high level of usability as well as a consistent expression of the Infineon brand. The DDS does not focus on the content of a web application but it describes how the design of the application’s structure should be.\n </ifx-accordion-item>\n <ifx-accordion-item caption=\"How do I get access to the DDS?\">\n You can use the provided Figma file as a foundation for mockups and prototypes, use Storybook to view what UI components and variants are available and use code components provided via Storybook or Github.\n </ifx-accordion-item>\n <ifx-accordion-item caption=\"Can I integrate the Infineon DDS into my project?\">\n Yes, you can. We are happy to discuss with you which point in time and which scope of integration is bestsuited for updating your interface to the Infineon DDS. (To avoid that users get confused by a mixture of UI components, we recommend choosing larger updates or technology changes as opportunity to integrate the Infineon DDS.)\n </ifx-accordion-item>\n <ifx-accordion-item caption=\"Are Infineon DDS components accessable?\">\n We have taken WCAG 2.0 Level AA as baseline level for all design decisions inside the Infineon Digital Design System. To make an online experience truly accessible you have to implement the specific code, content, and visual design according to the accessibility standard. Find an introduction to this topic here.\n </ifx-accordion-item>\n <ifx-accordion-item caption=\"How to request a new component?\">\n Please contact us like described in the contribution section! We are planning to expand the number of components continually. If your component is also usable for multiple other projects, there is a good chance we might work together with you.\n </ifx-accordion-item>\n </ifx-accordion>\n </div>\n );\n }\n}\n"],"mappings":"2CAAA,MAAMA,EAAS,+B,MCOFC,EAAG,M,yBAEd,MAAAC,GACE,OACEC,EAAA,OAAAC,IAAA,2CAAKC,MAAM,aACXF,EAAA,iBAAAC,IAAA,4CACED,EAAoB,sBAAAC,IAAA,2CAAAE,QAAQ,6BAEP,kdACrBH,EAAoB,sBAAAC,IAAA,2CAAAE,QAAQ,mCAEP,iNACrBH,EAAoB,sBAAAC,IAAA,2CAAAE,QAAQ,qDAEP,+UACrBH,EAAoB,sBAAAC,IAAA,2CAAAE,QAAQ,2CAEP,6TACrBH,EAAA,sBAAAC,IAAA,2CAAoBE,QAAQ,mCAAiC,wP","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import{r as s,h as i,a}from"./p-PqnYwNKt.js";import{d as o,t}from"./p-DcmcuUOA.js";import{i as r}from"./p-Bw2fh5LT.js";const e=':root{--ifx-font-family:"Source Sans 3", "Arial, sans-serif"}.action-list{background:#FFFFFF;border-radius:0;border:1px solid #EEEDED;overflow:hidden;display:flex;flex-direction:column}';const n=class{constructor(i){s(this,i)}async componentDidLoad(){if(!r(this.el)){const s=o();t("ifx-action-list",await s)}}render(){return i("div",{key:"a9da34b5b948204642b94582781d1b74a86dc6f5",class:"action-list",role:"list","aria-label":this.listAriaLabel},i("slot",{key:"bf5dea0baf869e9e072ebe7bfd0ae2104ceb477b"}))}get el(){return a(this)}};n.style=e;export{n as ifx_action_list};
2
+ //# sourceMappingURL=p-760cfc7e.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["actionListCss","ActionList","componentDidLoad","isNestedInIfxComponent","this","el","framework","detectFramework","trackComponent","render","h","key","class","role","listAriaLabel"],"sources":["src/components/action-list/action-list.scss?tag=ifx-action-list&encapsulation=shadow","src/components/action-list/action-list.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n@use \"../../global/font.scss\";\n\n.action-list {\n background: tokens.$ifxColorBaseWhite;\n border-radius: tokens.$ifxBorderRadiusNone;\n border: tokens.$ifxBorderWidth12 solid tokens.$ifxColorEngineering200;\n overflow: hidden;\n display: flex;\n flex-direction: column;\n}","import { Component, h, Prop, 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-action-list',\n styleUrl: 'action-list.scss',\n shadow: true,\n})\nexport class ActionList {\n @Element() el: HTMLElement;\n\n /**\n * Aria label for accessibility support\n */\n @Prop() listAriaLabel?: string;\n\n async componentDidLoad() {\n if (!isNestedInIfxComponent(this.el)) {\n const framework = detectFramework();\n trackComponent('ifx-action-list', await framework);\n }\n }\n\n render() {\n return (\n <div\n class=\"action-list\"\n role=\"list\"\n aria-label={this.listAriaLabel}\n >\n <slot></slot>\n </div>\n );\n }\n}"],"mappings":"uHAAA,MAAMA,EAAgB,4L,MCUTC,EAAU,M,yBAQrB,sBAAMC,GACJ,IAAKC,EAAuBC,KAAKC,IAAK,CACpC,MAAMC,EAAYC,IAClBC,EAAe,wBAAyBF,E,EAI5C,MAAAG,GACE,OACEC,EAAA,OAAAC,IAAA,2CACEC,MAAM,cACNC,KAAK,OAAM,aACCT,KAAKU,eAEjBJ,EAAa,QAAAC,IAAA,6C","ignoreList":[]}
@@ -1,2 +1,2 @@
1
- import{r as t,c as s,h as i,d as e,a as n}from"./p-PqnYwNKt.js";import{g as o}from"./p-CmdmgBUp.js";import{d as r,t as c}from"./p-DcmcuUOA.js";import{i as h}from"./p-Bw2fh5LT.js";const a="ifx-icon{display:inline-flex;justify-content:center}ifx-icon:empty{display:none}";const l=class{constructor(i){t(this,i);this.consoleError=s(this,"consoleError",7);this.icon=""}updateIcon(t){this.internalIcon=t;this.setIcon()}convertStringToHtml(t){const s=document.createElement("div");s.innerHTML=t;return s.firstChild}convertHtmlToObject(t){let s=Array.from(t.attributes,(({name:t,value:s})=>({name:t,value:s}))).reduce(((t,s)=>{t[s.name]=s.value;return t}),{});return s}convertPathsToVnode(t){let s=[];const e=this.convertHtmlToObject(t);const n=i("path",e);s.push(n);if(t.firstChild){const e=t.querySelectorAll("path");const n=t.querySelectorAll("path").length;for(let t=0;t<n;t++){let n=this.convertHtmlToObject(e[t]);let o=i("path",n);s.push(o)}}return s}getSVG(t){const s=this.convertStringToHtml(this.ifxIcon);const e=s.getAttribute("width");const n=s.getAttribute("height");const o=s.getAttribute("fill");const r=s.getAttribute("viewBox");return i("svg",{class:"inline-svg",width:e,height:n,xmlns:"http://www.w3.org/2000/svg",fill:o,viewBox:r},...t)}constructIcon(){if(this.ifxIcon){const t=this.convertStringToHtml(this.ifxIcon);const s=this.convertPathsToVnode(t);const i=this.getSVG(s);return i}else if(this.icon!==""){this.consoleError.emit(true);return}else{return}}setIcon(){const t=t=>t.replace(/[-_]+(.)/g,((t,s)=>s.toUpperCase())).replace(/^(.)/,(t=>t.toLowerCase()));const s=t(this.internalIcon);this.ifxIcon=o(s)}isInsideAgGrid(t){var s;let i=t;while(i){if((s=i.className)===null||s===void 0?void 0:s.toLowerCase().startsWith("ag-")){return true}i=i.parentElement}return false}isInsideChoices(t){var s;let i=t;while(i){if((s=i.className)===null||s===void 0?void 0:s.toLowerCase().startsWith("choices__")){return true}i=i.parentElement}return false}componentWillLoad(){this.internalIcon=this.icon;this.setIcon()}async componentDidLoad(){if(!h(this.el)){if(!this.isInsideAgGrid(this.el)&&!this.isInsideChoices(this.el)){const t=r();c("ifx-icon",await t)}}}render(){return i(e,{key:"a1e7e069aeae0646c83f65b30aa43ba9454cec52"},this.constructIcon())}get el(){return n(this)}static get watchers(){return{icon:["updateIcon"]}}};l.style=a;export{l as ifx_icon};
2
- //# sourceMappingURL=p-228e8272.entry.js.map
1
+ import{r as t,c as s,h as i,d as e,a as n}from"./p-PqnYwNKt.js";import{g as o}from"./p-CmdmgBUp.js";import{d as r,t as c}from"./p-DcmcuUOA.js";import{i as h}from"./p-Bw2fh5LT.js";const a="ifx-icon{display:inline-flex;justify-content:center}ifx-icon:empty{display:none}";const l=class{constructor(i){t(this,i);this.consoleError=s(this,"consoleError",7);this.icon=""}updateIcon(t){this.internalIcon=t;this.setIcon()}convertStringToHtml(t){const s=document.createElement("div");s.innerHTML=t;return s.firstChild}convertHtmlToObject(t){let s=Array.from(t.attributes,(({name:t,value:s})=>({name:t,value:s}))).reduce(((t,s)=>{t[s.name]=s.value;return t}),{});return s}convertPathsToVnode(t){let s=[];const e=this.convertHtmlToObject(t);const n=i("path",e);s.push(n);if(t.firstChild){const e=t.querySelectorAll("path");const n=t.querySelectorAll("path").length;for(let t=0;t<n;t++){let n=this.convertHtmlToObject(e[t]);let o=i("path",n);s.push(o)}}return s}getSVG(t){const s=this.convertStringToHtml(this.ifxIcon);const e=s.getAttribute("width");const n=s.getAttribute("height");const o=s.getAttribute("fill");const r=s.getAttribute("viewBox");return i("svg",{class:"inline-svg",width:e,height:n,xmlns:"http://www.w3.org/2000/svg",fill:o,viewBox:r},...t)}constructIcon(){if(this.ifxIcon){const t=this.convertStringToHtml(this.ifxIcon);const s=this.convertPathsToVnode(t);const i=this.getSVG(s);return i}else if(this.icon!==""){this.consoleError.emit(true);return}else{return}}setIcon(){const t=t=>t.replace(/[-_]+(.)/g,((t,s)=>s.toUpperCase())).replace(/^(.)/,(t=>t.toLowerCase()));const s=t(this.internalIcon);this.ifxIcon=o(s)}isInsideAgGrid(t){var s;let i=t;while(i){if((s=i.className)===null||s===void 0?void 0:s.toLowerCase().startsWith("ag-")){return true}i=i.parentElement}return false}isInsideChoices(t){var s;let i=t;while(i){if((s=i.className)===null||s===void 0?void 0:s.toLowerCase().startsWith("choices__")){return true}i=i.parentElement}return false}componentWillLoad(){this.internalIcon=this.icon;this.setIcon()}async componentDidLoad(){if(!h(this.el)){if(!this.isInsideAgGrid(this.el)&&!this.isInsideChoices(this.el)){const t=r();c("ifx-icon",await t)}}}render(){return i(e,{key:"e5cab8793c55383813b83e97038545526070d0a7"},this.constructIcon())}get el(){return n(this)}static get watchers(){return{icon:["updateIcon"]}}};l.style=a;export{l as ifx_icon};
2
+ //# sourceMappingURL=p-8a58c2be.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["infineonIconStencilCss","InfineonIconStencil","constructor","hostRef","this","icon","updateIcon","newIcon","internalIcon","setIcon","convertStringToHtml","htmlString","div","document","createElement","innerHTML","firstChild","convertHtmlToObject","htmlElement","pathToObject","Array","from","attributes","name","value","reduce","acc","current","convertPathsToVnode","htmlPath","svgPaths","parentPath","parentPathToVnode","h","push","paths","querySelectorAll","pathLength","length","i","objToVnode","getSVG","svgPath","ifxIcon","width","getAttribute","height","fill","viewBox","class","xmlns","constructIcon","SVG","consoleError","emit","toCamelCase","str","replace","_","chr","toUpperCase","m","toLowerCase","iconName","getIcon","isInsideAgGrid","el","_a","className","startsWith","parentElement","isInsideChoices","componentWillLoad","componentDidLoad","isNestedInIfxComponent","framework","detectFramework","trackComponent","render","Host","key"],"sources":["src/components/icon/infineonIconStencil.scss?tag=ifx-icon","src/components/icon/infineonIconStencil.tsx"],"sourcesContent":["ifx-icon {\n display: inline-flex;\n justify-content: center;\n\n &:empty {\n display: none;\n }\n}","import { Component, Prop, h, Host, Event, EventEmitter, Watch, State, Element } from '@stencil/core';\nimport { getIcon } from '@infineon/infineon-icons'\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-icon',\n styleUrl: './infineonIconStencil.scss'\n})\n\nexport class InfineonIconStencil {\n @Element() el: HTMLElement;\n @Prop({ mutable: true }) icon: string = \"\"\n @Prop({ mutable: true }) ifxIcon: any;\n @State() internalIcon: string;\n @Event() consoleError: EventEmitter<boolean>;\n\n @Watch('icon')\n updateIcon(newIcon: string) { \n this.internalIcon = newIcon;\n this.setIcon()\n }\n\n convertStringToHtml(htmlString) { \n const div = document.createElement('div')\n div.innerHTML = htmlString\n return div.firstChild\n }\n\n convertHtmlToObject(htmlElement) { \n let pathToObject = Array\n .from(htmlElement.attributes, ({ name, value }) => ({ name, value }))\n .reduce((acc, current) => {\n acc[current.name] = current.value\n return acc\n }, {})\n\n return pathToObject\n }\n\n convertPathsToVnode(htmlPath) { \n let svgPaths = []\n const parentPath = this.convertHtmlToObject(htmlPath);\n const parentPathToVnode = h(\"path\", parentPath);\n svgPaths.push(parentPathToVnode)\n if(htmlPath.firstChild) { \n const paths = htmlPath.querySelectorAll('path');\n const pathLength = htmlPath.querySelectorAll('path').length;\n for(let i = 0; i < pathLength; i++) { \n let pathToObject = this.convertHtmlToObject(paths[i])\n let objToVnode = h(\"path\", pathToObject)\n svgPaths.push(objToVnode)\n } \n }\n return svgPaths\n }\n\n getSVG(svgPath) {\n const htmlPath = this.convertStringToHtml(this.ifxIcon) as SVGElement;\n const width = htmlPath.getAttribute('width');\n const height = htmlPath.getAttribute('height');\n const fill = htmlPath.getAttribute('fill');\n const viewBox = htmlPath.getAttribute('viewBox');\n \n return <svg class=\"inline-svg\" width={width} height={height} xmlns=\"http://www.w3.org/2000/svg\" fill={fill} viewBox={viewBox}>{...svgPath}</svg>\n }\n\n constructIcon() {\n if(this.ifxIcon) {\n const htmlPath = this.convertStringToHtml(this.ifxIcon)\n const svgPath = this.convertPathsToVnode(htmlPath)\n const SVG = this.getSVG(svgPath)\n return SVG;\n } else if(this.icon !== \"\") {\n this.consoleError.emit(true)\n return;\n } else { \n return;\n }\n }\n\nsetIcon() { \n const toCamelCase = str =>\n str\n .replace(/[-_]+(.)/g, (_, chr) => chr.toUpperCase()) // handle - and _ to uppercase\n .replace(/^(.)/, (m) => m.toLowerCase()); // ensure first letter is lowercase\n\n const iconName = toCamelCase(this.internalIcon);\n this.ifxIcon = getIcon(iconName);\n}\n\n isInsideAgGrid(el: HTMLElement): boolean {\n let current = el;\n while (current) {\n if (current.className?.toLowerCase().startsWith('ag-')) {\n return true;\n }\n current = current.parentElement;\n }\n return false;\n}\n\n isInsideChoices(el: HTMLElement): boolean {\n let current = el;\n while (current) {\n if (current.className?.toLowerCase().startsWith('choices__')) {\n return true;\n }\n current = current.parentElement;\n }\n return false;\n }\n\n componentWillLoad() {\n this.internalIcon = this.icon;\n this.setIcon()\n }\n\n async componentDidLoad() { \n if(!isNestedInIfxComponent(this.el)) { \n if(!this.isInsideAgGrid(this.el) && !this.isInsideChoices(this.el)) { \n const framework = detectFramework();\n trackComponent('ifx-icon', await framework)\n }\n }\n }\n\n render() {\n return (\n <Host>\n {this.constructIcon()}\n </Host>\n );\n }\n}"],"mappings":"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","ignoreList":[]}
@@ -1,2 +1,2 @@
1
- import{r as t,c as e,h as i,d as s,a as r}from"./p-PqnYwNKt.js";const a=":host{display:flex}.filter-type-group{width:260px;align-items:flex-start;gap:8px}.filter-type-group>::slotted(*){margin-bottom:8px}";const n=class{constructor(i){t(this,i);this.ifxSidebarFilterChange=e(this,"ifxSidebarFilterChange",7);this.selectedOptions=[];this.handleResetEvent=()=>{const t=this.el.shadowRoot.querySelector('slot[name="filter-accordion"]');const e=t.assignedElements({flatten:true});e.forEach((t=>{const e=t.querySelectorAll("ifx-list");e.forEach((t=>{t.resetTrigger=!t.resetTrigger}))}));const i=this.el.shadowRoot.querySelector('slot[name="filter-search"]');const s=i.assignedElements({flatten:true});s.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.ifxSidebarFilterChange.emit(this.selectedOptions)};this.handleUpdateSidebarFilter=t=>{const{filterName:e}=t.detail;const i=this.el.shadowRoot.querySelector('slot[name="filter-accordion"]');const s=i?i.assignedElements({flatten:true}):[];s.forEach((t=>{const i=t.querySelectorAll("ifx-list");i.forEach((t=>{if(t.getAttribute("name")===e){t.resetTrigger=!t.resetTrigger}}))}));const r=this.el.shadowRoot.querySelector('slot[name="filter-search"]');const a=r?r.assignedNodes({flatten:true}):[];a.forEach((t=>{if(t.nodeType===Node.ELEMENT_NODE){const e=t;const i=e.firstElementChild;if(i){i.setAttribute("value","");i.dispatchEvent(new CustomEvent("ifxInput",{bubbles:true,composed:true,detail:""}))}}}));const n=this.selectedOptions.map((t=>{if(t.filterGroupName===e){return Object.assign(Object.assign({},t),{selectedItems:[],value:""})}return t}));this.selectedOptions=n;this.ifxSidebarFilterChange.emit(this.selectedOptions)};this.handleAccordionChange=t=>{this.handleFilterChange(t)};this.handleSearchChange=t=>{this.handleFilterChange(t)};this.handleFilterChange=t=>{const e=[...this.selectedOptions];if(t.type==="ifxFilterSearchChange"){const{filterName:i,filterValue:s}=t.detail;const r=e.findIndex((t=>typeof t!=="string"&&t.filterGroupName===i));if(r!==-1){e[r].value=s}else{e.push({filterGroupName:i,value:s})}}else if(t.type==="ifxFilterAccordionChange"){const{filterGroupName:i,selectedItems:s}=t.detail;const r=e.findIndex((t=>t.filterGroupName===i));if(r!==-1){e[r]={filterGroupName:i,selectedItems:s}}else{e.push({filterGroupName:i,selectedItems:s})}}this.selectedOptions=e;this.ifxSidebarFilterChange.emit(this.selectedOptions)}}connectedCallback(){this.el.addEventListener("ifxFilterAccordionChange",this.handleAccordionChange);this.el.addEventListener("ifxFilterSearchChange",this.handleSearchChange);window.addEventListener("ifxResetFiltersEvent",this.handleResetEvent);window.addEventListener("ifxUpdateSidebarFilter",this.handleUpdateSidebarFilter)}componentWillUnload(){this.el.removeEventListener("ifxFilterAccordionChange",this.handleAccordionChange);this.el.removeEventListener("ifxFilterSearchChange",this.handleSearchChange);window.removeEventListener("ifxResetFiltersEvent",this.handleResetEvent)}render(){return i(s,{key:"9645afa69f474c30c1263325a5785888cb2556e4"},i("div",{key:"072f98a53ccef18f29a3d22d463e8a98a0e12eed",class:"filter-type-group"},i("slot",{key:"489eadbeb2e78546e6893b7131c81256df09b1a4",name:"filter-search"}),i("slot",{key:"dba54b3eea4d88441f1df263e159858e91e04ebc",name:"filter-accordion"})))}get el(){return r(this)}};n.style=a;export{n as ifx_filter_type_group};
2
- //# sourceMappingURL=p-e8a60f3b.entry.js.map
1
+ import{r as t,c as e,h as i,d as s,a as r}from"./p-PqnYwNKt.js";const a=":host{display:flex}.filter-type-group{width:260px;align-items:flex-start;gap:8px}.filter-type-group>::slotted(*){margin-bottom:8px}";const c=class{constructor(i){t(this,i);this.ifxSidebarFilterChange=e(this,"ifxSidebarFilterChange",7);this.selectedOptions=[];this.handleResetEvent=()=>{const t=this.el.shadowRoot.querySelector('slot[name="filter-accordion"]');const e=t.assignedElements({flatten:true});e.forEach((t=>{const e=t.querySelectorAll("ifx-list");e.forEach((t=>{t.resetTrigger=!t.resetTrigger}))}));const i=this.el.shadowRoot.querySelector('slot[name="filter-search"]');const s=i.assignedElements({flatten:true});s.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.ifxSidebarFilterChange.emit(this.selectedOptions)};this.handleUpdateSidebarFilter=t=>{const{filterName:e}=t.detail;const i=this.el.shadowRoot.querySelector('slot[name="filter-accordion"]');const s=i?i.assignedElements({flatten:true}):[];s.forEach((t=>{const i=t.querySelectorAll("ifx-list");i.forEach((t=>{if(t.getAttribute("name")===e){t.resetTrigger=!t.resetTrigger}}))}));const r=this.el.shadowRoot.querySelector('slot[name="filter-search"]');const a=r?r.assignedNodes({flatten:true}):[];a.forEach((t=>{if(t.nodeType===Node.ELEMENT_NODE){const e=t;const i=e.firstElementChild;if(i){i.setAttribute("value","");i.dispatchEvent(new CustomEvent("ifxInput",{bubbles:true,composed:true,detail:""}))}}}));const c=this.selectedOptions.map((t=>{if(t.filterGroupName===e){return Object.assign(Object.assign({},t),{selectedItems:[],value:""})}return t}));this.selectedOptions=c;this.ifxSidebarFilterChange.emit(this.selectedOptions)};this.handleAccordionChange=t=>{this.handleFilterChange(t)};this.handleSearchChange=t=>{this.handleFilterChange(t)};this.handleFilterChange=t=>{const e=[...this.selectedOptions];if(t.type==="ifxFilterSearchChange"){const{filterName:i,filterValue:s}=t.detail;const r=e.findIndex((t=>typeof t!=="string"&&t.filterGroupName===i));if(r!==-1){e[r].value=s}else{e.push({filterGroupName:i,value:s})}}else if(t.type==="ifxFilterAccordionChange"){const{filterGroupName:i,selectedItems:s}=t.detail;const r=e.findIndex((t=>t.filterGroupName===i));if(r!==-1){e[r]={filterGroupName:i,selectedItems:s}}else{e.push({filterGroupName:i,selectedItems:s})}}this.selectedOptions=e;this.ifxSidebarFilterChange.emit(this.selectedOptions)}}connectedCallback(){this.el.addEventListener("ifxFilterAccordionChange",this.handleAccordionChange);this.el.addEventListener("ifxFilterSearchChange",this.handleSearchChange);window.addEventListener("ifxResetFiltersEvent",this.handleResetEvent);window.addEventListener("ifxUpdateSidebarFilter",this.handleUpdateSidebarFilter)}componentWillUnload(){this.el.removeEventListener("ifxFilterAccordionChange",this.handleAccordionChange);this.el.removeEventListener("ifxFilterSearchChange",this.handleSearchChange);window.removeEventListener("ifxResetFiltersEvent",this.handleResetEvent)}render(){return i(s,{key:"94b9242c4dfad88c33d3cc60ce16f275c6599e19"},i("div",{key:"e2e65ea326edd9bb145f3f9dac2828195acd32b3",class:"filter-type-group"},i("slot",{key:"74ab49bf1a2d7e5ee43f7dfdda975a85791aab55",name:"filter-search"}),i("slot",{key:"b245f5b5ce1fa14e5c707512947069b9ddd28bc6",name:"filter-accordion"})))}get el(){return r(this)}};c.style=a;export{c as ifx_filter_type_group};
2
+ //# sourceMappingURL=p-8ceb2ccc.entry.js.map