@infineon/infineon-design-system-stencil 33.6.0--canary.1869.b1674220449fed92bf0dee5aead2bd511f2c78f1.0 → 33.6.0--canary.1871.2aa8cbc66d167a59effb50ad9e87274dd48eaa59.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.
- package/dist/cjs/ifx-accordion_2.cjs.entry.js +1 -1
- package/dist/cjs/ifx-alert_2.cjs.entry.js +1 -1
- package/dist/cjs/ifx-badge.cjs.entry.js +1 -1
- package/dist/cjs/ifx-basic-table.cjs.entry.js +1 -1
- package/dist/cjs/ifx-breadcrumb-item-label.cjs.entry.js +1 -1
- package/dist/cjs/ifx-breadcrumb-item.cjs.entry.js +1 -1
- package/dist/cjs/ifx-breadcrumb.cjs.entry.js +1 -1
- package/dist/cjs/ifx-button.cjs.entry.js +1 -1
- package/dist/cjs/ifx-card-headline.cjs.entry.js +1 -1
- package/dist/cjs/ifx-card-image.cjs.entry.js +1 -1
- package/dist/cjs/ifx-card-links.cjs.entry.js +1 -1
- package/dist/cjs/ifx-card-overline.cjs.entry.js +1 -1
- package/dist/cjs/ifx-card-text.cjs.entry.js +1 -1
- package/dist/cjs/ifx-card.cjs.entry.js +1 -1
- package/dist/cjs/ifx-checkbox-group.cjs.entry.js +1 -1
- package/dist/cjs/ifx-checkbox.cjs.entry.js +1 -1
- package/dist/cjs/ifx-chip_3.cjs.entry.js +1 -1
- package/dist/cjs/ifx-content-switcher-item.cjs.entry.js +1 -1
- package/dist/cjs/ifx-content-switcher.cjs.entry.js +1 -1
- package/dist/cjs/ifx-date-picker.cjs.entry.js +1 -1
- package/dist/cjs/ifx-download.cjs.entry.js +1 -1
- package/dist/cjs/ifx-dropdown-header.cjs.entry.js +1 -1
- package/dist/cjs/ifx-dropdown-item.cjs.entry.js +1 -1
- package/dist/cjs/ifx-dropdown-menu.cjs.entry.js +1 -1
- package/dist/cjs/ifx-dropdown-separator.cjs.entry.js +1 -1
- package/dist/cjs/ifx-dropdown-trigger-button.cjs.entry.js +1 -1
- package/dist/cjs/ifx-dropdown-trigger.cjs.entry.js +1 -1
- package/dist/cjs/ifx-dropdown.cjs.entry.js +1 -1
- package/dist/cjs/ifx-faq.cjs.entry.js +2 -2
- package/dist/cjs/ifx-file-upload.cjs.entry.js +1 -1
- package/dist/cjs/ifx-filter-accordion.cjs.entry.js +1 -1
- package/dist/cjs/ifx-filter-bar.cjs.entry.js +1 -1
- package/dist/cjs/ifx-filter-search.cjs.entry.js +1 -1
- package/dist/cjs/ifx-filter-type-group.cjs.entry.js +1 -1
- package/dist/cjs/ifx-footer-column.cjs.entry.js +1 -1
- package/dist/cjs/ifx-footer.cjs.entry.js +1 -1
- package/dist/cjs/ifx-icon-button.cjs.entry.js +1 -1
- package/dist/cjs/ifx-icon.cjs.entry.js +1 -1
- package/dist/cjs/ifx-icons-preview.cjs.entry.js +1 -1
- package/dist/cjs/ifx-link.cjs.entry.js +1 -1
- package/dist/cjs/ifx-list-entry.cjs.entry.js +1 -1
- package/dist/cjs/ifx-list.cjs.entry.js +1 -1
- package/dist/cjs/ifx-modal.cjs.entry.js +16 -4
- package/dist/cjs/ifx-modal.cjs.entry.js.map +1 -1
- package/dist/cjs/ifx-multiselect.cjs.entry.js +1 -1
- package/dist/cjs/ifx-navbar-item.cjs.entry.js +1 -1
- package/dist/cjs/ifx-navbar-profile.cjs.entry.js +1 -1
- package/dist/cjs/ifx-navbar.cjs.entry.js +1 -1
- package/dist/cjs/ifx-notification.cjs.entry.js +1 -1
- package/dist/cjs/ifx-number-indicator.cjs.entry.js +1 -1
- package/dist/cjs/ifx-overview-table.cjs.entry.js +1 -1
- package/dist/cjs/ifx-progress-bar.cjs.entry.js +1 -1
- package/dist/cjs/ifx-radio-button-group.cjs.entry.js +1 -1
- package/dist/cjs/ifx-radio-button.cjs.entry.js +1 -1
- package/dist/cjs/ifx-search-bar.cjs.entry.js +1 -1
- package/dist/cjs/ifx-search-field.cjs.entry.js +1 -1
- package/dist/cjs/ifx-segment.cjs.entry.js +1 -1
- package/dist/cjs/ifx-segmented-control.cjs.entry.js +1 -1
- package/dist/cjs/ifx-select.cjs.entry.js +1 -1
- package/dist/cjs/ifx-set-filter.cjs.entry.js +1 -1
- package/dist/cjs/ifx-sidebar-item.cjs.entry.js +1 -1
- package/dist/cjs/ifx-sidebar-title.cjs.entry.js +1 -1
- package/dist/cjs/ifx-sidebar.cjs.entry.js +1 -1
- package/dist/cjs/ifx-slider.cjs.entry.js +1 -1
- package/dist/cjs/ifx-spinner_2.cjs.entry.js +1 -1
- package/dist/cjs/ifx-status.cjs.entry.js +1 -1
- package/dist/cjs/ifx-step.cjs.entry.js +1 -1
- package/dist/cjs/ifx-stepper.cjs.entry.js +1 -1
- package/dist/cjs/ifx-switch.cjs.entry.js +1 -1
- package/dist/cjs/ifx-tab.cjs.entry.js +1 -1
- package/dist/cjs/ifx-table.cjs.entry.js +1 -1
- package/dist/cjs/ifx-tabs.cjs.entry.js +1 -1
- package/dist/cjs/ifx-tag.cjs.entry.js +1 -1
- package/dist/cjs/ifx-templates-ui.cjs.entry.js +1 -1
- package/dist/cjs/ifx-textarea.cjs.entry.js +1 -1
- package/dist/cjs/ifx-tooltip.cjs.entry.js +1 -1
- package/dist/cjs/{index-7f4df11a.js → index-c9480f70.js} +6 -55
- package/dist/cjs/index-c9480f70.js.map +1 -0
- package/dist/cjs/infineon-design-system-stencil.cjs.js +2 -2
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/collection/collection-manifest.json +0 -2
- package/dist/collection/components/modal/modal.css +7 -2
- package/dist/collection/components/modal/modal.js +14 -2
- package/dist/collection/components/modal/modal.js.map +1 -1
- package/dist/collection/stories/setup-and-installation/faq/faq.js +1 -1
- package/dist/components/ifx-accordion-item.js +1 -1
- package/dist/components/ifx-accordion.js +1 -1
- package/dist/components/ifx-alert.js +1 -1
- package/dist/components/ifx-badge.js +1 -1
- package/dist/components/ifx-basic-table.js +1 -1
- package/dist/components/ifx-breadcrumb-item-label.js +2 -2
- package/dist/components/ifx-breadcrumb-item.js +1 -1
- package/dist/components/ifx-breadcrumb.js +1 -1
- package/dist/components/ifx-button.js +1 -1
- package/dist/components/ifx-card-headline.js +1 -1
- package/dist/components/ifx-card-image.js +1 -1
- package/dist/components/ifx-card-links.js +1 -1
- package/dist/components/ifx-card-overline.js +1 -1
- package/dist/components/ifx-card-text.js +1 -1
- package/dist/components/ifx-card.js +1 -1
- package/dist/components/ifx-checkbox-group.js +2 -2
- package/dist/components/ifx-checkbox.js +1 -1
- package/dist/components/ifx-chip-item.js +1 -1
- package/dist/components/ifx-chip.js +1 -1
- package/dist/components/ifx-content-switcher-item.js +1 -1
- package/dist/components/ifx-content-switcher.js +1 -1
- package/dist/components/ifx-date-picker.js +2 -2
- package/dist/components/ifx-download.js +2 -2
- package/dist/components/ifx-dropdown-header.js +1 -1
- package/dist/components/ifx-dropdown-item.js +2 -2
- package/dist/components/ifx-dropdown-menu.js +1 -1
- package/dist/components/ifx-dropdown-separator.js +1 -1
- package/dist/components/ifx-dropdown-trigger-button.js +3 -3
- package/dist/components/ifx-dropdown-trigger.js +1 -1
- package/dist/components/ifx-dropdown.js +1 -1
- package/dist/components/ifx-faq.js +5 -5
- package/dist/components/ifx-file-upload.js +5 -5
- package/dist/components/ifx-filter-accordion.js +3 -3
- package/dist/components/ifx-filter-bar.js +3 -3
- package/dist/components/ifx-filter-search.js +3 -3
- package/dist/components/ifx-filter-type-group.js +1 -1
- package/dist/components/ifx-footer-column.js +1 -1
- package/dist/components/ifx-footer.js +1 -1
- package/dist/components/ifx-icon-button.js +1 -1
- package/dist/components/ifx-icon.js +1 -1
- package/dist/components/ifx-icons-preview.js +4 -4
- package/dist/components/ifx-link.js +1 -1
- package/dist/components/ifx-list-entry.js +4 -4
- package/dist/components/ifx-list.js +3 -3
- package/dist/components/ifx-modal.js +18 -6
- package/dist/components/ifx-modal.js.map +1 -1
- package/dist/components/ifx-multiselect.js +1 -1
- package/dist/components/ifx-navbar-item.js +3 -3
- package/dist/components/ifx-navbar-profile.js +1 -1
- package/dist/components/ifx-navbar.js +2 -2
- package/dist/components/ifx-notification.js +1 -1
- package/dist/components/ifx-number-indicator.js +1 -1
- package/dist/components/ifx-overview-table.js +4 -4
- package/dist/components/ifx-pagination.js +1 -1
- package/dist/components/ifx-progress-bar.js +1 -1
- package/dist/components/ifx-radio-button-group.js +2 -2
- package/dist/components/ifx-radio-button.js +1 -1
- package/dist/components/ifx-search-bar.js +3 -3
- package/dist/components/ifx-search-field.js +1 -1
- package/dist/components/ifx-segment.js +2 -2
- package/dist/components/ifx-segmented-control.js +2 -2
- package/dist/components/ifx-select.js +1 -1
- package/dist/components/ifx-set-filter.js +7 -7
- package/dist/components/ifx-sidebar-item.js +3 -3
- package/dist/components/ifx-sidebar-title.js +1 -1
- package/dist/components/ifx-sidebar.js +1 -1
- package/dist/components/ifx-slider.js +2 -2
- package/dist/components/ifx-spinner.js +1 -1
- package/dist/components/ifx-status.js +1 -1
- package/dist/components/ifx-step.js +2 -2
- package/dist/components/ifx-stepper.js +1 -1
- package/dist/components/ifx-switch.js +1 -1
- package/dist/components/ifx-tab.js +1 -1
- package/dist/components/ifx-table.js +10 -10
- package/dist/components/ifx-tabs.js +2 -2
- package/dist/components/ifx-tag.js +2 -2
- package/dist/components/ifx-template.js +1 -1
- package/dist/components/ifx-templates-ui.js +9 -9
- package/dist/components/ifx-text-field.js +1 -1
- package/dist/components/ifx-textarea.js +1 -1
- package/dist/components/ifx-tooltip.js +2 -2
- package/dist/components/index.js +1 -1
- package/dist/components/{p-ab5c15bf.js → p-04cfc587.js} +3 -3
- package/dist/components/{p-ab5c15bf.js.map → p-04cfc587.js.map} +1 -1
- package/dist/components/{p-3b6a432e.js → p-0aee2554.js} +2 -2
- package/dist/components/{p-3b6a432e.js.map → p-0aee2554.js.map} +1 -1
- package/dist/components/{p-236bf70f.js → p-18ad1165.js} +3 -3
- package/dist/components/{p-236bf70f.js.map → p-18ad1165.js.map} +1 -1
- package/dist/components/{p-e73e6dce.js → p-23a993bc.js} +4 -4
- package/dist/components/{p-e73e6dce.js.map → p-23a993bc.js.map} +1 -1
- package/dist/components/{p-11e95622.js → p-2a46b223.js} +2 -2
- package/dist/components/{p-11e95622.js.map → p-2a46b223.js.map} +1 -1
- package/dist/components/{p-f8e6a4ef.js → p-2cc378b8.js} +3 -43
- package/dist/components/p-2cc378b8.js.map +1 -0
- package/dist/components/{p-68016aea.js → p-42dca0c9.js} +2 -2
- package/dist/components/{p-68016aea.js.map → p-42dca0c9.js.map} +1 -1
- package/dist/components/{p-3ec421ea.js → p-4d7b13e3.js} +3 -3
- package/dist/components/{p-3ec421ea.js.map → p-4d7b13e3.js.map} +1 -1
- package/dist/components/{p-e3cd5556.js → p-52c9a12e.js} +3 -3
- package/dist/components/{p-e3cd5556.js.map → p-52c9a12e.js.map} +1 -1
- package/dist/components/{p-2bd941eb.js → p-5b5399c2.js} +2 -2
- package/dist/components/{p-2bd941eb.js.map → p-5b5399c2.js.map} +1 -1
- package/dist/components/{p-162a9364.js → p-5fd6328a.js} +2 -2
- package/dist/components/{p-162a9364.js.map → p-5fd6328a.js.map} +1 -1
- package/dist/components/{p-c88b4b7c.js → p-681bd5b1.js} +4 -4
- package/dist/components/{p-c88b4b7c.js.map → p-681bd5b1.js.map} +1 -1
- package/dist/components/{p-f511219b.js → p-8824ca83.js} +2 -2
- package/dist/components/{p-f511219b.js.map → p-8824ca83.js.map} +1 -1
- package/dist/components/{p-0ba7b063.js → p-bfae6ae0.js} +2 -2
- package/dist/components/{p-0ba7b063.js.map → p-bfae6ae0.js.map} +1 -1
- package/dist/components/{p-6e579eb5.js → p-ca6c8507.js} +3 -3
- package/dist/components/{p-6e579eb5.js.map → p-ca6c8507.js.map} +1 -1
- package/dist/components/{p-dcecb226.js → p-cc9cb040.js} +2 -2
- package/dist/components/{p-dcecb226.js.map → p-cc9cb040.js.map} +1 -1
- package/dist/components/{p-b5256810.js → p-cefd9f73.js} +4 -4
- package/dist/components/{p-b5256810.js.map → p-cefd9f73.js.map} +1 -1
- package/dist/components/{p-a9289acb.js → p-d64e5297.js} +7 -7
- package/dist/components/{p-a9289acb.js.map → p-d64e5297.js.map} +1 -1
- package/dist/components/{p-a957f7ad.js → p-f41c84fa.js} +5 -5
- package/dist/components/{p-a957f7ad.js.map → p-f41c84fa.js.map} +1 -1
- package/dist/components/{p-26dfe620.js → p-f69a7795.js} +5 -5
- package/dist/components/{p-26dfe620.js.map → p-f69a7795.js.map} +1 -1
- package/dist/components/{p-75572595.js → p-f76b674f.js} +3 -3
- package/dist/components/{p-75572595.js.map → p-f76b674f.js.map} +1 -1
- package/dist/components/{p-817e9528.js → p-f7a8339d.js} +3 -3
- package/dist/components/{p-817e9528.js.map → p-f7a8339d.js.map} +1 -1
- package/dist/components/{p-108c28cb.js → p-f8ce0088.js} +2 -2
- package/dist/components/{p-108c28cb.js.map → p-f8ce0088.js.map} +1 -1
- package/dist/esm/ifx-accordion_2.entry.js +1 -1
- package/dist/esm/ifx-alert_2.entry.js +1 -1
- package/dist/esm/ifx-badge.entry.js +1 -1
- package/dist/esm/ifx-basic-table.entry.js +1 -1
- package/dist/esm/ifx-breadcrumb-item-label.entry.js +1 -1
- package/dist/esm/ifx-breadcrumb-item.entry.js +1 -1
- package/dist/esm/ifx-breadcrumb.entry.js +1 -1
- package/dist/esm/ifx-button.entry.js +1 -1
- package/dist/esm/ifx-card-headline.entry.js +1 -1
- package/dist/esm/ifx-card-image.entry.js +1 -1
- package/dist/esm/ifx-card-links.entry.js +1 -1
- package/dist/esm/ifx-card-overline.entry.js +1 -1
- package/dist/esm/ifx-card-text.entry.js +1 -1
- package/dist/esm/ifx-card.entry.js +1 -1
- package/dist/esm/ifx-checkbox-group.entry.js +1 -1
- package/dist/esm/ifx-checkbox.entry.js +1 -1
- package/dist/esm/ifx-chip_3.entry.js +1 -1
- package/dist/esm/ifx-content-switcher-item.entry.js +1 -1
- package/dist/esm/ifx-content-switcher.entry.js +1 -1
- package/dist/esm/ifx-date-picker.entry.js +1 -1
- package/dist/esm/ifx-download.entry.js +1 -1
- package/dist/esm/ifx-dropdown-header.entry.js +1 -1
- package/dist/esm/ifx-dropdown-item.entry.js +1 -1
- package/dist/esm/ifx-dropdown-menu.entry.js +1 -1
- package/dist/esm/ifx-dropdown-separator.entry.js +1 -1
- package/dist/esm/ifx-dropdown-trigger-button.entry.js +1 -1
- package/dist/esm/ifx-dropdown-trigger.entry.js +1 -1
- package/dist/esm/ifx-dropdown.entry.js +1 -1
- package/dist/esm/ifx-faq.entry.js +2 -2
- package/dist/esm/ifx-file-upload.entry.js +1 -1
- package/dist/esm/ifx-filter-accordion.entry.js +1 -1
- package/dist/esm/ifx-filter-bar.entry.js +1 -1
- package/dist/esm/ifx-filter-search.entry.js +1 -1
- package/dist/esm/ifx-filter-type-group.entry.js +1 -1
- package/dist/esm/ifx-footer-column.entry.js +1 -1
- package/dist/esm/ifx-footer.entry.js +1 -1
- package/dist/esm/ifx-icon-button.entry.js +1 -1
- package/dist/esm/ifx-icon.entry.js +1 -1
- package/dist/esm/ifx-icons-preview.entry.js +1 -1
- package/dist/esm/ifx-link.entry.js +1 -1
- package/dist/esm/ifx-list-entry.entry.js +1 -1
- package/dist/esm/ifx-list.entry.js +1 -1
- package/dist/esm/ifx-modal.entry.js +16 -4
- package/dist/esm/ifx-modal.entry.js.map +1 -1
- package/dist/esm/ifx-multiselect.entry.js +1 -1
- package/dist/esm/ifx-navbar-item.entry.js +1 -1
- package/dist/esm/ifx-navbar-profile.entry.js +1 -1
- package/dist/esm/ifx-navbar.entry.js +1 -1
- package/dist/esm/ifx-notification.entry.js +1 -1
- package/dist/esm/ifx-number-indicator.entry.js +1 -1
- package/dist/esm/ifx-overview-table.entry.js +1 -1
- package/dist/esm/ifx-progress-bar.entry.js +1 -1
- package/dist/esm/ifx-radio-button-group.entry.js +1 -1
- package/dist/esm/ifx-radio-button.entry.js +1 -1
- package/dist/esm/ifx-search-bar.entry.js +1 -1
- package/dist/esm/ifx-search-field.entry.js +1 -1
- package/dist/esm/ifx-segment.entry.js +1 -1
- package/dist/esm/ifx-segmented-control.entry.js +1 -1
- package/dist/esm/ifx-select.entry.js +1 -1
- package/dist/esm/ifx-set-filter.entry.js +1 -1
- package/dist/esm/ifx-sidebar-item.entry.js +1 -1
- package/dist/esm/ifx-sidebar-title.entry.js +1 -1
- package/dist/esm/ifx-sidebar.entry.js +1 -1
- package/dist/esm/ifx-slider.entry.js +1 -1
- package/dist/esm/ifx-spinner_2.entry.js +1 -1
- package/dist/esm/ifx-status.entry.js +1 -1
- package/dist/esm/ifx-step.entry.js +1 -1
- package/dist/esm/ifx-stepper.entry.js +1 -1
- package/dist/esm/ifx-switch.entry.js +1 -1
- package/dist/esm/ifx-tab.entry.js +1 -1
- package/dist/esm/ifx-table.entry.js +1 -1
- package/dist/esm/ifx-tabs.entry.js +1 -1
- package/dist/esm/ifx-tag.entry.js +1 -1
- package/dist/esm/ifx-templates-ui.entry.js +1 -1
- package/dist/esm/ifx-textarea.entry.js +1 -1
- package/dist/esm/ifx-tooltip.entry.js +1 -1
- package/dist/esm/{index-6c9eba32.js → index-c77e25a0.js} +7 -55
- package/dist/esm/index-c77e25a0.js.map +1 -0
- package/dist/esm/infineon-design-system-stencil.js +3 -3
- package/dist/esm/loader.js +3 -3
- package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js +1 -1
- package/dist/infineon-design-system-stencil/infineon-design-system-stencil.esm.js.map +1 -1
- package/dist/infineon-design-system-stencil/{p-b1332d35.entry.js → p-007f032b.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-2281b467.entry.js → p-00fd53b9.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-20de8fb7.entry.js → p-0333c09a.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-d5c87934.entry.js → p-040dfe3a.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-03c9d3fe.entry.js → p-0474c62d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-f0233249.entry.js → p-063dc766.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-b892a205.entry.js → p-0a69604b.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-f0c2e188.entry.js → p-0d11b881.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-3a7f32df.entry.js → p-1218cd67.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-741ee6fd.entry.js → p-1958f029.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-1d8518f1.entry.js → p-1a29bbb2.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-1c90eb21.entry.js +2 -0
- package/dist/infineon-design-system-stencil/p-1c90eb21.entry.js.map +1 -0
- package/dist/infineon-design-system-stencil/{p-dd50c9cc.entry.js → p-22615332.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-dd28f3a1.entry.js → p-29984af2.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-c0c148ec.entry.js → p-2fa26bf7.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-7c06a6bd.entry.js → p-2fb84e5d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-9b94e2ae.entry.js → p-33f48cf1.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-6bd0690d.entry.js → p-3469adb7.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-62303f57.entry.js → p-3545f2d5.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-7001bc7d.entry.js → p-361d1e31.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-d4eff9d8.entry.js → p-3ff188be.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-406b00eb.entry.js +2 -0
- package/dist/infineon-design-system-stencil/{p-fb7fbe44.entry.js → p-41846fb5.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-4b1e700d.entry.js → p-41f245f6.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-5efc38d5.entry.js → p-47893f7e.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-5fc8cf08.entry.js → p-4d0da3de.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-4ddb3e72.entry.js +2 -0
- package/dist/infineon-design-system-stencil/{p-f9364479.entry.js → p-53411f03.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-527afe1e.entry.js → p-53abaa78.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-87e684d5.entry.js → p-59036c10.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-676e0a62.entry.js → p-5a5df7de.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-bf7bb869.entry.js → p-61117bda.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-62a04d45.entry.js → p-65d5e257.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-07ecc076.entry.js → p-661a7c0b.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-ad4305fd.entry.js → p-6693fddc.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-af1be17e.entry.js → p-6a8bfce7.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-30503cdf.entry.js → p-723cace7.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-9b6f98a6.entry.js → p-7355c5fe.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-a3c0eb25.entry.js → p-7e55680a.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-800704ec.entry.js → p-88ae2d37.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-a2615d6f.entry.js → p-8a733ad7.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-202a39ff.entry.js → p-964e15d1.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-50252b28.entry.js → p-99461b11.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-715070f7.entry.js → p-9da1f8b9.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-96244232.entry.js → p-a25618fd.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-fe38ca7b.entry.js → p-a3ece62e.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-e014d22e.entry.js → p-a8241d5d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-a92465d1.entry.js +2 -0
- package/dist/infineon-design-system-stencil/{p-1a82e21d.entry.js → p-ac4aaa18.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-1f24970a.entry.js → p-b0c402e0.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-eb5e154d.entry.js → p-b26d054b.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-0262de1d.entry.js → p-b2ff6914.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-6bb224ed.entry.js → p-b39303be.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-5fb32319.entry.js → p-b44360ea.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-28de8581.entry.js → p-b8e74ad3.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-cbd79068.entry.js → p-ba4f65f1.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-e913b4bc.entry.js → p-c172e015.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-82d372b4.entry.js → p-c2cc54c0.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-d73913fd.entry.js → p-c4eac5cd.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-8dad964c.entry.js → p-c6b76d4a.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-fa81a54a.entry.js → p-ce448991.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-cb81ea29.entry.js → p-d04dbacf.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-00a1ec40.entry.js → p-d2dfe109.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-e11f02e9.entry.js → p-d4da0515.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-bab776f1.entry.js → p-d5936509.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-571e0df8.entry.js → p-d928585e.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-f41db87c.entry.js → p-de733e32.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-9d4b5f5a.entry.js → p-e5df823b.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-e6edf72d.js +3 -0
- package/dist/infineon-design-system-stencil/p-e6edf72d.js.map +1 -0
- package/dist/infineon-design-system-stencil/{p-30bd18de.entry.js → p-e93396ed.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-3bd9ec1c.entry.js → p-edc77e53.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-37c45825.entry.js → p-f22dad77.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-a74c4f55.entry.js → p-f4866ad9.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-1772ef7d.entry.js → p-f88b928c.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-2e900240.entry.js → p-fdad4729.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-45ac2698.entry.js → p-fe2d60b9.entry.js} +2 -2
- package/dist/types/components/modal/modal.d.ts +2 -0
- package/dist/types/components.d.ts +0 -82
- package/package.json +1 -1
- package/dist/cjs/ifx-tree-view-item.cjs.entry.js +0 -326
- package/dist/cjs/ifx-tree-view-item.cjs.entry.js.map +0 -1
- package/dist/cjs/ifx-tree-view.cjs.entry.js +0 -52
- package/dist/cjs/ifx-tree-view.cjs.entry.js.map +0 -1
- package/dist/cjs/index-7f4df11a.js.map +0 -1
- package/dist/collection/components/tree-view/tree-view-item.css +0 -112
- package/dist/collection/components/tree-view/tree-view-item.js +0 -487
- package/dist/collection/components/tree-view/tree-view-item.js.map +0 -1
- package/dist/collection/components/tree-view/tree-view.css +0 -18
- package/dist/collection/components/tree-view/tree-view.js +0 -169
- package/dist/collection/components/tree-view/tree-view.js.map +0 -1
- package/dist/collection/components/tree-view/tree-view.stories.js +0 -272
- package/dist/collection/components/tree-view/tree-view.stories.js.map +0 -1
- package/dist/components/ifx-tree-view-item.d.ts +0 -11
- package/dist/components/ifx-tree-view-item.js +0 -367
- package/dist/components/ifx-tree-view-item.js.map +0 -1
- package/dist/components/ifx-tree-view.d.ts +0 -11
- package/dist/components/ifx-tree-view.js +0 -74
- package/dist/components/ifx-tree-view.js.map +0 -1
- package/dist/components/p-f8e6a4ef.js.map +0 -1
- package/dist/esm/ifx-tree-view-item.entry.js +0 -322
- package/dist/esm/ifx-tree-view-item.entry.js.map +0 -1
- package/dist/esm/ifx-tree-view.entry.js +0 -48
- package/dist/esm/ifx-tree-view.entry.js.map +0 -1
- package/dist/esm/index-6c9eba32.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-34930b99.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-488408d3.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-60ee12c3.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-60ee12c3.entry.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-8e599ad3.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-8e599ad3.entry.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-b7a462e5.js +0 -3
- package/dist/infineon-design-system-stencil/p-b7a462e5.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-c1caa426.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-d5c7d113.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-d5c7d113.entry.js.map +0 -1
- package/dist/types/components/tree-view/tree-view-item.d.ts +0 -50
- package/dist/types/components/tree-view/tree-view.d.ts +0 -13
- package/dist/types/components/tree-view/tree-view.stories.d.ts +0 -6
- /package/dist/infineon-design-system-stencil/{p-b1332d35.entry.js.map → p-007f032b.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-2281b467.entry.js.map → p-00fd53b9.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-20de8fb7.entry.js.map → p-0333c09a.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-d5c87934.entry.js.map → p-040dfe3a.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-03c9d3fe.entry.js.map → p-0474c62d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-f0233249.entry.js.map → p-063dc766.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-b892a205.entry.js.map → p-0a69604b.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-f0c2e188.entry.js.map → p-0d11b881.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-3a7f32df.entry.js.map → p-1218cd67.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-741ee6fd.entry.js.map → p-1958f029.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-1d8518f1.entry.js.map → p-1a29bbb2.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-dd50c9cc.entry.js.map → p-22615332.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-dd28f3a1.entry.js.map → p-29984af2.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-c0c148ec.entry.js.map → p-2fa26bf7.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-7c06a6bd.entry.js.map → p-2fb84e5d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-9b94e2ae.entry.js.map → p-33f48cf1.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-6bd0690d.entry.js.map → p-3469adb7.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-62303f57.entry.js.map → p-3545f2d5.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-7001bc7d.entry.js.map → p-361d1e31.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-d4eff9d8.entry.js.map → p-3ff188be.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-34930b99.entry.js.map → p-406b00eb.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-fb7fbe44.entry.js.map → p-41846fb5.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-4b1e700d.entry.js.map → p-41f245f6.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-5efc38d5.entry.js.map → p-47893f7e.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-5fc8cf08.entry.js.map → p-4d0da3de.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-c1caa426.entry.js.map → p-4ddb3e72.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-f9364479.entry.js.map → p-53411f03.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-527afe1e.entry.js.map → p-53abaa78.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-87e684d5.entry.js.map → p-59036c10.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-676e0a62.entry.js.map → p-5a5df7de.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-bf7bb869.entry.js.map → p-61117bda.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-62a04d45.entry.js.map → p-65d5e257.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-07ecc076.entry.js.map → p-661a7c0b.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-ad4305fd.entry.js.map → p-6693fddc.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-af1be17e.entry.js.map → p-6a8bfce7.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-30503cdf.entry.js.map → p-723cace7.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-9b6f98a6.entry.js.map → p-7355c5fe.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-a3c0eb25.entry.js.map → p-7e55680a.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-800704ec.entry.js.map → p-88ae2d37.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-a2615d6f.entry.js.map → p-8a733ad7.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-202a39ff.entry.js.map → p-964e15d1.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-50252b28.entry.js.map → p-99461b11.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-715070f7.entry.js.map → p-9da1f8b9.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-96244232.entry.js.map → p-a25618fd.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-fe38ca7b.entry.js.map → p-a3ece62e.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-e014d22e.entry.js.map → p-a8241d5d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-488408d3.entry.js.map → p-a92465d1.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-1a82e21d.entry.js.map → p-ac4aaa18.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-1f24970a.entry.js.map → p-b0c402e0.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-eb5e154d.entry.js.map → p-b26d054b.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-0262de1d.entry.js.map → p-b2ff6914.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-6bb224ed.entry.js.map → p-b39303be.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-5fb32319.entry.js.map → p-b44360ea.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-28de8581.entry.js.map → p-b8e74ad3.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-cbd79068.entry.js.map → p-ba4f65f1.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-e913b4bc.entry.js.map → p-c172e015.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-82d372b4.entry.js.map → p-c2cc54c0.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-d73913fd.entry.js.map → p-c4eac5cd.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-8dad964c.entry.js.map → p-c6b76d4a.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-fa81a54a.entry.js.map → p-ce448991.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-cb81ea29.entry.js.map → p-d04dbacf.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-00a1ec40.entry.js.map → p-d2dfe109.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-e11f02e9.entry.js.map → p-d4da0515.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-bab776f1.entry.js.map → p-d5936509.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-571e0df8.entry.js.map → p-d928585e.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-f41db87c.entry.js.map → p-de733e32.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-9d4b5f5a.entry.js.map → p-e5df823b.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-30bd18de.entry.js.map → p-e93396ed.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-3bd9ec1c.entry.js.map → p-edc77e53.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-37c45825.entry.js.map → p-f22dad77.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-a74c4f55.entry.js.map → p-f4866ad9.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-1772ef7d.entry.js.map → p-f88b928c.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-2e900240.entry.js.map → p-fdad4729.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-45ac2698.entry.js.map → p-fe2d60b9.entry.js.map} +0 -0
@@ -1,322 +0,0 @@
|
|
1
|
-
import { r as registerInstance, c as createEvent, h, F as Fragment, g as getElement } from './index-6c9eba32.js';
|
2
|
-
|
3
|
-
const treeViewItemCss = ".tree-item{position:relative;cursor:pointer;list-style:none}.tree-item.tree-item--expanded{position:relative}.tree-item.tree-item--has-children{position:relative}.tree-item.tree-item--has-children .tree-item__header>.tree-item__chevron-container{display:flex}.tree-item.tree-item--has-children.tree-item--expanded .tree-item__header>.tree-item__chevron-container::after{display:block}.tree-item--disabled{cursor:not-allowed;pointer-events:none;color:#BFBBBB}.tree-item__content{display:flex;flex-direction:row}.tree-item__content:hover .tree-item__checkbox-container,.tree-item__content:hover .tree-item__header{background-color:#F7F7F7}.tree-item__checkbox-container{position:sticky;left:0;z-index:10;padding:4px;background-color:#FFFFFF}.tree-item__header{flex-grow:1;display:flex;align-items:center;white-space:nowrap;height:20px;padding-top:4px;padding-right:16px;padding-bottom:4px;padding-left:8px}.tree-item__chevron-container{display:none;align-items:center;margin-right:8px;height:20px}.tree-item__chevron-container::after{--height-line-start:28px;display:none;content:\"\";position:absolute;z-index:1;top:var(--height-line-start);left:auto;margin-left:8px;width:1px;height:calc(100% - var(--height-line-start));background-color:#EEEDED}.tree-item--disabled .tree-item__chevron-container::after{color:#EEEDED}.tree-item__chevron.chevron-down{transform:rotate(90deg)}.tree-item__chevron.chevron-right{transform:rotate(0)}.tree-item__label-icon-container{display:flex;align-items:center}.tree-item__label-icon-container:focus{outline:none}.tree-item__label-icon-container:focus-visible{outline:2px solid #0A8276;outline-offset:2px;border-radius:1px}.tree-item__icon-container{position:relative;width:16px;height:16px}.tree-item__icon-container ifx-icon{position:absolute;left:0;top:0;opacity:1;transition:opacity 0.2s ease-in-out}.tree-item__icon-container ifx-icon.icon--hidden{opacity:0}.tree-item__label{padding-left:8px}.tree-item__children{display:none}.tree-item[aria-expanded=true]>.tree-item__children{display:block}";
|
4
|
-
const IfxTreeViewItemStyle0 = treeViewItemCss;
|
5
|
-
|
6
|
-
const TreeViewItem = class {
|
7
|
-
constructor(hostRef) {
|
8
|
-
registerInstance(this, hostRef);
|
9
|
-
this.ifxTreeViewItemExpandChange = createEvent(this, "ifxTreeViewItemExpandChange", 7);
|
10
|
-
this.ifxTreeViewItemCheckChange = createEvent(this, "ifxTreeViewItemCheckChange", 7);
|
11
|
-
this.ifxTreeViewItemDisableChange = createEvent(this, "ifxTreeViewItemDisableChange", 7);
|
12
|
-
this.expanded = false;
|
13
|
-
this.initiallyExpanded = false;
|
14
|
-
this.disableItem = false;
|
15
|
-
this.hasChildren = false;
|
16
|
-
this.isChecked = false;
|
17
|
-
this.partialChecked = false;
|
18
|
-
this.level = 0;
|
19
|
-
this.disableAllItems = false;
|
20
|
-
this.expandAllItems = false;
|
21
|
-
this.findChildren = () => Array.from(this.host.children)
|
22
|
-
.filter((child) => child instanceof HTMLElement && child.tagName === 'IFX-TREE-VIEW-ITEM');
|
23
|
-
this.calculateNodeLevel = () => {
|
24
|
-
let level = 0, parent = this.host.parentElement;
|
25
|
-
while (parent) {
|
26
|
-
if (parent.tagName === 'IFX-TREE-VIEW-ITEM')
|
27
|
-
level++;
|
28
|
-
parent = parent.parentElement;
|
29
|
-
}
|
30
|
-
return level;
|
31
|
-
};
|
32
|
-
this.handleStateChange = (event) => {
|
33
|
-
if (this.disabled)
|
34
|
-
return;
|
35
|
-
event.stopPropagation();
|
36
|
-
this.updateCheckState(event.detail.checked);
|
37
|
-
};
|
38
|
-
this.handleCheckboxChange = (event) => {
|
39
|
-
var _a, _b;
|
40
|
-
if (this.disabled)
|
41
|
-
return;
|
42
|
-
this.updateCheckState((_b = (_a = event.detail) === null || _a === void 0 ? void 0 : _a.checked) !== null && _b !== void 0 ? _b : !this.isChecked);
|
43
|
-
};
|
44
|
-
this.handleHeaderClick = ({ target }) => {
|
45
|
-
if (this.disabled)
|
46
|
-
return;
|
47
|
-
if (!target.closest('.tree-item__checkbox-container, .tree-item__chevron-container')) {
|
48
|
-
this.updateCheckState(!this.isChecked);
|
49
|
-
}
|
50
|
-
};
|
51
|
-
this.toggleExpand = () => {
|
52
|
-
if (this.disabled)
|
53
|
-
return;
|
54
|
-
this.hasChildren && (this.expanded = !this.expanded);
|
55
|
-
};
|
56
|
-
this.handleKeyDown = (event) => {
|
57
|
-
var _a, _b, _c, _d, _e, _f;
|
58
|
-
const allItems = Array.from(((_a = this.host
|
59
|
-
.closest('ifx-tree-view')) === null || _a === void 0 ? void 0 : _a.querySelectorAll('ifx-tree-view-item')) || []);
|
60
|
-
const visibleItems = allItems.filter(item => {
|
61
|
-
var _a, _b;
|
62
|
-
let parent = (_a = item.parentElement) === null || _a === void 0 ? void 0 : _a.closest('ifx-tree-view-item');
|
63
|
-
while (parent) {
|
64
|
-
const parentCmp = parent;
|
65
|
-
if (!(parentCmp.expandAllItems || parentCmp.expanded)) {
|
66
|
-
return false;
|
67
|
-
}
|
68
|
-
parent = (_b = parent.parentElement) === null || _b === void 0 ? void 0 : _b.closest('ifx-tree-view-item');
|
69
|
-
}
|
70
|
-
return true;
|
71
|
-
});
|
72
|
-
const currentIndex = visibleItems.findIndex(el => el === this.host);
|
73
|
-
function focusLabelIcon(el) {
|
74
|
-
el === null || el === void 0 ? void 0 : el.focus();
|
75
|
-
}
|
76
|
-
switch (event.key) {
|
77
|
-
case 'ArrowDown': {
|
78
|
-
event.preventDefault();
|
79
|
-
let nextIndex = currentIndex + 1;
|
80
|
-
while (nextIndex < visibleItems.length) {
|
81
|
-
const next = visibleItems[nextIndex];
|
82
|
-
if (!next.disabled) {
|
83
|
-
focusLabelIcon((_b = next.shadowRoot) === null || _b === void 0 ? void 0 : _b.querySelector('.tree-item__label-icon-container'));
|
84
|
-
break;
|
85
|
-
}
|
86
|
-
nextIndex++;
|
87
|
-
}
|
88
|
-
break;
|
89
|
-
}
|
90
|
-
case 'ArrowUp': {
|
91
|
-
event.preventDefault();
|
92
|
-
let prevIndex = currentIndex - 1;
|
93
|
-
while (prevIndex >= 0) {
|
94
|
-
const prev = visibleItems[prevIndex];
|
95
|
-
if (!prev.disabled) {
|
96
|
-
focusLabelIcon((_c = prev.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelector('.tree-item__label-icon-container'));
|
97
|
-
break;
|
98
|
-
}
|
99
|
-
prevIndex--;
|
100
|
-
}
|
101
|
-
break;
|
102
|
-
}
|
103
|
-
case 'ArrowRight': {
|
104
|
-
event.preventDefault();
|
105
|
-
if (!this.isExpanded && this.hasChildren) {
|
106
|
-
this.expanded = true;
|
107
|
-
}
|
108
|
-
else if (this.isExpanded && this.hasChildren) {
|
109
|
-
const firstChild = this.host.querySelector('ifx-tree-view-item');
|
110
|
-
if (firstChild && !firstChild.disabled) {
|
111
|
-
focusLabelIcon((_d = firstChild.shadowRoot) === null || _d === void 0 ? void 0 : _d.querySelector('.tree-item__label-icon-container'));
|
112
|
-
}
|
113
|
-
}
|
114
|
-
break;
|
115
|
-
}
|
116
|
-
case 'ArrowLeft': {
|
117
|
-
event.preventDefault();
|
118
|
-
if (this.isExpanded && this.hasChildren) {
|
119
|
-
this.expanded = false;
|
120
|
-
}
|
121
|
-
else {
|
122
|
-
const parent = (_e = this.host.parentElement) === null || _e === void 0 ? void 0 : _e.closest('ifx-tree-view-item');
|
123
|
-
if (parent && !parent.disabled) {
|
124
|
-
focusLabelIcon((_f = parent.shadowRoot) === null || _f === void 0 ? void 0 : _f.querySelector('.tree-item__label-icon-container'));
|
125
|
-
}
|
126
|
-
}
|
127
|
-
break;
|
128
|
-
}
|
129
|
-
case ' ':
|
130
|
-
case 'Enter': {
|
131
|
-
event.preventDefault();
|
132
|
-
this.updateCheckState(!this.isChecked);
|
133
|
-
break;
|
134
|
-
}
|
135
|
-
}
|
136
|
-
};
|
137
|
-
}
|
138
|
-
get disabled() {
|
139
|
-
return this.disableAllItems || this.disableItem;
|
140
|
-
}
|
141
|
-
get isExpanded() {
|
142
|
-
return this.expandAllItems || this.expanded;
|
143
|
-
}
|
144
|
-
componentWillLoad() {
|
145
|
-
this.initializeNode();
|
146
|
-
this.setupEventListeners();
|
147
|
-
}
|
148
|
-
componentDidLoad() {
|
149
|
-
this.observeDisableAllItems();
|
150
|
-
this.observeExpandAllItems();
|
151
|
-
if (this.shouldExpandFromParent()) {
|
152
|
-
this.expandAllDescendants();
|
153
|
-
}
|
154
|
-
}
|
155
|
-
shouldExpandFromParent() {
|
156
|
-
let parent = this.host.parentElement;
|
157
|
-
while (parent) {
|
158
|
-
if (parent.tagName === 'IFX-TREE-VIEW' &&
|
159
|
-
(parent.hasAttribute('expand-all-items') || parent.hasAttribute('data-expand-all-items'))) {
|
160
|
-
return true;
|
161
|
-
}
|
162
|
-
parent = parent.parentElement;
|
163
|
-
}
|
164
|
-
return false;
|
165
|
-
}
|
166
|
-
expandAllDescendants() {
|
167
|
-
this.expanded = true;
|
168
|
-
const children = this.findChildren();
|
169
|
-
for (const child of children) {
|
170
|
-
if (typeof child.expanded !== 'undefined') {
|
171
|
-
child.expanded = true;
|
172
|
-
}
|
173
|
-
if (typeof child.expandAllDescendants === 'function') {
|
174
|
-
child.expandAllDescendants();
|
175
|
-
}
|
176
|
-
}
|
177
|
-
}
|
178
|
-
observeDisableAllItems() {
|
179
|
-
let parent = this.host.parentElement;
|
180
|
-
while (parent) {
|
181
|
-
if (parent.tagName === 'IFX-TREE-VIEW') {
|
182
|
-
const observer = new MutationObserver(mutations => {
|
183
|
-
for (const mutation of mutations) {
|
184
|
-
if (mutation.type === 'attributes' &&
|
185
|
-
mutation.attributeName === 'disable-all-items') {
|
186
|
-
const disableAll = parent.disableAllItems;
|
187
|
-
this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');
|
188
|
-
}
|
189
|
-
}
|
190
|
-
});
|
191
|
-
observer.observe(parent, { attributes: true });
|
192
|
-
const disableAll = parent.disableAllItems;
|
193
|
-
this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');
|
194
|
-
break;
|
195
|
-
}
|
196
|
-
parent = parent.parentElement;
|
197
|
-
}
|
198
|
-
}
|
199
|
-
observeExpandAllItems() {
|
200
|
-
let parent = this.host.parentElement;
|
201
|
-
while (parent) {
|
202
|
-
if (parent.tagName === 'IFX-TREE-VIEW' || parent.hasAttribute('data-expand-all-items')) {
|
203
|
-
const observer = new MutationObserver(mutations => {
|
204
|
-
for (const mutation of mutations) {
|
205
|
-
if (mutation.type === 'attributes' &&
|
206
|
-
mutation.attributeName === 'data-expand-all-items') {
|
207
|
-
this.expandAllItems = parent.hasAttribute('data-expand-all-items');
|
208
|
-
}
|
209
|
-
}
|
210
|
-
});
|
211
|
-
observer.observe(parent, { attributes: true });
|
212
|
-
this.expandAllItems = parent.hasAttribute('data-expand-all-items');
|
213
|
-
break;
|
214
|
-
}
|
215
|
-
parent = parent.parentElement;
|
216
|
-
}
|
217
|
-
}
|
218
|
-
initializeNode() {
|
219
|
-
this.expanded = this.initiallyExpanded;
|
220
|
-
this.hasChildren = this.findChildren().length > 0;
|
221
|
-
this.level = this.calculateNodeLevel();
|
222
|
-
this.host.setAttribute('data-level', this.level.toString());
|
223
|
-
}
|
224
|
-
setupEventListeners() {
|
225
|
-
this.host.addEventListener('internal-check-state-change', this.handleStateChange);
|
226
|
-
}
|
227
|
-
async updateCheckState(checked) {
|
228
|
-
if (this.disabled)
|
229
|
-
return;
|
230
|
-
this.setNodeState({ isChecked: checked, partialChecked: false });
|
231
|
-
await this.updateChildrenState(checked);
|
232
|
-
this.updateParentState();
|
233
|
-
}
|
234
|
-
handleExpandedChange(newValue) {
|
235
|
-
this.ifxTreeViewItemExpandChange.emit(newValue);
|
236
|
-
}
|
237
|
-
handleDisableItemChange(newValue) {
|
238
|
-
this.ifxTreeViewItemDisableChange.emit(newValue);
|
239
|
-
}
|
240
|
-
setNodeState(state) {
|
241
|
-
this.isChecked = state.isChecked;
|
242
|
-
this.partialChecked = state.partialChecked;
|
243
|
-
this.ifxTreeViewItemCheckChange.emit({
|
244
|
-
checked: this.isChecked,
|
245
|
-
indeterminate: this.partialChecked,
|
246
|
-
});
|
247
|
-
}
|
248
|
-
async updateChildrenState(checked) {
|
249
|
-
const children = this.findChildren();
|
250
|
-
for (const child of children) {
|
251
|
-
await child.componentOnReady();
|
252
|
-
child.dispatchEvent(new CustomEvent('internal-check-state-change', {
|
253
|
-
detail: { checked },
|
254
|
-
bubbles: false,
|
255
|
-
composed: true
|
256
|
-
}));
|
257
|
-
}
|
258
|
-
}
|
259
|
-
findSiblingNodes(parent) {
|
260
|
-
const parentEl = parent.parentElement;
|
261
|
-
if (!parentEl)
|
262
|
-
return [];
|
263
|
-
return Array.from(parentEl.querySelectorAll('ifx-tree-view-item')).map(el => el);
|
264
|
-
}
|
265
|
-
updateParentState() {
|
266
|
-
var _a;
|
267
|
-
const parent = (_a = this.host.parentElement) === null || _a === void 0 ? void 0 : _a.closest('ifx-tree-view-item');
|
268
|
-
if (!parent)
|
269
|
-
return;
|
270
|
-
parent.componentOnReady().then(resolved => {
|
271
|
-
const parentNode = resolved;
|
272
|
-
if (!(parentNode === null || parentNode === void 0 ? void 0 : parentNode.updateParentState))
|
273
|
-
return;
|
274
|
-
const siblings = this.findSiblingNodes(parent);
|
275
|
-
const states = this.calculateSiblingStates(siblings);
|
276
|
-
parentNode.setNodeState({
|
277
|
-
isChecked: states.allChecked,
|
278
|
-
partialChecked: !states.allChecked && states.someChecked
|
279
|
-
});
|
280
|
-
parentNode.updateParentState();
|
281
|
-
});
|
282
|
-
}
|
283
|
-
calculateSiblingStates(siblings) {
|
284
|
-
return {
|
285
|
-
allChecked: siblings.every(sib => sib.isChecked),
|
286
|
-
someChecked: siblings.some(sib => {
|
287
|
-
const node = sib;
|
288
|
-
return node.isChecked || node.partialChecked;
|
289
|
-
})
|
290
|
-
};
|
291
|
-
}
|
292
|
-
render() {
|
293
|
-
return (h("div", { key: '10a31a82078320a73d026ec8d42ae23d78049a9b', class: {
|
294
|
-
'tree-item': true,
|
295
|
-
'tree-item--expanded': this.isExpanded,
|
296
|
-
'tree-item--has-children': this.hasChildren,
|
297
|
-
'tree-item--disabled': this.disabled,
|
298
|
-
}, role: "treeitem", "aria-expanded": this.isExpanded ? 'true' : 'false', "data-level": this.level, "aria-disabled": this.disabled ? 'true' : undefined, "aria-label": this.ariaLabel }, h("div", { key: 'ad1dcf1ca93fd3f35f00d411e8740bfc54dc7c9f', class: "tree-item__content" }, this.renderCheckbox(), this.renderHeader()), this.isExpanded && h("div", { key: '1023010ffb83954bc852cafc18f3b79003ffbf3e', class: "tree-item__children" }, h("slot", { key: 'c7cd0a61015b29a99b963576c8bc3fd0725541f3' }))));
|
299
|
-
}
|
300
|
-
renderHeader() {
|
301
|
-
return (h("div", { class: "tree-item__header", style: { paddingLeft: `${this.level * 24 + 10}px` }, onClick: this.handleHeaderClick, tabIndex: -1, "aria-disabled": this.disabled ? 'true' : undefined }, this.renderControls()));
|
302
|
-
}
|
303
|
-
renderCheckbox() {
|
304
|
-
return (h("div", { class: "tree-item__checkbox-container", onClick: e => e.stopPropagation() }, h("ifx-checkbox", { size: 's', checked: this.isChecked, indeterminate: this.partialChecked, onIfxChange: this.handleCheckboxChange, disabled: this.disabled })));
|
305
|
-
}
|
306
|
-
renderControls() {
|
307
|
-
return [
|
308
|
-
this.hasChildren && (h("div", { class: "tree-item__chevron-container", onClick: this.toggleExpand }, h("ifx-icon", { class: `tree-item__chevron ${this.isExpanded ? 'chevron-down' : 'chevron-right'}`, icon: "chevron-right-16" }), h("div", { class: "tree-item__line" }))),
|
309
|
-
h("div", { class: "tree-item__label-icon-container", tabIndex: this.disabled ? -1 : 0, onKeyDown: this.handleKeyDown }, h("div", { class: "tree-item__icon-container" }, this.hasChildren ? (h(Fragment, null, h("ifx-icon", { class: { 'icon--hidden': this.isExpanded }, icon: "folder-16" }), h("ifx-icon", { class: { 'icon--hidden': !this.isExpanded }, icon: "folder-open-16" }))) : (h("ifx-icon", { icon: "file-16" }))), h("span", { class: "tree-item__label" }, this.label))
|
310
|
-
];
|
311
|
-
}
|
312
|
-
get host() { return getElement(this); }
|
313
|
-
static get watchers() { return {
|
314
|
-
"expanded": ["handleExpandedChange"],
|
315
|
-
"disableItem": ["handleDisableItemChange"]
|
316
|
-
}; }
|
317
|
-
};
|
318
|
-
TreeViewItem.style = IfxTreeViewItemStyle0;
|
319
|
-
|
320
|
-
export { TreeViewItem as ifx_tree_view_item };
|
321
|
-
|
322
|
-
//# sourceMappingURL=ifx-tree-view-item.entry.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"file":"ifx-tree-view-item.entry.js","mappings":";;AAAA,MAAM,eAAe,GAAG,i/DAAi/D,CAAC;AAC1gE,8BAAe,eAAe;;MCajB,YAAY;IALzB;;;;;QAQ0C,aAAQ,GAAY,KAAK,CAAC;QAC1D,sBAAiB,GAAY,KAAK,CAAC;QACnC,gBAAW,GAAY,KAAK,CAAC;QAOpB,gBAAW,GAAY,KAAK,CAAC;QAC7B,cAAS,GAAY,KAAK,CAAC;QAC3B,mBAAc,GAAY,KAAK,CAAC;QAChC,UAAK,GAAW,CAAC,CAAC;QAClB,oBAAe,GAAY,KAAK,CAAC;QACjC,mBAAc,GAAY,KAAK,CAAC;QAUzC,iBAAY,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;aACxD,MAAM,CAAC,CAAC,KAAK,KACZ,KAAK,YAAY,WAAW,IAAI,KAAK,CAAC,OAAO,KAAK,oBAAoB,CACvE,CAAC;QAEI,uBAAkB,GAAG;YAC3B,IAAI,KAAK,GAAG,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;YAChD,OAAO,MAAM,EAAE;gBACb,IAAI,MAAM,CAAC,OAAO,KAAK,oBAAoB;oBAAE,KAAK,EAAE,CAAC;gBACrD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;aAC/B;YACD,OAAO,KAAK,CAAC;SACd,CAAC;QAmGM,sBAAiB,GAAG,CAAC,KAAkB;YAC7C,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO;YAC1B,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;SAC7C,CAAC;QAEM,yBAAoB,GAAG,CAAC,KAAkB;;YAChD,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO;YAC1B,IAAI,CAAC,gBAAgB,CAAC,MAAA,MAAA,KAAK,CAAC,MAAM,0CAAE,OAAO,mCAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACjE,CAAC;QAEM,sBAAiB,GAAG,CAAC,EAAE,MAAM,EAAc;YACjD,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO;YAC1B,IAAI,CAAE,MAAsB,CAAC,OAAO,CAAC,+DAA+D,CAAC,EAAE;gBACrG,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aACxC;SACF,CAAC;QA0EM,iBAAY,GAAG;YACrB,IAAI,IAAI,CAAC,QAAQ;gBAAE,OAAO;YAC1B,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtD,CAAC;QAEM,kBAAa,GAAG,CAAC,KAAoB;;YAE3C,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CACzB,CAAA,MAAA,IAAI,CAAC,IAAI;iBACN,OAAO,CAAC,eAAe,CAAC,0CACvB,gBAAgB,CAAC,oBAAoB,CAAC,KAAI,EAAE,CACjD,CAAC;YAEF,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI;;gBACvC,IAAI,MAAM,GAAG,MAAA,IAAI,CAAC,aAAa,0CAAE,OAAO,CAAC,oBAAoB,CAAC,CAAC;gBAC/D,OAAO,MAAM,EAAE;oBACb,MAAM,SAAS,GAAG,MAAa,CAAC;oBAChC,IAAI,EAAE,SAAS,CAAC,cAAc,IAAI,SAAS,CAAC,QAAQ,CAAC,EAAE;wBACrD,OAAO,KAAK,CAAC;qBACd;oBACD,MAAM,GAAG,MAAA,MAAM,CAAC,aAAa,0CAAE,OAAO,CAAC,oBAAoB,CAAC,CAAC;iBAC9D;gBACD,OAAO,IAAI,CAAC;aACb,CAAC,CAAC;YAEH,MAAM,YAAY,GAAG,YAAY,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC;YAEpE,SAAS,cAAc,CAAC,EAAkB;gBACvC,EAAyB,aAAzB,EAAE,uBAAF,EAAE,CAAyB,KAAK,EAAE,CAAC;aACrC;YAED,QAAQ,KAAK,CAAC,GAAG;gBACf,KAAK,WAAW,EAAE;oBAChB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,SAAS,GAAG,YAAY,GAAG,CAAC,CAAC;oBACjC,OAAO,SAAS,GAAG,YAAY,CAAC,MAAM,EAAE;wBACtC,MAAM,IAAI,GAAG,YAAY,CAAC,SAAS,CAAQ,CAAC;wBAC5C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;4BAClB,cAAc,CAAC,MAAA,IAAI,CAAC,UAAU,0CAAE,aAAa,CAAC,kCAAkC,CAAC,CAAC,CAAC;4BACnF,MAAM;yBACP;wBACD,SAAS,EAAE,CAAC;qBACb;oBACD,MAAM;iBACP;gBACD,KAAK,SAAS,EAAE;oBACd,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,SAAS,GAAG,YAAY,GAAG,CAAC,CAAC;oBACjC,OAAO,SAAS,IAAI,CAAC,EAAE;wBACrB,MAAM,IAAI,GAAG,YAAY,CAAC,SAAS,CAAQ,CAAC;wBAC5C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;4BAClB,cAAc,CAAC,MAAA,IAAI,CAAC,UAAU,0CAAE,aAAa,CAAC,kCAAkC,CAAC,CAAC,CAAC;4BACnF,MAAM;yBACP;wBACD,SAAS,EAAE,CAAC;qBACb;oBACD,MAAM;iBACP;gBACD,KAAK,YAAY,EAAE;oBACjB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE;wBACxC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;qBACtB;yBAAM,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE;wBAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;wBACjE,IAAI,UAAU,IAAI,CAAE,UAAkB,CAAC,QAAQ,EAAE;4BAC/C,cAAc,CAAC,MAAC,UAA0B,CAAC,UAAU,0CAAE,aAAa,CAAC,kCAAkC,CAAC,CAAC,CAAC;yBAC3G;qBACF;oBACD,MAAM;iBACP;gBACD,KAAK,WAAW,EAAE;oBAChB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE;wBACvC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;qBACvB;yBAAM;wBACL,MAAM,MAAM,GAAG,MAAA,IAAI,CAAC,IAAI,CAAC,aAAa,0CAAE,OAAO,CAAC,oBAAoB,CAAC,CAAC;wBACtE,IAAI,MAAM,IAAI,CAAE,MAAc,CAAC,QAAQ,EAAE;4BACvC,cAAc,CAAC,MAAC,MAAsB,CAAC,UAAU,0CAAE,aAAa,CAAC,kCAAkC,CAAC,CAAC,CAAC;yBACvG;qBACF;oBACD,MAAM;iBACP;gBACD,KAAK,GAAG,CAAC;gBACT,KAAK,OAAO,EAAE;oBACZ,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;oBACvC,MAAM;iBACP;aACF;SACF,CAAC;KAoFH;IA9XC,IAAY,QAAQ;QAClB,OAAO,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,WAAW,CAAC;KACjD;IAED,IAAY,UAAU;QACpB,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC;KAC7C;IAgBD,iBAAiB;QACf,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,mBAAmB,EAAE,CAAC;KAC5B;IAED,gBAAgB;QACd,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,IAAI,CAAC,sBAAsB,EAAE,EAAE;YACjC,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;KACF;IAEO,sBAAsB;QAC5B,IAAI,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;QACrC,OAAO,MAAM,EAAE;YACb,IACE,MAAM,CAAC,OAAO,KAAK,eAAe;iBACjC,MAAM,CAAC,YAAY,CAAC,kBAAkB,CAAC,IAAI,MAAM,CAAC,YAAY,CAAC,uBAAuB,CAAC,CAAC,EACzF;gBACA,OAAO,IAAI,CAAC;aACb;YACD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;SAC/B;QACD,OAAO,KAAK,CAAC;KACd;IAEO,oBAAoB;QAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACrC,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE;YAC5B,IAAI,OAAQ,KAAa,CAAC,QAAQ,KAAK,WAAW,EAAE;gBACjD,KAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;aAChC;YACD,IAAI,OAAQ,KAAa,CAAC,oBAAoB,KAAK,UAAU,EAAE;gBAC5D,KAAa,CAAC,oBAAoB,EAAE,CAAC;aACvC;SACF;KACF;IAEO,sBAAsB;QAC5B,IAAI,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;QACrC,OAAO,MAAM,EAAE;YACb,IAAI,MAAM,CAAC,OAAO,KAAK,eAAe,EAAE;gBACtC,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,SAAS;oBAC7C,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;wBAChC,IACE,QAAQ,CAAC,IAAI,KAAK,YAAY;4BAC9B,QAAQ,CAAC,aAAa,KAAK,mBAAmB,EAC9C;4BACA,MAAM,UAAU,GAAI,MAAc,CAAC,eAAe,CAAC;4BACnD,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,UAAU,IAAI,MAAM,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;yBACjF;qBACF;iBACF,CAAC,CAAC;gBACH,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC/C,MAAM,UAAU,GAAI,MAAc,CAAC,eAAe,CAAC;gBACnD,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,UAAU,IAAI,MAAM,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;gBAChF,MAAM;aACP;YACD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;SAC/B;KACF;IAEO,qBAAqB;QAC3B,IAAI,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;QACrC,OAAO,MAAM,EAAE;YACb,IAAI,MAAM,CAAC,OAAO,KAAK,eAAe,IAAI,MAAM,CAAC,YAAY,CAAC,uBAAuB,CAAC,EAAE;gBACtF,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,SAAS;oBAC7C,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;wBAChC,IACE,QAAQ,CAAC,IAAI,KAAK,YAAY;4BAC9B,QAAQ,CAAC,aAAa,KAAK,uBAAuB,EAClD;4BACA,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,YAAY,CAAC,uBAAuB,CAAC,CAAC;yBACpE;qBACF;iBACF,CAAC,CAAC;gBACH,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC/C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,YAAY,CAAC,uBAAuB,CAAC,CAAC;gBACnE,MAAM;aACP;YACD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;SAC/B;KACF;IAEO,cAAc;QACpB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC;QACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;QAClD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACvC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;KAC7D;IAEO,mBAAmB;QACzB,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,6BAA6B,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;KACnF;IAoBO,MAAM,gBAAgB,CAAC,OAAgB;QAC7C,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,YAAY,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAC;QACjE,MAAM,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;QACxC,IAAI,CAAC,iBAAiB,EAAE,CAAC;KAC1B;IAGD,oBAAoB,CAAC,QAAiB;QACpC,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KACjD;IAGD,uBAAuB,CAAC,QAAiB;QACvC,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KAClD;IAEO,YAAY,CAAC,KAAgB;QACnC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC;YACnC,OAAO,EAAE,IAAI,CAAC,SAAS;YACvB,aAAa,EAAE,IAAI,CAAC,cAAc;SACnC,CAAC,CAAC;KACJ;IAEO,MAAM,mBAAmB,CAAC,OAAgB;QAChD,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACrC,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE;YAC5B,MAAO,KAAoC,CAAC,gBAAgB,EAAE,CAAC;YAC/D,KAAK,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,6BAA6B,EAAE;gBACjE,MAAM,EAAE,EAAE,OAAO,EAAE;gBACnB,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE,IAAI;aACf,CAAC,CAAC,CAAC;SACL;KACF;IAEO,gBAAgB,CAAC,MAAmB;QAC1C,MAAM,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC;QACtC,IAAI,CAAC,QAAQ;YAAE,OAAO,EAAE,CAAC;QACzB,OAAO,KAAK,CAAC,IAAI,CACf,QAAQ,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAChD,CAAC,GAAG,CAAC,EAAE,IAAI,EAAgC,CAAC,CAAC;KAC/C;IAEO,iBAAiB;;QACvB,MAAM,MAAM,GAAG,MAAA,IAAI,CAAC,IAAI,CAAC,aAAa,0CAAE,OAAO,CAAC,oBAAoB,CAA+B,CAAC;QACpG,IAAI,CAAC,MAAM;YAAE,OAAO;QACpB,MAAM,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAC,QAAQ;YACrC,MAAM,UAAU,GAAG,QAAmC,CAAC;YACvD,IAAI,EAAC,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,iBAAiB,CAAA;gBAAE,OAAO;YAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,CAAC;YACrD,UAAU,CAAC,YAAY,CAAC;gBACtB,SAAS,EAAE,MAAM,CAAC,UAAU;gBAC5B,cAAc,EAAE,CAAC,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,WAAW;aACzD,CAAC,CAAC;YACH,UAAU,CAAC,iBAAiB,EAAE,CAAC;SAChC,CAAC,CAAC;KACJ;IAEO,sBAAsB,CAAC,QAAsC;QACnE,OAAO;YACL,UAAU,EAAE,QAAQ,CAAC,KAAK,CAAC,GAAG,IAAK,GAA+B,CAAC,SAAS,CAAC;YAC7E,WAAW,EAAE,QAAQ,CAAC,IAAI,CAAC,GAAG;gBAC5B,MAAM,IAAI,GAAG,GAA8B,CAAC;gBAC5C,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,cAAc,CAAC;aAC9C,CAAC;SACH,CAAC;KACH;IA6FD,MAAM;QACJ,QACE,4DACE,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI;gBACjB,qBAAqB,EAAE,IAAI,CAAC,UAAU;gBACtC,yBAAyB,EAAE,IAAI,CAAC,WAAW;gBAC3C,qBAAqB,EAAE,IAAI,CAAC,QAAQ;aACrC,EACD,IAAI,EAAC,UAAU,mBACA,IAAI,CAAC,UAAU,GAAG,MAAM,GAAG,OAAO,gBACrC,IAAI,CAAC,KAAK,mBACP,IAAI,CAAC,QAAQ,GAAG,MAAM,GAAG,SAAS,gBACrC,IAAI,CAAC,SAAS,IAE1B,4DAAK,KAAK,EAAC,oBAAoB,IAC5B,IAAI,CAAC,cAAc,EAAE,EACrB,IAAI,CAAC,YAAY,EAAE,CAChB,EACL,IAAI,CAAC,UAAU,IAAI,4DAAK,KAAK,EAAC,qBAAqB,IAAC,8DAAO,CAAM,CAC9D,EACN;KACH;IAEO,YAAY;QAClB,QACE,WACE,KAAK,EAAC,mBAAmB,EACzB,KAAK,EAAE,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EACnD,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAC/B,QAAQ,EAAE,CAAC,CAAC,mBACG,IAAI,CAAC,QAAQ,GAAG,MAAM,GAAG,SAAS,IAEhD,IAAI,CAAC,cAAc,EAAE,CAClB,EACN;KACH;IAEO,cAAc;QACpB,QACE,WAAK,KAAK,EAAC,+BAA+B,EAAC,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC,eAAe,EAAE,IAC1E,oBACE,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,IAAI,CAAC,SAAS,EACvB,aAAa,EAAE,IAAI,CAAC,cAAc,EAClC,WAAW,EAAE,IAAI,CAAC,oBAAoB,EACtC,QAAQ,EAAE,IAAI,CAAC,QAAQ,GACvB,CACE,EACN;KACH;IAEO,cAAc;QACpB,OAAO;YACL,IAAI,CAAC,WAAW,KACd,WAAK,KAAK,EAAC,8BAA8B,EAAC,OAAO,EAAE,IAAI,CAAC,YAAY,IAClE,gBAAU,KAAK,EAAE,sBAAsB,IAAI,CAAC,UAAU,GAAG,cAAc,GAAG,eAAe,EAAE,EACjF,IAAI,EAAC,kBAAkB,GAAE,EACnC,WAAK,KAAK,EAAC,iBAAiB,GAAE,CAC1B,CACP;YACD,WACE,KAAK,EAAC,iCAAiC,EACvC,QAAQ,EAAE,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,EAChC,SAAS,EAAE,IAAI,CAAC,aAAa,IAE7B,WAAK,KAAK,EAAC,2BAA2B,IAElC,IAAI,CAAC,WAAW,IACd,EAAC,QAAQ,QACP,gBAAU,KAAK,EAAE,EAAC,cAAc,EAAE,IAAI,CAAC,UAAU,EAAC,EAAE,IAAI,EAAC,WAAW,GAAE,EACtE,gBAAU,KAAK,EAAE,EAAC,cAAc,EAAE,CAAC,IAAI,CAAC,UAAU,EAAC,EAAE,IAAI,EAAC,gBAAgB,GAAE,CACnE,KAEX,gBAAU,IAAI,EAAC,SAAS,GAAE,CAC3B,CAEC,EACN,YAAM,KAAK,EAAC,kBAAkB,IAAE,IAAI,CAAC,KAAK,CAAQ,CAC9C;SACP,CAAC;KACH;;;;;;;;;;;","names":[],"sources":["src/components/tree-view/tree-view-item.scss?tag=ifx-tree-view-item&encapsulation=shadow","src/components/tree-view/tree-view-item.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n.tree-item {\n position: relative;\n cursor: pointer;\n list-style: none;\n\n &.tree-item--expanded {\n position: relative;\n }\n\n &.tree-item--has-children {\n position: relative;\n\n .tree-item__header > .tree-item__chevron-container {\n display: flex;\n }\n\n &.tree-item--expanded {\n .tree-item__header > .tree-item__chevron-container::after {\n display: block;\n }\n }\n }\n\n &--disabled {\n cursor: not-allowed;\n pointer-events: none;\n color: tokens.$ifxColorEngineering300;\n }\n\n &__content {\n display: flex;\n flex-direction: row;\n\n &:hover {\n .tree-item__checkbox-container,\n .tree-item__header {\n background-color: tokens.$ifxColorEngineering100;\n }\n }\n }\n\n &__checkbox-container {\n position: sticky;\n left: 0;\n z-index: 10;\n padding: tokens.$ifxSpace50;\n background-color: tokens.$ifxColorBaseWhite;\n }\n\n &__header {\n flex-grow: 1;\n display: flex;\n align-items: center;\n white-space: nowrap;\n height: tokens.$ifxSize250;\n padding-top: tokens.$ifxSpace50;\n padding-right: tokens.$ifxSpace200;\n padding-bottom: tokens.$ifxSpace50;\n padding-left: tokens.$ifxSpace100;\n }\n\n &__chevron-container {\n display: none;\n align-items: center;\n margin-right: tokens.$ifxSpace100;\n height: tokens.$ifxSize250;\n\n &::after {\n --height-line-start: 28px;\n\n display: none;\n content: '';\n position: absolute;\n z-index: 1;\n top: var(--height-line-start);\n left: auto;\n margin-left: tokens.$ifxSpace100;\n width: tokens.$ifxSize12;\n height: calc(100% - var(--height-line-start));\n background-color: tokens.$ifxColorEngineering200;\n\n .tree-item--disabled & {\n color: tokens.$ifxColorEngineering200;\n }\n }\n }\n\n &__chevron {\n &.chevron-down {\n transform: rotate(90deg);\n }\n\n &.chevron-right {\n transform: rotate(0);\n }\n }\n\n &__label-icon-container {\n display: flex;\n align-items: center;\n\n &:focus {\n outline: none;\n }\n\n &:focus-visible {\n outline: 2px solid tokens.$ifxColorOcean500;\n outline-offset: 2px;\n border-radius: tokens.$ifxBorderRadius12;\n }\n }\n\n &__icon-container {\n position: relative;\n width: tokens.$ifxSize200;\n height: tokens.$ifxSize200;\n\n ifx-icon {\n position: absolute;\n left: 0;\n top: 0;\n opacity: 1;\n transition: opacity 0.2s ease-in-out;\n\n &.icon--hidden {\n opacity: 0;\n }\n }\n }\n\n &__label {\n padding-left: tokens.$ifxSpace100;\n }\n\n &__children {\n display: none;\n\n .tree-item[aria-expanded=\"true\"] > & {\n display: block;\n }\n }\n}\n\n","import { Component, h, Prop, State, Element, Fragment, Event, EventEmitter, Watch } from '@stencil/core';\n\ninterface TreeState {\n isChecked: boolean;\n partialChecked: boolean;\n}\n\ntype HTMLIfxTreeViewItemElement = HTMLElement & { componentOnReady: () => Promise<unknown> };\n\n@Component({\n tag: 'ifx-tree-view-item',\n styleUrl: 'tree-view-item.scss',\n shadow: true,\n})\nexport class TreeViewItem {\n @Element() host: HTMLElement;\n @Prop() label: string;\n @Prop({ reflect: true, mutable: true }) expanded: boolean = false;\n @Prop() initiallyExpanded: boolean = false;\n @Prop() disableItem: boolean = false;\n @Prop() ariaLabel: string | null;\n\n @Event() ifxTreeViewItemExpandChange: EventEmitter<boolean>;\n @Event() ifxTreeViewItemCheckChange: EventEmitter<{ checked: boolean; indeterminate: boolean }>;\n @Event() ifxTreeViewItemDisableChange: EventEmitter<boolean>;\n\n @State() private hasChildren: boolean = false;\n @State() private isChecked: boolean = false;\n @State() private partialChecked: boolean = false;\n @State() private level: number = 0;\n @State() private disableAllItems: boolean = false;\n @State() private expandAllItems: boolean = false;\n\n private get disabled() {\n return this.disableAllItems || this.disableItem;\n }\n\n private get isExpanded() {\n return this.expandAllItems || this.expanded;\n }\n\n private findChildren = () => Array.from(this.host.children)\n .filter((child): child is HTMLElement =>\n child instanceof HTMLElement && child.tagName === 'IFX-TREE-VIEW-ITEM'\n );\n\n private calculateNodeLevel = (): number => {\n let level = 0, parent = this.host.parentElement;\n while (parent) {\n if (parent.tagName === 'IFX-TREE-VIEW-ITEM') level++;\n parent = parent.parentElement;\n }\n return level;\n };\n\n componentWillLoad() {\n this.initializeNode();\n this.setupEventListeners();\n }\n\n componentDidLoad() {\n this.observeDisableAllItems();\n this.observeExpandAllItems();\n if (this.shouldExpandFromParent()) {\n this.expandAllDescendants();\n }\n }\n\n private shouldExpandFromParent(): boolean {\n let parent = this.host.parentElement;\n while (parent) {\n if (\n parent.tagName === 'IFX-TREE-VIEW' &&\n (parent.hasAttribute('expand-all-items') || parent.hasAttribute('data-expand-all-items'))\n ) {\n return true;\n }\n parent = parent.parentElement;\n }\n return false;\n }\n\n private expandAllDescendants() {\n this.expanded = true;\n const children = this.findChildren();\n for (const child of children) {\n if (typeof (child as any).expanded !== 'undefined') {\n (child as any).expanded = true;\n }\n if (typeof (child as any).expandAllDescendants === 'function') {\n (child as any).expandAllDescendants();\n }\n }\n }\n\n private observeDisableAllItems() {\n let parent = this.host.parentElement;\n while (parent) {\n if (parent.tagName === 'IFX-TREE-VIEW') {\n const observer = new MutationObserver(mutations => {\n for (const mutation of mutations) {\n if (\n mutation.type === 'attributes' &&\n mutation.attributeName === 'disable-all-items'\n ) {\n const disableAll = (parent as any).disableAllItems;\n this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');\n }\n }\n });\n observer.observe(parent, { attributes: true });\n const disableAll = (parent as any).disableAllItems;\n this.disableAllItems = !!disableAll || parent.hasAttribute('disable-all-items');\n break;\n }\n parent = parent.parentElement;\n }\n }\n\n private observeExpandAllItems() {\n let parent = this.host.parentElement;\n while (parent) {\n if (parent.tagName === 'IFX-TREE-VIEW' || parent.hasAttribute('data-expand-all-items')) {\n const observer = new MutationObserver(mutations => {\n for (const mutation of mutations) {\n if (\n mutation.type === 'attributes' &&\n mutation.attributeName === 'data-expand-all-items'\n ) {\n this.expandAllItems = parent.hasAttribute('data-expand-all-items');\n }\n }\n });\n observer.observe(parent, { attributes: true });\n this.expandAllItems = parent.hasAttribute('data-expand-all-items');\n break;\n }\n parent = parent.parentElement;\n }\n }\n\n private initializeNode() {\n this.expanded = this.initiallyExpanded;\n this.hasChildren = this.findChildren().length > 0;\n this.level = this.calculateNodeLevel();\n this.host.setAttribute('data-level', this.level.toString());\n }\n\n private setupEventListeners() {\n this.host.addEventListener('internal-check-state-change', this.handleStateChange);\n }\n\n private handleStateChange = (event: CustomEvent) => {\n if (this.disabled) return;\n event.stopPropagation();\n this.updateCheckState(event.detail.checked);\n };\n\n private handleCheckboxChange = (event: CustomEvent) => {\n if (this.disabled) return;\n this.updateCheckState(event.detail?.checked ?? !this.isChecked);\n };\n\n private handleHeaderClick = ({ target }: MouseEvent) => {\n if (this.disabled) return;\n if (!(target as HTMLElement).closest('.tree-item__checkbox-container, .tree-item__chevron-container')) {\n this.updateCheckState(!this.isChecked);\n }\n };\n\n private async updateCheckState(checked: boolean) {\n if (this.disabled) return;\n this.setNodeState({ isChecked: checked, partialChecked: false });\n await this.updateChildrenState(checked);\n this.updateParentState();\n }\n\n @Watch('expanded')\n handleExpandedChange(newValue: boolean) {\n this.ifxTreeViewItemExpandChange.emit(newValue);\n }\n\n @Watch('disableItem')\n handleDisableItemChange(newValue: boolean) {\n this.ifxTreeViewItemDisableChange.emit(newValue);\n }\n\n private setNodeState(state: TreeState) {\n this.isChecked = state.isChecked;\n this.partialChecked = state.partialChecked;\n this.ifxTreeViewItemCheckChange.emit({\n checked: this.isChecked,\n indeterminate: this.partialChecked,\n });\n }\n\n private async updateChildrenState(checked: boolean) {\n const children = this.findChildren();\n for (const child of children) {\n await (child as HTMLIfxTreeViewItemElement).componentOnReady();\n child.dispatchEvent(new CustomEvent('internal-check-state-change', {\n detail: { checked },\n bubbles: false,\n composed: true\n }));\n }\n }\n\n private findSiblingNodes(parent: HTMLElement): HTMLIfxTreeViewItemElement[] {\n const parentEl = parent.parentElement;\n if (!parentEl) return [];\n return Array.from(\n parentEl.querySelectorAll('ifx-tree-view-item')\n ).map(el => el as HTMLIfxTreeViewItemElement);\n }\n\n private updateParentState() {\n const parent = this.host.parentElement?.closest('ifx-tree-view-item') as HTMLIfxTreeViewItemElement;\n if (!parent) return;\n parent.componentOnReady().then(resolved => {\n const parentNode = resolved as unknown as TreeViewItem;\n if (!parentNode?.updateParentState) return;\n const siblings = this.findSiblingNodes(parent);\n const states = this.calculateSiblingStates(siblings);\n parentNode.setNodeState({\n isChecked: states.allChecked,\n partialChecked: !states.allChecked && states.someChecked\n });\n parentNode.updateParentState();\n });\n }\n\n private calculateSiblingStates(siblings: HTMLIfxTreeViewItemElement[]) {\n return {\n allChecked: siblings.every(sib => (sib as unknown as TreeViewItem).isChecked),\n someChecked: siblings.some(sib => {\n const node = sib as unknown as TreeViewItem;\n return node.isChecked || node.partialChecked;\n })\n };\n }\n\n private toggleExpand = () => {\n if (this.disabled) return;\n this.hasChildren && (this.expanded = !this.expanded);\n };\n\n private handleKeyDown = (event: KeyboardEvent) => {\n\n const allItems = Array.from(\n this.host\n .closest('ifx-tree-view')\n ?.querySelectorAll('ifx-tree-view-item') || []\n );\n\n const visibleItems = allItems.filter(item => {\n let parent = item.parentElement?.closest('ifx-tree-view-item');\n while (parent) {\n const parentCmp = parent as any;\n if (!(parentCmp.expandAllItems || parentCmp.expanded)) {\n return false;\n }\n parent = parent.parentElement?.closest('ifx-tree-view-item');\n }\n return true;\n });\n\n const currentIndex = visibleItems.findIndex(el => el === this.host);\n\n function focusLabelIcon(el: Element | null) {\n (el as HTMLElement | null)?.focus();\n }\n\n switch (event.key) {\n case 'ArrowDown': {\n event.preventDefault();\n let nextIndex = currentIndex + 1;\n while (nextIndex < visibleItems.length) {\n const next = visibleItems[nextIndex] as any;\n if (!next.disabled) {\n focusLabelIcon(next.shadowRoot?.querySelector('.tree-item__label-icon-container'));\n break;\n }\n nextIndex++;\n }\n break;\n }\n case 'ArrowUp': {\n event.preventDefault();\n let prevIndex = currentIndex - 1;\n while (prevIndex >= 0) {\n const prev = visibleItems[prevIndex] as any;\n if (!prev.disabled) {\n focusLabelIcon(prev.shadowRoot?.querySelector('.tree-item__label-icon-container'));\n break;\n }\n prevIndex--;\n }\n break;\n }\n case 'ArrowRight': {\n event.preventDefault();\n if (!this.isExpanded && this.hasChildren) {\n this.expanded = true;\n } else if (this.isExpanded && this.hasChildren) {\n const firstChild = this.host.querySelector('ifx-tree-view-item');\n if (firstChild && !(firstChild as any).disabled) {\n focusLabelIcon((firstChild as HTMLElement).shadowRoot?.querySelector('.tree-item__label-icon-container'));\n }\n }\n break;\n }\n case 'ArrowLeft': {\n event.preventDefault();\n if (this.isExpanded && this.hasChildren) {\n this.expanded = false;\n } else {\n const parent = this.host.parentElement?.closest('ifx-tree-view-item');\n if (parent && !(parent as any).disabled) {\n focusLabelIcon((parent as HTMLElement).shadowRoot?.querySelector('.tree-item__label-icon-container'));\n }\n }\n break;\n }\n case ' ':\n case 'Enter': {\n event.preventDefault();\n this.updateCheckState(!this.isChecked);\n break;\n }\n }\n };\n\n render() {\n return (\n <div\n class={{\n 'tree-item': true,\n 'tree-item--expanded': this.isExpanded,\n 'tree-item--has-children': this.hasChildren,\n 'tree-item--disabled': this.disabled,\n }}\n role=\"treeitem\"\n aria-expanded={this.isExpanded ? 'true' : 'false'}\n data-level={this.level}\n aria-disabled={this.disabled ? 'true' : undefined}\n aria-label={this.ariaLabel}\n >\n <div class=\"tree-item__content\">\n {this.renderCheckbox()}\n {this.renderHeader()}\n </div>\n {this.isExpanded && <div class=\"tree-item__children\"><slot/></div>}\n </div>\n );\n }\n\n private renderHeader() {\n return (\n <div\n class=\"tree-item__header\"\n style={{ paddingLeft: `${this.level * 24 + 10}px` }}\n onClick={this.handleHeaderClick}\n tabIndex={-1}\n aria-disabled={this.disabled ? 'true' : undefined}\n >\n {this.renderControls()}\n </div>\n );\n }\n\n private renderCheckbox() {\n return (\n <div class=\"tree-item__checkbox-container\" onClick={e => e.stopPropagation()}>\n <ifx-checkbox\n size='s'\n checked={this.isChecked}\n indeterminate={this.partialChecked}\n onIfxChange={this.handleCheckboxChange}\n disabled={this.disabled}\n />\n </div>\n );\n }\n\n private renderControls() {\n return [\n this.hasChildren && (\n <div class=\"tree-item__chevron-container\" onClick={this.toggleExpand}>\n <ifx-icon class={`tree-item__chevron ${this.isExpanded ? 'chevron-down' : 'chevron-right'}`}\n icon=\"chevron-right-16\"/>\n <div class=\"tree-item__line\"/>\n </div>\n ),\n <div\n class=\"tree-item__label-icon-container\"\n tabIndex={this.disabled ? -1 : 0}\n onKeyDown={this.handleKeyDown}\n >\n <div class=\"tree-item__icon-container\">\n {\n this.hasChildren ? (\n <Fragment>\n <ifx-icon class={{'icon--hidden': this.isExpanded}} icon=\"folder-16\"/>\n <ifx-icon class={{'icon--hidden': !this.isExpanded}} icon=\"folder-open-16\"/>\n </Fragment>\n ) : (\n <ifx-icon icon=\"file-16\"/>\n )\n }\n </div>\n <span class=\"tree-item__label\">{this.label}</span>\n </div>\n ];\n }\n}\n"],"version":3}
|
@@ -1,48 +0,0 @@
|
|
1
|
-
import { r as registerInstance, c as createEvent, h } from './index-6c9eba32.js';
|
2
|
-
|
3
|
-
const treeViewCss = ":host{display:block}.tree-view{font-family:var(--ifx-font-family, sans-serif);font-size:14px;color:var(--ifx-color-text, #1a1a1a);display:flex;flex-wrap:wrap;flex-direction:column;overflow-x:auto;overflow-y:hidden}.tree-view__label{font:600 1.125rem/1.625rem \"Source Sans 3\";margin-bottom:8px}";
|
4
|
-
const IfxTreeViewStyle0 = treeViewCss;
|
5
|
-
|
6
|
-
const TreeView = class {
|
7
|
-
constructor(hostRef) {
|
8
|
-
registerInstance(this, hostRef);
|
9
|
-
this.ifxTreeViewExpandAllChange = createEvent(this, "ifxTreeViewExpandAllChange", 7);
|
10
|
-
this.ifxTreeViewDisableAllChange = createEvent(this, "ifxTreeViewDisableAllChange", 7);
|
11
|
-
this.disableAllItems = false;
|
12
|
-
this.expandAllItems = false;
|
13
|
-
this.handleSlotRef = (el) => {
|
14
|
-
if (el) {
|
15
|
-
if (this.disableAllItems) {
|
16
|
-
el.setAttribute('data-disable-all-items', 'true');
|
17
|
-
}
|
18
|
-
else {
|
19
|
-
el.removeAttribute('data-disable-all-items');
|
20
|
-
}
|
21
|
-
if (this.expandAllItems) {
|
22
|
-
el.setAttribute('data-expand-all-items', 'true');
|
23
|
-
}
|
24
|
-
else {
|
25
|
-
el.removeAttribute('data-expand-all-items');
|
26
|
-
}
|
27
|
-
}
|
28
|
-
};
|
29
|
-
}
|
30
|
-
handleExpandAllItemsChange(newValue) {
|
31
|
-
this.ifxTreeViewExpandAllChange.emit(newValue);
|
32
|
-
}
|
33
|
-
handleDisableAllItemsChange(newValue) {
|
34
|
-
this.ifxTreeViewDisableAllChange.emit(newValue);
|
35
|
-
}
|
36
|
-
render() {
|
37
|
-
return (h("div", { key: 'e4008bca00cc0ed1517a8ca27a64ac94dec0d694', class: `tree-view ${this.disableAllItems ? ' tree-view--disabled' : ''}`, role: "tree", "aria-label": this.ariaLabel }, this.label && this.label.trim() !== '' && h("div", { key: '654d40e84aadd93ff83ec1401fbf99ac46ae06e3', class: "tree-view__label" }, this.label), h("slot", { key: '1a5a28cec9dde5cdfc100ab97cdfe99ffddc886b', ref: this.handleSlotRef })));
|
38
|
-
}
|
39
|
-
static get watchers() { return {
|
40
|
-
"expandAllItems": ["handleExpandAllItemsChange"],
|
41
|
-
"disableAllItems": ["handleDisableAllItemsChange"]
|
42
|
-
}; }
|
43
|
-
};
|
44
|
-
TreeView.style = IfxTreeViewStyle0;
|
45
|
-
|
46
|
-
export { TreeView as ifx_tree_view };
|
47
|
-
|
48
|
-
//# sourceMappingURL=ifx-tree-view.entry.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"file":"ifx-tree-view.entry.js","mappings":";;AAAA,MAAM,WAAW,GAAG,ySAAyS,CAAC;AAC9T,0BAAe,WAAW;;MCMb,QAAQ;IALrB;;;;QAOU,oBAAe,GAAY,KAAK,CAAC;QACjC,mBAAc,GAAY,KAAK,CAAC;QAgBhC,kBAAa,GAAG,CAAC,EAA0B;YACjD,IAAI,EAAE,EAAE;gBACN,IAAI,IAAI,CAAC,eAAe,EAAE;oBACxB,EAAE,CAAC,YAAY,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;iBACnD;qBAAM;oBACL,EAAE,CAAC,eAAe,CAAC,wBAAwB,CAAC,CAAC;iBAC9C;gBACD,IAAI,IAAI,CAAC,cAAc,EAAE;oBACvB,EAAE,CAAC,YAAY,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;iBAClD;qBAAM;oBACL,EAAE,CAAC,eAAe,CAAC,uBAAuB,CAAC,CAAC;iBAC7C;aACF;SACF,CAAC;KAcH;IApCC,0BAA0B,CAAC,QAAiB;QAC1C,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KAChD;IAGD,2BAA2B,CAAC,QAAiB;QAC3C,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;KACjD;IAiBD,MAAM;QACJ,QACE,4DACE,KAAK,EAAE,aAAa,IAAI,CAAC,eAAe,GAAG,sBAAsB,GAAG,EAAE,EAAE,EACxE,IAAI,EAAC,MAAM,gBACC,IAAI,CAAC,SAAS,IAEzB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,4DAAK,KAAK,EAAC,kBAAkB,IAAE,IAAI,CAAC,KAAK,CAAO,EAC3F,6DAAM,GAAG,EAAE,IAAI,CAAC,aAAa,GAAS,CAClC,EACN;KACH;;;;;;;;;;","names":[],"sources":["src/components/tree-view/tree-view.scss?tag=ifx-tree-view&encapsulation=shadow","src/components/tree-view/tree-view.tsx"],"sourcesContent":["@use \"~@infineon/design-system-tokens/dist/tokens\";\n\n:host {\n display: block;\n}\n\n.tree-view {\n font-family: var(--ifx-font-family, sans-serif);\n font-size: 14px;\n color: var(--ifx-color-text, #1a1a1a);\n\n display: flex;\n flex-wrap: wrap;\n flex-direction: column;\n overflow-x: auto;\n overflow-y: hidden;\n\n &__label {\n font: tokens.$ifxHeadingHeading06;\n margin-bottom: tokens.$ifxSpace100;\n }\n}\n","import { Component, h, Prop, Event, EventEmitter, Watch } from '@stencil/core';\n\n@Component({\n tag: 'ifx-tree-view',\n styleUrl: 'tree-view.scss',\n shadow: true,\n})\nexport class TreeView {\n @Prop() label?: string;\n @Prop() disableAllItems: boolean = false;\n @Prop() expandAllItems: boolean = false;\n @Prop() ariaLabel: string | null;\n\n @Event() ifxTreeViewExpandAllChange: EventEmitter<boolean>;\n @Event() ifxTreeViewDisableAllChange: EventEmitter<boolean>;\n\n @Watch('expandAllItems')\n handleExpandAllItemsChange(newValue: boolean) {\n this.ifxTreeViewExpandAllChange.emit(newValue);\n }\n\n @Watch('disableAllItems')\n handleDisableAllItemsChange(newValue: boolean) {\n this.ifxTreeViewDisableAllChange.emit(newValue);\n }\n\n private handleSlotRef = (el: HTMLSlotElement | null) => {\n if (el) {\n if (this.disableAllItems) {\n el.setAttribute('data-disable-all-items', 'true');\n } else {\n el.removeAttribute('data-disable-all-items');\n }\n if (this.expandAllItems) {\n el.setAttribute('data-expand-all-items', 'true');\n } else {\n el.removeAttribute('data-expand-all-items');\n }\n }\n };\n\n render() {\n return (\n <div\n class={`tree-view ${this.disableAllItems ? ' tree-view--disabled' : ''}`}\n role=\"tree\"\n aria-label={this.ariaLabel}\n >\n {this.label && this.label.trim() !== '' && <div class=\"tree-view__label\">{this.label}</div>}\n <slot ref={this.handleSlotRef}></slot>\n </div>\n );\n }\n}\n"],"version":3}
|