@infineon/infineon-design-system-stencil 36.0.0--canary.1926.3384b08beedd4bd0bf0894c709a0e3eb8096602d.0 → 36.0.0--canary.1941.7599a6785f62cbeb62b2525db0089aa1d1f9fc08.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/{icons-2cd72a7d.js → icons-0d4d096d.js} +1 -4
- package/dist/cjs/icons-0d4d096d.js.map +1 -0
- package/dist/cjs/ifx-alert_2.cjs.entry.js +1 -1
- package/dist/cjs/ifx-basic-table.cjs.entry.js +1 -1
- package/dist/cjs/ifx-faq.cjs.entry.js +1 -1
- package/dist/cjs/ifx-filter-accordion.cjs.entry.js +2 -2
- 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-icon.cjs.entry.js +1 -1
- package/dist/cjs/ifx-icons-preview.cjs.entry.js +1 -1
- package/dist/cjs/ifx-list-entry.cjs.entry.js +1 -1
- package/dist/cjs/ifx-multiselect.cjs.entry.js +545 -0
- package/dist/cjs/ifx-multiselect.cjs.entry.js.map +1 -0
- package/dist/cjs/ifx-select.cjs.entry.js +2 -2
- package/dist/cjs/ifx-set-filter.cjs.entry.js +2 -19
- package/dist/cjs/ifx-set-filter.cjs.entry.js.map +1 -1
- package/dist/cjs/ifx-slider.cjs.entry.js +2 -2
- package/dist/cjs/ifx-spinner_2.cjs.entry.js +6 -6
- package/dist/cjs/ifx-status.cjs.entry.js +1 -1
- package/dist/cjs/ifx-step.cjs.entry.js +4 -4
- package/dist/cjs/ifx-stepper.cjs.entry.js +2 -2
- 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 +2 -2
- package/dist/cjs/ifx-tabs.cjs.entry.js +2 -2
- 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 +4 -4
- package/dist/cjs/ifx-tree-view-item.cjs.entry.js +2 -2
- package/dist/cjs/ifx-tree-view.cjs.entry.js +1 -1
- package/dist/cjs/index-7f4df11a.js +14 -14
- package/dist/cjs/infineon-design-system-stencil.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/collection-manifest.json +0 -1
- package/dist/collection/components/breadcrumb/breadcrumb.stories.js +1 -1
- package/dist/collection/components/breadcrumb/breadcrumb.stories.js.map +1 -1
- package/dist/collection/components/select/multi-select/interfaces.js.map +1 -1
- package/dist/collection/components/select/multi-select/multiselect.css +65 -60
- package/dist/collection/components/select/multi-select/multiselect.js +427 -675
- package/dist/collection/components/select/multi-select/multiselect.js.map +1 -1
- package/dist/collection/components/select/multi-select/multiselect.stories.js +135 -439
- package/dist/collection/components/select/multi-select/multiselect.stories.js.map +1 -1
- package/dist/collection/components/select/single-select/select.js +2 -2
- package/dist/collection/components/slider/slider.js +2 -2
- package/dist/collection/components/spinner/spinner.js +2 -2
- package/dist/collection/components/status/status.js +1 -1
- package/dist/collection/components/stepper/step/step.js +4 -4
- package/dist/collection/components/stepper/stepper.js +2 -2
- package/dist/collection/components/switch/switch.js +1 -1
- package/dist/collection/components/table-advanced-version/filter-bar/filter-bar.js +1 -1
- package/dist/collection/components/table-advanced-version/filter-type-group/filter-accordion/filter-accordion.js +2 -2
- package/dist/collection/components/table-advanced-version/filter-type-group/filter-search/filter-search.js +1 -1
- package/dist/collection/components/table-advanced-version/filter-type-group/filter-type-group.js +1 -1
- package/dist/collection/components/table-advanced-version/list/list-entry/list-entry.js +1 -1
- package/dist/collection/components/table-advanced-version/set-filter/setFilter.js +2 -19
- package/dist/collection/components/table-advanced-version/set-filter/setFilter.js.map +1 -1
- package/dist/collection/components/table-advanced-version/table.js +2 -2
- package/dist/collection/components/table-advanced-version/table.stories.js +3 -2
- package/dist/collection/components/table-advanced-version/table.stories.js.map +1 -1
- package/dist/collection/components/table-basic-version/table.js +1 -1
- package/dist/collection/components/tabs/tab.js +1 -1
- package/dist/collection/components/tabs/tabs.js +2 -2
- package/dist/collection/components/tag/tag.js +1 -1
- package/dist/collection/components/templates/template/template.js +1 -1
- package/dist/collection/components/templates/templates-ui/templates-ui.js +1 -1
- package/dist/collection/components/text-field/text-field.js +4 -4
- package/dist/collection/components/textarea/textarea.js +1 -1
- package/dist/collection/components/tooltip/tooltip.js +4 -4
- package/dist/collection/components/tree-view/tree-view-item.js +2 -2
- package/dist/collection/components/tree-view/tree-view.js +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-alert.js +1 -1
- package/dist/components/ifx-basic-table.js +1 -1
- package/dist/components/ifx-breadcrumb-item-label.js +1 -1
- package/dist/components/ifx-checkbox-group.js +1 -1
- 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-date-picker.js +1 -1
- package/dist/components/ifx-dropdown-item.js +1 -1
- package/dist/components/ifx-dropdown-separator.js +1 -29
- package/dist/components/ifx-dropdown-separator.js.map +1 -1
- package/dist/components/ifx-dropdown-trigger-button.js +1 -1
- package/dist/components/ifx-faq.js +3 -3
- package/dist/components/ifx-file-upload.js +2 -2
- package/dist/components/ifx-filter-accordion.js +3 -3
- package/dist/components/ifx-filter-bar.js +2 -2
- package/dist/components/ifx-filter-search.js +3 -3
- package/dist/components/ifx-filter-type-group.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 +3 -3
- package/dist/components/ifx-list-entry.js +3 -3
- package/dist/components/ifx-list.js +1 -1
- package/dist/components/ifx-modal.js +2 -2
- package/dist/components/ifx-multiselect.js +1 -1
- package/dist/components/ifx-navbar-item.js +1 -1
- package/dist/components/ifx-navbar.js +1 -1
- package/dist/components/ifx-notification.js +1 -1
- package/dist/components/ifx-overview-table.js +1 -1
- package/dist/components/ifx-pagination.js +1 -1
- package/dist/components/ifx-radio-button-group.js +1 -1
- package/dist/components/ifx-search-bar.js +2 -2
- package/dist/components/ifx-search-field.js +1 -1
- package/dist/components/ifx-segment.js +1 -1
- package/dist/components/ifx-segmented-control.js +1 -1
- package/dist/components/ifx-select.js +1 -1
- package/dist/components/ifx-set-filter.js +12 -35
- package/dist/components/ifx-set-filter.js.map +1 -1
- package/dist/components/ifx-sidebar-item.js +1 -1
- package/dist/components/ifx-slider.js +3 -3
- package/dist/components/ifx-spinner.js +1 -1
- package/dist/components/ifx-status.js +1 -1
- package/dist/components/ifx-step.js +5 -5
- package/dist/components/ifx-stepper.js +2 -2
- package/dist/components/ifx-switch.js +1 -1
- package/dist/components/ifx-tab.js +1 -1
- package/dist/components/ifx-table.js +9 -9
- package/dist/components/ifx-tabs.js +3 -3
- package/dist/components/ifx-tag.js +2 -2
- package/dist/components/ifx-template.js +1 -1
- package/dist/components/ifx-templates-ui.js +7 -7
- package/dist/components/ifx-text-field.js +1 -1
- package/dist/components/ifx-textarea.js +1 -1
- package/dist/components/ifx-tooltip.js +5 -5
- package/dist/components/ifx-tree-view-item.js +4 -4
- package/dist/components/ifx-tree-view.js +1 -1
- package/dist/components/{p-f2f58eb1.js → p-0c449780.js} +2 -2
- package/dist/components/{p-f2f58eb1.js.map → p-0c449780.js.map} +1 -1
- package/dist/components/{p-b6b0d09b.js → p-186dacc8.js} +2 -2
- package/dist/components/{p-b6b0d09b.js.map → p-186dacc8.js.map} +1 -1
- package/dist/components/{p-34a36730.js → p-2a65d85a.js} +5 -5
- package/dist/components/{p-34a36730.js.map → p-2a65d85a.js.map} +1 -1
- package/dist/components/{p-afd6d4f5.js → p-38396fe7.js} +2 -2
- package/dist/components/{p-afd6d4f5.js.map → p-38396fe7.js.map} +1 -1
- package/dist/components/{p-fe3f24e7.js → p-67573b5f.js} +6 -6
- package/dist/components/{p-fe3f24e7.js.map → p-67573b5f.js.map} +1 -1
- package/dist/components/p-68016aea.js +33 -0
- package/dist/components/p-68016aea.js.map +1 -0
- package/dist/components/{p-20d6a006.js → p-6d12f845.js} +2 -2
- package/dist/components/{p-20d6a006.js.map → p-6d12f845.js.map} +1 -1
- package/dist/components/{p-351949f1.js → p-a4922416.js} +3 -3
- package/dist/components/{p-351949f1.js.map → p-a4922416.js.map} +1 -1
- package/dist/components/{p-b293963f.js → p-a8d0ef73.js} +2 -2
- package/dist/components/{p-b293963f.js.map → p-a8d0ef73.js.map} +1 -1
- package/dist/components/{p-6c0ec65a.js → p-b0039ef1.js} +2 -2
- package/dist/components/{p-6c0ec65a.js.map → p-b0039ef1.js.map} +1 -1
- package/dist/components/{p-12e75dad.js → p-bb4de57d.js} +1 -4
- package/dist/components/p-bb4de57d.js.map +1 -0
- package/dist/components/{p-98c86d16.js → p-c9aec5fa.js} +4 -4
- package/dist/components/{p-98c86d16.js.map → p-c9aec5fa.js.map} +1 -1
- package/dist/components/{p-1bfd69f4.js → p-cc5bd74b.js} +4 -4
- package/dist/components/{p-1bfd69f4.js.map → p-cc5bd74b.js.map} +1 -1
- package/dist/components/p-cd833a9b.js +598 -0
- package/dist/components/p-cd833a9b.js.map +1 -0
- package/dist/components/{p-2a500ed7.js → p-cd913238.js} +3 -3
- package/dist/components/{p-2a500ed7.js.map → p-cd913238.js.map} +1 -1
- package/dist/components/{p-5c96860f.js → p-d1790232.js} +2 -2
- package/dist/components/{p-5c96860f.js.map → p-d1790232.js.map} +1 -1
- package/dist/esm/{icons-75858876.js → icons-788fe290.js} +1 -4
- package/dist/esm/icons-788fe290.js.map +1 -0
- package/dist/esm/ifx-alert_2.entry.js +1 -1
- package/dist/esm/ifx-basic-table.entry.js +1 -1
- package/dist/esm/ifx-faq.entry.js +1 -1
- package/dist/esm/ifx-filter-accordion.entry.js +2 -2
- 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-icon.entry.js +1 -1
- package/dist/esm/ifx-icons-preview.entry.js +1 -1
- package/dist/esm/ifx-list-entry.entry.js +1 -1
- package/dist/esm/ifx-multiselect.entry.js +541 -0
- package/dist/esm/ifx-multiselect.entry.js.map +1 -0
- package/dist/esm/ifx-select.entry.js +2 -2
- package/dist/esm/ifx-set-filter.entry.js +2 -19
- package/dist/esm/ifx-set-filter.entry.js.map +1 -1
- package/dist/esm/ifx-slider.entry.js +2 -2
- package/dist/esm/ifx-spinner_2.entry.js +6 -6
- package/dist/esm/ifx-status.entry.js +1 -1
- package/dist/esm/ifx-step.entry.js +4 -4
- package/dist/esm/ifx-stepper.entry.js +2 -2
- 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 +2 -2
- package/dist/esm/ifx-tabs.entry.js +2 -2
- 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 +4 -4
- package/dist/esm/ifx-tree-view-item.entry.js +2 -2
- package/dist/esm/ifx-tree-view.entry.js +1 -1
- package/dist/esm/index-6c9eba32.js +14 -14
- package/dist/esm/infineon-design-system-stencil.js +1 -1
- package/dist/esm/loader.js +1 -1
- 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-06bfabcf.entry.js +2 -0
- package/dist/infineon-design-system-stencil/{p-76e0c34f.entry.js.map → p-06bfabcf.entry.js.map} +1 -1
- package/dist/infineon-design-system-stencil/{p-3d037fa4.entry.js → p-0f096cf1.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-ad7b58c3.entry.js → p-1048ee19.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-d890b0de.entry.js → p-142878ee.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-4d96fed0.js → p-27d2afb4.js} +2 -2
- package/dist/infineon-design-system-stencil/p-27d2afb4.js.map +1 -0
- package/dist/infineon-design-system-stencil/{p-18a81f5f.entry.js → p-2b38c405.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-34738a10.entry.js +2 -0
- package/dist/infineon-design-system-stencil/p-45ac2698.entry.js +2 -0
- package/dist/infineon-design-system-stencil/p-45ac2698.entry.js.map +1 -0
- package/dist/infineon-design-system-stencil/{p-4d9a4329.entry.js → p-49252616.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-65e57b85.entry.js +2 -0
- package/dist/infineon-design-system-stencil/{p-74bee1c8.entry.js → p-65fe2246.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-7adee2dd.entry.js → p-6d99d01d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-4764665d.entry.js → p-702a48f8.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-b6dd2ac0.entry.js → p-7440ea9d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-c7e86c7c.entry.js → p-7b7ac7fa.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-0c1c831c.entry.js → p-87fbd617.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/p-885adc48.entry.js +2 -0
- package/dist/infineon-design-system-stencil/p-885adc48.entry.js.map +1 -0
- package/dist/infineon-design-system-stencil/{p-aaf08082.entry.js → p-88af2e64.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-13c107bf.entry.js → p-959285a7.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-36dcebde.entry.js → p-a9cfb70d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-6250b9f6.entry.js → p-acf0f4ed.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-02496917.entry.js → p-b637c44c.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-6c2698a3.entry.js → p-babf3f2d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-5e376887.entry.js → p-c2791360.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-a80e321b.entry.js → p-c5a785d7.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-2e7d87ed.entry.js → p-e98d2280.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-5f38cace.entry.js → p-ecc17497.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-5285ca40.entry.js → p-f25f014d.entry.js} +2 -2
- package/dist/infineon-design-system-stencil/{p-04d8ea38.entry.js → p-f2bea855.entry.js} +2 -2
- package/dist/types/components/breadcrumb/breadcrumb.stories.d.ts +1 -1
- package/dist/types/components/select/multi-select/interfaces.d.ts +1 -1
- package/dist/types/components/select/multi-select/multiselect.d.ts +61 -39
- package/dist/types/components/select/multi-select/multiselect.stories.d.ts +30 -219
- package/dist/types/components.d.ts +8 -54
- package/package.json +2 -2
- package/dist/cjs/icons-2cd72a7d.js.map +0 -1
- package/dist/cjs/ifx-multiselect_2.cjs.entry.js +0 -929
- package/dist/cjs/ifx-multiselect_2.cjs.entry.js.map +0 -1
- package/dist/collection/components/select/multi-select/multiselect-option.css +0 -112
- package/dist/collection/components/select/multi-select/multiselect-option.js +0 -505
- package/dist/collection/components/select/multi-select/multiselect-option.js.map +0 -1
- package/dist/components/ifx-multiselect-option.d.ts +0 -11
- package/dist/components/ifx-multiselect-option.js +0 -8
- package/dist/components/ifx-multiselect-option.js.map +0 -1
- package/dist/components/p-12e75dad.js.map +0 -1
- package/dist/components/p-3906f639.js +0 -432
- package/dist/components/p-3906f639.js.map +0 -1
- package/dist/components/p-aedd7be5.js +0 -599
- package/dist/components/p-aedd7be5.js.map +0 -1
- package/dist/esm/icons-75858876.js.map +0 -1
- package/dist/esm/ifx-multiselect_2.entry.js +0 -924
- package/dist/esm/ifx-multiselect_2.entry.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-25204a1e.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-25204a1e.entry.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-4d96fed0.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-6c999b11.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-6c999b11.entry.js.map +0 -1
- package/dist/infineon-design-system-stencil/p-76e0c34f.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-a2a44fbe.entry.js +0 -2
- package/dist/infineon-design-system-stencil/p-e571c002.entry.js +0 -2
- package/dist/types/components/select/multi-select/multiselect-option.d.ts +0 -36
- /package/dist/infineon-design-system-stencil/{p-3d037fa4.entry.js.map → p-0f096cf1.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-ad7b58c3.entry.js.map → p-1048ee19.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-d890b0de.entry.js.map → p-142878ee.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-18a81f5f.entry.js.map → p-2b38c405.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-e571c002.entry.js.map → p-34738a10.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-4d9a4329.entry.js.map → p-49252616.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-a2a44fbe.entry.js.map → p-65e57b85.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-74bee1c8.entry.js.map → p-65fe2246.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-7adee2dd.entry.js.map → p-6d99d01d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-4764665d.entry.js.map → p-702a48f8.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-b6dd2ac0.entry.js.map → p-7440ea9d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-c7e86c7c.entry.js.map → p-7b7ac7fa.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-0c1c831c.entry.js.map → p-87fbd617.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-aaf08082.entry.js.map → p-88af2e64.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-13c107bf.entry.js.map → p-959285a7.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-36dcebde.entry.js.map → p-a9cfb70d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-6250b9f6.entry.js.map → p-acf0f4ed.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-02496917.entry.js.map → p-b637c44c.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-6c2698a3.entry.js.map → p-babf3f2d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-5e376887.entry.js.map → p-c2791360.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-a80e321b.entry.js.map → p-c5a785d7.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-2e7d87ed.entry.js.map → p-e98d2280.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-5f38cace.entry.js.map → p-ecc17497.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-5285ca40.entry.js.map → p-f25f014d.entry.js.map} +0 -0
- /package/dist/infineon-design-system-stencil/{p-04d8ea38.entry.js.map → p-f2bea855.entry.js.map} +0 -0
@@ -1,505 +0,0 @@
|
|
1
|
-
import { h, Host } from "@stencil/core";
|
2
|
-
export class MultiselectOption {
|
3
|
-
constructor() {
|
4
|
-
this.selected = false;
|
5
|
-
this.disabled = false;
|
6
|
-
this.indeterminate = false;
|
7
|
-
this.isExpanded = false;
|
8
|
-
this.hasChildren = false;
|
9
|
-
this.depth = 0;
|
10
|
-
this.searchTerm = '';
|
11
|
-
this.isSearchActive = false;
|
12
|
-
this.isSearchDisabled = false;
|
13
|
-
this.handleSearchFilter = (event) => {
|
14
|
-
const { searchTerm, isActive } = event.detail;
|
15
|
-
this.searchTerm = searchTerm.toLowerCase();
|
16
|
-
this.isSearchActive = isActive;
|
17
|
-
requestAnimationFrame(() => {
|
18
|
-
this.updateSearchClasses();
|
19
|
-
});
|
20
|
-
};
|
21
|
-
this.handleCheckboxClick = (event) => {
|
22
|
-
if (this.disabled || (this.isSearchActive && this.isSearchDisabled))
|
23
|
-
return;
|
24
|
-
event.stopPropagation();
|
25
|
-
let newSelectedState;
|
26
|
-
if (this.indeterminate) {
|
27
|
-
newSelectedState = true;
|
28
|
-
}
|
29
|
-
else {
|
30
|
-
newSelectedState = !this.selected;
|
31
|
-
}
|
32
|
-
this.selected = newSelectedState;
|
33
|
-
this.indeterminate = false;
|
34
|
-
if (this.hasChildren) {
|
35
|
-
this.isExpanded = newSelectedState;
|
36
|
-
requestAnimationFrame(() => {
|
37
|
-
this.selectAllChildren(newSelectedState);
|
38
|
-
this.expandAllChildren(newSelectedState);
|
39
|
-
});
|
40
|
-
}
|
41
|
-
this.updateParentStates();
|
42
|
-
this.notifyMultiselect();
|
43
|
-
};
|
44
|
-
this.handleHeaderClick = (event) => {
|
45
|
-
event.stopPropagation();
|
46
|
-
if (!this.disabled && !(this.isSearchActive && this.isSearchDisabled)) {
|
47
|
-
this.handleClick(event);
|
48
|
-
}
|
49
|
-
};
|
50
|
-
}
|
51
|
-
componentWillLoad() {
|
52
|
-
this.hasChildren = this.el.children.length > 0;
|
53
|
-
this.depth = this.calculateDepth();
|
54
|
-
this.el.setAttribute('data-level', this.depth.toString());
|
55
|
-
if (this.hasChildren) {
|
56
|
-
const hasSelectedChildren = this.hasAnySelectedChildren();
|
57
|
-
if (hasSelectedChildren) {
|
58
|
-
this.isExpanded = true;
|
59
|
-
}
|
60
|
-
}
|
61
|
-
}
|
62
|
-
componentDidLoad() {
|
63
|
-
this.el['__stencil_instance'] = this;
|
64
|
-
this.notifyMultiselect();
|
65
|
-
this.el.addEventListener('ifx-search-filter', this.handleSearchFilter);
|
66
|
-
}
|
67
|
-
disconnectedCallback() {
|
68
|
-
this.el.removeEventListener('ifx-search-filter', this.handleSearchFilter);
|
69
|
-
}
|
70
|
-
updateSearchClasses() {
|
71
|
-
var _a;
|
72
|
-
const optionDiv = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.option');
|
73
|
-
if (!optionDiv)
|
74
|
-
return;
|
75
|
-
if (!this.isSearchActive) {
|
76
|
-
optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');
|
77
|
-
this.removeHighlighting();
|
78
|
-
this.isSearchDisabled = false;
|
79
|
-
return;
|
80
|
-
}
|
81
|
-
const textContent = this.getTextContent().toLowerCase();
|
82
|
-
const matchesSearch = textContent.includes(this.searchTerm);
|
83
|
-
const hasMatchingParent = this.hasMatchingParent();
|
84
|
-
requestAnimationFrame(() => {
|
85
|
-
const hasMatchingChildren = this.hasMatchingChildren();
|
86
|
-
optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');
|
87
|
-
this.isSearchDisabled = false;
|
88
|
-
if (matchesSearch && !this.hasChildren) {
|
89
|
-
optionDiv.classList.add('search-match');
|
90
|
-
this.highlightSearchTerm();
|
91
|
-
}
|
92
|
-
else if (matchesSearch && this.hasChildren) {
|
93
|
-
optionDiv.classList.add('search-match');
|
94
|
-
this.highlightSearchTerm();
|
95
|
-
this.isExpanded = true;
|
96
|
-
}
|
97
|
-
else if (!matchesSearch && this.hasChildren && hasMatchingChildren) {
|
98
|
-
optionDiv.classList.add('search-parent');
|
99
|
-
this.removeHighlighting();
|
100
|
-
this.isExpanded = true;
|
101
|
-
this.isSearchDisabled = true;
|
102
|
-
}
|
103
|
-
else if (hasMatchingParent) {
|
104
|
-
optionDiv.classList.add('search-match');
|
105
|
-
this.removeHighlighting();
|
106
|
-
}
|
107
|
-
else {
|
108
|
-
optionDiv.classList.add('search-hidden');
|
109
|
-
this.removeHighlighting();
|
110
|
-
}
|
111
|
-
});
|
112
|
-
}
|
113
|
-
highlightSearchTerm() {
|
114
|
-
var _a;
|
115
|
-
if (!this.searchTerm)
|
116
|
-
return;
|
117
|
-
const labelElement = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.option-label');
|
118
|
-
if (!labelElement)
|
119
|
-
return;
|
120
|
-
const slotElement = labelElement.querySelector('slot');
|
121
|
-
if (!slotElement)
|
122
|
-
return;
|
123
|
-
this.removeHighlighting();
|
124
|
-
const originalText = this.getTextContent();
|
125
|
-
const searchTermLower = this.searchTerm.toLowerCase();
|
126
|
-
const originalTextLower = originalText.toLowerCase();
|
127
|
-
if (!originalTextLower.includes(searchTermLower))
|
128
|
-
return;
|
129
|
-
const searchIndex = originalTextLower.indexOf(searchTermLower);
|
130
|
-
if (searchIndex === -1)
|
131
|
-
return;
|
132
|
-
const beforeMatch = originalText.substring(0, searchIndex);
|
133
|
-
const matchText = originalText.substring(searchIndex, searchIndex + searchTermLower.length);
|
134
|
-
const afterMatch = originalText.substring(searchIndex + searchTermLower.length);
|
135
|
-
const highlightedContent = document.createElement('span');
|
136
|
-
highlightedContent.className = 'highlighted-text';
|
137
|
-
if (beforeMatch) {
|
138
|
-
highlightedContent.appendChild(document.createTextNode(beforeMatch));
|
139
|
-
}
|
140
|
-
const boldElement = document.createElement('strong');
|
141
|
-
boldElement.className = 'search-highlight';
|
142
|
-
boldElement.textContent = matchText;
|
143
|
-
highlightedContent.appendChild(boldElement);
|
144
|
-
if (afterMatch) {
|
145
|
-
highlightedContent.appendChild(document.createTextNode(afterMatch));
|
146
|
-
}
|
147
|
-
labelElement.setAttribute('data-original-content', 'true');
|
148
|
-
slotElement.style.display = 'none';
|
149
|
-
labelElement.appendChild(highlightedContent);
|
150
|
-
}
|
151
|
-
removeHighlighting() {
|
152
|
-
var _a;
|
153
|
-
const labelElement = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.option-label');
|
154
|
-
if (!labelElement)
|
155
|
-
return;
|
156
|
-
const slotElement = labelElement.querySelector('slot');
|
157
|
-
const highlightedElement = labelElement.querySelector('.highlighted-text');
|
158
|
-
if (highlightedElement) {
|
159
|
-
labelElement.removeChild(highlightedElement);
|
160
|
-
}
|
161
|
-
if (slotElement) {
|
162
|
-
slotElement.style.display = '';
|
163
|
-
}
|
164
|
-
labelElement.removeAttribute('data-original-content');
|
165
|
-
}
|
166
|
-
getTextContent() {
|
167
|
-
let text = '';
|
168
|
-
Array.from(this.el.childNodes).forEach(node => {
|
169
|
-
var _a;
|
170
|
-
if (node.nodeType === Node.TEXT_NODE) {
|
171
|
-
text += ((_a = node.textContent) === null || _a === void 0 ? void 0 : _a.trim()) || '';
|
172
|
-
}
|
173
|
-
});
|
174
|
-
return text || this.value || '';
|
175
|
-
}
|
176
|
-
hasMatchingChildren() {
|
177
|
-
if (!this.hasChildren)
|
178
|
-
return false;
|
179
|
-
const childOptions = Array.from(this.el.children)
|
180
|
-
.filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
|
181
|
-
return childOptions.some(child => {
|
182
|
-
const childInstance = child['__stencil_instance'];
|
183
|
-
if (!childInstance)
|
184
|
-
return false;
|
185
|
-
const childText = childInstance.getTextContent().toLowerCase();
|
186
|
-
const childMatches = childText.includes(this.searchTerm);
|
187
|
-
const grandChildrenMatch = childInstance.hasMatchingChildren();
|
188
|
-
return childMatches || grandChildrenMatch;
|
189
|
-
});
|
190
|
-
}
|
191
|
-
hasMatchingParent() {
|
192
|
-
let parent = this.el.parentElement;
|
193
|
-
while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {
|
194
|
-
const parentInstance = parent['__stencil_instance'];
|
195
|
-
if (parentInstance) {
|
196
|
-
const parentText = parentInstance.getTextContent().toLowerCase();
|
197
|
-
if (parentText.includes(this.searchTerm)) {
|
198
|
-
return true;
|
199
|
-
}
|
200
|
-
}
|
201
|
-
parent = parent.parentElement;
|
202
|
-
}
|
203
|
-
return false;
|
204
|
-
}
|
205
|
-
calculateDepth() {
|
206
|
-
let depth = 0;
|
207
|
-
let parent = this.el.parentElement;
|
208
|
-
while (parent && parent.tagName !== 'IFX-MULTISELECT') {
|
209
|
-
if (parent.tagName === 'IFX-MULTISELECT-OPTION') {
|
210
|
-
depth++;
|
211
|
-
}
|
212
|
-
parent = parent.parentElement;
|
213
|
-
}
|
214
|
-
return depth;
|
215
|
-
}
|
216
|
-
handleClick(event) {
|
217
|
-
if (this.disabled || (this.isSearchActive && this.isSearchDisabled))
|
218
|
-
return;
|
219
|
-
event.stopPropagation();
|
220
|
-
if (event.type === 'click' && event.target.closest('.chevron-wrapper')) {
|
221
|
-
this.toggleExpansion();
|
222
|
-
return;
|
223
|
-
}
|
224
|
-
let newSelectedState;
|
225
|
-
if (this.indeterminate) {
|
226
|
-
newSelectedState = true;
|
227
|
-
}
|
228
|
-
else {
|
229
|
-
newSelectedState = !this.selected;
|
230
|
-
}
|
231
|
-
this.selected = newSelectedState;
|
232
|
-
this.indeterminate = false;
|
233
|
-
if (this.hasChildren) {
|
234
|
-
this.isExpanded = newSelectedState;
|
235
|
-
requestAnimationFrame(() => {
|
236
|
-
this.selectAllChildren(newSelectedState);
|
237
|
-
this.expandAllChildren(newSelectedState);
|
238
|
-
});
|
239
|
-
}
|
240
|
-
this.updateParentStates();
|
241
|
-
this.notifyMultiselect();
|
242
|
-
}
|
243
|
-
handleKeyDown(event) {
|
244
|
-
if (this.disabled || (this.isSearchActive && this.isSearchDisabled))
|
245
|
-
return;
|
246
|
-
const target = event.target;
|
247
|
-
if (target.closest('.chevron-wrapper') || target.closest('.checkbox-wrapper')) {
|
248
|
-
return;
|
249
|
-
}
|
250
|
-
if (event.key !== 'ArrowUp' && event.key !== 'ArrowDown') {
|
251
|
-
event.stopPropagation();
|
252
|
-
}
|
253
|
-
if (event.key === 'ArrowRight' && this.hasChildren) {
|
254
|
-
this.isExpanded = true;
|
255
|
-
}
|
256
|
-
if (event.key === 'ArrowLeft' && this.hasChildren) {
|
257
|
-
this.isExpanded = false;
|
258
|
-
}
|
259
|
-
}
|
260
|
-
notifyMultiselect() {
|
261
|
-
const updateEvent = new CustomEvent('ifx-option-changed', {
|
262
|
-
bubbles: true,
|
263
|
-
detail: {
|
264
|
-
value: this.value,
|
265
|
-
selected: this.selected,
|
266
|
-
indeterminate: this.indeterminate
|
267
|
-
}
|
268
|
-
});
|
269
|
-
this.el.dispatchEvent(updateEvent);
|
270
|
-
}
|
271
|
-
selectAllChildren(selected) {
|
272
|
-
const directChildren = Array.from(this.el.children)
|
273
|
-
.filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
|
274
|
-
directChildren.forEach((child) => {
|
275
|
-
var _a;
|
276
|
-
const childInstance = child['__stencil_instance'];
|
277
|
-
if (childInstance) {
|
278
|
-
childInstance.selected = selected;
|
279
|
-
childInstance.indeterminate = false;
|
280
|
-
if (childInstance.hasChildren) {
|
281
|
-
childInstance.isExpanded = selected;
|
282
|
-
childInstance.selectAllChildren(selected);
|
283
|
-
}
|
284
|
-
(_a = childInstance.notifyMultiselect) === null || _a === void 0 ? void 0 : _a.call(childInstance);
|
285
|
-
}
|
286
|
-
});
|
287
|
-
}
|
288
|
-
expandAllChildren(expanded) {
|
289
|
-
const directChildren = Array.from(this.el.children)
|
290
|
-
.filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
|
291
|
-
directChildren.forEach((child) => {
|
292
|
-
const childInstance = child['__stencil_instance'];
|
293
|
-
if (childInstance && childInstance.hasChildren) {
|
294
|
-
childInstance.isExpanded = expanded;
|
295
|
-
childInstance.expandAllChildren(expanded);
|
296
|
-
}
|
297
|
-
});
|
298
|
-
}
|
299
|
-
updateParentStates() {
|
300
|
-
var _a;
|
301
|
-
let parent = this.el.parentElement;
|
302
|
-
while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {
|
303
|
-
const parentInstance = parent['__stencil_instance'];
|
304
|
-
if (!parentInstance) {
|
305
|
-
parent = parent.parentElement;
|
306
|
-
continue;
|
307
|
-
}
|
308
|
-
const siblings = Array.from(parent.children)
|
309
|
-
.filter(child => child.tagName === 'IFX-MULTISELECT-OPTION')
|
310
|
-
.map(child => child['__stencil_instance'])
|
311
|
-
.filter(instance => instance !== null);
|
312
|
-
const selectedCount = siblings.filter(sibling => sibling.selected).length;
|
313
|
-
const indeterminateCount = siblings.filter(sibling => sibling.indeterminate).length;
|
314
|
-
const totalCount = siblings.length;
|
315
|
-
if (selectedCount === totalCount && indeterminateCount === 0) {
|
316
|
-
parentInstance.selected = true;
|
317
|
-
parentInstance.indeterminate = false;
|
318
|
-
}
|
319
|
-
else if (selectedCount === 0 && indeterminateCount === 0) {
|
320
|
-
parentInstance.selected = false;
|
321
|
-
parentInstance.indeterminate = false;
|
322
|
-
}
|
323
|
-
else {
|
324
|
-
parentInstance.selected = false;
|
325
|
-
parentInstance.indeterminate = true;
|
326
|
-
}
|
327
|
-
(_a = parentInstance.notifyMultiselect) === null || _a === void 0 ? void 0 : _a.call(parentInstance);
|
328
|
-
parent = parent.parentElement;
|
329
|
-
}
|
330
|
-
}
|
331
|
-
toggleExpansion() {
|
332
|
-
this.isExpanded = !this.isExpanded;
|
333
|
-
}
|
334
|
-
hasAnySelectedChildren() {
|
335
|
-
const childOptions = Array.from(this.el.children)
|
336
|
-
.filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
|
337
|
-
return childOptions.some(child => {
|
338
|
-
const hasSelected = child.hasAttribute('selected');
|
339
|
-
const hasSelectedDescendants = this.checkForSelectedDescendants(child);
|
340
|
-
return hasSelected || hasSelectedDescendants;
|
341
|
-
});
|
342
|
-
}
|
343
|
-
checkForSelectedDescendants(element) {
|
344
|
-
const nestedOptions = Array.from(element.children)
|
345
|
-
.filter(child => child.tagName === 'IFX-MULTISELECT-OPTION');
|
346
|
-
return nestedOptions.some(nestedChild => {
|
347
|
-
const isSelected = nestedChild.hasAttribute('selected');
|
348
|
-
const hasSelectedNested = this.checkForSelectedDescendants(nestedChild);
|
349
|
-
return isSelected || hasSelectedNested;
|
350
|
-
});
|
351
|
-
}
|
352
|
-
render() {
|
353
|
-
let isFlatMultiselect = false;
|
354
|
-
const parentMultiselect = this.el.closest('ifx-multiselect');
|
355
|
-
if (parentMultiselect) {
|
356
|
-
const allOptions = Array.from(parentMultiselect.querySelectorAll('ifx-multiselect-option'));
|
357
|
-
isFlatMultiselect = allOptions.every(option => option.children.length === 0);
|
358
|
-
}
|
359
|
-
const basePadding = this.depth * 28 + 16;
|
360
|
-
const additionalPadding = this.hasChildren ? 0 : 28;
|
361
|
-
let totalPadding = basePadding + additionalPadding;
|
362
|
-
const optionItemStyle = isFlatMultiselect ? undefined : { paddingLeft: `${totalPadding}px` };
|
363
|
-
return (h(Host, { key: 'f836f58884e2e57c4c5fb4953f10d5ff4a34c8da' }, h("div", { key: '9eca6e87bb3c21512a051596b1e92931b707e88f', class: {
|
364
|
-
'option': true,
|
365
|
-
'option--has-children': this.hasChildren,
|
366
|
-
'option--expanded': this.isExpanded,
|
367
|
-
'option--disabled': this.disabled,
|
368
|
-
'option--selected': this.selected,
|
369
|
-
}, role: "option", "aria-expanded": this.hasChildren ? (this.isExpanded ? 'true' : 'false') : undefined, "aria-selected": this.selected ? 'true' : 'false', "aria-disabled": this.disabled ? 'true' : 'false', "data-level": this.depth, "data-value": this.value }, h("div", { key: '41d24ef38470f5f7f8aa36daa33b339b7d8079f3', class: "option-item", style: optionItemStyle }, h("div", { key: '27d33336e7d15ccce1703429b70494fe86808214', class: "chevron-wrapper", tabIndex: this.hasChildren ? 0 : -1, role: this.hasChildren ? "button" : undefined, "aria-label": this.hasChildren ? (this.isExpanded ? "Collapse" : "Expand") : undefined, onClick: (e) => { e.stopPropagation(); this.toggleExpansion(); }, onKeyDown: (e) => {
|
370
|
-
if (e.key === 'Enter' || e.key === ' ') {
|
371
|
-
e.preventDefault();
|
372
|
-
e.stopPropagation();
|
373
|
-
this.toggleExpansion();
|
374
|
-
}
|
375
|
-
} }, this.hasChildren && (h("ifx-icon", { key: '68e975b49b4aa9edf564b80644c5a55809185629', class: `chevron ${this.isExpanded ? 'chevron--expanded' : 'chevron--collapsed'}`, icon: "chevron-right-16" }))), h("div", { key: 'f651aefe4cc30db6056331ffaafd8e6ea17039fc', class: "checkbox-wrapper", onClick: (e) => e.stopPropagation() }, h("ifx-checkbox", { key: 'e8cb2c7a75921a81e0321ff22718d9373cb6f437', size: 's', checked: (this.isSearchActive && this.isSearchDisabled) ? false : (this.indeterminate ? false : this.selected), indeterminate: (this.isSearchActive && this.isSearchDisabled) ? false : this.indeterminate, onClick: this.handleCheckboxClick, disabled: this.disabled || (this.isSearchActive && this.isSearchDisabled), onKeyDown: (e) => {
|
376
|
-
if (e.key === 'Enter' || e.key === ' ') {
|
377
|
-
e.preventDefault();
|
378
|
-
e.stopPropagation();
|
379
|
-
this.handleCheckboxClick(e);
|
380
|
-
}
|
381
|
-
} })), h("div", { key: '4f626380753927d4bedca0f78643e6647eff6356', class: "option-label", onClick: this.handleHeaderClick, tabIndex: -1 }, h("slot", { key: '8207d9f952bff231fda0bf0be43e1c567aa6a6da' }))), this.isExpanded && h("div", { key: '930d611f27451ff393d1403386bb6cd6b4a54980', class: "option-children" }, h("slot", { key: '269eb6381257f82b74b888188646559e6881a9d9', name: "children" })))));
|
382
|
-
}
|
383
|
-
static get is() { return "ifx-multiselect-option"; }
|
384
|
-
static get encapsulation() { return "shadow"; }
|
385
|
-
static get originalStyleUrls() {
|
386
|
-
return {
|
387
|
-
"$": ["multiselect-option.scss"]
|
388
|
-
};
|
389
|
-
}
|
390
|
-
static get styleUrls() {
|
391
|
-
return {
|
392
|
-
"$": ["multiselect-option.css"]
|
393
|
-
};
|
394
|
-
}
|
395
|
-
static get properties() {
|
396
|
-
return {
|
397
|
-
"value": {
|
398
|
-
"type": "string",
|
399
|
-
"mutable": false,
|
400
|
-
"complexType": {
|
401
|
-
"original": "string",
|
402
|
-
"resolved": "string",
|
403
|
-
"references": {}
|
404
|
-
},
|
405
|
-
"required": false,
|
406
|
-
"optional": false,
|
407
|
-
"docs": {
|
408
|
-
"tags": [],
|
409
|
-
"text": ""
|
410
|
-
},
|
411
|
-
"getter": false,
|
412
|
-
"setter": false,
|
413
|
-
"attribute": "value",
|
414
|
-
"reflect": false
|
415
|
-
},
|
416
|
-
"selected": {
|
417
|
-
"type": "boolean",
|
418
|
-
"mutable": true,
|
419
|
-
"complexType": {
|
420
|
-
"original": "boolean",
|
421
|
-
"resolved": "boolean",
|
422
|
-
"references": {}
|
423
|
-
},
|
424
|
-
"required": false,
|
425
|
-
"optional": false,
|
426
|
-
"docs": {
|
427
|
-
"tags": [],
|
428
|
-
"text": ""
|
429
|
-
},
|
430
|
-
"getter": false,
|
431
|
-
"setter": false,
|
432
|
-
"attribute": "selected",
|
433
|
-
"reflect": true,
|
434
|
-
"defaultValue": "false"
|
435
|
-
},
|
436
|
-
"disabled": {
|
437
|
-
"type": "boolean",
|
438
|
-
"mutable": true,
|
439
|
-
"complexType": {
|
440
|
-
"original": "boolean",
|
441
|
-
"resolved": "boolean",
|
442
|
-
"references": {}
|
443
|
-
},
|
444
|
-
"required": false,
|
445
|
-
"optional": false,
|
446
|
-
"docs": {
|
447
|
-
"tags": [],
|
448
|
-
"text": ""
|
449
|
-
},
|
450
|
-
"getter": false,
|
451
|
-
"setter": false,
|
452
|
-
"attribute": "disabled",
|
453
|
-
"reflect": true,
|
454
|
-
"defaultValue": "false"
|
455
|
-
},
|
456
|
-
"indeterminate": {
|
457
|
-
"type": "boolean",
|
458
|
-
"mutable": true,
|
459
|
-
"complexType": {
|
460
|
-
"original": "boolean",
|
461
|
-
"resolved": "boolean",
|
462
|
-
"references": {}
|
463
|
-
},
|
464
|
-
"required": false,
|
465
|
-
"optional": false,
|
466
|
-
"docs": {
|
467
|
-
"tags": [],
|
468
|
-
"text": ""
|
469
|
-
},
|
470
|
-
"getter": false,
|
471
|
-
"setter": false,
|
472
|
-
"attribute": "indeterminate",
|
473
|
-
"reflect": true,
|
474
|
-
"defaultValue": "false"
|
475
|
-
}
|
476
|
-
};
|
477
|
-
}
|
478
|
-
static get states() {
|
479
|
-
return {
|
480
|
-
"isExpanded": {},
|
481
|
-
"hasChildren": {},
|
482
|
-
"depth": {},
|
483
|
-
"searchTerm": {},
|
484
|
-
"isSearchActive": {},
|
485
|
-
"isSearchDisabled": {}
|
486
|
-
};
|
487
|
-
}
|
488
|
-
static get elementRef() { return "el"; }
|
489
|
-
static get listeners() {
|
490
|
-
return [{
|
491
|
-
"name": "click",
|
492
|
-
"method": "handleClick",
|
493
|
-
"target": undefined,
|
494
|
-
"capture": false,
|
495
|
-
"passive": false
|
496
|
-
}, {
|
497
|
-
"name": "keydown",
|
498
|
-
"method": "handleKeyDown",
|
499
|
-
"target": undefined,
|
500
|
-
"capture": false,
|
501
|
-
"passive": false
|
502
|
-
}];
|
503
|
-
}
|
504
|
-
}
|
505
|
-
//# sourceMappingURL=multiselect-option.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"multiselect-option.js","sourceRoot":"","sources":["../../../../src/components/select/multi-select/multiselect-option.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Prop, Element, h, Host, State, Listen } from '@stencil/core';\n\n@Component({\n tag: 'ifx-multiselect-option',\n styleUrl: 'multiselect-option.scss',\n shadow: true,\n})\nexport class MultiselectOption {\n @Element() el: HTMLElement;\n\n @Prop() value: string;\n @Prop({ reflect: true, mutable: true }) selected: boolean = false;\n @Prop({ reflect: true, mutable: true }) disabled: boolean = false;\n @Prop({ reflect: true, mutable: true }) indeterminate: boolean = false;\n\n @State() private isExpanded: boolean = false;\n @State() private hasChildren: boolean = false;\n @State() private depth: number = 0;\n @State() private searchTerm: string = '';\n @State() private isSearchActive: boolean = false;\n @State() private isSearchDisabled: boolean = false;\n\n componentWillLoad() {\n this.hasChildren = this.el.children.length > 0;\n this.depth = this.calculateDepth();\n\n this.el.setAttribute('data-level', this.depth.toString());\n\n if (this.hasChildren) {\n const hasSelectedChildren = this.hasAnySelectedChildren();\n if (hasSelectedChildren) {\n this.isExpanded = true;\n }\n }\n }\n\n componentDidLoad() {\n (this.el as any)['__stencil_instance'] = this;\n this.notifyMultiselect();\n this.el.addEventListener('ifx-search-filter', this.handleSearchFilter);\n }\n\n disconnectedCallback() {\n this.el.removeEventListener('ifx-search-filter', this.handleSearchFilter);\n }\n\n private handleSearchFilter = (event: CustomEvent) => {\n const { searchTerm, isActive } = event.detail;\n this.searchTerm = searchTerm.toLowerCase();\n this.isSearchActive = isActive;\n\n requestAnimationFrame(() => {\n this.updateSearchClasses();\n });\n }\n\n private updateSearchClasses() {\n const optionDiv = this.el.shadowRoot?.querySelector('.option');\n if (!optionDiv) return;\n\n if (!this.isSearchActive) {\n optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');\n this.removeHighlighting();\n this.isSearchDisabled = false;\n return;\n }\n\n const textContent = this.getTextContent().toLowerCase();\n const matchesSearch = textContent.includes(this.searchTerm);\n const hasMatchingParent = this.hasMatchingParent();\n\n requestAnimationFrame(() => {\n const hasMatchingChildren = this.hasMatchingChildren();\n\n optionDiv.classList.remove('search-hidden', 'search-parent', 'search-match');\n this.isSearchDisabled = false;\n\n if (matchesSearch && !this.hasChildren) {\n optionDiv.classList.add('search-match');\n this.highlightSearchTerm();\n } else if (matchesSearch && this.hasChildren) {\n optionDiv.classList.add('search-match');\n this.highlightSearchTerm();\n this.isExpanded = true;\n } else if (!matchesSearch && this.hasChildren && hasMatchingChildren) {\n optionDiv.classList.add('search-parent');\n this.removeHighlighting();\n this.isExpanded = true;\n this.isSearchDisabled = true;\n } else if (hasMatchingParent) {\n optionDiv.classList.add('search-match');\n this.removeHighlighting();\n } else {\n optionDiv.classList.add('search-hidden');\n this.removeHighlighting();\n }\n });\n }\n\n private highlightSearchTerm() {\n if (!this.searchTerm) return;\n\n const labelElement = this.el.shadowRoot?.querySelector('.option-label');\n if (!labelElement) return;\n\n const slotElement = labelElement.querySelector('slot');\n if (!slotElement) return;\n\n this.removeHighlighting();\n\n const originalText = this.getTextContent();\n const searchTermLower = this.searchTerm.toLowerCase();\n const originalTextLower = originalText.toLowerCase();\n\n if (!originalTextLower.includes(searchTermLower)) return;\n\n const searchIndex = originalTextLower.indexOf(searchTermLower);\n\n if (searchIndex === -1) return;\n\n const beforeMatch = originalText.substring(0, searchIndex);\n const matchText = originalText.substring(searchIndex, searchIndex + searchTermLower.length);\n const afterMatch = originalText.substring(searchIndex + searchTermLower.length);\n\n const highlightedContent = document.createElement('span');\n highlightedContent.className = 'highlighted-text';\n\n if (beforeMatch) {\n highlightedContent.appendChild(document.createTextNode(beforeMatch));\n }\n\n const boldElement = document.createElement('strong');\n boldElement.className = 'search-highlight';\n boldElement.textContent = matchText;\n highlightedContent.appendChild(boldElement);\n\n if (afterMatch) {\n highlightedContent.appendChild(document.createTextNode(afterMatch));\n }\n\n labelElement.setAttribute('data-original-content', 'true');\n slotElement.style.display = 'none';\n labelElement.appendChild(highlightedContent);\n }\n\n private removeHighlighting() {\n const labelElement = this.el.shadowRoot?.querySelector('.option-label');\n if (!labelElement) return;\n\n const slotElement = labelElement.querySelector('slot');\n const highlightedElement = labelElement.querySelector('.highlighted-text');\n\n if (highlightedElement) {\n labelElement.removeChild(highlightedElement);\n }\n\n if (slotElement) {\n slotElement.style.display = '';\n }\n\n labelElement.removeAttribute('data-original-content');\n }\n\n private getTextContent(): string {\n let text = '';\n Array.from(this.el.childNodes).forEach(node => {\n if (node.nodeType === Node.TEXT_NODE) {\n text += node.textContent?.trim() || '';\n }\n });\n return text || this.value || '';\n }\n\n private hasMatchingChildren(): boolean {\n if (!this.hasChildren) return false;\n\n const childOptions = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as HTMLElement[];\n\n return childOptions.some(child => {\n const childInstance = (child as any)['__stencil_instance'];\n if (!childInstance) return false;\n\n const childText = childInstance.getTextContent().toLowerCase();\n const childMatches = childText.includes(this.searchTerm);\n const grandChildrenMatch = childInstance.hasMatchingChildren();\n\n return childMatches || grandChildrenMatch;\n });\n }\n\n private hasMatchingParent(): boolean {\n let parent = this.el.parentElement;\n while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {\n const parentInstance = (parent as any)['__stencil_instance'];\n if (parentInstance) {\n const parentText = parentInstance.getTextContent().toLowerCase();\n if (parentText.includes(this.searchTerm)) {\n return true;\n }\n }\n parent = parent.parentElement;\n }\n return false;\n }\n\n private calculateDepth(): number {\n let depth = 0;\n let parent = this.el.parentElement;\n while (parent && parent.tagName !== 'IFX-MULTISELECT') {\n if (parent.tagName === 'IFX-MULTISELECT-OPTION') {\n depth++;\n }\n parent = parent.parentElement;\n }\n return depth;\n }\n\n @Listen('click')\n handleClick(event: Event) {\n if (this.disabled || (this.isSearchActive && this.isSearchDisabled)) return;\n\n event.stopPropagation();\n\n if (event.type === 'click' && (event.target as HTMLElement).closest('.chevron-wrapper')) {\n this.toggleExpansion();\n return;\n }\n\n let newSelectedState: boolean;\n\n if (this.indeterminate) {\n newSelectedState = true;\n } else {\n newSelectedState = !this.selected;\n }\n\n this.selected = newSelectedState;\n this.indeterminate = false;\n\n if (this.hasChildren) {\n this.isExpanded = newSelectedState;\n\n requestAnimationFrame(() => {\n this.selectAllChildren(newSelectedState);\n this.expandAllChildren(newSelectedState);\n });\n }\n\n this.updateParentStates();\n this.notifyMultiselect();\n }\n\n @Listen('keydown')\n handleKeyDown(event: KeyboardEvent) {\n if (this.disabled || (this.isSearchActive && this.isSearchDisabled)) return;\n\n const target = event.target as HTMLElement;\n\n if (target.closest('.chevron-wrapper') || target.closest('.checkbox-wrapper')) {\n return;\n }\n\n if (event.key !== 'ArrowUp' && event.key !== 'ArrowDown') {\n event.stopPropagation();\n }\n\n if (event.key === 'ArrowRight' && this.hasChildren) {\n this.isExpanded = true;\n }\n\n if (event.key === 'ArrowLeft' && this.hasChildren) {\n this.isExpanded = false;\n }\n }\n\n private notifyMultiselect() {\n const updateEvent = new CustomEvent('ifx-option-changed', {\n bubbles: true,\n detail: {\n value: this.value,\n selected: this.selected,\n indeterminate: this.indeterminate\n }\n });\n this.el.dispatchEvent(updateEvent);\n }\n\n private selectAllChildren(selected: boolean) {\n const directChildren = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as any[];\n\n directChildren.forEach((child: any) => {\n const childInstance = child['__stencil_instance'];\n if (childInstance) {\n childInstance.selected = selected;\n childInstance.indeterminate = false;\n\n if (childInstance.hasChildren) {\n childInstance.isExpanded = selected;\n childInstance.selectAllChildren(selected);\n }\n childInstance.notifyMultiselect?.();\n }\n });\n }\n\n private expandAllChildren(expanded: boolean) {\n const directChildren = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as any[];\n\n directChildren.forEach((child: any) => {\n const childInstance = child['__stencil_instance'];\n if (childInstance && childInstance.hasChildren) {\n childInstance.isExpanded = expanded;\n childInstance.expandAllChildren(expanded);\n }\n });\n }\n\n private updateParentStates() {\n let parent = this.el.parentElement;\n while (parent && parent.tagName === 'IFX-MULTISELECT-OPTION') {\n const parentInstance = (parent as any)['__stencil_instance'];\n if (!parentInstance) {\n parent = parent.parentElement;\n continue;\n }\n\n const siblings = Array.from(parent.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION')\n .map(child => (child as any)['__stencil_instance'])\n .filter(instance => instance !== null);\n\n const selectedCount = siblings.filter(sibling => sibling.selected).length;\n const indeterminateCount = siblings.filter(sibling => sibling.indeterminate).length;\n const totalCount = siblings.length;\n\n if (selectedCount === totalCount && indeterminateCount === 0) {\n parentInstance.selected = true;\n parentInstance.indeterminate = false;\n } else if (selectedCount === 0 && indeterminateCount === 0) {\n parentInstance.selected = false;\n parentInstance.indeterminate = false;\n } else {\n parentInstance.selected = false;\n parentInstance.indeterminate = true;\n }\n\n parentInstance.notifyMultiselect?.();\n parent = parent.parentElement;\n }\n }\n\n private toggleExpansion() {\n this.isExpanded = !this.isExpanded;\n }\n\n private handleCheckboxClick = (event: Event) => {\n if (this.disabled || (this.isSearchActive && this.isSearchDisabled)) return;\n\n event.stopPropagation();\n\n let newSelectedState: boolean;\n\n if (this.indeterminate) {\n newSelectedState = true;\n } else {\n newSelectedState = !this.selected;\n }\n\n this.selected = newSelectedState;\n this.indeterminate = false;\n\n if (this.hasChildren) {\n this.isExpanded = newSelectedState;\n\n requestAnimationFrame(() => {\n this.selectAllChildren(newSelectedState);\n this.expandAllChildren(newSelectedState);\n });\n }\n\n this.updateParentStates();\n this.notifyMultiselect();\n }\n\n private handleHeaderClick = (event: Event) => {\n event.stopPropagation();\n if (!this.disabled && !(this.isSearchActive && this.isSearchDisabled)) {\n this.handleClick(event);\n }\n }\n\n private hasAnySelectedChildren(): boolean {\n const childOptions = Array.from(this.el.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as HTMLElement[];\n\n return childOptions.some(child => {\n const hasSelected = child.hasAttribute('selected');\n const hasSelectedDescendants = this.checkForSelectedDescendants(child);\n\n return hasSelected || hasSelectedDescendants;\n });\n }\n\n private checkForSelectedDescendants(element: HTMLElement): boolean {\n const nestedOptions = Array.from(element.children)\n .filter(child => child.tagName === 'IFX-MULTISELECT-OPTION') as HTMLElement[];\n\n return nestedOptions.some(nestedChild => {\n const isSelected = nestedChild.hasAttribute('selected');\n const hasSelectedNested = this.checkForSelectedDescendants(nestedChild);\n\n return isSelected || hasSelectedNested;\n });\n }\n\n render() {\n let isFlatMultiselect = false;\n const parentMultiselect = this.el.closest('ifx-multiselect');\n if (parentMultiselect) {\n const allOptions = Array.from(parentMultiselect.querySelectorAll('ifx-multiselect-option'));\n isFlatMultiselect = allOptions.every(option => option.children.length === 0);\n }\n\n const basePadding = this.depth * 28 + 16;\n const additionalPadding = this.hasChildren ? 0 : 28;\n let totalPadding = basePadding + additionalPadding;\n\n const optionItemStyle = isFlatMultiselect ? undefined : { paddingLeft: `${totalPadding}px` };\n\n return (\n <Host>\n <div\n class={{\n 'option': true,\n 'option--has-children': this.hasChildren,\n 'option--expanded': this.isExpanded,\n 'option--disabled': this.disabled,\n 'option--selected': this.selected,\n }}\n role=\"option\"\n aria-expanded={this.hasChildren ? (this.isExpanded ? 'true' : 'false') : undefined}\n aria-selected={this.selected ? 'true' : 'false'}\n aria-disabled={this.disabled ? 'true' : 'false'}\n data-level={this.depth}\n data-value={this.value}\n >\n <div\n class=\"option-item\"\n style={optionItemStyle}\n >\n <div\n class=\"chevron-wrapper\"\n tabIndex={this.hasChildren ? 0 : -1}\n role={this.hasChildren ? \"button\" : undefined}\n aria-label={this.hasChildren ? (this.isExpanded ? \"Collapse\" : \"Expand\") : undefined}\n onClick={(e) => { e.stopPropagation(); this.toggleExpansion(); }}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n this.toggleExpansion();\n }\n }}\n >\n {this.hasChildren && (\n <ifx-icon\n class={`chevron ${this.isExpanded ? 'chevron--expanded' : 'chevron--collapsed'}`}\n icon=\"chevron-right-16\"\n />\n )}\n </div>\n\n <div class=\"checkbox-wrapper\" onClick={(e) => e.stopPropagation()}>\n <ifx-checkbox\n size='s'\n checked={(this.isSearchActive && this.isSearchDisabled) ? false : (this.indeterminate ? false : this.selected)}\n indeterminate={(this.isSearchActive && this.isSearchDisabled) ? false : this.indeterminate}\n onClick={this.handleCheckboxClick}\n disabled={this.disabled || (this.isSearchActive && this.isSearchDisabled)}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n e.stopPropagation();\n this.handleCheckboxClick(e);\n }\n }}\n />\n </div>\n\n <div\n class=\"option-label\"\n onClick={this.handleHeaderClick}\n tabIndex={-1}\n >\n <slot/>\n </div>\n </div>\n\n {this.isExpanded && <div class=\"option-children\"><slot name=\"children\"/></div>}\n </div>\n </Host>\n );\n }\n}\n"]}
|
@@ -1,11 +0,0 @@
|
|
1
|
-
import type { Components, JSX } from "../types/components";
|
2
|
-
|
3
|
-
interface IfxMultiselectOption extends Components.IfxMultiselectOption, HTMLElement {}
|
4
|
-
export const IfxMultiselectOption: {
|
5
|
-
prototype: IfxMultiselectOption;
|
6
|
-
new (): IfxMultiselectOption;
|
7
|
-
};
|
8
|
-
/**
|
9
|
-
* Used to define this component and all nested components recursively.
|
10
|
-
*/
|
11
|
-
export const defineCustomElement: () => void;
|
@@ -1,8 +0,0 @@
|
|
1
|
-
import { M as MultiselectOption, d as defineCustomElement$1 } from './p-3906f639.js';
|
2
|
-
|
3
|
-
const IfxMultiselectOption = MultiselectOption;
|
4
|
-
const defineCustomElement = defineCustomElement$1;
|
5
|
-
|
6
|
-
export { IfxMultiselectOption, defineCustomElement };
|
7
|
-
|
8
|
-
//# sourceMappingURL=ifx-multiselect-option.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"file":"ifx-multiselect-option.js","mappings":";;;;;;;","names":[],"sources":[],"sourcesContent":[],"version":3}
|