primenglab 22.0.0-beta.1
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/LICENSE.md +77 -0
- package/README.md +11 -0
- package/fesm2022/primenglab-accordion.mjs +656 -0
- package/fesm2022/primenglab-accordion.mjs.map +1 -0
- package/fesm2022/primenglab-animateonscroll.mjs +166 -0
- package/fesm2022/primenglab-animateonscroll.mjs.map +1 -0
- package/fesm2022/primenglab-api.mjs +850 -0
- package/fesm2022/primenglab-api.mjs.map +1 -0
- package/fesm2022/primenglab-autocomplete.mjs +2140 -0
- package/fesm2022/primenglab-autocomplete.mjs.map +1 -0
- package/fesm2022/primenglab-autofocus.mjs +78 -0
- package/fesm2022/primenglab-autofocus.mjs.map +1 -0
- package/fesm2022/primenglab-avatar.mjs +211 -0
- package/fesm2022/primenglab-avatar.mjs.map +1 -0
- package/fesm2022/primenglab-avatargroup.mjs +99 -0
- package/fesm2022/primenglab-avatargroup.mjs.map +1 -0
- package/fesm2022/primenglab-badge.mjs +161 -0
- package/fesm2022/primenglab-badge.mjs.map +1 -0
- package/fesm2022/primenglab-base.mjs +124 -0
- package/fesm2022/primenglab-base.mjs.map +1 -0
- package/fesm2022/primenglab-basecomponent.mjs +477 -0
- package/fesm2022/primenglab-basecomponent.mjs.map +1 -0
- package/fesm2022/primenglab-baseeditableholder.mjs +70 -0
- package/fesm2022/primenglab-baseeditableholder.mjs.map +1 -0
- package/fesm2022/primenglab-baseinput.mjs +100 -0
- package/fesm2022/primenglab-baseinput.mjs.map +1 -0
- package/fesm2022/primenglab-basemodelholder.mjs +27 -0
- package/fesm2022/primenglab-basemodelholder.mjs.map +1 -0
- package/fesm2022/primenglab-bind.mjs +97 -0
- package/fesm2022/primenglab-bind.mjs.map +1 -0
- package/fesm2022/primenglab-blockui.mjs +240 -0
- package/fesm2022/primenglab-blockui.mjs.map +1 -0
- package/fesm2022/primenglab-breadcrumb.mjs +582 -0
- package/fesm2022/primenglab-breadcrumb.mjs.map +1 -0
- package/fesm2022/primenglab-button.mjs +799 -0
- package/fesm2022/primenglab-button.mjs.map +1 -0
- package/fesm2022/primenglab-buttongroup.mjs +110 -0
- package/fesm2022/primenglab-buttongroup.mjs.map +1 -0
- package/fesm2022/primenglab-card.mjs +252 -0
- package/fesm2022/primenglab-card.mjs.map +1 -0
- package/fesm2022/primenglab-carousel.mjs +2052 -0
- package/fesm2022/primenglab-carousel.mjs.map +1 -0
- package/fesm2022/primenglab-cascadeselect.mjs +1756 -0
- package/fesm2022/primenglab-cascadeselect.mjs.map +1 -0
- package/fesm2022/primenglab-chart.mjs +235 -0
- package/fesm2022/primenglab-chart.mjs.map +1 -0
- package/fesm2022/primenglab-checkbox.mjs +441 -0
- package/fesm2022/primenglab-checkbox.mjs.map +1 -0
- package/fesm2022/primenglab-chip.mjs +304 -0
- package/fesm2022/primenglab-chip.mjs.map +1 -0
- package/fesm2022/primenglab-classnames.mjs +49 -0
- package/fesm2022/primenglab-classnames.mjs.map +1 -0
- package/fesm2022/primenglab-colorpicker.mjs +741 -0
- package/fesm2022/primenglab-colorpicker.mjs.map +1 -0
- package/fesm2022/primenglab-commandmenu.mjs +419 -0
- package/fesm2022/primenglab-commandmenu.mjs.map +1 -0
- package/fesm2022/primenglab-compare.mjs +520 -0
- package/fesm2022/primenglab-compare.mjs.map +1 -0
- package/fesm2022/primenglab-config.mjs +322 -0
- package/fesm2022/primenglab-config.mjs.map +1 -0
- package/fesm2022/primenglab-confirmdialog.mjs +746 -0
- package/fesm2022/primenglab-confirmdialog.mjs.map +1 -0
- package/fesm2022/primenglab-confirmpopup.mjs +685 -0
- package/fesm2022/primenglab-confirmpopup.mjs.map +1 -0
- package/fesm2022/primenglab-contextmenu.mjs +1485 -0
- package/fesm2022/primenglab-contextmenu.mjs.map +1 -0
- package/fesm2022/primenglab-dataview.mjs +765 -0
- package/fesm2022/primenglab-dataview.mjs.map +1 -0
- package/fesm2022/primenglab-datepicker.mjs +4373 -0
- package/fesm2022/primenglab-datepicker.mjs.map +1 -0
- package/fesm2022/primenglab-dialog.mjs +1234 -0
- package/fesm2022/primenglab-dialog.mjs.map +1 -0
- package/fesm2022/primenglab-divider.mjs +160 -0
- package/fesm2022/primenglab-divider.mjs.map +1 -0
- package/fesm2022/primenglab-dock.mjs +580 -0
- package/fesm2022/primenglab-dock.mjs.map +1 -0
- package/fesm2022/primenglab-dom.mjs +778 -0
- package/fesm2022/primenglab-dom.mjs.map +1 -0
- package/fesm2022/primenglab-dragdrop.mjs +312 -0
- package/fesm2022/primenglab-dragdrop.mjs.map +1 -0
- package/fesm2022/primenglab-drawer.mjs +708 -0
- package/fesm2022/primenglab-drawer.mjs.map +1 -0
- package/fesm2022/primenglab-dynamicdialog.mjs +1096 -0
- package/fesm2022/primenglab-dynamicdialog.mjs.map +1 -0
- package/fesm2022/primenglab-editor.mjs +496 -0
- package/fesm2022/primenglab-editor.mjs.map +1 -0
- package/fesm2022/primenglab-fieldset.mjs +418 -0
- package/fesm2022/primenglab-fieldset.mjs.map +1 -0
- package/fesm2022/primenglab-fileupload.mjs +1486 -0
- package/fesm2022/primenglab-fileupload.mjs.map +1 -0
- package/fesm2022/primenglab-floatlabel.mjs +106 -0
- package/fesm2022/primenglab-floatlabel.mjs.map +1 -0
- package/fesm2022/primenglab-fluid.mjs +89 -0
- package/fesm2022/primenglab-fluid.mjs.map +1 -0
- package/fesm2022/primenglab-focustrap.mjs +113 -0
- package/fesm2022/primenglab-focustrap.mjs.map +1 -0
- package/fesm2022/primenglab-galleria.mjs +1854 -0
- package/fesm2022/primenglab-galleria.mjs.map +1 -0
- package/fesm2022/primenglab-gallery.mjs +1859 -0
- package/fesm2022/primenglab-gallery.mjs.map +1 -0
- package/fesm2022/primenglab-iconfield.mjs +97 -0
- package/fesm2022/primenglab-iconfield.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angledoubledown.mjs +37 -0
- package/fesm2022/primenglab-icons-angledoubledown.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angledoubleleft.mjs +37 -0
- package/fesm2022/primenglab-icons-angledoubleleft.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angledoubleright.mjs +37 -0
- package/fesm2022/primenglab-icons-angledoubleright.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angledoubleup.mjs +37 -0
- package/fesm2022/primenglab-icons-angledoubleup.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angledown.mjs +33 -0
- package/fesm2022/primenglab-icons-angledown.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angleleft.mjs +33 -0
- package/fesm2022/primenglab-icons-angleleft.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angleright.mjs +33 -0
- package/fesm2022/primenglab-icons-angleright.mjs.map +1 -0
- package/fesm2022/primenglab-icons-angleup.mjs +33 -0
- package/fesm2022/primenglab-icons-angleup.mjs.map +1 -0
- package/fesm2022/primenglab-icons-arrowdown.mjs +56 -0
- package/fesm2022/primenglab-icons-arrowdown.mjs.map +1 -0
- package/fesm2022/primenglab-icons-arrowdownleft.mjs +33 -0
- package/fesm2022/primenglab-icons-arrowdownleft.mjs.map +1 -0
- package/fesm2022/primenglab-icons-arrowdownright.mjs +33 -0
- package/fesm2022/primenglab-icons-arrowdownright.mjs.map +1 -0
- package/fesm2022/primenglab-icons-arrowleft.mjs +56 -0
- package/fesm2022/primenglab-icons-arrowleft.mjs.map +1 -0
- package/fesm2022/primenglab-icons-arrowright.mjs +37 -0
- package/fesm2022/primenglab-icons-arrowright.mjs.map +1 -0
- package/fesm2022/primenglab-icons-arrowup.mjs +56 -0
- package/fesm2022/primenglab-icons-arrowup.mjs.map +1 -0
- package/fesm2022/primenglab-icons-ban.mjs +52 -0
- package/fesm2022/primenglab-icons-ban.mjs.map +1 -0
- package/fesm2022/primenglab-icons-bars.mjs +37 -0
- package/fesm2022/primenglab-icons-bars.mjs.map +1 -0
- package/fesm2022/primenglab-icons-baseicon.mjs +103 -0
- package/fesm2022/primenglab-icons-baseicon.mjs.map +1 -0
- package/fesm2022/primenglab-icons-blank.mjs +23 -0
- package/fesm2022/primenglab-icons-blank.mjs.map +1 -0
- package/fesm2022/primenglab-icons-calendar.mjs +33 -0
- package/fesm2022/primenglab-icons-calendar.mjs.map +1 -0
- package/fesm2022/primenglab-icons-caretleft.mjs +33 -0
- package/fesm2022/primenglab-icons-caretleft.mjs.map +1 -0
- package/fesm2022/primenglab-icons-caretright.mjs +33 -0
- package/fesm2022/primenglab-icons-caretright.mjs.map +1 -0
- package/fesm2022/primenglab-icons-check.mjs +33 -0
- package/fesm2022/primenglab-icons-check.mjs.map +1 -0
- package/fesm2022/primenglab-icons-chevrondown.mjs +33 -0
- package/fesm2022/primenglab-icons-chevrondown.mjs.map +1 -0
- package/fesm2022/primenglab-icons-chevronleft.mjs +33 -0
- package/fesm2022/primenglab-icons-chevronleft.mjs.map +1 -0
- package/fesm2022/primenglab-icons-chevronright.mjs +33 -0
- package/fesm2022/primenglab-icons-chevronright.mjs.map +1 -0
- package/fesm2022/primenglab-icons-chevronup.mjs +33 -0
- package/fesm2022/primenglab-icons-chevronup.mjs.map +1 -0
- package/fesm2022/primenglab-icons-exclamationtriangle.mjs +68 -0
- package/fesm2022/primenglab-icons-exclamationtriangle.mjs.map +1 -0
- package/fesm2022/primenglab-icons-eye.mjs +37 -0
- package/fesm2022/primenglab-icons-eye.mjs.map +1 -0
- package/fesm2022/primenglab-icons-eyeslash.mjs +56 -0
- package/fesm2022/primenglab-icons-eyeslash.mjs.map +1 -0
- package/fesm2022/primenglab-icons-filter.mjs +52 -0
- package/fesm2022/primenglab-icons-filter.mjs.map +1 -0
- package/fesm2022/primenglab-icons-filterfill.mjs +33 -0
- package/fesm2022/primenglab-icons-filterfill.mjs.map +1 -0
- package/fesm2022/primenglab-icons-filterslash.mjs +56 -0
- package/fesm2022/primenglab-icons-filterslash.mjs.map +1 -0
- package/fesm2022/primenglab-icons-home.mjs +56 -0
- package/fesm2022/primenglab-icons-home.mjs.map +1 -0
- package/fesm2022/primenglab-icons-infocircle.mjs +56 -0
- package/fesm2022/primenglab-icons-infocircle.mjs.map +1 -0
- package/fesm2022/primenglab-icons-minus.mjs +33 -0
- package/fesm2022/primenglab-icons-minus.mjs.map +1 -0
- package/fesm2022/primenglab-icons-pencil.mjs +52 -0
- package/fesm2022/primenglab-icons-pencil.mjs.map +1 -0
- package/fesm2022/primenglab-icons-plus.mjs +52 -0
- package/fesm2022/primenglab-icons-plus.mjs.map +1 -0
- package/fesm2022/primenglab-icons-refresh.mjs +56 -0
- package/fesm2022/primenglab-icons-refresh.mjs.map +1 -0
- package/fesm2022/primenglab-icons-search.mjs +56 -0
- package/fesm2022/primenglab-icons-search.mjs.map +1 -0
- package/fesm2022/primenglab-icons-searchminus.mjs +56 -0
- package/fesm2022/primenglab-icons-searchminus.mjs.map +1 -0
- package/fesm2022/primenglab-icons-searchplus.mjs +56 -0
- package/fesm2022/primenglab-icons-searchplus.mjs.map +1 -0
- package/fesm2022/primenglab-icons-sortalt.mjs +64 -0
- package/fesm2022/primenglab-icons-sortalt.mjs.map +1 -0
- package/fesm2022/primenglab-icons-sortamountdown.mjs +52 -0
- package/fesm2022/primenglab-icons-sortamountdown.mjs.map +1 -0
- package/fesm2022/primenglab-icons-sortamountupalt.mjs +52 -0
- package/fesm2022/primenglab-icons-sortamountupalt.mjs.map +1 -0
- package/fesm2022/primenglab-icons-spinner.mjs +52 -0
- package/fesm2022/primenglab-icons-spinner.mjs.map +1 -0
- package/fesm2022/primenglab-icons-star.mjs +52 -0
- package/fesm2022/primenglab-icons-star.mjs.map +1 -0
- package/fesm2022/primenglab-icons-starfill.mjs +52 -0
- package/fesm2022/primenglab-icons-starfill.mjs.map +1 -0
- package/fesm2022/primenglab-icons-thlarge.mjs +56 -0
- package/fesm2022/primenglab-icons-thlarge.mjs.map +1 -0
- package/fesm2022/primenglab-icons-times.mjs +33 -0
- package/fesm2022/primenglab-icons-times.mjs.map +1 -0
- package/fesm2022/primenglab-icons-timescircle.mjs +56 -0
- package/fesm2022/primenglab-icons-timescircle.mjs.map +1 -0
- package/fesm2022/primenglab-icons-trash.mjs +56 -0
- package/fesm2022/primenglab-icons-trash.mjs.map +1 -0
- package/fesm2022/primenglab-icons-undo.mjs +56 -0
- package/fesm2022/primenglab-icons-undo.mjs.map +1 -0
- package/fesm2022/primenglab-icons-upload.mjs +56 -0
- package/fesm2022/primenglab-icons-upload.mjs.map +1 -0
- package/fesm2022/primenglab-icons-windowmaximize.mjs +56 -0
- package/fesm2022/primenglab-icons-windowmaximize.mjs.map +1 -0
- package/fesm2022/primenglab-icons-windowminimize.mjs +56 -0
- package/fesm2022/primenglab-icons-windowminimize.mjs.map +1 -0
- package/fesm2022/primenglab-icons.mjs +63 -0
- package/fesm2022/primenglab-icons.mjs.map +1 -0
- package/fesm2022/primenglab-iftalabel.mjs +90 -0
- package/fesm2022/primenglab-iftalabel.mjs.map +1 -0
- package/fesm2022/primenglab-image.mjs +728 -0
- package/fesm2022/primenglab-image.mjs.map +1 -0
- package/fesm2022/primenglab-imagecompare.mjs +177 -0
- package/fesm2022/primenglab-imagecompare.mjs.map +1 -0
- package/fesm2022/primenglab-inplace.mjs +237 -0
- package/fesm2022/primenglab-inplace.mjs.map +1 -0
- package/fesm2022/primenglab-inputcolor.mjs +2262 -0
- package/fesm2022/primenglab-inputcolor.mjs.map +1 -0
- package/fesm2022/primenglab-inputgroup.mjs +121 -0
- package/fesm2022/primenglab-inputgroup.mjs.map +1 -0
- package/fesm2022/primenglab-inputgroupaddon.mjs +70 -0
- package/fesm2022/primenglab-inputgroupaddon.mjs.map +1 -0
- package/fesm2022/primenglab-inputicon.mjs +74 -0
- package/fesm2022/primenglab-inputicon.mjs.map +1 -0
- package/fesm2022/primenglab-inputmask.mjs +1495 -0
- package/fesm2022/primenglab-inputmask.mjs.map +1 -0
- package/fesm2022/primenglab-inputnumber.mjs +1624 -0
- package/fesm2022/primenglab-inputnumber.mjs.map +1 -0
- package/fesm2022/primenglab-inputotp.mjs +445 -0
- package/fesm2022/primenglab-inputotp.mjs.map +1 -0
- package/fesm2022/primenglab-inputpassword.mjs +102 -0
- package/fesm2022/primenglab-inputpassword.mjs.map +1 -0
- package/fesm2022/primenglab-inputtags.mjs +748 -0
- package/fesm2022/primenglab-inputtags.mjs.map +1 -0
- package/fesm2022/primenglab-inputtext.mjs +174 -0
- package/fesm2022/primenglab-inputtext.mjs.map +1 -0
- package/fesm2022/primenglab-keyfilter.mjs +252 -0
- package/fesm2022/primenglab-keyfilter.mjs.map +1 -0
- package/fesm2022/primenglab-knob.mjs +467 -0
- package/fesm2022/primenglab-knob.mjs.map +1 -0
- package/fesm2022/primenglab-label.mjs +85 -0
- package/fesm2022/primenglab-label.mjs.map +1 -0
- package/fesm2022/primenglab-license.mjs +39 -0
- package/fesm2022/primenglab-license.mjs.map +1 -0
- package/fesm2022/primenglab-listbox.mjs +2108 -0
- package/fesm2022/primenglab-listbox.mjs.map +1 -0
- package/fesm2022/primenglab-megamenu.mjs +1595 -0
- package/fesm2022/primenglab-megamenu.mjs.map +1 -0
- package/fesm2022/primenglab-menu.mjs +1224 -0
- package/fesm2022/primenglab-menu.mjs.map +1 -0
- package/fesm2022/primenglab-menubar.mjs +1448 -0
- package/fesm2022/primenglab-menubar.mjs.map +1 -0
- package/fesm2022/primenglab-message.mjs +306 -0
- package/fesm2022/primenglab-message.mjs.map +1 -0
- package/fesm2022/primenglab-metergroup.mjs +412 -0
- package/fesm2022/primenglab-metergroup.mjs.map +1 -0
- package/fesm2022/primenglab-motion.mjs +719 -0
- package/fesm2022/primenglab-motion.mjs.map +1 -0
- package/fesm2022/primenglab-multiselect.mjs +2543 -0
- package/fesm2022/primenglab-multiselect.mjs.map +1 -0
- package/fesm2022/primenglab-orderlist.mjs +868 -0
- package/fesm2022/primenglab-orderlist.mjs.map +1 -0
- package/fesm2022/primenglab-organizationchart.mjs +617 -0
- package/fesm2022/primenglab-organizationchart.mjs.map +1 -0
- package/fesm2022/primenglab-overlay.mjs +751 -0
- package/fesm2022/primenglab-overlay.mjs.map +1 -0
- package/fesm2022/primenglab-overlaybadge.mjs +134 -0
- package/fesm2022/primenglab-overlaybadge.mjs.map +1 -0
- package/fesm2022/primenglab-paginator.mjs +759 -0
- package/fesm2022/primenglab-paginator.mjs.map +1 -0
- package/fesm2022/primenglab-panel.mjs +487 -0
- package/fesm2022/primenglab-panel.mjs.map +1 -0
- package/fesm2022/primenglab-panelmenu.mjs +1599 -0
- package/fesm2022/primenglab-panelmenu.mjs.map +1 -0
- package/fesm2022/primenglab-passthrough.mjs +21 -0
- package/fesm2022/primenglab-passthrough.mjs.map +1 -0
- package/fesm2022/primenglab-password.mjs +1089 -0
- package/fesm2022/primenglab-password.mjs.map +1 -0
- package/fesm2022/primenglab-picklist.mjs +1992 -0
- package/fesm2022/primenglab-picklist.mjs.map +1 -0
- package/fesm2022/primenglab-popover.mjs +488 -0
- package/fesm2022/primenglab-popover.mjs.map +1 -0
- package/fesm2022/primenglab-progressbar.mjs +200 -0
- package/fesm2022/primenglab-progressbar.mjs.map +1 -0
- package/fesm2022/primenglab-progressspinner.mjs +313 -0
- package/fesm2022/primenglab-progressspinner.mjs.map +1 -0
- package/fesm2022/primenglab-radiobutton.mjs +347 -0
- package/fesm2022/primenglab-radiobutton.mjs.map +1 -0
- package/fesm2022/primenglab-rating.mjs +488 -0
- package/fesm2022/primenglab-rating.mjs.map +1 -0
- package/fesm2022/primenglab-ripple.mjs +192 -0
- package/fesm2022/primenglab-ripple.mjs.map +1 -0
- package/fesm2022/primenglab-scrollarea.mjs +730 -0
- package/fesm2022/primenglab-scrollarea.mjs.map +1 -0
- package/fesm2022/primenglab-scroller.mjs +1183 -0
- package/fesm2022/primenglab-scroller.mjs.map +1 -0
- package/fesm2022/primenglab-scrollpanel.mjs +543 -0
- package/fesm2022/primenglab-scrollpanel.mjs.map +1 -0
- package/fesm2022/primenglab-scrolltop.mjs +323 -0
- package/fesm2022/primenglab-scrolltop.mjs.map +1 -0
- package/fesm2022/primenglab-select.mjs +2287 -0
- package/fesm2022/primenglab-select.mjs.map +1 -0
- package/fesm2022/primenglab-selectbutton.mjs +390 -0
- package/fesm2022/primenglab-selectbutton.mjs.map +1 -0
- package/fesm2022/primenglab-sidebar.mjs +1461 -0
- package/fesm2022/primenglab-sidebar.mjs.map +1 -0
- package/fesm2022/primenglab-skeleton.mjs +161 -0
- package/fesm2022/primenglab-skeleton.mjs.map +1 -0
- package/fesm2022/primenglab-slider.mjs +776 -0
- package/fesm2022/primenglab-slider.mjs.map +1 -0
- package/fesm2022/primenglab-speeddial.mjs +892 -0
- package/fesm2022/primenglab-speeddial.mjs.map +1 -0
- package/fesm2022/primenglab-splitbutton.mjs +544 -0
- package/fesm2022/primenglab-splitbutton.mjs.map +1 -0
- package/fesm2022/primenglab-splitter.mjs +853 -0
- package/fesm2022/primenglab-splitter.mjs.map +1 -0
- package/fesm2022/primenglab-stepper.mjs +724 -0
- package/fesm2022/primenglab-stepper.mjs.map +1 -0
- package/fesm2022/primenglab-steps.mjs +425 -0
- package/fesm2022/primenglab-steps.mjs.map +1 -0
- package/fesm2022/primenglab-styleclass.mjs +331 -0
- package/fesm2022/primenglab-styleclass.mjs.map +1 -0
- package/fesm2022/primenglab-table.mjs +7125 -0
- package/fesm2022/primenglab-table.mjs.map +1 -0
- package/fesm2022/primenglab-tabs.mjs +932 -0
- package/fesm2022/primenglab-tabs.mjs.map +1 -0
- package/fesm2022/primenglab-tag.mjs +179 -0
- package/fesm2022/primenglab-tag.mjs.map +1 -0
- package/fesm2022/primenglab-terminal.mjs +253 -0
- package/fesm2022/primenglab-terminal.mjs.map +1 -0
- package/fesm2022/primenglab-textarea.mjs +208 -0
- package/fesm2022/primenglab-textarea.mjs.map +1 -0
- package/fesm2022/primenglab-tieredmenu.mjs +1547 -0
- package/fesm2022/primenglab-tieredmenu.mjs.map +1 -0
- package/fesm2022/primenglab-timeline.mjs +211 -0
- package/fesm2022/primenglab-timeline.mjs.map +1 -0
- package/fesm2022/primenglab-toast.mjs +1140 -0
- package/fesm2022/primenglab-toast.mjs.map +1 -0
- package/fesm2022/primenglab-togglebutton.mjs +343 -0
- package/fesm2022/primenglab-togglebutton.mjs.map +1 -0
- package/fesm2022/primenglab-toggleswitch.mjs +296 -0
- package/fesm2022/primenglab-toggleswitch.mjs.map +1 -0
- package/fesm2022/primenglab-toolbar.mjs +167 -0
- package/fesm2022/primenglab-toolbar.mjs.map +1 -0
- package/fesm2022/primenglab-tooltip.mjs +770 -0
- package/fesm2022/primenglab-tooltip.mjs.map +1 -0
- package/fesm2022/primenglab-tree.mjs +2332 -0
- package/fesm2022/primenglab-tree.mjs.map +1 -0
- package/fesm2022/primenglab-treeselect.mjs +1263 -0
- package/fesm2022/primenglab-treeselect.mjs.map +1 -0
- package/fesm2022/primenglab-treetable.mjs +4817 -0
- package/fesm2022/primenglab-treetable.mjs.map +1 -0
- package/fesm2022/primenglab-ts-helpers.mjs +4 -0
- package/fesm2022/primenglab-ts-helpers.mjs.map +1 -0
- package/fesm2022/primenglab-types-accordion.mjs +4 -0
- package/fesm2022/primenglab-types-accordion.mjs.map +1 -0
- package/fesm2022/primenglab-types-autocomplete.mjs +4 -0
- package/fesm2022/primenglab-types-autocomplete.mjs.map +1 -0
- package/fesm2022/primenglab-types-avatar.mjs +4 -0
- package/fesm2022/primenglab-types-avatar.mjs.map +1 -0
- package/fesm2022/primenglab-types-avatargroup.mjs +4 -0
- package/fesm2022/primenglab-types-avatargroup.mjs.map +1 -0
- package/fesm2022/primenglab-types-badge.mjs +4 -0
- package/fesm2022/primenglab-types-badge.mjs.map +1 -0
- package/fesm2022/primenglab-types-blockui.mjs +4 -0
- package/fesm2022/primenglab-types-blockui.mjs.map +1 -0
- package/fesm2022/primenglab-types-breadcrumb.mjs +4 -0
- package/fesm2022/primenglab-types-breadcrumb.mjs.map +1 -0
- package/fesm2022/primenglab-types-button.mjs +4 -0
- package/fesm2022/primenglab-types-button.mjs.map +1 -0
- package/fesm2022/primenglab-types-card.mjs +4 -0
- package/fesm2022/primenglab-types-card.mjs.map +1 -0
- package/fesm2022/primenglab-types-carousel.mjs +4 -0
- package/fesm2022/primenglab-types-carousel.mjs.map +1 -0
- package/fesm2022/primenglab-types-cascadeselect.mjs +4 -0
- package/fesm2022/primenglab-types-cascadeselect.mjs.map +1 -0
- package/fesm2022/primenglab-types-chart.mjs +4 -0
- package/fesm2022/primenglab-types-chart.mjs.map +1 -0
- package/fesm2022/primenglab-types-checkbox.mjs +4 -0
- package/fesm2022/primenglab-types-checkbox.mjs.map +1 -0
- package/fesm2022/primenglab-types-chip.mjs +4 -0
- package/fesm2022/primenglab-types-chip.mjs.map +1 -0
- package/fesm2022/primenglab-types-colorpicker.mjs +4 -0
- package/fesm2022/primenglab-types-colorpicker.mjs.map +1 -0
- package/fesm2022/primenglab-types-commandmenu.mjs +4 -0
- package/fesm2022/primenglab-types-commandmenu.mjs.map +1 -0
- package/fesm2022/primenglab-types-compare.mjs +4 -0
- package/fesm2022/primenglab-types-compare.mjs.map +1 -0
- package/fesm2022/primenglab-types-confirmdialog.mjs +4 -0
- package/fesm2022/primenglab-types-confirmdialog.mjs.map +1 -0
- package/fesm2022/primenglab-types-confirmpopup.mjs +4 -0
- package/fesm2022/primenglab-types-confirmpopup.mjs.map +1 -0
- package/fesm2022/primenglab-types-contextmenu.mjs +4 -0
- package/fesm2022/primenglab-types-contextmenu.mjs.map +1 -0
- package/fesm2022/primenglab-types-dataview.mjs +4 -0
- package/fesm2022/primenglab-types-dataview.mjs.map +1 -0
- package/fesm2022/primenglab-types-datepicker.mjs +4 -0
- package/fesm2022/primenglab-types-datepicker.mjs.map +1 -0
- package/fesm2022/primenglab-types-dialog.mjs +4 -0
- package/fesm2022/primenglab-types-dialog.mjs.map +1 -0
- package/fesm2022/primenglab-types-divider.mjs +4 -0
- package/fesm2022/primenglab-types-divider.mjs.map +1 -0
- package/fesm2022/primenglab-types-dock.mjs +4 -0
- package/fesm2022/primenglab-types-dock.mjs.map +1 -0
- package/fesm2022/primenglab-types-drawer.mjs +4 -0
- package/fesm2022/primenglab-types-drawer.mjs.map +1 -0
- package/fesm2022/primenglab-types-editor.mjs +4 -0
- package/fesm2022/primenglab-types-editor.mjs.map +1 -0
- package/fesm2022/primenglab-types-fieldset.mjs +4 -0
- package/fesm2022/primenglab-types-fieldset.mjs.map +1 -0
- package/fesm2022/primenglab-types-fileupload.mjs +4 -0
- package/fesm2022/primenglab-types-fileupload.mjs.map +1 -0
- package/fesm2022/primenglab-types-floatlabel.mjs +4 -0
- package/fesm2022/primenglab-types-floatlabel.mjs.map +1 -0
- package/fesm2022/primenglab-types-fluid.mjs +4 -0
- package/fesm2022/primenglab-types-fluid.mjs.map +1 -0
- package/fesm2022/primenglab-types-galleria.mjs +4 -0
- package/fesm2022/primenglab-types-galleria.mjs.map +1 -0
- package/fesm2022/primenglab-types-gallery.mjs +4 -0
- package/fesm2022/primenglab-types-gallery.mjs.map +1 -0
- package/fesm2022/primenglab-types-iconfield.mjs +4 -0
- package/fesm2022/primenglab-types-iconfield.mjs.map +1 -0
- package/fesm2022/primenglab-types-iftalabel.mjs +4 -0
- package/fesm2022/primenglab-types-iftalabel.mjs.map +1 -0
- package/fesm2022/primenglab-types-image.mjs +4 -0
- package/fesm2022/primenglab-types-image.mjs.map +1 -0
- package/fesm2022/primenglab-types-imagecompare.mjs +4 -0
- package/fesm2022/primenglab-types-imagecompare.mjs.map +1 -0
- package/fesm2022/primenglab-types-inplace.mjs +4 -0
- package/fesm2022/primenglab-types-inplace.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputcolor.mjs +4 -0
- package/fesm2022/primenglab-types-inputcolor.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputgroup.mjs +4 -0
- package/fesm2022/primenglab-types-inputgroup.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputgroupaddon.mjs +4 -0
- package/fesm2022/primenglab-types-inputgroupaddon.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputicon.mjs +4 -0
- package/fesm2022/primenglab-types-inputicon.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputmask.mjs +4 -0
- package/fesm2022/primenglab-types-inputmask.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputnumber.mjs +4 -0
- package/fesm2022/primenglab-types-inputnumber.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputotp.mjs +4 -0
- package/fesm2022/primenglab-types-inputotp.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputpassword.mjs +4 -0
- package/fesm2022/primenglab-types-inputpassword.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputtags.mjs +4 -0
- package/fesm2022/primenglab-types-inputtags.mjs.map +1 -0
- package/fesm2022/primenglab-types-inputtext.mjs +4 -0
- package/fesm2022/primenglab-types-inputtext.mjs.map +1 -0
- package/fesm2022/primenglab-types-knob.mjs +4 -0
- package/fesm2022/primenglab-types-knob.mjs.map +1 -0
- package/fesm2022/primenglab-types-label.mjs +4 -0
- package/fesm2022/primenglab-types-label.mjs.map +1 -0
- package/fesm2022/primenglab-types-listbox.mjs +4 -0
- package/fesm2022/primenglab-types-listbox.mjs.map +1 -0
- package/fesm2022/primenglab-types-megamenu.mjs +4 -0
- package/fesm2022/primenglab-types-megamenu.mjs.map +1 -0
- package/fesm2022/primenglab-types-menu.mjs +4 -0
- package/fesm2022/primenglab-types-menu.mjs.map +1 -0
- package/fesm2022/primenglab-types-menubar.mjs +4 -0
- package/fesm2022/primenglab-types-menubar.mjs.map +1 -0
- package/fesm2022/primenglab-types-message.mjs +4 -0
- package/fesm2022/primenglab-types-message.mjs.map +1 -0
- package/fesm2022/primenglab-types-metergroup.mjs +4 -0
- package/fesm2022/primenglab-types-metergroup.mjs.map +1 -0
- package/fesm2022/primenglab-types-motion.mjs +4 -0
- package/fesm2022/primenglab-types-motion.mjs.map +1 -0
- package/fesm2022/primenglab-types-multiselect.mjs +4 -0
- package/fesm2022/primenglab-types-multiselect.mjs.map +1 -0
- package/fesm2022/primenglab-types-orderlist.mjs +4 -0
- package/fesm2022/primenglab-types-orderlist.mjs.map +1 -0
- package/fesm2022/primenglab-types-organizationchart.mjs +4 -0
- package/fesm2022/primenglab-types-organizationchart.mjs.map +1 -0
- package/fesm2022/primenglab-types-overlay.mjs +4 -0
- package/fesm2022/primenglab-types-overlay.mjs.map +1 -0
- package/fesm2022/primenglab-types-overlaybadge.mjs +4 -0
- package/fesm2022/primenglab-types-overlaybadge.mjs.map +1 -0
- package/fesm2022/primenglab-types-paginator.mjs +4 -0
- package/fesm2022/primenglab-types-paginator.mjs.map +1 -0
- package/fesm2022/primenglab-types-panel.mjs +4 -0
- package/fesm2022/primenglab-types-panel.mjs.map +1 -0
- package/fesm2022/primenglab-types-panelmenu.mjs +4 -0
- package/fesm2022/primenglab-types-panelmenu.mjs.map +1 -0
- package/fesm2022/primenglab-types-password.mjs +4 -0
- package/fesm2022/primenglab-types-password.mjs.map +1 -0
- package/fesm2022/primenglab-types-picklist.mjs +4 -0
- package/fesm2022/primenglab-types-picklist.mjs.map +1 -0
- package/fesm2022/primenglab-types-popover.mjs +4 -0
- package/fesm2022/primenglab-types-popover.mjs.map +1 -0
- package/fesm2022/primenglab-types-progressbar.mjs +4 -0
- package/fesm2022/primenglab-types-progressbar.mjs.map +1 -0
- package/fesm2022/primenglab-types-progressspinner.mjs +4 -0
- package/fesm2022/primenglab-types-progressspinner.mjs.map +1 -0
- package/fesm2022/primenglab-types-radiobutton.mjs +4 -0
- package/fesm2022/primenglab-types-radiobutton.mjs.map +1 -0
- package/fesm2022/primenglab-types-rating.mjs +4 -0
- package/fesm2022/primenglab-types-rating.mjs.map +1 -0
- package/fesm2022/primenglab-types-scrollarea.mjs +4 -0
- package/fesm2022/primenglab-types-scrollarea.mjs.map +1 -0
- package/fesm2022/primenglab-types-scroller.mjs +4 -0
- package/fesm2022/primenglab-types-scroller.mjs.map +1 -0
- package/fesm2022/primenglab-types-scrollpanel.mjs +4 -0
- package/fesm2022/primenglab-types-scrollpanel.mjs.map +1 -0
- package/fesm2022/primenglab-types-scrolltop.mjs +4 -0
- package/fesm2022/primenglab-types-scrolltop.mjs.map +1 -0
- package/fesm2022/primenglab-types-select.mjs +4 -0
- package/fesm2022/primenglab-types-select.mjs.map +1 -0
- package/fesm2022/primenglab-types-selectbutton.mjs +4 -0
- package/fesm2022/primenglab-types-selectbutton.mjs.map +1 -0
- package/fesm2022/primenglab-types-shared.mjs +4 -0
- package/fesm2022/primenglab-types-shared.mjs.map +1 -0
- package/fesm2022/primenglab-types-sidebar.mjs +4 -0
- package/fesm2022/primenglab-types-sidebar.mjs.map +1 -0
- package/fesm2022/primenglab-types-skeleton.mjs +4 -0
- package/fesm2022/primenglab-types-skeleton.mjs.map +1 -0
- package/fesm2022/primenglab-types-slider.mjs +4 -0
- package/fesm2022/primenglab-types-slider.mjs.map +1 -0
- package/fesm2022/primenglab-types-speeddial.mjs +4 -0
- package/fesm2022/primenglab-types-speeddial.mjs.map +1 -0
- package/fesm2022/primenglab-types-splitbutton.mjs +4 -0
- package/fesm2022/primenglab-types-splitbutton.mjs.map +1 -0
- package/fesm2022/primenglab-types-splitter.mjs +4 -0
- package/fesm2022/primenglab-types-splitter.mjs.map +1 -0
- package/fesm2022/primenglab-types-stepper.mjs +4 -0
- package/fesm2022/primenglab-types-stepper.mjs.map +1 -0
- package/fesm2022/primenglab-types-table.mjs +4 -0
- package/fesm2022/primenglab-types-table.mjs.map +1 -0
- package/fesm2022/primenglab-types-tabs.mjs +4 -0
- package/fesm2022/primenglab-types-tabs.mjs.map +1 -0
- package/fesm2022/primenglab-types-tag.mjs +4 -0
- package/fesm2022/primenglab-types-tag.mjs.map +1 -0
- package/fesm2022/primenglab-types-terminal.mjs +4 -0
- package/fesm2022/primenglab-types-terminal.mjs.map +1 -0
- package/fesm2022/primenglab-types-textarea.mjs +4 -0
- package/fesm2022/primenglab-types-textarea.mjs.map +1 -0
- package/fesm2022/primenglab-types-tieredmenu.mjs +4 -0
- package/fesm2022/primenglab-types-tieredmenu.mjs.map +1 -0
- package/fesm2022/primenglab-types-timeline.mjs +4 -0
- package/fesm2022/primenglab-types-timeline.mjs.map +1 -0
- package/fesm2022/primenglab-types-toast.mjs +4 -0
- package/fesm2022/primenglab-types-toast.mjs.map +1 -0
- package/fesm2022/primenglab-types-togglebutton.mjs +4 -0
- package/fesm2022/primenglab-types-togglebutton.mjs.map +1 -0
- package/fesm2022/primenglab-types-toggleswitch.mjs +4 -0
- package/fesm2022/primenglab-types-toggleswitch.mjs.map +1 -0
- package/fesm2022/primenglab-types-toolbar.mjs +4 -0
- package/fesm2022/primenglab-types-toolbar.mjs.map +1 -0
- package/fesm2022/primenglab-types-tooltip.mjs +4 -0
- package/fesm2022/primenglab-types-tooltip.mjs.map +1 -0
- package/fesm2022/primenglab-types-tree.mjs +4 -0
- package/fesm2022/primenglab-types-tree.mjs.map +1 -0
- package/fesm2022/primenglab-types-treeselect.mjs +4 -0
- package/fesm2022/primenglab-types-treeselect.mjs.map +1 -0
- package/fesm2022/primenglab-types-treetable.mjs +4 -0
- package/fesm2022/primenglab-types-treetable.mjs.map +1 -0
- package/fesm2022/primenglab-usestyle.mjs +54 -0
- package/fesm2022/primenglab-usestyle.mjs.map +1 -0
- package/fesm2022/primenglab-utils.mjs +332 -0
- package/fesm2022/primenglab-utils.mjs.map +1 -0
- package/fesm2022/primenglab.mjs +6 -0
- package/fesm2022/primenglab.mjs.map +1 -0
- package/package.json +1188 -0
- package/types/primenglab-accordion.d.ts +252 -0
- package/types/primenglab-animateonscroll.d.ts +68 -0
- package/types/primenglab-api.d.ts +2000 -0
- package/types/primenglab-autocomplete.d.ts +774 -0
- package/types/primenglab-autofocus.d.ts +29 -0
- package/types/primenglab-avatar.d.ts +133 -0
- package/types/primenglab-avatargroup.d.ts +58 -0
- package/types/primenglab-badge.d.ts +96 -0
- package/types/primenglab-base.d.ts +58 -0
- package/types/primenglab-basecomponent.d.ts +178 -0
- package/types/primenglab-baseeditableholder.d.ts +45 -0
- package/types/primenglab-baseinput.d.ts +74 -0
- package/types/primenglab-basemodelholder.d.ts +12 -0
- package/types/primenglab-bind.d.ts +37 -0
- package/types/primenglab-blockui.d.ts +97 -0
- package/types/primenglab-breadcrumb.d.ts +150 -0
- package/types/primenglab-button.d.ts +468 -0
- package/types/primenglab-buttongroup.d.ts +44 -0
- package/types/primenglab-card.d.ts +138 -0
- package/types/primenglab-carousel.d.ts +687 -0
- package/types/primenglab-cascadeselect.d.ts +581 -0
- package/types/primenglab-chart.d.ts +133 -0
- package/types/primenglab-checkbox.d.ts +227 -0
- package/types/primenglab-chip.d.ts +159 -0
- package/types/primenglab-classnames.d.ts +32 -0
- package/types/primenglab-colorpicker.d.ts +295 -0
- package/types/primenglab-commandmenu.d.ts +182 -0
- package/types/primenglab-compare.d.ts +225 -0
- package/types/primenglab-config.d.ts +313 -0
- package/types/primenglab-confirmdialog.d.ts +344 -0
- package/types/primenglab-confirmpopup.d.ts +230 -0
- package/types/primenglab-contextmenu.d.ts +388 -0
- package/types/primenglab-dataview.d.ts +361 -0
- package/types/primenglab-datepicker.d.ts +967 -0
- package/types/primenglab-dialog.d.ts +481 -0
- package/types/primenglab-divider.d.ts +116 -0
- package/types/primenglab-dock.d.ts +189 -0
- package/types/primenglab-dom.d.ts +109 -0
- package/types/primenglab-dragdrop.d.ts +117 -0
- package/types/primenglab-drawer.d.ts +272 -0
- package/types/primenglab-dynamicdialog.d.ts +576 -0
- package/types/primenglab-editor.d.ts +182 -0
- package/types/primenglab-fieldset.d.ts +182 -0
- package/types/primenglab-fileupload.d.ts +542 -0
- package/types/primenglab-floatlabel.d.ts +67 -0
- package/types/primenglab-fluid.d.ts +54 -0
- package/types/primenglab-focustrap.d.ts +32 -0
- package/types/primenglab-galleria.d.ts +450 -0
- package/types/primenglab-gallery.d.ts +653 -0
- package/types/primenglab-iconfield.d.ts +61 -0
- package/types/primenglab-icons-angledoubledown.d.ts +9 -0
- package/types/primenglab-icons-angledoubleleft.d.ts +9 -0
- package/types/primenglab-icons-angledoubleright.d.ts +9 -0
- package/types/primenglab-icons-angledoubleup.d.ts +9 -0
- package/types/primenglab-icons-angledown.d.ts +9 -0
- package/types/primenglab-icons-angleleft.d.ts +9 -0
- package/types/primenglab-icons-angleright.d.ts +9 -0
- package/types/primenglab-icons-angleup.d.ts +9 -0
- package/types/primenglab-icons-arrowdown.d.ts +11 -0
- package/types/primenglab-icons-arrowdownleft.d.ts +9 -0
- package/types/primenglab-icons-arrowdownright.d.ts +9 -0
- package/types/primenglab-icons-arrowleft.d.ts +11 -0
- package/types/primenglab-icons-arrowright.d.ts +9 -0
- package/types/primenglab-icons-arrowup.d.ts +11 -0
- package/types/primenglab-icons-ban.d.ts +11 -0
- package/types/primenglab-icons-bars.d.ts +9 -0
- package/types/primenglab-icons-baseicon.d.ts +33 -0
- package/types/primenglab-icons-blank.d.ts +9 -0
- package/types/primenglab-icons-calendar.d.ts +9 -0
- package/types/primenglab-icons-caretleft.d.ts +9 -0
- package/types/primenglab-icons-caretright.d.ts +9 -0
- package/types/primenglab-icons-check.d.ts +9 -0
- package/types/primenglab-icons-chevrondown.d.ts +9 -0
- package/types/primenglab-icons-chevronleft.d.ts +9 -0
- package/types/primenglab-icons-chevronright.d.ts +9 -0
- package/types/primenglab-icons-chevronup.d.ts +9 -0
- package/types/primenglab-icons-exclamationtriangle.d.ts +11 -0
- package/types/primenglab-icons-eye.d.ts +9 -0
- package/types/primenglab-icons-eyeslash.d.ts +11 -0
- package/types/primenglab-icons-filter.d.ts +11 -0
- package/types/primenglab-icons-filterfill.d.ts +9 -0
- package/types/primenglab-icons-filterslash.d.ts +11 -0
- package/types/primenglab-icons-home.d.ts +11 -0
- package/types/primenglab-icons-infocircle.d.ts +11 -0
- package/types/primenglab-icons-minus.d.ts +9 -0
- package/types/primenglab-icons-pencil.d.ts +11 -0
- package/types/primenglab-icons-plus.d.ts +11 -0
- package/types/primenglab-icons-refresh.d.ts +11 -0
- package/types/primenglab-icons-search.d.ts +11 -0
- package/types/primenglab-icons-searchminus.d.ts +11 -0
- package/types/primenglab-icons-searchplus.d.ts +11 -0
- package/types/primenglab-icons-sortalt.d.ts +11 -0
- package/types/primenglab-icons-sortamountdown.d.ts +11 -0
- package/types/primenglab-icons-sortamountupalt.d.ts +11 -0
- package/types/primenglab-icons-spinner.d.ts +11 -0
- package/types/primenglab-icons-star.d.ts +11 -0
- package/types/primenglab-icons-starfill.d.ts +11 -0
- package/types/primenglab-icons-thlarge.d.ts +11 -0
- package/types/primenglab-icons-times.d.ts +9 -0
- package/types/primenglab-icons-timescircle.d.ts +11 -0
- package/types/primenglab-icons-trash.d.ts +11 -0
- package/types/primenglab-icons-undo.d.ts +11 -0
- package/types/primenglab-icons-upload.d.ts +11 -0
- package/types/primenglab-icons-windowmaximize.d.ts +11 -0
- package/types/primenglab-icons-windowminimize.d.ts +11 -0
- package/types/primenglab-icons.d.ts +53 -0
- package/types/primenglab-iftalabel.d.ts +56 -0
- package/types/primenglab-image.d.ts +336 -0
- package/types/primenglab-imagecompare.d.ts +97 -0
- package/types/primenglab-inplace.d.ts +132 -0
- package/types/primenglab-inputcolor.d.ts +568 -0
- package/types/primenglab-inputgroup.d.ts +59 -0
- package/types/primenglab-inputgroupaddon.d.ts +37 -0
- package/types/primenglab-inputicon.d.ts +38 -0
- package/types/primenglab-inputmask.d.ts +385 -0
- package/types/primenglab-inputnumber.d.ts +424 -0
- package/types/primenglab-inputotp.d.ts +177 -0
- package/types/primenglab-inputpassword.d.ts +63 -0
- package/types/primenglab-inputtags.d.ts +315 -0
- package/types/primenglab-inputtext.d.ts +112 -0
- package/types/primenglab-keyfilter.d.ts +58 -0
- package/types/primenglab-knob.d.ts +202 -0
- package/types/primenglab-label.d.ts +55 -0
- package/types/primenglab-license.d.ts +23 -0
- package/types/primenglab-listbox.d.ts +775 -0
- package/types/primenglab-megamenu.d.ts +402 -0
- package/types/primenglab-menu.d.ts +382 -0
- package/types/primenglab-menubar.d.ts +374 -0
- package/types/primenglab-message.d.ts +166 -0
- package/types/primenglab-metergroup.d.ts +209 -0
- package/types/primenglab-motion.d.ts +398 -0
- package/types/primenglab-multiselect.d.ts +877 -0
- package/types/primenglab-orderlist.d.ts +390 -0
- package/types/primenglab-organizationchart.d.ts +189 -0
- package/types/primenglab-overlay.d.ts +300 -0
- package/types/primenglab-overlaybadge.d.ts +70 -0
- package/types/primenglab-paginator.d.ts +330 -0
- package/types/primenglab-panel.d.ts +234 -0
- package/types/primenglab-panelmenu.d.ts +248 -0
- package/types/primenglab-passthrough.d.ts +14 -0
- package/types/primenglab-password.d.ts +459 -0
- package/types/primenglab-picklist.d.ts +751 -0
- package/types/primenglab-popover.d.ts +183 -0
- package/types/primenglab-progressbar.d.ts +118 -0
- package/types/primenglab-progressspinner.d.ts +126 -0
- package/types/primenglab-radiobutton.d.ts +188 -0
- package/types/primenglab-rating.d.ts +210 -0
- package/types/primenglab-ripple.d.ts +60 -0
- package/types/primenglab-scrollarea.d.ts +286 -0
- package/types/primenglab-scroller.d.ts +462 -0
- package/types/primenglab-scrollpanel.d.ts +147 -0
- package/types/primenglab-scrolltop.d.ts +143 -0
- package/types/primenglab-select.d.ts +757 -0
- package/types/primenglab-selectbutton.d.ts +184 -0
- package/types/primenglab-sidebar.d.ts +669 -0
- package/types/primenglab-skeleton.d.ts +103 -0
- package/types/primenglab-slider.d.ts +327 -0
- package/types/primenglab-speeddial.d.ts +394 -0
- package/types/primenglab-splitbutton.d.ts +259 -0
- package/types/primenglab-splitter.d.ts +334 -0
- package/types/primenglab-stepper.d.ts +311 -0
- package/types/primenglab-steps.d.ts +153 -0
- package/types/primenglab-styleclass.d.ts +110 -0
- package/types/primenglab-table.d.ts +1953 -0
- package/types/primenglab-tabs.d.ts +356 -0
- package/types/primenglab-tag.d.ts +104 -0
- package/types/primenglab-terminal.d.ts +137 -0
- package/types/primenglab-textarea.d.ts +126 -0
- package/types/primenglab-tieredmenu.d.ts +419 -0
- package/types/primenglab-timeline.d.ts +128 -0
- package/types/primenglab-toast.d.ts +268 -0
- package/types/primenglab-togglebutton.d.ts +200 -0
- package/types/primenglab-toggleswitch.d.ts +161 -0
- package/types/primenglab-toolbar.d.ts +95 -0
- package/types/primenglab-tooltip.d.ts +251 -0
- package/types/primenglab-tree.d.ts +571 -0
- package/types/primenglab-treeselect.d.ts +560 -0
- package/types/primenglab-treetable.d.ts +1290 -0
- package/types/primenglab-ts-helpers.d.ts +6 -0
- package/types/primenglab-types-accordion.d.ts +135 -0
- package/types/primenglab-types-autocomplete.d.ts +312 -0
- package/types/primenglab-types-avatar.d.ts +50 -0
- package/types/primenglab-types-avatargroup.d.ts +28 -0
- package/types/primenglab-types-badge.d.ts +36 -0
- package/types/primenglab-types-blockui.d.ts +39 -0
- package/types/primenglab-types-breadcrumb.d.ts +96 -0
- package/types/primenglab-types-button.d.ts +140 -0
- package/types/primenglab-types-card.d.ts +75 -0
- package/types/primenglab-types-carousel.d.ts +244 -0
- package/types/primenglab-types-cascadeselect.d.ts +278 -0
- package/types/primenglab-types-chart.d.ts +57 -0
- package/types/primenglab-types-checkbox.d.ts +85 -0
- package/types/primenglab-types-chip.d.ts +70 -0
- package/types/primenglab-types-colorpicker.d.ts +83 -0
- package/types/primenglab-types-commandmenu.d.ts +154 -0
- package/types/primenglab-types-compare.d.ts +55 -0
- package/types/primenglab-types-confirmdialog.d.ts +161 -0
- package/types/primenglab-types-confirmpopup.d.ts +110 -0
- package/types/primenglab-types-contextmenu.d.ts +135 -0
- package/types/primenglab-types-dataview.d.ts +263 -0
- package/types/primenglab-types-datepicker.d.ts +535 -0
- package/types/primenglab-types-dialog.d.ts +124 -0
- package/types/primenglab-types-divider.d.ts +43 -0
- package/types/primenglab-types-dock.d.ts +75 -0
- package/types/primenglab-types-drawer.d.ts +83 -0
- package/types/primenglab-types-editor.d.ts +210 -0
- package/types/primenglab-types-fieldset.d.ts +120 -0
- package/types/primenglab-types-fileupload.d.ts +416 -0
- package/types/primenglab-types-floatlabel.d.ts +27 -0
- package/types/primenglab-types-fluid.d.ts +28 -0
- package/types/primenglab-types-galleria.d.ts +259 -0
- package/types/primenglab-types-gallery.d.ts +434 -0
- package/types/primenglab-types-iconfield.d.ts +27 -0
- package/types/primenglab-types-iftalabel.d.ts +26 -0
- package/types/primenglab-types-image.d.ts +149 -0
- package/types/primenglab-types-imagecompare.d.ts +43 -0
- package/types/primenglab-types-inplace.d.ts +72 -0
- package/types/primenglab-types-inputcolor.d.ts +206 -0
- package/types/primenglab-types-inputgroup.d.ts +28 -0
- package/types/primenglab-types-inputgroupaddon.d.ts +28 -0
- package/types/primenglab-types-inputicon.d.ts +26 -0
- package/types/primenglab-types-inputmask.d.ts +56 -0
- package/types/primenglab-types-inputnumber.d.ts +115 -0
- package/types/primenglab-types-inputotp.d.ts +101 -0
- package/types/primenglab-types-inputpassword.d.ts +24 -0
- package/types/primenglab-types-inputtags.d.ts +178 -0
- package/types/primenglab-types-inputtext.d.ts +24 -0
- package/types/primenglab-types-knob.d.ts +40 -0
- package/types/primenglab-types-label.d.ts +24 -0
- package/types/primenglab-types-listbox.d.ts +359 -0
- package/types/primenglab-types-megamenu.d.ts +183 -0
- package/types/primenglab-types-menu.d.ts +135 -0
- package/types/primenglab-types-menubar.d.ts +171 -0
- package/types/primenglab-types-message.d.ts +112 -0
- package/types/primenglab-types-metergroup.d.ts +178 -0
- package/types/primenglab-types-motion.d.ts +26 -0
- package/types/primenglab-types-multiselect.d.ts +454 -0
- package/types/primenglab-types-orderlist.d.ts +177 -0
- package/types/primenglab-types-organizationchart.d.ts +187 -0
- package/types/primenglab-types-overlay.d.ts +60 -0
- package/types/primenglab-types-overlaybadge.d.ts +34 -0
- package/types/primenglab-types-paginator.d.ts +167 -0
- package/types/primenglab-types-panel.d.ts +139 -0
- package/types/primenglab-types-panelmenu.d.ts +180 -0
- package/types/primenglab-types-password.d.ts +120 -0
- package/types/primenglab-types-picklist.d.ts +358 -0
- package/types/primenglab-types-popover.d.ts +59 -0
- package/types/primenglab-types-progressbar.d.ts +63 -0
- package/types/primenglab-types-progressspinner.d.ts +44 -0
- package/types/primenglab-types-radiobutton.d.ts +51 -0
- package/types/primenglab-types-rating.d.ts +94 -0
- package/types/primenglab-types-scrollarea.d.ts +60 -0
- package/types/primenglab-types-scroller.d.ts +231 -0
- package/types/primenglab-types-scrollpanel.d.ts +56 -0
- package/types/primenglab-types-scrolltop.d.ts +71 -0
- package/types/primenglab-types-select.d.ts +330 -0
- package/types/primenglab-types-selectbutton.d.ts +92 -0
- package/types/primenglab-types-shared.d.ts +27 -0
- package/types/primenglab-types-sidebar.d.ts +108 -0
- package/types/primenglab-types-skeleton.d.ts +28 -0
- package/types/primenglab-types-slider.d.ts +91 -0
- package/types/primenglab-types-speeddial.d.ts +110 -0
- package/types/primenglab-types-splitbutton.d.ts +60 -0
- package/types/primenglab-types-splitter.d.ts +127 -0
- package/types/primenglab-types-stepper.d.ts +186 -0
- package/types/primenglab-types-table.d.ts +902 -0
- package/types/primenglab-types-tabs.d.ts +120 -0
- package/types/primenglab-types-tag.d.ts +48 -0
- package/types/primenglab-types-terminal.d.ts +60 -0
- package/types/primenglab-types-textarea.d.ts +28 -0
- package/types/primenglab-types-tieredmenu.d.ts +203 -0
- package/types/primenglab-types-timeline.d.ts +93 -0
- package/types/primenglab-types-toast.d.ts +148 -0
- package/types/primenglab-types-togglebutton.d.ts +91 -0
- package/types/primenglab-types-toggleswitch.d.ts +73 -0
- package/types/primenglab-types-toolbar.d.ts +55 -0
- package/types/primenglab-types-tooltip.d.ts +42 -0
- package/types/primenglab-types-tree.d.ts +355 -0
- package/types/primenglab-types-treeselect.d.ts +266 -0
- package/types/primenglab-types-treetable.d.ts +659 -0
- package/types/primenglab-usestyle.d.ts +15 -0
- package/types/primenglab-utils.d.ts +43 -0
- package/types/primenglab.d.ts +2 -0
|
@@ -0,0 +1,2332 @@
|
|
|
1
|
+
export * from 'primenglab/types/tree';
|
|
2
|
+
import { NgTemplateOutlet } from '@angular/common';
|
|
3
|
+
import * as i0 from '@angular/core';
|
|
4
|
+
import { InjectionToken, Injectable, inject, input, booleanAttribute, signal, computed, ViewEncapsulation, ChangeDetectionStrategy, Component, model, numberAttribute, output, contentChild, viewChild, DestroyRef, effect, untracked, NgModule } from '@angular/core';
|
|
5
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
6
|
+
import { getOuterWidth, getOuterHeight, find, findSingle, focus, removeAccents, resolveFieldData } from '@primeuix/utils';
|
|
7
|
+
import { TreeDragDropService, TranslationKeys } from 'primenglab/api';
|
|
8
|
+
import * as i2 from 'primenglab/autofocus';
|
|
9
|
+
import { AutoFocusModule } from 'primenglab/autofocus';
|
|
10
|
+
import { BaseComponent, PARENT_INSTANCE } from 'primenglab/basecomponent';
|
|
11
|
+
import * as i1$1 from 'primenglab/bind';
|
|
12
|
+
import { Bind } from 'primenglab/bind';
|
|
13
|
+
import { IconField } from 'primenglab/iconfield';
|
|
14
|
+
import { Search } from '@primeicons/angular/search';
|
|
15
|
+
import { Spinner } from '@primeicons/angular/spinner';
|
|
16
|
+
import { InputIcon } from 'primenglab/inputicon';
|
|
17
|
+
import { InputText } from 'primenglab/inputtext';
|
|
18
|
+
import { Scroller } from 'primenglab/scroller';
|
|
19
|
+
import * as i1 from '@angular/forms';
|
|
20
|
+
import { FormsModule } from '@angular/forms';
|
|
21
|
+
import { Checkbox } from 'primenglab/checkbox';
|
|
22
|
+
import { ChevronDown } from '@primeicons/angular/chevron-down';
|
|
23
|
+
import { ChevronRight } from '@primeicons/angular/chevron-right';
|
|
24
|
+
import { Ripple } from 'primenglab/ripple';
|
|
25
|
+
import { style } from '@primeuix/styles/tree';
|
|
26
|
+
import { BaseStyle } from 'primenglab/base';
|
|
27
|
+
|
|
28
|
+
const TREE_INSTANCE = new InjectionToken('TREE_INSTANCE');
|
|
29
|
+
const TREENODE_INSTANCE = new InjectionToken('TREENODE_INSTANCE');
|
|
30
|
+
|
|
31
|
+
const classes = {
|
|
32
|
+
root: ({ instance }) => [
|
|
33
|
+
'p-tree p-component',
|
|
34
|
+
{
|
|
35
|
+
'p-tree-selectable': instance.selectionMode() != null,
|
|
36
|
+
'p-tree-loading': instance.loading(),
|
|
37
|
+
'p-tree-flex-scrollable': instance.scrollHeight() === 'flex',
|
|
38
|
+
'p-tree-node-dragover': instance.dragHover
|
|
39
|
+
}
|
|
40
|
+
],
|
|
41
|
+
mask: 'p-tree-mask p-overlay-mask',
|
|
42
|
+
loadingIcon: 'p-tree-loading-icon',
|
|
43
|
+
pcFilterInput: 'p-tree-filter-input',
|
|
44
|
+
wrapper: 'p-tree-root',
|
|
45
|
+
rootChildren: 'p-tree-root-children',
|
|
46
|
+
node: ({ instance }) => ({ 'p-tree-node': true, 'p-tree-node-leaf': instance.isLeaf() }),
|
|
47
|
+
nodeContent: ({ instance }) => ({
|
|
48
|
+
'p-tree-node-content': true,
|
|
49
|
+
'p-tree-node-selectable': instance.selectable,
|
|
50
|
+
'p-tree-node-dragover': instance.isNodeDropActive(),
|
|
51
|
+
'p-tree-node-selected': instance.tree.selectionMode() === 'checkbox' && instance.tree.highlightOnSelect() ? instance.checked : instance.selected,
|
|
52
|
+
'p-tree-node-contextmenu-selected': instance.isContextMenuSelected()
|
|
53
|
+
}),
|
|
54
|
+
nodeToggleButton: 'p-tree-node-toggle-button',
|
|
55
|
+
nodeToggleIcon: 'p-tree-node-toggle-icon',
|
|
56
|
+
nodeCheckbox: 'p-tree-node-checkbox',
|
|
57
|
+
nodeIcon: 'p-tree-node-icon',
|
|
58
|
+
nodeLabel: 'p-tree-node-label',
|
|
59
|
+
nodeChildren: 'p-tree-node-children',
|
|
60
|
+
emptyMessage: 'p-tree-empty-message',
|
|
61
|
+
dropPoint: 'p-tree-node-drop-point'
|
|
62
|
+
};
|
|
63
|
+
class TreeStyle extends BaseStyle {
|
|
64
|
+
name = 'tree';
|
|
65
|
+
style = style;
|
|
66
|
+
classes = classes;
|
|
67
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeStyle, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
68
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeStyle });
|
|
69
|
+
}
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeStyle, decorators: [{
|
|
71
|
+
type: Injectable
|
|
72
|
+
}] });
|
|
73
|
+
/**
|
|
74
|
+
*
|
|
75
|
+
* Tree is used to display hierarchical data.
|
|
76
|
+
*
|
|
77
|
+
* [Live Demo](https://www.primeng.org/tree/)
|
|
78
|
+
*
|
|
79
|
+
* @module treestyle
|
|
80
|
+
*
|
|
81
|
+
*/
|
|
82
|
+
var TreeClasses;
|
|
83
|
+
(function (TreeClasses) {
|
|
84
|
+
/**
|
|
85
|
+
* Class name of the root element
|
|
86
|
+
*/
|
|
87
|
+
TreeClasses["root"] = "p-tree";
|
|
88
|
+
/**
|
|
89
|
+
* Class name of the mask element
|
|
90
|
+
*/
|
|
91
|
+
TreeClasses["mask"] = "p-tree-mask";
|
|
92
|
+
/**
|
|
93
|
+
* Class name of the loading icon element
|
|
94
|
+
*/
|
|
95
|
+
TreeClasses["loadingIcon"] = "p-tree-loading-icon";
|
|
96
|
+
/**
|
|
97
|
+
* Class name of the filter input element
|
|
98
|
+
*/
|
|
99
|
+
TreeClasses["pcFilterInput"] = "p-tree-filter-input";
|
|
100
|
+
/**
|
|
101
|
+
* Class name of the wrapper element
|
|
102
|
+
*/
|
|
103
|
+
TreeClasses["wrapper"] = "p-tree-root";
|
|
104
|
+
/**
|
|
105
|
+
* Class name of the root children element
|
|
106
|
+
*/
|
|
107
|
+
TreeClasses["rootChildren"] = "p-tree-root-children";
|
|
108
|
+
/**
|
|
109
|
+
* Class name of the node element
|
|
110
|
+
*/
|
|
111
|
+
TreeClasses["node"] = "p-tree-node";
|
|
112
|
+
/**
|
|
113
|
+
* Class name of the node content element
|
|
114
|
+
*/
|
|
115
|
+
TreeClasses["nodeContent"] = "p-tree-node-content";
|
|
116
|
+
/**
|
|
117
|
+
* Class name of the node toggle button element
|
|
118
|
+
*/
|
|
119
|
+
TreeClasses["nodeToggleButton"] = "p-tree-node-toggle-button";
|
|
120
|
+
/**
|
|
121
|
+
* Class name of the node toggle icon element
|
|
122
|
+
*/
|
|
123
|
+
TreeClasses["nodeToggleIcon"] = "p-tree-node-toggle-icon";
|
|
124
|
+
/**
|
|
125
|
+
* Class name of the node checkbox element
|
|
126
|
+
*/
|
|
127
|
+
TreeClasses["nodeCheckbox"] = "p-tree-node-checkbox";
|
|
128
|
+
/**
|
|
129
|
+
* Class name of the node icon element
|
|
130
|
+
*/
|
|
131
|
+
TreeClasses["nodeIcon"] = "p-tree-node-icon";
|
|
132
|
+
/**
|
|
133
|
+
* Class name of the node label element
|
|
134
|
+
*/
|
|
135
|
+
TreeClasses["nodeLabel"] = "p-tree-node-label";
|
|
136
|
+
/**
|
|
137
|
+
* Class name of the node children element
|
|
138
|
+
*/
|
|
139
|
+
TreeClasses["nodeChildren"] = "p-tree-node-children";
|
|
140
|
+
/**
|
|
141
|
+
* Class name of the empty message element
|
|
142
|
+
*/
|
|
143
|
+
TreeClasses["emptyMessage"] = "p-tree-empty-message";
|
|
144
|
+
/**
|
|
145
|
+
* Class name of the drop point element
|
|
146
|
+
*/
|
|
147
|
+
TreeClasses["dropPoint"] = "p-tree-node-droppoint";
|
|
148
|
+
})(TreeClasses || (TreeClasses = {}));
|
|
149
|
+
|
|
150
|
+
class UITreeNode extends BaseComponent {
|
|
151
|
+
$pcTreeNode = inject(TREENODE_INSTANCE, { optional: true, skipSelf: true }) ?? undefined;
|
|
152
|
+
static ICON_CLASS = 'p-tree-node-icon ';
|
|
153
|
+
rowNode = input(/* @ts-ignore */
|
|
154
|
+
...(ngDevMode ? [undefined, { debugName: "rowNode" }] : /* istanbul ignore next */ []));
|
|
155
|
+
node = input(/* @ts-ignore */
|
|
156
|
+
...(ngDevMode ? [undefined, { debugName: "node" }] : /* istanbul ignore next */ []));
|
|
157
|
+
parentNode = input(/* @ts-ignore */
|
|
158
|
+
...(ngDevMode ? [undefined, { debugName: "parentNode" }] : /* istanbul ignore next */ []));
|
|
159
|
+
root = input(false, { ...(ngDevMode ? { debugName: "root" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
160
|
+
index = input(/* @ts-ignore */
|
|
161
|
+
...(ngDevMode ? [undefined, { debugName: "index" }] : /* istanbul ignore next */ []));
|
|
162
|
+
firstChild = input(false, { ...(ngDevMode ? { debugName: "firstChild" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
163
|
+
lastChild = input(false, { ...(ngDevMode ? { debugName: "lastChild" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
164
|
+
level = input(/* @ts-ignore */
|
|
165
|
+
...(ngDevMode ? [undefined, { debugName: "level" }] : /* istanbul ignore next */ []));
|
|
166
|
+
indentation = input(/* @ts-ignore */
|
|
167
|
+
...(ngDevMode ? [undefined, { debugName: "indentation" }] : /* istanbul ignore next */ []));
|
|
168
|
+
itemSize = input(/* @ts-ignore */
|
|
169
|
+
...(ngDevMode ? [undefined, { debugName: "itemSize" }] : /* istanbul ignore next */ []));
|
|
170
|
+
loadingMode = input(/* @ts-ignore */
|
|
171
|
+
...(ngDevMode ? [undefined, { debugName: "loadingMode" }] : /* istanbul ignore next */ []));
|
|
172
|
+
tree = inject(TREE_INSTANCE);
|
|
173
|
+
timeout;
|
|
174
|
+
isPrevDropPointHovered = signal(false, /* @ts-ignore */
|
|
175
|
+
...(ngDevMode ? [{ debugName: "isPrevDropPointHovered" }] : /* istanbul ignore next */ []));
|
|
176
|
+
isNextDropPointHovered = signal(false, /* @ts-ignore */
|
|
177
|
+
...(ngDevMode ? [{ debugName: "isNextDropPointHovered" }] : /* istanbul ignore next */ []));
|
|
178
|
+
isNodeDropHovered = signal(false, /* @ts-ignore */
|
|
179
|
+
...(ngDevMode ? [{ debugName: "isNodeDropHovered" }] : /* istanbul ignore next */ []));
|
|
180
|
+
isPrevDropPointActive = computed(() => this.isPrevDropPointHovered() && this.isDroppable(), /* @ts-ignore */
|
|
181
|
+
...(ngDevMode ? [{ debugName: "isPrevDropPointActive" }] : /* istanbul ignore next */ []));
|
|
182
|
+
isNextDropPointActive = computed(() => this.isNextDropPointHovered() && this.isDroppable(), /* @ts-ignore */
|
|
183
|
+
...(ngDevMode ? [{ debugName: "isNextDropPointActive" }] : /* istanbul ignore next */ []));
|
|
184
|
+
isNodeDropActive = computed(() => this.isNodeDropHovered() && this.isNodeDroppable(), /* @ts-ignore */
|
|
185
|
+
...(ngDevMode ? [{ debugName: "isNodeDropActive" }] : /* istanbul ignore next */ []));
|
|
186
|
+
dropPosition = computed(() => (this.isPrevDropPointActive() ? -1 : this.isNextDropPointActive() ? 1 : 0), /* @ts-ignore */
|
|
187
|
+
...(ngDevMode ? [{ debugName: "dropPosition" }] : /* istanbul ignore next */ []));
|
|
188
|
+
get ariaSetSize() {
|
|
189
|
+
return this.node()?.children?.length ?? 0;
|
|
190
|
+
}
|
|
191
|
+
get ariaExpanded() {
|
|
192
|
+
return this.node()?.expanded;
|
|
193
|
+
}
|
|
194
|
+
ariaPosInSet = computed(() => (this.index() ?? 0) + 1, /* @ts-ignore */
|
|
195
|
+
...(ngDevMode ? [{ debugName: "ariaPosInSet" }] : /* istanbul ignore next */ []));
|
|
196
|
+
ariaLevel = computed(() => (this.level() ?? 0) + 1, /* @ts-ignore */
|
|
197
|
+
...(ngDevMode ? [{ debugName: "ariaLevel" }] : /* istanbul ignore next */ []));
|
|
198
|
+
nodeTabindex = computed(() => (this.index() === 0 ? 0 : -1), /* @ts-ignore */
|
|
199
|
+
...(ngDevMode ? [{ debugName: "nodeTabindex" }] : /* istanbul ignore next */ []));
|
|
200
|
+
nodeContentPaddingLeft = computed(() => this.level() * this.indentation() + 'rem', /* @ts-ignore */
|
|
201
|
+
...(ngDevMode ? [{ debugName: "nodeContentPaddingLeft" }] : /* istanbul ignore next */ []));
|
|
202
|
+
get hasNodeIcon() {
|
|
203
|
+
return !!(this.node()?.icon || this.node()?.expandedIcon || this.node()?.collapsedIcon);
|
|
204
|
+
}
|
|
205
|
+
get showChildren() {
|
|
206
|
+
return !this.tree.virtualScroll() && !!this.node()?.children && !!this.node()?.expanded;
|
|
207
|
+
}
|
|
208
|
+
get showLoadingSpinner() {
|
|
209
|
+
return this.loadingMode() === 'icon' && !!this.node()?.loading;
|
|
210
|
+
}
|
|
211
|
+
checkboxVariant = computed(() => this.tree?.config.inputVariant() || 'outlined', /* @ts-ignore */
|
|
212
|
+
...(ngDevMode ? [{ debugName: "checkboxVariant" }] : /* istanbul ignore next */ []));
|
|
213
|
+
get togglerIconContext() {
|
|
214
|
+
return {
|
|
215
|
+
$implicit: this.node()?.expanded,
|
|
216
|
+
loading: this.node()?.loading
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
get checkboxIconContext() {
|
|
220
|
+
return {
|
|
221
|
+
$implicit: this.isSelected(),
|
|
222
|
+
partialSelected: this.node()?.partialSelected,
|
|
223
|
+
class: this.cx('nodeCheckbox')
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
_componentStyle = inject(TreeStyle);
|
|
227
|
+
/**
|
|
228
|
+
* Computed signal that reactively tracks selection state.
|
|
229
|
+
*/
|
|
230
|
+
_selected = computed(() => {
|
|
231
|
+
// Reading selection() makes this computed reactive to selection changes
|
|
232
|
+
this.tree.selection();
|
|
233
|
+
return this.tree.isSelected(this.node());
|
|
234
|
+
}, /* @ts-ignore */
|
|
235
|
+
...(ngDevMode ? [{ debugName: "_selected" }] : /* istanbul ignore next */ []));
|
|
236
|
+
/**
|
|
237
|
+
* Computed signal that reactively tracks context menu selection state.
|
|
238
|
+
*/
|
|
239
|
+
_contextMenuSelected = computed(() => {
|
|
240
|
+
const selection = this.tree.contextMenuSelection();
|
|
241
|
+
const node = this.node();
|
|
242
|
+
if (!selection || !node) {
|
|
243
|
+
return false;
|
|
244
|
+
}
|
|
245
|
+
return selection === node || (selection.key && selection.key === node.key);
|
|
246
|
+
}, /* @ts-ignore */
|
|
247
|
+
...(ngDevMode ? [{ debugName: "_contextMenuSelected" }] : /* istanbul ignore next */ []));
|
|
248
|
+
get selected() {
|
|
249
|
+
return this.tree.selectionMode() === 'single' || this.tree.selectionMode() === 'multiple' ? this._selected() : undefined;
|
|
250
|
+
}
|
|
251
|
+
get checked() {
|
|
252
|
+
return this.tree.selectionMode() === 'checkbox' ? this._selected() : undefined;
|
|
253
|
+
}
|
|
254
|
+
get nodeClass() {
|
|
255
|
+
return this.tree._componentStyle.classes.node({ instance: this });
|
|
256
|
+
}
|
|
257
|
+
get selectable() {
|
|
258
|
+
return this.node()?.selectable === false ? false : this.tree?.selectionMode() != null;
|
|
259
|
+
}
|
|
260
|
+
get subNodes() {
|
|
261
|
+
return this.node()?.parent ? this.node().parent.children : this.tree.value();
|
|
262
|
+
}
|
|
263
|
+
getPTOptions(key) {
|
|
264
|
+
return this.ptm(key, {
|
|
265
|
+
context: {
|
|
266
|
+
node: this.node(),
|
|
267
|
+
index: this.index(),
|
|
268
|
+
expanded: this.node()?.expanded,
|
|
269
|
+
selected: this.selected,
|
|
270
|
+
checked: this.checked,
|
|
271
|
+
partialChecked: this.node()?.partialSelected,
|
|
272
|
+
leaf: this.isLeaf()
|
|
273
|
+
}
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
onInit() {
|
|
277
|
+
this.node().parent = this.parentNode();
|
|
278
|
+
const nativeElement = this.tree.el.nativeElement;
|
|
279
|
+
const pDialogWrapper = nativeElement.closest('p-dialog');
|
|
280
|
+
if (this.parentNode() && !pDialogWrapper) {
|
|
281
|
+
this.setAllNodesTabIndexes();
|
|
282
|
+
this.tree.syncNodeOption(this.node(), this.tree.value(), 'parent', this.tree.getNodeWithKey(this.parentNode().key, this.tree.value()));
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
getIcon() {
|
|
286
|
+
let icon;
|
|
287
|
+
const node = this.node();
|
|
288
|
+
if (node.icon)
|
|
289
|
+
icon = node.icon;
|
|
290
|
+
else
|
|
291
|
+
icon = node.expanded && node.children && node.children?.length ? node.expandedIcon : node.collapsedIcon;
|
|
292
|
+
return UITreeNode.ICON_CLASS + ' ' + icon + ' p-tree-node-icon';
|
|
293
|
+
}
|
|
294
|
+
isLeaf() {
|
|
295
|
+
return this.tree.isNodeLeaf(this.node());
|
|
296
|
+
}
|
|
297
|
+
isSelected() {
|
|
298
|
+
return this._selected();
|
|
299
|
+
}
|
|
300
|
+
isContextMenuSelected() {
|
|
301
|
+
return this._contextMenuSelected();
|
|
302
|
+
}
|
|
303
|
+
isSameNode(event) {
|
|
304
|
+
return event.currentTarget && (event.currentTarget.isSameNode(event.target) || event.currentTarget.isSameNode(event.target.closest('[role="treeitem"]')));
|
|
305
|
+
}
|
|
306
|
+
isDraggable() {
|
|
307
|
+
return this.tree.draggableNodes();
|
|
308
|
+
}
|
|
309
|
+
isDroppable() {
|
|
310
|
+
return this.tree.droppableNodes() && this.tree.allowDrop(this.tree.dragNode, this.node(), this.tree.dragNodeScope);
|
|
311
|
+
}
|
|
312
|
+
isNodeDroppable() {
|
|
313
|
+
return this.node()?.droppable !== false && this.isDroppable();
|
|
314
|
+
}
|
|
315
|
+
isNodeDraggable() {
|
|
316
|
+
return this.node()?.draggable !== false && this.isDraggable();
|
|
317
|
+
}
|
|
318
|
+
toggle(event) {
|
|
319
|
+
if (this.node().expanded)
|
|
320
|
+
this.collapse(event);
|
|
321
|
+
else
|
|
322
|
+
this.expand(event);
|
|
323
|
+
event.stopPropagation();
|
|
324
|
+
}
|
|
325
|
+
expand(event) {
|
|
326
|
+
this.node().expanded = true;
|
|
327
|
+
this.tree.setNodeCollapsed(this.node(), false);
|
|
328
|
+
if (this.tree.virtualScroll()) {
|
|
329
|
+
this.tree.updateSerializedValue();
|
|
330
|
+
this.focusVirtualNode();
|
|
331
|
+
}
|
|
332
|
+
this.tree.onNodeExpand.emit({ originalEvent: event, node: this.node() });
|
|
333
|
+
}
|
|
334
|
+
collapse(event) {
|
|
335
|
+
this.node().expanded = false;
|
|
336
|
+
this.tree.setNodeCollapsed(this.node(), true);
|
|
337
|
+
if (this.tree.virtualScroll()) {
|
|
338
|
+
this.tree.updateSerializedValue();
|
|
339
|
+
}
|
|
340
|
+
this.tree.onNodeCollapse.emit({ originalEvent: event, node: this.node() });
|
|
341
|
+
this.focusVirtualNode();
|
|
342
|
+
}
|
|
343
|
+
onNodeClick(event) {
|
|
344
|
+
this.tree.onNodeClick(event, this.node());
|
|
345
|
+
}
|
|
346
|
+
onNodeKeydown(event) {
|
|
347
|
+
if (event.key === 'Enter') {
|
|
348
|
+
this.tree.onNodeClick(event, this.node());
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
onNodeTouchEnd() {
|
|
352
|
+
this.tree.onNodeTouchEnd();
|
|
353
|
+
}
|
|
354
|
+
onNodeRightClick(event) {
|
|
355
|
+
this.tree.onNodeRightClick(event, this.node());
|
|
356
|
+
}
|
|
357
|
+
onNodeDblClick(event) {
|
|
358
|
+
this.tree.onNodeDblClick(event, this.node());
|
|
359
|
+
}
|
|
360
|
+
insertNodeOnDrop() {
|
|
361
|
+
const { dragNode, dragNodeIndex, dragNodeSubNodes } = this.tree;
|
|
362
|
+
if (!this.node() || dragNodeIndex == null || !dragNode || !dragNodeSubNodes) {
|
|
363
|
+
return;
|
|
364
|
+
}
|
|
365
|
+
const position = this.dropPosition();
|
|
366
|
+
const subNodes = this.subNodes || [];
|
|
367
|
+
const index = this.index() || 0;
|
|
368
|
+
const dropIndex = dragNodeSubNodes === subNodes ? (dragNodeIndex > index ? index : index - 1) : index;
|
|
369
|
+
dragNodeSubNodes.splice(dragNodeIndex, 1);
|
|
370
|
+
if (position < 0) {
|
|
371
|
+
// insert before a Node
|
|
372
|
+
subNodes.splice(dropIndex, 0, dragNode);
|
|
373
|
+
}
|
|
374
|
+
else if (position > 0) {
|
|
375
|
+
// insert after a Node
|
|
376
|
+
subNodes.splice(dropIndex + 1, 0, dragNode);
|
|
377
|
+
}
|
|
378
|
+
else {
|
|
379
|
+
// insert as child of a Node
|
|
380
|
+
this.node().children = this.node().children || [];
|
|
381
|
+
this.node().children.push(dragNode);
|
|
382
|
+
}
|
|
383
|
+
this.tree.dragDropService.stopDrag({
|
|
384
|
+
node: dragNode,
|
|
385
|
+
subNodes,
|
|
386
|
+
index: dragNodeIndex
|
|
387
|
+
});
|
|
388
|
+
}
|
|
389
|
+
onNodeDrop(event) {
|
|
390
|
+
event.preventDefault();
|
|
391
|
+
event.stopPropagation();
|
|
392
|
+
if (this.isDroppable()) {
|
|
393
|
+
const { dragNode } = this.tree;
|
|
394
|
+
const position = this.dropPosition();
|
|
395
|
+
const isValidDrop = position !== 0 || (position === 0 && this.isNodeDroppable());
|
|
396
|
+
const dropPoint = position === 0 ? 'node' : 'between';
|
|
397
|
+
if (isValidDrop) {
|
|
398
|
+
if (this.tree.validateDrop()) {
|
|
399
|
+
this.tree.onNodeDrop.emit({
|
|
400
|
+
originalEvent: event,
|
|
401
|
+
dragNode: dragNode,
|
|
402
|
+
dropNode: this.node(),
|
|
403
|
+
index: this.index(),
|
|
404
|
+
dropPoint: dropPoint,
|
|
405
|
+
accept: () => {
|
|
406
|
+
this.insertNodeOnDrop();
|
|
407
|
+
}
|
|
408
|
+
});
|
|
409
|
+
}
|
|
410
|
+
else {
|
|
411
|
+
this.insertNodeOnDrop();
|
|
412
|
+
this.tree.onNodeDrop.emit({
|
|
413
|
+
originalEvent: event,
|
|
414
|
+
dragNode: dragNode,
|
|
415
|
+
dropNode: this.node(),
|
|
416
|
+
index: this.index(),
|
|
417
|
+
dropPoint: dropPoint
|
|
418
|
+
});
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
this.isPrevDropPointHovered.set(false);
|
|
423
|
+
this.isNextDropPointHovered.set(false);
|
|
424
|
+
this.isNodeDropHovered.set(false);
|
|
425
|
+
}
|
|
426
|
+
onNodeDragStart(event) {
|
|
427
|
+
if (this.isNodeDraggable()) {
|
|
428
|
+
event.dataTransfer.effectAllowed = 'all';
|
|
429
|
+
event.dataTransfer?.setData('text', 'data');
|
|
430
|
+
const target = event.currentTarget;
|
|
431
|
+
const dragEl = target.cloneNode(true);
|
|
432
|
+
const toggler = dragEl.querySelector('[data-pc-section="nodetogglebutton"]');
|
|
433
|
+
const checkbox = dragEl.querySelector('[data-pc-name="pcnodecheckbox"]');
|
|
434
|
+
target.setAttribute('data-p-dragging', 'true');
|
|
435
|
+
dragEl.style.width = getOuterWidth(target) + 'px';
|
|
436
|
+
dragEl.style.height = getOuterHeight(target) + 'px';
|
|
437
|
+
dragEl.setAttribute('data-pc-section', 'drag-image');
|
|
438
|
+
toggler.style.visibility = 'hidden';
|
|
439
|
+
checkbox?.remove();
|
|
440
|
+
document.body.appendChild(dragEl);
|
|
441
|
+
event.dataTransfer?.setDragImage(dragEl, 0, 0);
|
|
442
|
+
setTimeout(() => document.body.removeChild(dragEl), 0);
|
|
443
|
+
this.tree.dragDropService.startDrag({
|
|
444
|
+
tree: this,
|
|
445
|
+
node: this.node(),
|
|
446
|
+
subNodes: this.subNodes,
|
|
447
|
+
index: this.index(),
|
|
448
|
+
scope: this.tree.draggableScope()
|
|
449
|
+
});
|
|
450
|
+
}
|
|
451
|
+
else {
|
|
452
|
+
event.preventDefault();
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
onNodeDragOver(event) {
|
|
456
|
+
if (this.isDroppable()) {
|
|
457
|
+
event.dataTransfer.dropEffect = 'copy';
|
|
458
|
+
const nodeElement = event.currentTarget;
|
|
459
|
+
const rect = nodeElement.getBoundingClientRect();
|
|
460
|
+
const y = event.clientY - parseInt(rect.top);
|
|
461
|
+
this.isPrevDropPointHovered.set(false);
|
|
462
|
+
this.isNextDropPointHovered.set(false);
|
|
463
|
+
this.isNodeDropHovered.set(false);
|
|
464
|
+
if (y < rect.height * 0.25) {
|
|
465
|
+
this.isPrevDropPointHovered.set(true);
|
|
466
|
+
}
|
|
467
|
+
else if (y > rect.height * 0.75) {
|
|
468
|
+
this.isNextDropPointHovered.set(true);
|
|
469
|
+
}
|
|
470
|
+
else if (this.isNodeDroppable()) {
|
|
471
|
+
this.isNodeDropHovered.set(true);
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
else {
|
|
475
|
+
event.dataTransfer.dropEffect = 'none';
|
|
476
|
+
}
|
|
477
|
+
if (this.tree.droppableNodes()) {
|
|
478
|
+
event.preventDefault();
|
|
479
|
+
event.stopPropagation();
|
|
480
|
+
}
|
|
481
|
+
}
|
|
482
|
+
onNodeDragLeave() {
|
|
483
|
+
this.isPrevDropPointHovered.set(false);
|
|
484
|
+
this.isNextDropPointHovered.set(false);
|
|
485
|
+
this.isNodeDropHovered.set(false);
|
|
486
|
+
}
|
|
487
|
+
onNodeDragEnd(event) {
|
|
488
|
+
event.currentTarget?.removeAttribute('data-p-dragging');
|
|
489
|
+
this.tree.dragDropService.stopDrag({
|
|
490
|
+
node: this.node(),
|
|
491
|
+
subNodes: this.subNodes,
|
|
492
|
+
index: this.index()
|
|
493
|
+
});
|
|
494
|
+
}
|
|
495
|
+
onKeyDown(event) {
|
|
496
|
+
if (!this.isSameNode(event) || (this.tree.contextMenu() && this.tree.contextMenu().containerViewChild?.nativeElement.style.display === 'block')) {
|
|
497
|
+
return;
|
|
498
|
+
}
|
|
499
|
+
switch (event.code) {
|
|
500
|
+
//down arrow
|
|
501
|
+
case 'ArrowDown':
|
|
502
|
+
this.onArrowDown(event);
|
|
503
|
+
break;
|
|
504
|
+
//up arrow
|
|
505
|
+
case 'ArrowUp':
|
|
506
|
+
this.onArrowUp(event);
|
|
507
|
+
break;
|
|
508
|
+
//right arrow
|
|
509
|
+
case 'ArrowRight':
|
|
510
|
+
this.onArrowRight(event);
|
|
511
|
+
break;
|
|
512
|
+
//left arrow
|
|
513
|
+
case 'ArrowLeft':
|
|
514
|
+
this.onArrowLeft(event);
|
|
515
|
+
break;
|
|
516
|
+
//enter
|
|
517
|
+
case 'Enter':
|
|
518
|
+
case 'Space':
|
|
519
|
+
case 'NumpadEnter':
|
|
520
|
+
this.onEnter(event);
|
|
521
|
+
break;
|
|
522
|
+
//tab
|
|
523
|
+
case 'Tab':
|
|
524
|
+
this.setAllNodesTabIndexes();
|
|
525
|
+
break;
|
|
526
|
+
default:
|
|
527
|
+
//no op
|
|
528
|
+
break;
|
|
529
|
+
}
|
|
530
|
+
}
|
|
531
|
+
onArrowUp(event) {
|
|
532
|
+
const nodeElement = event.target.getAttribute('data-pc-section') === 'nodetogglebutton' ? event.target.closest('[role="treeitem"]') : event.target.parentElement;
|
|
533
|
+
if (nodeElement?.previousElementSibling) {
|
|
534
|
+
this.focusRowChange(nodeElement, nodeElement.previousElementSibling, this.findLastVisibleDescendant(nodeElement.previousElementSibling));
|
|
535
|
+
}
|
|
536
|
+
else {
|
|
537
|
+
let parentNodeElement = this.getParentNodeElement(nodeElement);
|
|
538
|
+
if (parentNodeElement) {
|
|
539
|
+
this.focusRowChange(nodeElement, parentNodeElement);
|
|
540
|
+
}
|
|
541
|
+
}
|
|
542
|
+
event.preventDefault();
|
|
543
|
+
}
|
|
544
|
+
onArrowDown(event) {
|
|
545
|
+
const nodeElement = event.target.getAttribute('data-pc-section') === 'nodetogglebutton' ? event.target.closest('[role="treeitem"]') : event.target;
|
|
546
|
+
const listElement = nodeElement?.children[1];
|
|
547
|
+
if (listElement && listElement.children.length > 0) {
|
|
548
|
+
this.focusRowChange(nodeElement, listElement.children[0]);
|
|
549
|
+
}
|
|
550
|
+
else {
|
|
551
|
+
if (nodeElement?.parentElement?.nextElementSibling) {
|
|
552
|
+
this.focusRowChange(nodeElement, nodeElement.parentElement.nextElementSibling);
|
|
553
|
+
}
|
|
554
|
+
else {
|
|
555
|
+
let nextSiblingAncestor = this.findNextSiblingOfAncestor(nodeElement?.parentElement);
|
|
556
|
+
if (nextSiblingAncestor) {
|
|
557
|
+
this.focusRowChange(nodeElement, nextSiblingAncestor);
|
|
558
|
+
}
|
|
559
|
+
}
|
|
560
|
+
}
|
|
561
|
+
event.preventDefault();
|
|
562
|
+
}
|
|
563
|
+
onArrowRight(event) {
|
|
564
|
+
if (!this.node()?.expanded && !this.tree.isNodeLeaf(this.node())) {
|
|
565
|
+
this.expand(event);
|
|
566
|
+
event.currentTarget.tabIndex = -1;
|
|
567
|
+
setTimeout(() => {
|
|
568
|
+
this.onArrowDown(event);
|
|
569
|
+
}, 1);
|
|
570
|
+
}
|
|
571
|
+
event.preventDefault();
|
|
572
|
+
}
|
|
573
|
+
onArrowLeft(event) {
|
|
574
|
+
const nodeElement = event.target.getAttribute('data-pc-section') === 'nodetogglebutton' ? event.target.closest('[role="treeitem"]') : event.target;
|
|
575
|
+
if (this.level() === 0 && !this.node()?.expanded) {
|
|
576
|
+
return false;
|
|
577
|
+
}
|
|
578
|
+
if (this.node()?.expanded) {
|
|
579
|
+
this.collapse(event);
|
|
580
|
+
return;
|
|
581
|
+
}
|
|
582
|
+
let parentNodeElement = this.getParentNodeElement(nodeElement?.parentElement);
|
|
583
|
+
if (parentNodeElement) {
|
|
584
|
+
this.focusRowChange(event.currentTarget, parentNodeElement);
|
|
585
|
+
}
|
|
586
|
+
event.preventDefault();
|
|
587
|
+
}
|
|
588
|
+
onEnter(event) {
|
|
589
|
+
this.tree.onNodeClick(event, this.node());
|
|
590
|
+
this.setTabIndexForSelectionMode(event, this.tree.nodeTouched);
|
|
591
|
+
event.preventDefault();
|
|
592
|
+
}
|
|
593
|
+
setAllNodesTabIndexes() {
|
|
594
|
+
const nodes = find(this.tree.el.nativeElement, '[data-pc-section="node"]');
|
|
595
|
+
const hasSelectedNode = [...nodes].some((node) => node.getAttribute('aria-selected') === 'true' || node.getAttribute('aria-checked') === 'true');
|
|
596
|
+
[...nodes].forEach((node) => {
|
|
597
|
+
node.tabIndex = -1;
|
|
598
|
+
});
|
|
599
|
+
if (hasSelectedNode) {
|
|
600
|
+
const selectedNodes = [...nodes].filter((node) => node.getAttribute('aria-selected') === 'true' || node.getAttribute('aria-checked') === 'true');
|
|
601
|
+
selectedNodes[0].tabIndex = 0;
|
|
602
|
+
return;
|
|
603
|
+
}
|
|
604
|
+
if (nodes.length) {
|
|
605
|
+
[...nodes][0].tabIndex = 0;
|
|
606
|
+
}
|
|
607
|
+
}
|
|
608
|
+
setTabIndexForSelectionMode(event, nodeTouched) {
|
|
609
|
+
if (this.tree.selectionMode() !== null) {
|
|
610
|
+
const elements = [...find(this.tree.el.nativeElement, '[role="treeitem"]')];
|
|
611
|
+
event.currentTarget.tabIndex = nodeTouched === false ? -1 : 0;
|
|
612
|
+
if (elements.every((element) => element.tabIndex === -1)) {
|
|
613
|
+
elements[0].tabIndex = 0;
|
|
614
|
+
}
|
|
615
|
+
}
|
|
616
|
+
}
|
|
617
|
+
findNextSiblingOfAncestor(nodeElement) {
|
|
618
|
+
let parentNodeElement = this.getParentNodeElement(nodeElement);
|
|
619
|
+
if (parentNodeElement) {
|
|
620
|
+
if (parentNodeElement.nextElementSibling)
|
|
621
|
+
return parentNodeElement.nextElementSibling;
|
|
622
|
+
else
|
|
623
|
+
return this.findNextSiblingOfAncestor(parentNodeElement);
|
|
624
|
+
}
|
|
625
|
+
else {
|
|
626
|
+
return null;
|
|
627
|
+
}
|
|
628
|
+
}
|
|
629
|
+
findLastVisibleDescendant(nodeElement) {
|
|
630
|
+
const listElement = Array.from(nodeElement.children).find((el) => el.getAttribute('data-pc-section') === 'node');
|
|
631
|
+
const childrenListElement = listElement?.children[1];
|
|
632
|
+
if (childrenListElement && childrenListElement.children.length > 0) {
|
|
633
|
+
const lastChildElement = childrenListElement.children[childrenListElement.children.length - 1];
|
|
634
|
+
return this.findLastVisibleDescendant(lastChildElement);
|
|
635
|
+
}
|
|
636
|
+
else {
|
|
637
|
+
return nodeElement;
|
|
638
|
+
}
|
|
639
|
+
}
|
|
640
|
+
getParentNodeElement(nodeElement) {
|
|
641
|
+
const parentNodeElement = nodeElement.parentElement?.parentElement?.parentElement;
|
|
642
|
+
return parentNodeElement?.tagName === 'P-TREENODE' ? parentNodeElement : null;
|
|
643
|
+
}
|
|
644
|
+
focusNode(element) {
|
|
645
|
+
element.children[0].focus();
|
|
646
|
+
}
|
|
647
|
+
focusRowChange(firstFocusableRow, currentFocusedRow, lastVisibleDescendant) {
|
|
648
|
+
firstFocusableRow.tabIndex = '-1';
|
|
649
|
+
currentFocusedRow.children[0].tabIndex = '0';
|
|
650
|
+
this.focusNode(lastVisibleDescendant || currentFocusedRow);
|
|
651
|
+
}
|
|
652
|
+
focusVirtualNode() {
|
|
653
|
+
this.timeout = setTimeout(() => {
|
|
654
|
+
let node = findSingle(this.tree?.contentViewChild()?.nativeElement, `[data-id="${this.node()?.key ?? this.node()?.data}"]`);
|
|
655
|
+
focus(node);
|
|
656
|
+
}, 1);
|
|
657
|
+
}
|
|
658
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: UITreeNode, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
659
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: UITreeNode, isStandalone: true, selector: "p-treenode", inputs: { rowNode: { classPropertyName: "rowNode", publicName: "rowNode", isSignal: true, isRequired: false, transformFunction: null }, node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: false, transformFunction: null }, parentNode: { classPropertyName: "parentNode", publicName: "parentNode", isSignal: true, isRequired: false, transformFunction: null }, root: { classPropertyName: "root", publicName: "root", isSignal: true, isRequired: false, transformFunction: null }, index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: false, transformFunction: null }, firstChild: { classPropertyName: "firstChild", publicName: "firstChild", isSignal: true, isRequired: false, transformFunction: null }, lastChild: { classPropertyName: "lastChild", publicName: "lastChild", isSignal: true, isRequired: false, transformFunction: null }, level: { classPropertyName: "level", publicName: "level", isSignal: true, isRequired: false, transformFunction: null }, indentation: { classPropertyName: "indentation", publicName: "indentation", isSignal: true, isRequired: false, transformFunction: null }, itemSize: { classPropertyName: "itemSize", publicName: "itemSize", isSignal: true, isRequired: false, transformFunction: null }, loadingMode: { classPropertyName: "loadingMode", publicName: "loadingMode", isSignal: true, isRequired: false, transformFunction: null } }, providers: [TreeStyle, { provide: TREENODE_INSTANCE, useExisting: UITreeNode }, { provide: PARENT_INSTANCE, useExisting: UITreeNode }], usesInheritance: true, ngImport: i0, template: `
|
|
660
|
+
@if (node()) {
|
|
661
|
+
<li
|
|
662
|
+
[class]="cn(cx('node'), node()!.styleClass)"
|
|
663
|
+
[style.height.px]="itemSize()"
|
|
664
|
+
[style]="node()!.style"
|
|
665
|
+
[attr.aria-label]="node()!.label"
|
|
666
|
+
[attr.aria-checked]="checked"
|
|
667
|
+
[attr.aria-setsize]="ariaSetSize"
|
|
668
|
+
[attr.aria-selected]="selected"
|
|
669
|
+
[attr.aria-expanded]="ariaExpanded"
|
|
670
|
+
[attr.aria-posinset]="ariaPosInSet()"
|
|
671
|
+
[attr.aria-level]="ariaLevel()"
|
|
672
|
+
[attr.tabindex]="nodeTabindex()"
|
|
673
|
+
[attr.data-id]="node()!.key"
|
|
674
|
+
role="treeitem"
|
|
675
|
+
(keydown)="onKeyDown($event)"
|
|
676
|
+
[pBind]="getPTOptions('node')"
|
|
677
|
+
>
|
|
678
|
+
@if (isPrevDropPointActive()) {
|
|
679
|
+
<div [class]="cx('dropPoint')" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
|
|
680
|
+
}
|
|
681
|
+
<div
|
|
682
|
+
[class]="cx('nodeContent')"
|
|
683
|
+
[style.paddingLeft]="nodeContentPaddingLeft()"
|
|
684
|
+
(click)="onNodeClick($event)"
|
|
685
|
+
(contextmenu)="onNodeRightClick($event)"
|
|
686
|
+
(dblclick)="onNodeDblClick($event)"
|
|
687
|
+
(touchend)="onNodeTouchEnd()"
|
|
688
|
+
(drop)="onNodeDrop($event)"
|
|
689
|
+
(dragstart)="onNodeDragStart($event)"
|
|
690
|
+
(dragover)="onNodeDragOver($event)"
|
|
691
|
+
(dragleave)="onNodeDragLeave($event)"
|
|
692
|
+
(dragend)="onNodeDragEnd($event)"
|
|
693
|
+
[draggable]="tree.draggableNodes()"
|
|
694
|
+
[pBind]="getPTOptions('nodeContent')"
|
|
695
|
+
>
|
|
696
|
+
<button type="button" [class]="cx('nodeToggleButton')" (click)="toggle($event)" pRipple tabindex="-1" [pBind]="getPTOptions('nodeToggleButton')">
|
|
697
|
+
@if (!tree.togglerIconTemplate()) {
|
|
698
|
+
@if (!node()!.loading) {
|
|
699
|
+
@if (!node()!.expanded) {
|
|
700
|
+
<svg data-p-icon="chevron-right" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
|
|
701
|
+
}
|
|
702
|
+
@if (node()!.expanded) {
|
|
703
|
+
<svg data-p-icon="chevron-down" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
|
|
704
|
+
}
|
|
705
|
+
}
|
|
706
|
+
@if (showLoadingSpinner) {
|
|
707
|
+
<svg data-p-icon="spinner" [class]="cn(cx('nodeToggleIcon'), 'animate-spin')" [pBind]="getPTOptions('nodeToggleIcon')" />
|
|
708
|
+
}
|
|
709
|
+
}
|
|
710
|
+
@if (tree.togglerIconTemplate()) {
|
|
711
|
+
<span [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')">
|
|
712
|
+
<ng-template *ngTemplateOutlet="tree.togglerIconTemplate()!; context: togglerIconContext"></ng-template>
|
|
713
|
+
</span>
|
|
714
|
+
}
|
|
715
|
+
</button>
|
|
716
|
+
|
|
717
|
+
@if (tree.selectionMode() == 'checkbox') {
|
|
718
|
+
<p-checkbox
|
|
719
|
+
[ngModel]="isSelected()"
|
|
720
|
+
[class]="cx('nodeCheckbox')"
|
|
721
|
+
[binary]="true"
|
|
722
|
+
[indeterminate]="node()!.partialSelected"
|
|
723
|
+
[disabled]="node()!.selectable === false"
|
|
724
|
+
[variant]="checkboxVariant()"
|
|
725
|
+
[attr.data-p-partialchecked]="node()!.partialSelected"
|
|
726
|
+
[tabindex]="-1"
|
|
727
|
+
(click)="$event.preventDefault()"
|
|
728
|
+
[pt]="getPTOptions('pcNodeCheckbox')"
|
|
729
|
+
[unstyled]="unstyled()"
|
|
730
|
+
>
|
|
731
|
+
@if (tree.checkboxIconTemplate()) {
|
|
732
|
+
<ng-template #icon>
|
|
733
|
+
<ng-template *ngTemplateOutlet="tree.checkboxIconTemplate()!; context: checkboxIconContext"></ng-template>
|
|
734
|
+
</ng-template>
|
|
735
|
+
}
|
|
736
|
+
</p-checkbox>
|
|
737
|
+
}
|
|
738
|
+
|
|
739
|
+
@if (hasNodeIcon) {
|
|
740
|
+
<span [class]="getIcon()" [pBind]="getPTOptions('nodeIcon')"></span>
|
|
741
|
+
}
|
|
742
|
+
<span [class]="cx('nodeLabel')" [pBind]="getPTOptions('nodeLabel')">
|
|
743
|
+
@if (!tree.getTemplateForNode(node()!)) {
|
|
744
|
+
<span>{{ node()!.label }}</span>
|
|
745
|
+
}
|
|
746
|
+
@if (tree.getTemplateForNode(node()!)) {
|
|
747
|
+
<span>
|
|
748
|
+
<ng-container *ngTemplateOutlet="tree.getTemplateForNode(node()!)!; context: { $implicit: node() }"></ng-container>
|
|
749
|
+
</span>
|
|
750
|
+
}
|
|
751
|
+
</span>
|
|
752
|
+
</div>
|
|
753
|
+
@if (isNextDropPointActive()) {
|
|
754
|
+
<div [class]="cx('dropPoint', { next: true })" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
|
|
755
|
+
}
|
|
756
|
+
@if (showChildren) {
|
|
757
|
+
<ul [class]="cx('nodeChildren')" role="group" [pBind]="ptm('nodeChildren')">
|
|
758
|
+
@for (childNode of node()!.children; track tree.trackBy()($index, childNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
|
|
759
|
+
<p-treenode
|
|
760
|
+
[node]="childNode"
|
|
761
|
+
[parentNode]="node()"
|
|
762
|
+
[firstChild]="firstChild"
|
|
763
|
+
[lastChild]="lastChild"
|
|
764
|
+
[index]="idx"
|
|
765
|
+
[itemSize]="itemSize()"
|
|
766
|
+
[level]="level()! + 1"
|
|
767
|
+
[loadingMode]="loadingMode()"
|
|
768
|
+
[pt]="pt"
|
|
769
|
+
[unstyled]="unstyled()"
|
|
770
|
+
/>
|
|
771
|
+
}
|
|
772
|
+
</ul>
|
|
773
|
+
}
|
|
774
|
+
</li>
|
|
775
|
+
}
|
|
776
|
+
`, isInline: true, dependencies: [{ kind: "component", type: UITreeNode, selector: "p-treenode", inputs: ["rowNode", "node", "parentNode", "root", "index", "firstChild", "lastChild", "level", "indentation", "itemSize", "loadingMode"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: Ripple, selector: "[pRipple]" }, { kind: "component", type: Checkbox, selector: "p-checkbox, p-check-box", inputs: ["value", "binary", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "inputStyle", "inputClass", "indeterminate", "formControl", "checkboxIcon", "readonly", "autofocus", "trueValue", "falseValue", "variant", "size"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: ChevronRight, selector: "svg[data-p-icon=\"chevron-right\"]" }, { kind: "component", type: ChevronDown, selector: "svg[data-p-icon=\"chevron-down\"]" }, { kind: "component", type: Spinner, selector: "svg[data-p-icon=\"spinner\"]" }, { kind: "directive", type: Bind, selector: "[pBind]", inputs: ["pBind"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
777
|
+
}
|
|
778
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: UITreeNode, decorators: [{
|
|
779
|
+
type: Component,
|
|
780
|
+
args: [{
|
|
781
|
+
selector: 'p-treenode',
|
|
782
|
+
standalone: true,
|
|
783
|
+
imports: [NgTemplateOutlet, Ripple, Checkbox, FormsModule, ChevronRight, ChevronDown, Spinner, Bind],
|
|
784
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
785
|
+
template: `
|
|
786
|
+
@if (node()) {
|
|
787
|
+
<li
|
|
788
|
+
[class]="cn(cx('node'), node()!.styleClass)"
|
|
789
|
+
[style.height.px]="itemSize()"
|
|
790
|
+
[style]="node()!.style"
|
|
791
|
+
[attr.aria-label]="node()!.label"
|
|
792
|
+
[attr.aria-checked]="checked"
|
|
793
|
+
[attr.aria-setsize]="ariaSetSize"
|
|
794
|
+
[attr.aria-selected]="selected"
|
|
795
|
+
[attr.aria-expanded]="ariaExpanded"
|
|
796
|
+
[attr.aria-posinset]="ariaPosInSet()"
|
|
797
|
+
[attr.aria-level]="ariaLevel()"
|
|
798
|
+
[attr.tabindex]="nodeTabindex()"
|
|
799
|
+
[attr.data-id]="node()!.key"
|
|
800
|
+
role="treeitem"
|
|
801
|
+
(keydown)="onKeyDown($event)"
|
|
802
|
+
[pBind]="getPTOptions('node')"
|
|
803
|
+
>
|
|
804
|
+
@if (isPrevDropPointActive()) {
|
|
805
|
+
<div [class]="cx('dropPoint')" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
|
|
806
|
+
}
|
|
807
|
+
<div
|
|
808
|
+
[class]="cx('nodeContent')"
|
|
809
|
+
[style.paddingLeft]="nodeContentPaddingLeft()"
|
|
810
|
+
(click)="onNodeClick($event)"
|
|
811
|
+
(contextmenu)="onNodeRightClick($event)"
|
|
812
|
+
(dblclick)="onNodeDblClick($event)"
|
|
813
|
+
(touchend)="onNodeTouchEnd()"
|
|
814
|
+
(drop)="onNodeDrop($event)"
|
|
815
|
+
(dragstart)="onNodeDragStart($event)"
|
|
816
|
+
(dragover)="onNodeDragOver($event)"
|
|
817
|
+
(dragleave)="onNodeDragLeave($event)"
|
|
818
|
+
(dragend)="onNodeDragEnd($event)"
|
|
819
|
+
[draggable]="tree.draggableNodes()"
|
|
820
|
+
[pBind]="getPTOptions('nodeContent')"
|
|
821
|
+
>
|
|
822
|
+
<button type="button" [class]="cx('nodeToggleButton')" (click)="toggle($event)" pRipple tabindex="-1" [pBind]="getPTOptions('nodeToggleButton')">
|
|
823
|
+
@if (!tree.togglerIconTemplate()) {
|
|
824
|
+
@if (!node()!.loading) {
|
|
825
|
+
@if (!node()!.expanded) {
|
|
826
|
+
<svg data-p-icon="chevron-right" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
|
|
827
|
+
}
|
|
828
|
+
@if (node()!.expanded) {
|
|
829
|
+
<svg data-p-icon="chevron-down" [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')" />
|
|
830
|
+
}
|
|
831
|
+
}
|
|
832
|
+
@if (showLoadingSpinner) {
|
|
833
|
+
<svg data-p-icon="spinner" [class]="cn(cx('nodeToggleIcon'), 'animate-spin')" [pBind]="getPTOptions('nodeToggleIcon')" />
|
|
834
|
+
}
|
|
835
|
+
}
|
|
836
|
+
@if (tree.togglerIconTemplate()) {
|
|
837
|
+
<span [class]="cx('nodeToggleIcon')" [pBind]="getPTOptions('nodeToggleIcon')">
|
|
838
|
+
<ng-template *ngTemplateOutlet="tree.togglerIconTemplate()!; context: togglerIconContext"></ng-template>
|
|
839
|
+
</span>
|
|
840
|
+
}
|
|
841
|
+
</button>
|
|
842
|
+
|
|
843
|
+
@if (tree.selectionMode() == 'checkbox') {
|
|
844
|
+
<p-checkbox
|
|
845
|
+
[ngModel]="isSelected()"
|
|
846
|
+
[class]="cx('nodeCheckbox')"
|
|
847
|
+
[binary]="true"
|
|
848
|
+
[indeterminate]="node()!.partialSelected"
|
|
849
|
+
[disabled]="node()!.selectable === false"
|
|
850
|
+
[variant]="checkboxVariant()"
|
|
851
|
+
[attr.data-p-partialchecked]="node()!.partialSelected"
|
|
852
|
+
[tabindex]="-1"
|
|
853
|
+
(click)="$event.preventDefault()"
|
|
854
|
+
[pt]="getPTOptions('pcNodeCheckbox')"
|
|
855
|
+
[unstyled]="unstyled()"
|
|
856
|
+
>
|
|
857
|
+
@if (tree.checkboxIconTemplate()) {
|
|
858
|
+
<ng-template #icon>
|
|
859
|
+
<ng-template *ngTemplateOutlet="tree.checkboxIconTemplate()!; context: checkboxIconContext"></ng-template>
|
|
860
|
+
</ng-template>
|
|
861
|
+
}
|
|
862
|
+
</p-checkbox>
|
|
863
|
+
}
|
|
864
|
+
|
|
865
|
+
@if (hasNodeIcon) {
|
|
866
|
+
<span [class]="getIcon()" [pBind]="getPTOptions('nodeIcon')"></span>
|
|
867
|
+
}
|
|
868
|
+
<span [class]="cx('nodeLabel')" [pBind]="getPTOptions('nodeLabel')">
|
|
869
|
+
@if (!tree.getTemplateForNode(node()!)) {
|
|
870
|
+
<span>{{ node()!.label }}</span>
|
|
871
|
+
}
|
|
872
|
+
@if (tree.getTemplateForNode(node()!)) {
|
|
873
|
+
<span>
|
|
874
|
+
<ng-container *ngTemplateOutlet="tree.getTemplateForNode(node()!)!; context: { $implicit: node() }"></ng-container>
|
|
875
|
+
</span>
|
|
876
|
+
}
|
|
877
|
+
</span>
|
|
878
|
+
</div>
|
|
879
|
+
@if (isNextDropPointActive()) {
|
|
880
|
+
<div [class]="cx('dropPoint', { next: true })" [attr.aria-hidden]="true" [pBind]="getPTOptions('dropPoint')"></div>
|
|
881
|
+
}
|
|
882
|
+
@if (showChildren) {
|
|
883
|
+
<ul [class]="cx('nodeChildren')" role="group" [pBind]="ptm('nodeChildren')">
|
|
884
|
+
@for (childNode of node()!.children; track tree.trackBy()($index, childNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
|
|
885
|
+
<p-treenode
|
|
886
|
+
[node]="childNode"
|
|
887
|
+
[parentNode]="node()"
|
|
888
|
+
[firstChild]="firstChild"
|
|
889
|
+
[lastChild]="lastChild"
|
|
890
|
+
[index]="idx"
|
|
891
|
+
[itemSize]="itemSize()"
|
|
892
|
+
[level]="level()! + 1"
|
|
893
|
+
[loadingMode]="loadingMode()"
|
|
894
|
+
[pt]="pt"
|
|
895
|
+
[unstyled]="unstyled()"
|
|
896
|
+
/>
|
|
897
|
+
}
|
|
898
|
+
</ul>
|
|
899
|
+
}
|
|
900
|
+
</li>
|
|
901
|
+
}
|
|
902
|
+
`,
|
|
903
|
+
encapsulation: ViewEncapsulation.None,
|
|
904
|
+
providers: [TreeStyle, { provide: TREENODE_INSTANCE, useExisting: UITreeNode }, { provide: PARENT_INSTANCE, useExisting: UITreeNode }]
|
|
905
|
+
}]
|
|
906
|
+
}], propDecorators: { rowNode: [{ type: i0.Input, args: [{ isSignal: true, alias: "rowNode", required: false }] }], node: [{ type: i0.Input, args: [{ isSignal: true, alias: "node", required: false }] }], parentNode: [{ type: i0.Input, args: [{ isSignal: true, alias: "parentNode", required: false }] }], root: [{ type: i0.Input, args: [{ isSignal: true, alias: "root", required: false }] }], index: [{ type: i0.Input, args: [{ isSignal: true, alias: "index", required: false }] }], firstChild: [{ type: i0.Input, args: [{ isSignal: true, alias: "firstChild", required: false }] }], lastChild: [{ type: i0.Input, args: [{ isSignal: true, alias: "lastChild", required: false }] }], level: [{ type: i0.Input, args: [{ isSignal: true, alias: "level", required: false }] }], indentation: [{ type: i0.Input, args: [{ isSignal: true, alias: "indentation", required: false }] }], itemSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "itemSize", required: false }] }], loadingMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingMode", required: false }] }] } });
|
|
907
|
+
|
|
908
|
+
/**
|
|
909
|
+
* Tree is used to display hierarchical data.
|
|
910
|
+
* @group Components
|
|
911
|
+
*/
|
|
912
|
+
class Tree extends BaseComponent {
|
|
913
|
+
componentName = 'Tree';
|
|
914
|
+
_destroyed = false;
|
|
915
|
+
bindDirectiveInstance = inject(Bind, { self: true });
|
|
916
|
+
$pcTree = inject(TREE_INSTANCE, { optional: true, skipSelf: true }) ?? undefined;
|
|
917
|
+
onDestroy() {
|
|
918
|
+
this._destroyed = true;
|
|
919
|
+
}
|
|
920
|
+
onAfterViewChecked() {
|
|
921
|
+
this.bindDirectiveInstance.setAttrs(this.ptms(['host', 'root']));
|
|
922
|
+
}
|
|
923
|
+
/**
|
|
924
|
+
* An array of treenodes.
|
|
925
|
+
* @group Props
|
|
926
|
+
*/
|
|
927
|
+
value = input(/* @ts-ignore */
|
|
928
|
+
...(ngDevMode ? [undefined, { debugName: "value" }] : /* istanbul ignore next */ []));
|
|
929
|
+
/**
|
|
930
|
+
* Defines the selection mode.
|
|
931
|
+
* @group Props
|
|
932
|
+
*/
|
|
933
|
+
selectionMode = input(/* @ts-ignore */
|
|
934
|
+
...(ngDevMode ? [undefined, { debugName: "selectionMode" }] : /* istanbul ignore next */ []));
|
|
935
|
+
/**
|
|
936
|
+
* Loading mode display.
|
|
937
|
+
* @group Props
|
|
938
|
+
*/
|
|
939
|
+
loadingMode = input('mask', /* @ts-ignore */
|
|
940
|
+
...(ngDevMode ? [{ debugName: "loadingMode" }] : /* istanbul ignore next */ []));
|
|
941
|
+
/**
|
|
942
|
+
* A single treenode instance or an array to refer to the selections.
|
|
943
|
+
* @deprecated since v22, use `selectionKeys` instead for key-based selection state.
|
|
944
|
+
* @group Props
|
|
945
|
+
*/
|
|
946
|
+
selection = model(null, /* @ts-ignore */
|
|
947
|
+
...(ngDevMode ? [{ debugName: "selection" }] : /* istanbul ignore next */ []));
|
|
948
|
+
/**
|
|
949
|
+
* A map of node keys (by `TreeNode.key`) whose value is `true` for collapsed nodes. Two-way bindable.
|
|
950
|
+
* When provided it controls expansion (a node is expanded unless its key maps to `true`); leave it
|
|
951
|
+
* unset to keep driving expansion from each node's `expanded` flag (default, non-breaking).
|
|
952
|
+
* @group Props
|
|
953
|
+
*/
|
|
954
|
+
collapsedKeys = model(null, /* @ts-ignore */
|
|
955
|
+
...(ngDevMode ? [{ debugName: "collapsedKeys" }] : /* istanbul ignore next */ []));
|
|
956
|
+
/**
|
|
957
|
+
* A map of node keys (by `TreeNode.key`) describing the selection state. Two-way bindable.
|
|
958
|
+
* For single/multiple selection a key maps to `true`; for checkbox selection it maps to
|
|
959
|
+
* `{ checked, partialChecked }`. When provided it is kept in sync with `selection`; leave it unset
|
|
960
|
+
* to keep using the node-reference based `selection` model (default, non-breaking).
|
|
961
|
+
* @group Props
|
|
962
|
+
*/
|
|
963
|
+
selectionKeys = model(null, /* @ts-ignore */
|
|
964
|
+
...(ngDevMode ? [{ debugName: "selectionKeys" }] : /* istanbul ignore next */ []));
|
|
965
|
+
/**
|
|
966
|
+
* Context menu instance.
|
|
967
|
+
* @group Props
|
|
968
|
+
*/
|
|
969
|
+
contextMenu = input(/* @ts-ignore */
|
|
970
|
+
...(ngDevMode ? [undefined, { debugName: "contextMenu" }] : /* istanbul ignore next */ []));
|
|
971
|
+
/**
|
|
972
|
+
* Selected node with a context menu.
|
|
973
|
+
* @group Props
|
|
974
|
+
*/
|
|
975
|
+
contextMenuSelection = model(null, /* @ts-ignore */
|
|
976
|
+
...(ngDevMode ? [{ debugName: "contextMenuSelection" }] : /* istanbul ignore next */ []));
|
|
977
|
+
/**
|
|
978
|
+
* Scope of the draggable nodes to match a droppableScope.
|
|
979
|
+
* @group Props
|
|
980
|
+
*/
|
|
981
|
+
draggableScope = input(/* @ts-ignore */
|
|
982
|
+
...(ngDevMode ? [undefined, { debugName: "draggableScope" }] : /* istanbul ignore next */ []));
|
|
983
|
+
/**
|
|
984
|
+
* Scope of the droppable nodes to match a draggableScope.
|
|
985
|
+
* @group Props
|
|
986
|
+
*/
|
|
987
|
+
droppableScope = input(/* @ts-ignore */
|
|
988
|
+
...(ngDevMode ? [undefined, { debugName: "droppableScope" }] : /* istanbul ignore next */ []));
|
|
989
|
+
/**
|
|
990
|
+
* Whether the nodes are draggable.
|
|
991
|
+
* @group Props
|
|
992
|
+
*/
|
|
993
|
+
draggableNodes = input(false, { ...(ngDevMode ? { debugName: "draggableNodes" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
994
|
+
/**
|
|
995
|
+
* Whether the nodes are droppable.
|
|
996
|
+
* @group Props
|
|
997
|
+
*/
|
|
998
|
+
droppableNodes = input(false, { ...(ngDevMode ? { debugName: "droppableNodes" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
999
|
+
/**
|
|
1000
|
+
* Defines how multiple items can be selected, when true metaKey needs to be pressed to select or unselect an item and when set to false selection of each item can be toggled individually. On touch enabled devices, metaKeySelection is turned off automatically.
|
|
1001
|
+
* @group Props
|
|
1002
|
+
*/
|
|
1003
|
+
metaKeySelection = input(false, { ...(ngDevMode ? { debugName: "metaKeySelection" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1004
|
+
/**
|
|
1005
|
+
* Whether checkbox selections propagate to ancestor nodes.
|
|
1006
|
+
* @group Props
|
|
1007
|
+
*/
|
|
1008
|
+
propagateSelectionUp = input(true, { ...(ngDevMode ? { debugName: "propagateSelectionUp" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1009
|
+
/**
|
|
1010
|
+
* Whether checkbox selections propagate to descendant nodes.
|
|
1011
|
+
* @group Props
|
|
1012
|
+
*/
|
|
1013
|
+
propagateSelectionDown = input(true, { ...(ngDevMode ? { debugName: "propagateSelectionDown" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1014
|
+
/**
|
|
1015
|
+
* Displays a loader to indicate data load is in progress.
|
|
1016
|
+
* @group Props
|
|
1017
|
+
*/
|
|
1018
|
+
loading = input(false, { ...(ngDevMode ? { debugName: "loading" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1019
|
+
/**
|
|
1020
|
+
* The icon to show while indicating data load is in progress.
|
|
1021
|
+
* @group Props
|
|
1022
|
+
*/
|
|
1023
|
+
loadingIcon = input(/* @ts-ignore */
|
|
1024
|
+
...(ngDevMode ? [undefined, { debugName: "loadingIcon" }] : /* istanbul ignore next */ []));
|
|
1025
|
+
/**
|
|
1026
|
+
* Text to display when there is no data.
|
|
1027
|
+
* @group Props
|
|
1028
|
+
*/
|
|
1029
|
+
emptyMessage = input('', /* @ts-ignore */
|
|
1030
|
+
...(ngDevMode ? [{ debugName: "emptyMessage" }] : /* istanbul ignore next */ []));
|
|
1031
|
+
/**
|
|
1032
|
+
* Used to define a string that labels the tree.
|
|
1033
|
+
* @group Props
|
|
1034
|
+
*/
|
|
1035
|
+
ariaLabel = input(/* @ts-ignore */
|
|
1036
|
+
...(ngDevMode ? [undefined, { debugName: "ariaLabel" }] : /* istanbul ignore next */ []));
|
|
1037
|
+
/**
|
|
1038
|
+
* Defines a string that labels the toggler icon for accessibility.
|
|
1039
|
+
* @group Props
|
|
1040
|
+
*/
|
|
1041
|
+
togglerAriaLabel = input(/* @ts-ignore */
|
|
1042
|
+
...(ngDevMode ? [undefined, { debugName: "togglerAriaLabel" }] : /* istanbul ignore next */ []));
|
|
1043
|
+
/**
|
|
1044
|
+
* Establishes relationships between the component and label(s) where its value should be one or more element IDs.
|
|
1045
|
+
* @group Props
|
|
1046
|
+
*/
|
|
1047
|
+
ariaLabelledBy = input(/* @ts-ignore */
|
|
1048
|
+
...(ngDevMode ? [undefined, { debugName: "ariaLabelledBy" }] : /* istanbul ignore next */ []));
|
|
1049
|
+
/**
|
|
1050
|
+
* When enabled, drop can be accepted or rejected based on condition defined at onNodeDrop.
|
|
1051
|
+
* @group Props
|
|
1052
|
+
*/
|
|
1053
|
+
validateDrop = input(false, { ...(ngDevMode ? { debugName: "validateDrop" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1054
|
+
/**
|
|
1055
|
+
* When specified, displays an input field to filter the items.
|
|
1056
|
+
* @group Props
|
|
1057
|
+
*/
|
|
1058
|
+
filter = input(false, { ...(ngDevMode ? { debugName: "filter" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1059
|
+
/**
|
|
1060
|
+
* Determines whether the filter input should be automatically focused when the component is rendered.
|
|
1061
|
+
* @group Props
|
|
1062
|
+
*/
|
|
1063
|
+
filterInputAutoFocus = input(false, { ...(ngDevMode ? { debugName: "filterInputAutoFocus" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1064
|
+
/**
|
|
1065
|
+
* When filtering is enabled, filterBy decides which field or fields (comma separated) to search against.
|
|
1066
|
+
* @group Props
|
|
1067
|
+
*/
|
|
1068
|
+
filterBy = input('label', /* @ts-ignore */
|
|
1069
|
+
...(ngDevMode ? [{ debugName: "filterBy" }] : /* istanbul ignore next */ []));
|
|
1070
|
+
/**
|
|
1071
|
+
* Mode for filtering valid values are "lenient" and "strict". Default is lenient.
|
|
1072
|
+
* @group Props
|
|
1073
|
+
*/
|
|
1074
|
+
filterMode = input('lenient', /* @ts-ignore */
|
|
1075
|
+
...(ngDevMode ? [{ debugName: "filterMode" }] : /* istanbul ignore next */ []));
|
|
1076
|
+
/**
|
|
1077
|
+
* Mode for filtering valid values are "lenient" and "strict". Default is lenient.
|
|
1078
|
+
* @group Props
|
|
1079
|
+
*/
|
|
1080
|
+
filterOptions;
|
|
1081
|
+
/**
|
|
1082
|
+
* Placeholder text to show when filter input is empty.
|
|
1083
|
+
* @group Props
|
|
1084
|
+
*/
|
|
1085
|
+
filterPlaceholder = input(/* @ts-ignore */
|
|
1086
|
+
...(ngDevMode ? [undefined, { debugName: "filterPlaceholder" }] : /* istanbul ignore next */ []));
|
|
1087
|
+
/**
|
|
1088
|
+
* Values after the tree nodes are filtered.
|
|
1089
|
+
* @group Props
|
|
1090
|
+
*/
|
|
1091
|
+
filteredNodes;
|
|
1092
|
+
/**
|
|
1093
|
+
* Locale to use in filtering. The default locale is the host environment's current locale.
|
|
1094
|
+
* @group Props
|
|
1095
|
+
*/
|
|
1096
|
+
filterLocale = input(/* @ts-ignore */
|
|
1097
|
+
...(ngDevMode ? [undefined, { debugName: "filterLocale" }] : /* istanbul ignore next */ []));
|
|
1098
|
+
/**
|
|
1099
|
+
* Height of the scrollable viewport.
|
|
1100
|
+
* @group Props
|
|
1101
|
+
*/
|
|
1102
|
+
scrollHeight = input(/* @ts-ignore */
|
|
1103
|
+
...(ngDevMode ? [undefined, { debugName: "scrollHeight" }] : /* istanbul ignore next */ []));
|
|
1104
|
+
/**
|
|
1105
|
+
* Defines if data is loaded and interacted with in lazy manner.
|
|
1106
|
+
* @group Props
|
|
1107
|
+
*/
|
|
1108
|
+
lazy = input(false, { ...(ngDevMode ? { debugName: "lazy" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1109
|
+
/**
|
|
1110
|
+
* Whether the data should be loaded on demand during scroll.
|
|
1111
|
+
* @group Props
|
|
1112
|
+
*/
|
|
1113
|
+
virtualScroll = input(false, { ...(ngDevMode ? { debugName: "virtualScroll" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1114
|
+
/**
|
|
1115
|
+
* Height of an item in the list for VirtualScrolling.
|
|
1116
|
+
* @group Props
|
|
1117
|
+
*/
|
|
1118
|
+
virtualScrollItemSize = input(/* @ts-ignore */
|
|
1119
|
+
...(ngDevMode ? [undefined, { debugName: "virtualScrollItemSize" }] : /* istanbul ignore next */ []));
|
|
1120
|
+
/**
|
|
1121
|
+
* Whether to use the scroller feature. The properties of scroller component can be used like an object in it.
|
|
1122
|
+
* @group Props
|
|
1123
|
+
*/
|
|
1124
|
+
virtualScrollOptions = input(/* @ts-ignore */
|
|
1125
|
+
...(ngDevMode ? [undefined, { debugName: "virtualScrollOptions" }] : /* istanbul ignore next */ []));
|
|
1126
|
+
/**
|
|
1127
|
+
* Indentation factor for spacing of the nested node when virtual scrolling is enabled.
|
|
1128
|
+
* @group Props
|
|
1129
|
+
*/
|
|
1130
|
+
indentation = input(1.5, { ...(ngDevMode ? { debugName: "indentation" } : /* istanbul ignore next */ {}), transform: numberAttribute });
|
|
1131
|
+
/**
|
|
1132
|
+
* Function to optimize the node list rendering, default algorithm checks for object identity.
|
|
1133
|
+
* @group Props
|
|
1134
|
+
*/
|
|
1135
|
+
trackBy = input((index, item) => item, /* @ts-ignore */
|
|
1136
|
+
...(ngDevMode ? [{ debugName: "trackBy" }] : /* istanbul ignore next */ []));
|
|
1137
|
+
/**
|
|
1138
|
+
* Highlights the node on select.
|
|
1139
|
+
* @group Props
|
|
1140
|
+
*/
|
|
1141
|
+
highlightOnSelect = input(false, { ...(ngDevMode ? { debugName: "highlightOnSelect" } : /* istanbul ignore next */ {}), transform: booleanAttribute });
|
|
1142
|
+
/**
|
|
1143
|
+
* Callback to invoke when a node is selected.
|
|
1144
|
+
* @param {TreeNodeSelectEvent} event - Node select event.
|
|
1145
|
+
* @group Emits
|
|
1146
|
+
*/
|
|
1147
|
+
onNodeSelect = output();
|
|
1148
|
+
/**
|
|
1149
|
+
* Callback to invoke when a node is unselected.
|
|
1150
|
+
* @param {TreeNodeUnSelectEvent} event - Node unselect event.
|
|
1151
|
+
* @group Emits
|
|
1152
|
+
*/
|
|
1153
|
+
onNodeUnselect = output();
|
|
1154
|
+
/**
|
|
1155
|
+
* Callback to invoke when a node is expanded.
|
|
1156
|
+
* @param {TreeNodeExpandEvent} event - Node expand event.
|
|
1157
|
+
* @group Emits
|
|
1158
|
+
*/
|
|
1159
|
+
onNodeExpand = output();
|
|
1160
|
+
/**
|
|
1161
|
+
* Callback to invoke when a node is collapsed.
|
|
1162
|
+
* @param {TreeNodeCollapseEvent} event - Node collapse event.
|
|
1163
|
+
* @group Emits
|
|
1164
|
+
*/
|
|
1165
|
+
onNodeCollapse = output();
|
|
1166
|
+
/**
|
|
1167
|
+
* Callback to invoke when a node is selected with right click.
|
|
1168
|
+
* @param {onNodeContextMenuSelect} event - Node context menu select event.
|
|
1169
|
+
* @group Emits
|
|
1170
|
+
*/
|
|
1171
|
+
onNodeContextMenuSelect = output();
|
|
1172
|
+
/**
|
|
1173
|
+
* Callback to invoke when a node is double clicked.
|
|
1174
|
+
* @param {TreeNodeDoubleClickEvent} event - Node double click event.
|
|
1175
|
+
* @group Emits
|
|
1176
|
+
*/
|
|
1177
|
+
onNodeDoubleClick = output();
|
|
1178
|
+
/**
|
|
1179
|
+
* Callback to invoke when a node is dropped.
|
|
1180
|
+
* @param {TreeNodeDropEvent} event - Node drop event.
|
|
1181
|
+
* @group Emits
|
|
1182
|
+
*/
|
|
1183
|
+
onNodeDrop = output();
|
|
1184
|
+
/**
|
|
1185
|
+
* Callback to invoke in lazy mode to load new data.
|
|
1186
|
+
* @param {TreeLazyLoadEvent} event - Custom lazy load event.
|
|
1187
|
+
* @group Emits
|
|
1188
|
+
*/
|
|
1189
|
+
onLazyLoad = output();
|
|
1190
|
+
/**
|
|
1191
|
+
* Callback to invoke in virtual scroll mode when scroll position changes.
|
|
1192
|
+
* @param {TreeScrollEvent} event - Custom scroll event.
|
|
1193
|
+
* @group Emits
|
|
1194
|
+
*/
|
|
1195
|
+
onScroll = output();
|
|
1196
|
+
/**
|
|
1197
|
+
* Callback to invoke in virtual scroll mode when scroll position and item's range in view changes.
|
|
1198
|
+
* @param {TreeScrollIndexChangeEvent} event - Scroll index change event.
|
|
1199
|
+
* @group Emits
|
|
1200
|
+
*/
|
|
1201
|
+
onScrollIndexChange = output();
|
|
1202
|
+
/**
|
|
1203
|
+
* Callback to invoke when data is filtered.
|
|
1204
|
+
* @param {TreeFilterEvent} event - Custom filter event.
|
|
1205
|
+
* @group Emits
|
|
1206
|
+
*/
|
|
1207
|
+
onFilter = output();
|
|
1208
|
+
/**
|
|
1209
|
+
* Custom filter template.
|
|
1210
|
+
* @param {TreeFilterTemplateContext} context - filter context.
|
|
1211
|
+
* @see {@link TreeFilterTemplateContext}
|
|
1212
|
+
* @group Templates
|
|
1213
|
+
*/
|
|
1214
|
+
filterTemplate = contentChild('filter', { ...(ngDevMode ? { debugName: "filterTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1215
|
+
/**
|
|
1216
|
+
* Custom node template.
|
|
1217
|
+
* @group Templates
|
|
1218
|
+
*/
|
|
1219
|
+
nodeTemplate = contentChild('node', { ...(ngDevMode ? { debugName: "nodeTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1220
|
+
/**
|
|
1221
|
+
* Custom header template.
|
|
1222
|
+
* @group Templates
|
|
1223
|
+
*/
|
|
1224
|
+
headerTemplate = contentChild('header', { ...(ngDevMode ? { debugName: "headerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1225
|
+
/**
|
|
1226
|
+
* Custom footer template.
|
|
1227
|
+
* @group Templates
|
|
1228
|
+
*/
|
|
1229
|
+
footerTemplate = contentChild('footer', { ...(ngDevMode ? { debugName: "footerTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1230
|
+
/**
|
|
1231
|
+
* Custom loader template.
|
|
1232
|
+
* @param {TreeLoaderTemplateContext} context - loader context.
|
|
1233
|
+
* @see {@link TreeLoaderTemplateContext}
|
|
1234
|
+
* @group Templates
|
|
1235
|
+
*/
|
|
1236
|
+
loaderTemplate = contentChild('loader', { ...(ngDevMode ? { debugName: "loaderTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1237
|
+
/**
|
|
1238
|
+
* Custom empty message template.
|
|
1239
|
+
* @group Templates
|
|
1240
|
+
*/
|
|
1241
|
+
emptyTemplate = contentChild('empty', { ...(ngDevMode ? { debugName: "emptyTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1242
|
+
/**
|
|
1243
|
+
* Custom toggler icon template.
|
|
1244
|
+
* @param {TreeTogglerIconTemplateContext} context - toggler icon context.
|
|
1245
|
+
* @see {@link TreeTogglerIconTemplateContext}
|
|
1246
|
+
* @group Templates
|
|
1247
|
+
*/
|
|
1248
|
+
togglerIconTemplate = contentChild('togglericon', { ...(ngDevMode ? { debugName: "togglerIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1249
|
+
/**
|
|
1250
|
+
* Custom checkbox icon template.
|
|
1251
|
+
* @param {TreeCheckboxIconTemplateContext} context - checkbox icon context.
|
|
1252
|
+
* @see {@link TreeCheckboxIconTemplateContext}
|
|
1253
|
+
* @group Templates
|
|
1254
|
+
*/
|
|
1255
|
+
checkboxIconTemplate = contentChild('checkboxicon', { ...(ngDevMode ? { debugName: "checkboxIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1256
|
+
/**
|
|
1257
|
+
* Custom loading icon template.
|
|
1258
|
+
* @group Templates
|
|
1259
|
+
*/
|
|
1260
|
+
loadingIconTemplate = contentChild('loadingicon', { ...(ngDevMode ? { debugName: "loadingIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1261
|
+
/**
|
|
1262
|
+
* Custom filter icon template.
|
|
1263
|
+
* @group Templates
|
|
1264
|
+
*/
|
|
1265
|
+
filterIconTemplate = contentChild('filtericon', { ...(ngDevMode ? { debugName: "filterIconTemplate" } : /* istanbul ignore next */ {}), descendants: false });
|
|
1266
|
+
filterViewChild = viewChild('filter', /* @ts-ignore */
|
|
1267
|
+
...(ngDevMode ? [{ debugName: "filterViewChild" }] : /* istanbul ignore next */ []));
|
|
1268
|
+
scroller = viewChild('scroller', /* @ts-ignore */
|
|
1269
|
+
...(ngDevMode ? [{ debugName: "scroller" }] : /* istanbul ignore next */ []));
|
|
1270
|
+
wrapperViewChild = viewChild('wrapper', /* @ts-ignore */
|
|
1271
|
+
...(ngDevMode ? [{ debugName: "wrapperViewChild" }] : /* istanbul ignore next */ []));
|
|
1272
|
+
contentViewChild = viewChild('content', /* @ts-ignore */
|
|
1273
|
+
...(ngDevMode ? [{ debugName: "contentViewChild" }] : /* istanbul ignore next */ []));
|
|
1274
|
+
serializedValue;
|
|
1275
|
+
nodeTouched;
|
|
1276
|
+
dragNodeTree;
|
|
1277
|
+
dragNode;
|
|
1278
|
+
dragNodeSubNodes;
|
|
1279
|
+
dragNodeIndex;
|
|
1280
|
+
dragNodeScope;
|
|
1281
|
+
dragHover;
|
|
1282
|
+
_componentStyle = inject(TreeStyle);
|
|
1283
|
+
dragDropService = inject(TreeDragDropService, { optional: true });
|
|
1284
|
+
destroyRef = inject(DestroyRef);
|
|
1285
|
+
constructor() {
|
|
1286
|
+
super();
|
|
1287
|
+
effect(() => {
|
|
1288
|
+
this.value();
|
|
1289
|
+
untracked(() => {
|
|
1290
|
+
this.updateSerializedValue();
|
|
1291
|
+
if (this.hasFilterActive()) {
|
|
1292
|
+
this._filter(this.filterViewChild()?.nativeElement?.value);
|
|
1293
|
+
}
|
|
1294
|
+
});
|
|
1295
|
+
});
|
|
1296
|
+
// Two-way `collapsedKeys` sync: when provided, project the map onto each node's `expanded` flag
|
|
1297
|
+
// so the existing expansion engine keeps working unchanged. Untracked writes avoid feedback loops.
|
|
1298
|
+
effect(() => {
|
|
1299
|
+
this.collapsedKeys();
|
|
1300
|
+
this.value();
|
|
1301
|
+
untracked(() => {
|
|
1302
|
+
if (this.collapsedKeys() == null) {
|
|
1303
|
+
return;
|
|
1304
|
+
}
|
|
1305
|
+
this.applyCollapsedKeys();
|
|
1306
|
+
this.updateSerializedValue();
|
|
1307
|
+
});
|
|
1308
|
+
});
|
|
1309
|
+
// Two-way `selectionKeys` <-> `selection` projection. Value-based comparison breaks the feedback
|
|
1310
|
+
// loop: once the two representations agree, neither effect writes again.
|
|
1311
|
+
effect(() => {
|
|
1312
|
+
this.selectionKeys();
|
|
1313
|
+
this.value();
|
|
1314
|
+
untracked(() => {
|
|
1315
|
+
if (this.selectionKeys() == null) {
|
|
1316
|
+
return;
|
|
1317
|
+
}
|
|
1318
|
+
if (!this.isSameSelectionKeys(this.deriveSelectionKeys(), this.selectionKeys())) {
|
|
1319
|
+
this.applySelectionKeys();
|
|
1320
|
+
}
|
|
1321
|
+
});
|
|
1322
|
+
});
|
|
1323
|
+
effect(() => {
|
|
1324
|
+
this.selection();
|
|
1325
|
+
untracked(() => {
|
|
1326
|
+
if (this.selectionKeys() == null) {
|
|
1327
|
+
return;
|
|
1328
|
+
}
|
|
1329
|
+
const derived = this.deriveSelectionKeys();
|
|
1330
|
+
if (!this.isSameSelectionKeys(derived, this.selectionKeys())) {
|
|
1331
|
+
this.selectionKeys.set(derived);
|
|
1332
|
+
}
|
|
1333
|
+
});
|
|
1334
|
+
});
|
|
1335
|
+
}
|
|
1336
|
+
onInit() {
|
|
1337
|
+
if (this.filterBy()) {
|
|
1338
|
+
this.filterOptions = {
|
|
1339
|
+
filter: (value) => this._filter(value),
|
|
1340
|
+
reset: () => this.resetFilter()
|
|
1341
|
+
};
|
|
1342
|
+
}
|
|
1343
|
+
if (this.droppableNodes()) {
|
|
1344
|
+
this.dragDropService?.dragStart$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {
|
|
1345
|
+
this.dragNodeTree = event.tree;
|
|
1346
|
+
this.dragNode = event.node;
|
|
1347
|
+
this.dragNodeSubNodes = event.subNodes;
|
|
1348
|
+
this.dragNodeIndex = event.index;
|
|
1349
|
+
this.dragNodeScope = event.scope;
|
|
1350
|
+
});
|
|
1351
|
+
this.dragDropService?.dragStop$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {
|
|
1352
|
+
this.dragNodeTree = null;
|
|
1353
|
+
this.dragNode = null;
|
|
1354
|
+
this.dragNodeSubNodes = null;
|
|
1355
|
+
this.dragNodeIndex = null;
|
|
1356
|
+
this.dragNodeScope = null;
|
|
1357
|
+
this.dragHover = false;
|
|
1358
|
+
});
|
|
1359
|
+
}
|
|
1360
|
+
}
|
|
1361
|
+
showLoadingMask = computed(() => this.loading() && this.loadingMode() === 'mask', /* @ts-ignore */
|
|
1362
|
+
...(ngDevMode ? [{ debugName: "showLoadingMask" }] : /* istanbul ignore next */ []));
|
|
1363
|
+
get showEmptyMessage() {
|
|
1364
|
+
return !this.loading() && (this.getRootNode() == null || this.getRootNode().length === 0);
|
|
1365
|
+
}
|
|
1366
|
+
scrollerStyleHeight = computed(() => (this.scrollHeight() !== 'flex' ? this.scrollHeight() : undefined), /* @ts-ignore */
|
|
1367
|
+
...(ngDevMode ? [{ debugName: "scrollerStyleHeight" }] : /* istanbul ignore next */ []));
|
|
1368
|
+
scrollerScrollHeight = computed(() => (this.scrollHeight() !== 'flex' ? undefined : '100%'), /* @ts-ignore */
|
|
1369
|
+
...(ngDevMode ? [{ debugName: "scrollerScrollHeight" }] : /* istanbul ignore next */ []));
|
|
1370
|
+
get emptyMessageLabel() {
|
|
1371
|
+
return this.emptyMessage() || this.translate(TranslationKeys.EMPTY_MESSAGE);
|
|
1372
|
+
}
|
|
1373
|
+
updateSerializedValue() {
|
|
1374
|
+
this.serializedValue = [];
|
|
1375
|
+
this.serializeNodes(null, this.getRootNode(), 0, true);
|
|
1376
|
+
}
|
|
1377
|
+
/**
|
|
1378
|
+
* Projects the current `collapsedKeys` map onto each node's `expanded` flag (a node is expanded
|
|
1379
|
+
* unless its key maps to `true`).
|
|
1380
|
+
*/
|
|
1381
|
+
applyCollapsedKeys() {
|
|
1382
|
+
const collapsedKeys = this.collapsedKeys();
|
|
1383
|
+
if (collapsedKeys == null) {
|
|
1384
|
+
return;
|
|
1385
|
+
}
|
|
1386
|
+
const walk = (nodes) => {
|
|
1387
|
+
if (!nodes)
|
|
1388
|
+
return;
|
|
1389
|
+
for (const node of nodes) {
|
|
1390
|
+
if (node.key != null) {
|
|
1391
|
+
node.expanded = !collapsedKeys[node.key];
|
|
1392
|
+
}
|
|
1393
|
+
if (node.children) {
|
|
1394
|
+
walk(node.children);
|
|
1395
|
+
}
|
|
1396
|
+
}
|
|
1397
|
+
};
|
|
1398
|
+
walk(this.getRootNode());
|
|
1399
|
+
}
|
|
1400
|
+
/**
|
|
1401
|
+
* Reflects a node's expansion change back into the two-way `collapsedKeys` map when it is in use.
|
|
1402
|
+
*/
|
|
1403
|
+
setNodeCollapsed(node, collapsed) {
|
|
1404
|
+
const collapsedKeys = this.collapsedKeys();
|
|
1405
|
+
if (collapsedKeys == null || node.key == null) {
|
|
1406
|
+
return;
|
|
1407
|
+
}
|
|
1408
|
+
const next = { ...collapsedKeys };
|
|
1409
|
+
if (collapsed) {
|
|
1410
|
+
next[node.key] = true;
|
|
1411
|
+
}
|
|
1412
|
+
else {
|
|
1413
|
+
delete next[node.key];
|
|
1414
|
+
}
|
|
1415
|
+
this.collapsedKeys.set(next);
|
|
1416
|
+
}
|
|
1417
|
+
/** Builds a `key -> node` lookup over the whole tree (for `selectionKeys` projection). */
|
|
1418
|
+
collectNodesByKey() {
|
|
1419
|
+
const map = new Map();
|
|
1420
|
+
const walk = (nodes) => {
|
|
1421
|
+
if (!nodes)
|
|
1422
|
+
return;
|
|
1423
|
+
for (const node of nodes) {
|
|
1424
|
+
if (node.key != null) {
|
|
1425
|
+
map.set(node.key, node);
|
|
1426
|
+
}
|
|
1427
|
+
if (node.children) {
|
|
1428
|
+
walk(node.children);
|
|
1429
|
+
}
|
|
1430
|
+
}
|
|
1431
|
+
};
|
|
1432
|
+
walk(this.getRootNode());
|
|
1433
|
+
return map;
|
|
1434
|
+
}
|
|
1435
|
+
/** Derives the `selectionKeys` map from the current `selection` (and `partialSelected` for checkbox). */
|
|
1436
|
+
deriveSelectionKeys() {
|
|
1437
|
+
const mode = this.selectionMode();
|
|
1438
|
+
const map = {};
|
|
1439
|
+
if (mode === 'checkbox') {
|
|
1440
|
+
const selection = this.selection() || [];
|
|
1441
|
+
const selectedKeys = new Set(selection.map((node) => node.key));
|
|
1442
|
+
const walk = (nodes) => {
|
|
1443
|
+
if (!nodes)
|
|
1444
|
+
return;
|
|
1445
|
+
for (const node of nodes) {
|
|
1446
|
+
if (node.key != null) {
|
|
1447
|
+
if (selectedKeys.has(node.key)) {
|
|
1448
|
+
map[node.key] = { checked: true, partialChecked: false };
|
|
1449
|
+
}
|
|
1450
|
+
else if (node.partialSelected) {
|
|
1451
|
+
map[node.key] = { checked: false, partialChecked: true };
|
|
1452
|
+
}
|
|
1453
|
+
}
|
|
1454
|
+
if (node.children) {
|
|
1455
|
+
walk(node.children);
|
|
1456
|
+
}
|
|
1457
|
+
}
|
|
1458
|
+
};
|
|
1459
|
+
walk(this.getRootNode());
|
|
1460
|
+
}
|
|
1461
|
+
else if (mode === 'single') {
|
|
1462
|
+
const selected = this.selection();
|
|
1463
|
+
if (selected?.key != null) {
|
|
1464
|
+
map[selected.key] = true;
|
|
1465
|
+
}
|
|
1466
|
+
}
|
|
1467
|
+
else {
|
|
1468
|
+
const selection = this.selection() || [];
|
|
1469
|
+
for (const node of selection) {
|
|
1470
|
+
if (node.key != null) {
|
|
1471
|
+
map[node.key] = true;
|
|
1472
|
+
}
|
|
1473
|
+
}
|
|
1474
|
+
}
|
|
1475
|
+
return map;
|
|
1476
|
+
}
|
|
1477
|
+
/** Applies the current `selectionKeys` map onto the `selection` model (and `partialSelected` for checkbox). */
|
|
1478
|
+
applySelectionKeys() {
|
|
1479
|
+
const keys = this.selectionKeys();
|
|
1480
|
+
if (keys == null) {
|
|
1481
|
+
return;
|
|
1482
|
+
}
|
|
1483
|
+
const mode = this.selectionMode();
|
|
1484
|
+
const nodesByKey = this.collectNodesByKey();
|
|
1485
|
+
const isChecked = (value) => value === true || value?.checked === true;
|
|
1486
|
+
if (mode === 'single') {
|
|
1487
|
+
const key = Object.keys(keys).find((k) => isChecked(keys[k]));
|
|
1488
|
+
this.selection.set(key != null ? (nodesByKey.get(key) ?? null) : null);
|
|
1489
|
+
return;
|
|
1490
|
+
}
|
|
1491
|
+
const selected = [];
|
|
1492
|
+
nodesByKey.forEach((node, key) => {
|
|
1493
|
+
const value = keys[key];
|
|
1494
|
+
if (mode === 'checkbox') {
|
|
1495
|
+
node.partialSelected = value?.partialChecked === true;
|
|
1496
|
+
}
|
|
1497
|
+
if (isChecked(value)) {
|
|
1498
|
+
selected.push(node);
|
|
1499
|
+
}
|
|
1500
|
+
});
|
|
1501
|
+
this.selection.set(selected);
|
|
1502
|
+
}
|
|
1503
|
+
/** Value-based equality for two `selectionKeys` maps (handles both boolean and `{checked,partialChecked}` values). */
|
|
1504
|
+
isSameSelectionKeys(a, b) {
|
|
1505
|
+
const aKeys = Object.keys(a || {});
|
|
1506
|
+
const bKeys = Object.keys(b || {});
|
|
1507
|
+
if (aKeys.length !== bKeys.length) {
|
|
1508
|
+
return false;
|
|
1509
|
+
}
|
|
1510
|
+
return aKeys.every((key) => {
|
|
1511
|
+
const av = a[key];
|
|
1512
|
+
const bv = b[key];
|
|
1513
|
+
if (av === bv)
|
|
1514
|
+
return true;
|
|
1515
|
+
if (av && bv && typeof av === 'object' && typeof bv === 'object') {
|
|
1516
|
+
return av.checked === bv.checked && av.partialChecked === bv.partialChecked;
|
|
1517
|
+
}
|
|
1518
|
+
return false;
|
|
1519
|
+
});
|
|
1520
|
+
}
|
|
1521
|
+
serializeNodes(parent, nodes, level, visible) {
|
|
1522
|
+
if (nodes && nodes.length) {
|
|
1523
|
+
for (let node of nodes) {
|
|
1524
|
+
node.parent = parent;
|
|
1525
|
+
const rowNode = {
|
|
1526
|
+
node: node,
|
|
1527
|
+
parent: parent,
|
|
1528
|
+
level: level,
|
|
1529
|
+
visible: visible && (parent ? parent.expanded : true)
|
|
1530
|
+
};
|
|
1531
|
+
this.serializedValue.push(rowNode);
|
|
1532
|
+
if (rowNode.visible && node.expanded) {
|
|
1533
|
+
this.serializeNodes(node, node.children, level + 1, rowNode.visible);
|
|
1534
|
+
}
|
|
1535
|
+
}
|
|
1536
|
+
}
|
|
1537
|
+
}
|
|
1538
|
+
onNodeClick(event, node) {
|
|
1539
|
+
let eventTarget = event.target;
|
|
1540
|
+
const section = eventTarget?.getAttribute?.('data-pc-section');
|
|
1541
|
+
if (section === 'nodetogglebutton' || section === 'nodetoggleicon') {
|
|
1542
|
+
return;
|
|
1543
|
+
}
|
|
1544
|
+
if (this.selectionMode()) {
|
|
1545
|
+
if (node.selectable === false) {
|
|
1546
|
+
return;
|
|
1547
|
+
}
|
|
1548
|
+
if (this.hasFilteredNodes()) {
|
|
1549
|
+
node = this.getNodeWithKey(node.key, this.filteredNodes);
|
|
1550
|
+
if (!node) {
|
|
1551
|
+
return;
|
|
1552
|
+
}
|
|
1553
|
+
}
|
|
1554
|
+
let index = this.findIndexInSelection(node);
|
|
1555
|
+
let selected = index >= 0;
|
|
1556
|
+
const currentSelection = this.selection();
|
|
1557
|
+
if (this.isCheckboxSelectionMode()) {
|
|
1558
|
+
if (selected) {
|
|
1559
|
+
if (this.propagateSelectionDown())
|
|
1560
|
+
this.propagateDown(node, false);
|
|
1561
|
+
else
|
|
1562
|
+
this.selection.set(currentSelection.filter((_val, i) => i != index));
|
|
1563
|
+
if (this.propagateSelectionUp() && node.parent) {
|
|
1564
|
+
this.propagateUp(node.parent, false);
|
|
1565
|
+
}
|
|
1566
|
+
this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
|
1567
|
+
}
|
|
1568
|
+
else {
|
|
1569
|
+
if (this.propagateSelectionDown())
|
|
1570
|
+
this.propagateDown(node, true);
|
|
1571
|
+
else
|
|
1572
|
+
this.selection.set([...(currentSelection || []), node]);
|
|
1573
|
+
if (this.propagateSelectionUp() && node.parent) {
|
|
1574
|
+
this.propagateUp(node.parent, true);
|
|
1575
|
+
}
|
|
1576
|
+
this.onNodeSelect.emit({ originalEvent: event, node: node });
|
|
1577
|
+
}
|
|
1578
|
+
}
|
|
1579
|
+
else {
|
|
1580
|
+
let metaSelection = this.nodeTouched ? false : this.metaKeySelection();
|
|
1581
|
+
if (metaSelection) {
|
|
1582
|
+
let metaKey = event.metaKey || event.ctrlKey;
|
|
1583
|
+
if (selected && metaKey) {
|
|
1584
|
+
if (this.isSingleSelectionMode()) {
|
|
1585
|
+
this.selection.set(null);
|
|
1586
|
+
}
|
|
1587
|
+
else {
|
|
1588
|
+
this.selection.set(currentSelection.filter((_val, i) => i != index));
|
|
1589
|
+
}
|
|
1590
|
+
this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
|
1591
|
+
}
|
|
1592
|
+
else {
|
|
1593
|
+
if (this.isSingleSelectionMode()) {
|
|
1594
|
+
this.selection.set(node);
|
|
1595
|
+
}
|
|
1596
|
+
else if (this.isMultipleSelectionMode()) {
|
|
1597
|
+
const base = !metaKey ? [] : currentSelection || [];
|
|
1598
|
+
this.selection.set([...base, node]);
|
|
1599
|
+
}
|
|
1600
|
+
this.onNodeSelect.emit({ originalEvent: event, node: node });
|
|
1601
|
+
}
|
|
1602
|
+
}
|
|
1603
|
+
else {
|
|
1604
|
+
if (this.isSingleSelectionMode()) {
|
|
1605
|
+
if (selected) {
|
|
1606
|
+
this.selection.set(null);
|
|
1607
|
+
this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
|
1608
|
+
}
|
|
1609
|
+
else {
|
|
1610
|
+
this.selection.set(node);
|
|
1611
|
+
setTimeout(() => {
|
|
1612
|
+
if (this._destroyed)
|
|
1613
|
+
return;
|
|
1614
|
+
this.onNodeSelect.emit({ originalEvent: event, node: node });
|
|
1615
|
+
});
|
|
1616
|
+
}
|
|
1617
|
+
}
|
|
1618
|
+
else {
|
|
1619
|
+
if (selected) {
|
|
1620
|
+
this.selection.set(currentSelection.filter((_val, i) => i != index));
|
|
1621
|
+
this.onNodeUnselect.emit({ originalEvent: event, node: node });
|
|
1622
|
+
}
|
|
1623
|
+
else {
|
|
1624
|
+
this.selection.set([...(currentSelection || []), node]);
|
|
1625
|
+
setTimeout(() => {
|
|
1626
|
+
if (this._destroyed)
|
|
1627
|
+
return;
|
|
1628
|
+
this.onNodeSelect.emit({ originalEvent: event, node: node });
|
|
1629
|
+
});
|
|
1630
|
+
}
|
|
1631
|
+
}
|
|
1632
|
+
}
|
|
1633
|
+
}
|
|
1634
|
+
}
|
|
1635
|
+
this.nodeTouched = false;
|
|
1636
|
+
}
|
|
1637
|
+
onNodeTouchEnd() {
|
|
1638
|
+
this.nodeTouched = true;
|
|
1639
|
+
}
|
|
1640
|
+
onNodeRightClick(event, node) {
|
|
1641
|
+
if (this.contextMenu()) {
|
|
1642
|
+
let eventTarget = event.target;
|
|
1643
|
+
const section = eventTarget.getAttribute('data-pc-section');
|
|
1644
|
+
if (section === 'nodetogglebutton' || section === 'nodetoggleicon') {
|
|
1645
|
+
return;
|
|
1646
|
+
}
|
|
1647
|
+
let index = this.findIndexInSelection(node);
|
|
1648
|
+
let isNodeSelected = index >= 0;
|
|
1649
|
+
const onContextMenuCallback = () => {
|
|
1650
|
+
this.contextMenu().show(event);
|
|
1651
|
+
this.contextMenu().hideCallback = () => {
|
|
1652
|
+
this.contextMenuSelection.set(null);
|
|
1653
|
+
};
|
|
1654
|
+
this.onNodeContextMenuSelect.emit({ originalEvent: event, node: node });
|
|
1655
|
+
};
|
|
1656
|
+
this.contextMenuSelection.set(node);
|
|
1657
|
+
onContextMenuCallback();
|
|
1658
|
+
}
|
|
1659
|
+
}
|
|
1660
|
+
onNodeDblClick(event, node) {
|
|
1661
|
+
this.onNodeDoubleClick.emit({ originalEvent: event, node: node });
|
|
1662
|
+
}
|
|
1663
|
+
findIndexInSelection(node) {
|
|
1664
|
+
let index = -1;
|
|
1665
|
+
const currentSelection = this.selection();
|
|
1666
|
+
if (this.selectionMode() && currentSelection) {
|
|
1667
|
+
if (this.isSingleSelectionMode()) {
|
|
1668
|
+
const sel = currentSelection;
|
|
1669
|
+
let areNodesEqual = (sel.key && sel.key === node.key) || sel == node;
|
|
1670
|
+
index = areNodesEqual ? 0 : -1;
|
|
1671
|
+
}
|
|
1672
|
+
else {
|
|
1673
|
+
const selArray = currentSelection;
|
|
1674
|
+
for (let i = 0; i < selArray.length; i++) {
|
|
1675
|
+
let selectedNode = selArray[i];
|
|
1676
|
+
let areNodesEqual = (selectedNode.key && selectedNode.key === node.key) || selectedNode == node;
|
|
1677
|
+
if (areNodesEqual) {
|
|
1678
|
+
index = i;
|
|
1679
|
+
break;
|
|
1680
|
+
}
|
|
1681
|
+
}
|
|
1682
|
+
}
|
|
1683
|
+
}
|
|
1684
|
+
return index;
|
|
1685
|
+
}
|
|
1686
|
+
syncNodeOption(node, parentNodes, option, value) {
|
|
1687
|
+
// to synchronize the node option between the filtered nodes and the original nodes(this.value)
|
|
1688
|
+
const _node = this.hasFilteredNodes() ? this.getNodeWithKey(node.key, parentNodes) : null;
|
|
1689
|
+
if (_node) {
|
|
1690
|
+
_node[option] = value || node[option];
|
|
1691
|
+
}
|
|
1692
|
+
}
|
|
1693
|
+
hasFilteredNodes() {
|
|
1694
|
+
return this.filter() && this.filteredNodes && this.filteredNodes.length;
|
|
1695
|
+
}
|
|
1696
|
+
hasFilterActive() {
|
|
1697
|
+
return this.filter() && this.filterViewChild()?.nativeElement?.value.length > 0;
|
|
1698
|
+
}
|
|
1699
|
+
getNodeWithKey(key, nodes) {
|
|
1700
|
+
for (let node of nodes) {
|
|
1701
|
+
if (node.key === key) {
|
|
1702
|
+
return node;
|
|
1703
|
+
}
|
|
1704
|
+
if (node.children) {
|
|
1705
|
+
let matchedNode = this.getNodeWithKey(key, node.children);
|
|
1706
|
+
if (matchedNode) {
|
|
1707
|
+
return matchedNode;
|
|
1708
|
+
}
|
|
1709
|
+
}
|
|
1710
|
+
}
|
|
1711
|
+
}
|
|
1712
|
+
propagateUp(node, select) {
|
|
1713
|
+
if (node.children && node.children.length) {
|
|
1714
|
+
let selectedCount = 0;
|
|
1715
|
+
let childPartialSelected = false;
|
|
1716
|
+
for (let child of node.children) {
|
|
1717
|
+
if (this.isSelected(child)) {
|
|
1718
|
+
selectedCount++;
|
|
1719
|
+
}
|
|
1720
|
+
else if (child.partialSelected) {
|
|
1721
|
+
childPartialSelected = true;
|
|
1722
|
+
}
|
|
1723
|
+
}
|
|
1724
|
+
const currentSelection = this.selection() || [];
|
|
1725
|
+
if (select && selectedCount == node.children.length) {
|
|
1726
|
+
this.selection.set([...currentSelection, node]);
|
|
1727
|
+
node.partialSelected = false;
|
|
1728
|
+
}
|
|
1729
|
+
else {
|
|
1730
|
+
if (!select) {
|
|
1731
|
+
let index = this.findIndexInSelection(node);
|
|
1732
|
+
if (index >= 0) {
|
|
1733
|
+
this.selection.set(currentSelection.filter((_val, i) => i != index));
|
|
1734
|
+
}
|
|
1735
|
+
}
|
|
1736
|
+
if (childPartialSelected || (selectedCount > 0 && selectedCount != node.children.length))
|
|
1737
|
+
node.partialSelected = true;
|
|
1738
|
+
else
|
|
1739
|
+
node.partialSelected = false;
|
|
1740
|
+
}
|
|
1741
|
+
this.syncNodeOption(node, this.filteredNodes, 'partialSelected');
|
|
1742
|
+
}
|
|
1743
|
+
let parent = node.parent;
|
|
1744
|
+
if (parent) {
|
|
1745
|
+
this.propagateUp(parent, select);
|
|
1746
|
+
}
|
|
1747
|
+
}
|
|
1748
|
+
propagateDown(node, select) {
|
|
1749
|
+
let index = this.findIndexInSelection(node);
|
|
1750
|
+
const currentSelection = this.selection() || [];
|
|
1751
|
+
if (select && index == -1) {
|
|
1752
|
+
this.selection.set([...currentSelection, node]);
|
|
1753
|
+
}
|
|
1754
|
+
else if (!select && index > -1) {
|
|
1755
|
+
this.selection.set(currentSelection.filter((_val, i) => i != index));
|
|
1756
|
+
}
|
|
1757
|
+
node.partialSelected = false;
|
|
1758
|
+
this.syncNodeOption(node, this.filteredNodes, 'partialSelected');
|
|
1759
|
+
if (node.children && node.children.length) {
|
|
1760
|
+
for (let child of node.children) {
|
|
1761
|
+
this.propagateDown(child, select);
|
|
1762
|
+
}
|
|
1763
|
+
}
|
|
1764
|
+
}
|
|
1765
|
+
isSelected(node) {
|
|
1766
|
+
return this.findIndexInSelection(node) != -1;
|
|
1767
|
+
}
|
|
1768
|
+
isSingleSelectionMode() {
|
|
1769
|
+
return this.selectionMode() && this.selectionMode() == 'single';
|
|
1770
|
+
}
|
|
1771
|
+
isMultipleSelectionMode() {
|
|
1772
|
+
return this.selectionMode() && this.selectionMode() == 'multiple';
|
|
1773
|
+
}
|
|
1774
|
+
isCheckboxSelectionMode() {
|
|
1775
|
+
return this.selectionMode() && this.selectionMode() == 'checkbox';
|
|
1776
|
+
}
|
|
1777
|
+
isNodeLeaf(node) {
|
|
1778
|
+
return node.leaf == false ? false : !(node.children && node.children.length);
|
|
1779
|
+
}
|
|
1780
|
+
getRootNode() {
|
|
1781
|
+
return this.filteredNodes ? this.filteredNodes : this.value();
|
|
1782
|
+
}
|
|
1783
|
+
getTemplateForNode(node) {
|
|
1784
|
+
return this.nodeTemplate() ?? null;
|
|
1785
|
+
}
|
|
1786
|
+
onDragOver(event) {
|
|
1787
|
+
if (this.droppableNodes() && this.allowDrop(this.dragNode, null, this.dragNodeScope)) {
|
|
1788
|
+
event.dataTransfer.dropEffect = 'copy';
|
|
1789
|
+
event.preventDefault();
|
|
1790
|
+
}
|
|
1791
|
+
}
|
|
1792
|
+
onDrop(event) {
|
|
1793
|
+
if (this.droppableNodes()) {
|
|
1794
|
+
event.preventDefault();
|
|
1795
|
+
let dragNode = this.dragNode;
|
|
1796
|
+
if (this.isSameTreeScope(this.dragNodeScope)) {
|
|
1797
|
+
return;
|
|
1798
|
+
}
|
|
1799
|
+
if (this.allowDrop(dragNode, null, this.dragNodeScope)) {
|
|
1800
|
+
let dragNodeIndex = this.dragNodeIndex;
|
|
1801
|
+
let currentValue = this.value() || [];
|
|
1802
|
+
if (this.validateDrop()) {
|
|
1803
|
+
this.onNodeDrop.emit({
|
|
1804
|
+
originalEvent: event,
|
|
1805
|
+
dragNode: dragNode,
|
|
1806
|
+
dropNode: null,
|
|
1807
|
+
index: dragNodeIndex,
|
|
1808
|
+
accept: () => {
|
|
1809
|
+
this.processTreeDrop(dragNode, dragNodeIndex);
|
|
1810
|
+
}
|
|
1811
|
+
});
|
|
1812
|
+
}
|
|
1813
|
+
else {
|
|
1814
|
+
this.onNodeDrop.emit({
|
|
1815
|
+
originalEvent: event,
|
|
1816
|
+
dragNode: dragNode,
|
|
1817
|
+
dropNode: null,
|
|
1818
|
+
index: dragNodeIndex
|
|
1819
|
+
});
|
|
1820
|
+
this.processTreeDrop(dragNode, dragNodeIndex);
|
|
1821
|
+
}
|
|
1822
|
+
}
|
|
1823
|
+
}
|
|
1824
|
+
}
|
|
1825
|
+
processTreeDrop(dragNode, dragNodeIndex) {
|
|
1826
|
+
this.dragNodeSubNodes.splice(dragNodeIndex, 1);
|
|
1827
|
+
this.value().push(dragNode);
|
|
1828
|
+
this.dragDropService.stopDrag({
|
|
1829
|
+
node: dragNode
|
|
1830
|
+
});
|
|
1831
|
+
}
|
|
1832
|
+
onDragEnter() {
|
|
1833
|
+
if (this.droppableNodes() && this.allowDrop(this.dragNode, null, this.dragNodeScope)) {
|
|
1834
|
+
this.dragHover = true;
|
|
1835
|
+
}
|
|
1836
|
+
}
|
|
1837
|
+
onDragLeave(event) {
|
|
1838
|
+
if (this.droppableNodes()) {
|
|
1839
|
+
let rect = event.currentTarget.getBoundingClientRect();
|
|
1840
|
+
if (event.x > parseInt(rect.left) + rect.width || event.x < parseInt(rect.left) || event.y > parseInt(rect.top) + rect.height || event.y < parseInt(rect.top)) {
|
|
1841
|
+
this.dragHover = false;
|
|
1842
|
+
}
|
|
1843
|
+
}
|
|
1844
|
+
}
|
|
1845
|
+
allowDrop(dragNode, dropNode, dragNodeScope) {
|
|
1846
|
+
if (!dragNode) {
|
|
1847
|
+
//prevent random html elements to be dragged
|
|
1848
|
+
return false;
|
|
1849
|
+
}
|
|
1850
|
+
else if (this.isValidDragScope(dragNodeScope)) {
|
|
1851
|
+
let allow = true;
|
|
1852
|
+
if (dropNode) {
|
|
1853
|
+
if (dragNode === dropNode) {
|
|
1854
|
+
allow = false;
|
|
1855
|
+
}
|
|
1856
|
+
else {
|
|
1857
|
+
let parent = dropNode.parent;
|
|
1858
|
+
while (parent != null) {
|
|
1859
|
+
if (parent === dragNode) {
|
|
1860
|
+
allow = false;
|
|
1861
|
+
break;
|
|
1862
|
+
}
|
|
1863
|
+
parent = parent.parent;
|
|
1864
|
+
}
|
|
1865
|
+
}
|
|
1866
|
+
}
|
|
1867
|
+
return allow;
|
|
1868
|
+
}
|
|
1869
|
+
else {
|
|
1870
|
+
return false;
|
|
1871
|
+
}
|
|
1872
|
+
}
|
|
1873
|
+
hasCommonScope(dragScope, dropScope) {
|
|
1874
|
+
if (typeof dropScope === 'string') {
|
|
1875
|
+
if (typeof dragScope === 'string')
|
|
1876
|
+
return dropScope === dragScope;
|
|
1877
|
+
else if (Array.isArray(dragScope))
|
|
1878
|
+
return dragScope.indexOf(dropScope) != -1;
|
|
1879
|
+
}
|
|
1880
|
+
else if (Array.isArray(dropScope)) {
|
|
1881
|
+
if (typeof dragScope === 'string') {
|
|
1882
|
+
return dropScope.indexOf(dragScope) != -1;
|
|
1883
|
+
}
|
|
1884
|
+
else if (Array.isArray(dragScope)) {
|
|
1885
|
+
for (let s of dropScope) {
|
|
1886
|
+
for (let ds of dragScope) {
|
|
1887
|
+
if (s === ds) {
|
|
1888
|
+
return true;
|
|
1889
|
+
}
|
|
1890
|
+
}
|
|
1891
|
+
}
|
|
1892
|
+
}
|
|
1893
|
+
}
|
|
1894
|
+
return false;
|
|
1895
|
+
}
|
|
1896
|
+
isSameTreeScope(dragScope) {
|
|
1897
|
+
return this.hasCommonScope(dragScope, this.draggableScope());
|
|
1898
|
+
}
|
|
1899
|
+
isValidDragScope(dragScope) {
|
|
1900
|
+
let dropScope = this.droppableScope();
|
|
1901
|
+
if (dropScope) {
|
|
1902
|
+
return this.hasCommonScope(dragScope, dropScope);
|
|
1903
|
+
}
|
|
1904
|
+
else {
|
|
1905
|
+
return true;
|
|
1906
|
+
}
|
|
1907
|
+
}
|
|
1908
|
+
_filter(value) {
|
|
1909
|
+
let filterValue = value;
|
|
1910
|
+
if (filterValue === '') {
|
|
1911
|
+
this.filteredNodes = null;
|
|
1912
|
+
}
|
|
1913
|
+
else {
|
|
1914
|
+
this.filteredNodes = [];
|
|
1915
|
+
const searchFields = this.filterBy().split(',');
|
|
1916
|
+
const filterText = removeAccents(filterValue).toLocaleLowerCase(this.filterLocale());
|
|
1917
|
+
const isStrictMode = this.filterMode() === 'strict';
|
|
1918
|
+
for (let node of this.value()) {
|
|
1919
|
+
let copyNode = { ...node };
|
|
1920
|
+
let paramsWithoutNode = { searchFields, filterText, isStrictMode };
|
|
1921
|
+
if ((isStrictMode && (this.findFilteredNodes(copyNode, paramsWithoutNode) || this.isFilterMatched(copyNode, paramsWithoutNode))) ||
|
|
1922
|
+
(!isStrictMode && (this.isFilterMatched(copyNode, paramsWithoutNode) || this.findFilteredNodes(copyNode, paramsWithoutNode)))) {
|
|
1923
|
+
this.filteredNodes.push(copyNode);
|
|
1924
|
+
}
|
|
1925
|
+
}
|
|
1926
|
+
}
|
|
1927
|
+
this.updateSerializedValue();
|
|
1928
|
+
this.onFilter.emit({
|
|
1929
|
+
filter: filterValue,
|
|
1930
|
+
filteredValue: this.filteredNodes
|
|
1931
|
+
});
|
|
1932
|
+
}
|
|
1933
|
+
/**
|
|
1934
|
+
* Resets filter.
|
|
1935
|
+
* @group Method
|
|
1936
|
+
*/
|
|
1937
|
+
resetFilter() {
|
|
1938
|
+
this.filteredNodes = null;
|
|
1939
|
+
const filterEl = this.filterViewChild();
|
|
1940
|
+
if (filterEl && filterEl.nativeElement) {
|
|
1941
|
+
filterEl.nativeElement.value = '';
|
|
1942
|
+
}
|
|
1943
|
+
}
|
|
1944
|
+
/**
|
|
1945
|
+
* Scrolls to virtual index.
|
|
1946
|
+
* @param {number} number - Index to be scrolled.
|
|
1947
|
+
* @group Method
|
|
1948
|
+
*/
|
|
1949
|
+
scrollToVirtualIndex(index) {
|
|
1950
|
+
this.virtualScroll() && this.scroller()?.scrollToIndex(index);
|
|
1951
|
+
}
|
|
1952
|
+
/**
|
|
1953
|
+
* Scrolls to virtual index.
|
|
1954
|
+
* @param {ScrollToOptions} options - Scroll options.
|
|
1955
|
+
* @group Method
|
|
1956
|
+
*/
|
|
1957
|
+
scrollTo(options) {
|
|
1958
|
+
if (this.virtualScroll()) {
|
|
1959
|
+
this.scroller()?.scrollTo(options);
|
|
1960
|
+
}
|
|
1961
|
+
else {
|
|
1962
|
+
const wrapper = this.wrapperViewChild();
|
|
1963
|
+
if (wrapper && wrapper.nativeElement) {
|
|
1964
|
+
if (wrapper.nativeElement.scrollTo) {
|
|
1965
|
+
wrapper.nativeElement.scrollTo(options);
|
|
1966
|
+
}
|
|
1967
|
+
else {
|
|
1968
|
+
wrapper.nativeElement.scrollLeft = options.left;
|
|
1969
|
+
wrapper.nativeElement.scrollTop = options.top;
|
|
1970
|
+
}
|
|
1971
|
+
}
|
|
1972
|
+
}
|
|
1973
|
+
}
|
|
1974
|
+
findFilteredNodes(node, paramsWithoutNode) {
|
|
1975
|
+
if (node) {
|
|
1976
|
+
let matched = false;
|
|
1977
|
+
if (node.children) {
|
|
1978
|
+
let childNodes = [...node.children];
|
|
1979
|
+
node.children = [];
|
|
1980
|
+
for (let childNode of childNodes) {
|
|
1981
|
+
let copyChildNode = { ...childNode };
|
|
1982
|
+
if (this.isFilterMatched(copyChildNode, paramsWithoutNode)) {
|
|
1983
|
+
matched = true;
|
|
1984
|
+
node.children.push(copyChildNode);
|
|
1985
|
+
}
|
|
1986
|
+
}
|
|
1987
|
+
}
|
|
1988
|
+
if (matched) {
|
|
1989
|
+
node.expanded = true;
|
|
1990
|
+
return true;
|
|
1991
|
+
}
|
|
1992
|
+
}
|
|
1993
|
+
}
|
|
1994
|
+
isFilterMatched(node, params) {
|
|
1995
|
+
let { searchFields, filterText, isStrictMode } = params;
|
|
1996
|
+
let matched = false;
|
|
1997
|
+
for (let field of searchFields) {
|
|
1998
|
+
let fieldValue = removeAccents(String(resolveFieldData(node, field))).toLocaleLowerCase(this.filterLocale());
|
|
1999
|
+
if (fieldValue.indexOf(filterText) > -1) {
|
|
2000
|
+
matched = true;
|
|
2001
|
+
}
|
|
2002
|
+
}
|
|
2003
|
+
if (!matched || (isStrictMode && !this.isNodeLeaf(node))) {
|
|
2004
|
+
matched = this.findFilteredNodes(node, { searchFields, filterText, isStrictMode }) || matched;
|
|
2005
|
+
}
|
|
2006
|
+
return matched;
|
|
2007
|
+
}
|
|
2008
|
+
getIndex(options, index) {
|
|
2009
|
+
const getItemOptions = options['getItemOptions'];
|
|
2010
|
+
return getItemOptions ? getItemOptions(index).index : index;
|
|
2011
|
+
}
|
|
2012
|
+
getBlockableElement() {
|
|
2013
|
+
return this.el.nativeElement.children[0];
|
|
2014
|
+
}
|
|
2015
|
+
get containerDataP() {
|
|
2016
|
+
return this.cn({
|
|
2017
|
+
loading: this.loading(),
|
|
2018
|
+
scrollable: this.scrollHeight() === 'flex'
|
|
2019
|
+
});
|
|
2020
|
+
}
|
|
2021
|
+
get wrapperDataP() {
|
|
2022
|
+
return this.cn({
|
|
2023
|
+
scrollable: this.scrollHeight() === 'flex'
|
|
2024
|
+
});
|
|
2025
|
+
}
|
|
2026
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: Tree, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
2027
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "22.0.3", type: Tree, isStandalone: true, selector: "p-tree", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, selectionMode: { classPropertyName: "selectionMode", publicName: "selectionMode", isSignal: true, isRequired: false, transformFunction: null }, loadingMode: { classPropertyName: "loadingMode", publicName: "loadingMode", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null }, collapsedKeys: { classPropertyName: "collapsedKeys", publicName: "collapsedKeys", isSignal: true, isRequired: false, transformFunction: null }, selectionKeys: { classPropertyName: "selectionKeys", publicName: "selectionKeys", isSignal: true, isRequired: false, transformFunction: null }, contextMenu: { classPropertyName: "contextMenu", publicName: "contextMenu", isSignal: true, isRequired: false, transformFunction: null }, contextMenuSelection: { classPropertyName: "contextMenuSelection", publicName: "contextMenuSelection", isSignal: true, isRequired: false, transformFunction: null }, draggableScope: { classPropertyName: "draggableScope", publicName: "draggableScope", isSignal: true, isRequired: false, transformFunction: null }, droppableScope: { classPropertyName: "droppableScope", publicName: "droppableScope", isSignal: true, isRequired: false, transformFunction: null }, draggableNodes: { classPropertyName: "draggableNodes", publicName: "draggableNodes", isSignal: true, isRequired: false, transformFunction: null }, droppableNodes: { classPropertyName: "droppableNodes", publicName: "droppableNodes", isSignal: true, isRequired: false, transformFunction: null }, metaKeySelection: { classPropertyName: "metaKeySelection", publicName: "metaKeySelection", isSignal: true, isRequired: false, transformFunction: null }, propagateSelectionUp: { classPropertyName: "propagateSelectionUp", publicName: "propagateSelectionUp", isSignal: true, isRequired: false, transformFunction: null }, propagateSelectionDown: { classPropertyName: "propagateSelectionDown", publicName: "propagateSelectionDown", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, loadingIcon: { classPropertyName: "loadingIcon", publicName: "loadingIcon", isSignal: true, isRequired: false, transformFunction: null }, emptyMessage: { classPropertyName: "emptyMessage", publicName: "emptyMessage", isSignal: true, isRequired: false, transformFunction: null }, ariaLabel: { classPropertyName: "ariaLabel", publicName: "ariaLabel", isSignal: true, isRequired: false, transformFunction: null }, togglerAriaLabel: { classPropertyName: "togglerAriaLabel", publicName: "togglerAriaLabel", isSignal: true, isRequired: false, transformFunction: null }, ariaLabelledBy: { classPropertyName: "ariaLabelledBy", publicName: "ariaLabelledBy", isSignal: true, isRequired: false, transformFunction: null }, validateDrop: { classPropertyName: "validateDrop", publicName: "validateDrop", isSignal: true, isRequired: false, transformFunction: null }, filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: false, transformFunction: null }, filterInputAutoFocus: { classPropertyName: "filterInputAutoFocus", publicName: "filterInputAutoFocus", isSignal: true, isRequired: false, transformFunction: null }, filterBy: { classPropertyName: "filterBy", publicName: "filterBy", isSignal: true, isRequired: false, transformFunction: null }, filterMode: { classPropertyName: "filterMode", publicName: "filterMode", isSignal: true, isRequired: false, transformFunction: null }, filterPlaceholder: { classPropertyName: "filterPlaceholder", publicName: "filterPlaceholder", isSignal: true, isRequired: false, transformFunction: null }, filterLocale: { classPropertyName: "filterLocale", publicName: "filterLocale", isSignal: true, isRequired: false, transformFunction: null }, scrollHeight: { classPropertyName: "scrollHeight", publicName: "scrollHeight", isSignal: true, isRequired: false, transformFunction: null }, lazy: { classPropertyName: "lazy", publicName: "lazy", isSignal: true, isRequired: false, transformFunction: null }, virtualScroll: { classPropertyName: "virtualScroll", publicName: "virtualScroll", isSignal: true, isRequired: false, transformFunction: null }, virtualScrollItemSize: { classPropertyName: "virtualScrollItemSize", publicName: "virtualScrollItemSize", isSignal: true, isRequired: false, transformFunction: null }, virtualScrollOptions: { classPropertyName: "virtualScrollOptions", publicName: "virtualScrollOptions", isSignal: true, isRequired: false, transformFunction: null }, indentation: { classPropertyName: "indentation", publicName: "indentation", isSignal: true, isRequired: false, transformFunction: null }, trackBy: { classPropertyName: "trackBy", publicName: "trackBy", isSignal: true, isRequired: false, transformFunction: null }, highlightOnSelect: { classPropertyName: "highlightOnSelect", publicName: "highlightOnSelect", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selection: "selectionChange", collapsedKeys: "collapsedKeysChange", selectionKeys: "selectionKeysChange", contextMenuSelection: "contextMenuSelectionChange", onNodeSelect: "onNodeSelect", onNodeUnselect: "onNodeUnselect", onNodeExpand: "onNodeExpand", onNodeCollapse: "onNodeCollapse", onNodeContextMenuSelect: "onNodeContextMenuSelect", onNodeDoubleClick: "onNodeDoubleClick", onNodeDrop: "onNodeDrop", onLazyLoad: "onLazyLoad", onScroll: "onScroll", onScrollIndexChange: "onScrollIndexChange", onFilter: "onFilter" }, host: { listeners: { "drop": "onDrop($event)", "dragover": "onDragOver($event)", "dragenter": "onDragEnter()", "dragleave": "onDragLeave($event)" }, properties: { "class": "cx('root')", "attr.data-p": "containerDataP" } }, providers: [TreeStyle, { provide: TREE_INSTANCE, useExisting: Tree }, { provide: PARENT_INSTANCE, useExisting: Tree }], queries: [{ propertyName: "filterTemplate", first: true, predicate: ["filter"], isSignal: true }, { propertyName: "nodeTemplate", first: true, predicate: ["node"], isSignal: true }, { propertyName: "headerTemplate", first: true, predicate: ["header"], isSignal: true }, { propertyName: "footerTemplate", first: true, predicate: ["footer"], isSignal: true }, { propertyName: "loaderTemplate", first: true, predicate: ["loader"], isSignal: true }, { propertyName: "emptyTemplate", first: true, predicate: ["empty"], isSignal: true }, { propertyName: "togglerIconTemplate", first: true, predicate: ["togglericon"], isSignal: true }, { propertyName: "checkboxIconTemplate", first: true, predicate: ["checkboxicon"], isSignal: true }, { propertyName: "loadingIconTemplate", first: true, predicate: ["loadingicon"], isSignal: true }, { propertyName: "filterIconTemplate", first: true, predicate: ["filtericon"], isSignal: true }], viewQueries: [{ propertyName: "filterViewChild", first: true, predicate: ["filter"], descendants: true, isSignal: true }, { propertyName: "scroller", first: true, predicate: ["scroller"], descendants: true, isSignal: true }, { propertyName: "wrapperViewChild", first: true, predicate: ["wrapper"], descendants: true, isSignal: true }, { propertyName: "contentViewChild", first: true, predicate: ["content"], descendants: true, isSignal: true }], usesInheritance: true, hostDirectives: [{ directive: i1$1.Bind }], ngImport: i0, template: `
|
|
2028
|
+
@if (showLoadingMask()) {
|
|
2029
|
+
<div [class]="cx('mask')" [pBind]="ptm('mask')" animate.enter="p-overlay-mask-enter-active" animate.leave="p-overlay-mask-leave-active">
|
|
2030
|
+
@if (loadingIcon()) {
|
|
2031
|
+
<i [class]="cn(cx('loadingIcon'), 'pi-spin' + loadingIcon())" [pBind]="ptm('loadingIcon')"></i>
|
|
2032
|
+
}
|
|
2033
|
+
@if (!loadingIcon()) {
|
|
2034
|
+
@if (!loadingIconTemplate()) {
|
|
2035
|
+
<svg data-p-icon="spinner" [class]="cn(cx('loadingIcon'), 'animate-spin')" [pBind]="ptm('loadingIcon')" />
|
|
2036
|
+
}
|
|
2037
|
+
@if (loadingIconTemplate()) {
|
|
2038
|
+
<span [class]="cx('loadingIcon')" [pBind]="ptm('loadingIcon')">
|
|
2039
|
+
<ng-template *ngTemplateOutlet="loadingIconTemplate()!"></ng-template>
|
|
2040
|
+
</span>
|
|
2041
|
+
}
|
|
2042
|
+
}
|
|
2043
|
+
</div>
|
|
2044
|
+
}
|
|
2045
|
+
<ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
|
|
2046
|
+
@if (filterTemplate()) {
|
|
2047
|
+
<ng-container *ngTemplateOutlet="filterTemplate()!; context: { $implicit: filterOptions }"></ng-container>
|
|
2048
|
+
} @else {
|
|
2049
|
+
@if (filter()) {
|
|
2050
|
+
<p-iconfield [class]="cx('pcFilterContainer')" [pt]="ptm('pcFilterContainer')" [unstyled]="unstyled()">
|
|
2051
|
+
<input
|
|
2052
|
+
#filter
|
|
2053
|
+
[pAutoFocus]="filterInputAutoFocus()"
|
|
2054
|
+
pInputText
|
|
2055
|
+
type="search"
|
|
2056
|
+
autocomplete="off"
|
|
2057
|
+
[class]="cx('pcFilterInput')"
|
|
2058
|
+
[attr.placeholder]="filterPlaceholder()"
|
|
2059
|
+
(keydown.enter)="$event.preventDefault()"
|
|
2060
|
+
(input)="_filter($event.target?.value)"
|
|
2061
|
+
[pt]="ptm('pcFilterInput')"
|
|
2062
|
+
[unstyled]="unstyled()"
|
|
2063
|
+
/>
|
|
2064
|
+
<p-inputicon [pt]="ptm('pcFilterIconContainer')" [unstyled]="unstyled()">
|
|
2065
|
+
@if (!filterIconTemplate()) {
|
|
2066
|
+
<svg data-p-icon="search" [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')" />
|
|
2067
|
+
}
|
|
2068
|
+
@if (filterIconTemplate()) {
|
|
2069
|
+
<span [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')">
|
|
2070
|
+
<ng-template *ngTemplateOutlet="filterIconTemplate()!"></ng-template>
|
|
2071
|
+
</span>
|
|
2072
|
+
}
|
|
2073
|
+
</p-inputicon>
|
|
2074
|
+
</p-iconfield>
|
|
2075
|
+
}
|
|
2076
|
+
}
|
|
2077
|
+
|
|
2078
|
+
@if (getRootNode()?.length) {
|
|
2079
|
+
@if (virtualScroll()) {
|
|
2080
|
+
<p-scroller
|
|
2081
|
+
#scroller
|
|
2082
|
+
[items]="serializedValue"
|
|
2083
|
+
[tabindex]="-1"
|
|
2084
|
+
[styleClass]="cx('wrapper')"
|
|
2085
|
+
[style]="{ height: scrollerStyleHeight() }"
|
|
2086
|
+
[scrollHeight]="scrollerScrollHeight()"
|
|
2087
|
+
[itemSize]="virtualScrollItemSize()"
|
|
2088
|
+
[lazy]="lazy()"
|
|
2089
|
+
(onScroll)="onScroll.emit($event)"
|
|
2090
|
+
(onScrollIndexChange)="onScrollIndexChange.emit($event)"
|
|
2091
|
+
(onLazyLoad)="onLazyLoad.emit($event)"
|
|
2092
|
+
[options]="virtualScrollOptions()"
|
|
2093
|
+
[pt]="ptm('virtualScroller')"
|
|
2094
|
+
hostName="tree"
|
|
2095
|
+
[attr.data-p]="wrapperDataP"
|
|
2096
|
+
>
|
|
2097
|
+
<ng-template #content let-items let-scrollerOptions="options">
|
|
2098
|
+
@if (items) {
|
|
2099
|
+
<ul
|
|
2100
|
+
#content
|
|
2101
|
+
[class]="cn(cx('rootChildren'), scrollerOptions.contentStyleClass)"
|
|
2102
|
+
[style]="scrollerOptions.contentStyle"
|
|
2103
|
+
role="tree"
|
|
2104
|
+
[attr.aria-label]="ariaLabel()"
|
|
2105
|
+
[attr.aria-labelledby]="ariaLabelledBy()"
|
|
2106
|
+
[pBind]="ptm('rootChildren')"
|
|
2107
|
+
>
|
|
2108
|
+
@for (rowNode of items; track trackBy()($index, rowNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
|
|
2109
|
+
<p-treenode
|
|
2110
|
+
#treeNode
|
|
2111
|
+
[level]="rowNode.level"
|
|
2112
|
+
[rowNode]="rowNode"
|
|
2113
|
+
[node]="rowNode.node"
|
|
2114
|
+
[parentNode]="rowNode.parent"
|
|
2115
|
+
[firstChild]="firstChild"
|
|
2116
|
+
[lastChild]="lastChild"
|
|
2117
|
+
[index]="getIndex(scrollerOptions, idx)"
|
|
2118
|
+
[itemSize]="scrollerOptions.itemSize"
|
|
2119
|
+
[indentation]="indentation()"
|
|
2120
|
+
[loadingMode]="loadingMode()"
|
|
2121
|
+
[pt]="pt"
|
|
2122
|
+
[unstyled]="unstyled()"
|
|
2123
|
+
/>
|
|
2124
|
+
}
|
|
2125
|
+
</ul>
|
|
2126
|
+
}
|
|
2127
|
+
</ng-template>
|
|
2128
|
+
@if (loaderTemplate()) {
|
|
2129
|
+
<ng-template #loader let-scrollerOptions="options">
|
|
2130
|
+
<ng-container *ngTemplateOutlet="loaderTemplate()!; context: { options: scrollerOptions }"></ng-container>
|
|
2131
|
+
</ng-template>
|
|
2132
|
+
}
|
|
2133
|
+
</p-scroller>
|
|
2134
|
+
}
|
|
2135
|
+
@if (!virtualScroll()) {
|
|
2136
|
+
<div #wrapper [class]="cx('wrapper')" [style.max-height]="scrollHeight()" [pBind]="ptm('wrapper')" [attr.data-p]="wrapperDataP">
|
|
2137
|
+
@if (getRootNode()) {
|
|
2138
|
+
<ul #content [class]="cx('rootChildren')" role="tree" [attr.aria-label]="ariaLabel()" [attr.aria-labelledby]="ariaLabelledBy()" [pBind]="ptm('rootChildren')">
|
|
2139
|
+
@for (node of getRootNode(); track trackBy().bind(this)($index, node); let firstChild = $first; let lastChild = $last; let idx = $index) {
|
|
2140
|
+
<p-treenode [node]="node" [firstChild]="firstChild" [lastChild]="lastChild" [index]="idx" [level]="0" [loadingMode]="loadingMode()" [pt]="pt" [unstyled]="unstyled()" />
|
|
2141
|
+
}
|
|
2142
|
+
</ul>
|
|
2143
|
+
}
|
|
2144
|
+
</div>
|
|
2145
|
+
}
|
|
2146
|
+
}
|
|
2147
|
+
|
|
2148
|
+
@if (showEmptyMessage) {
|
|
2149
|
+
<div [class]="cx('emptyMessage')" [pBind]="ptm('emptyMessage')">
|
|
2150
|
+
@if (!emptyTemplate()) {
|
|
2151
|
+
{{ emptyMessageLabel }}
|
|
2152
|
+
}
|
|
2153
|
+
@if (emptyTemplate()) {
|
|
2154
|
+
<ng-template *ngTemplateOutlet="emptyTemplate()!"></ng-template>
|
|
2155
|
+
}
|
|
2156
|
+
</div>
|
|
2157
|
+
}
|
|
2158
|
+
<ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
|
|
2159
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: Scroller, selector: "p-scroller, p-virtualscroller, p-virtual-scroller", inputs: ["hostName", "id", "style", "styleClass", "tabindex", "items", "itemSize", "scrollHeight", "scrollWidth", "orientation", "step", "delay", "resizeDelay", "appendOnly", "inline", "lazy", "disabled", "loaderDisabled", "columns", "showSpacer", "showLoader", "numToleratedItems", "loading", "autoSize", "trackBy", "options"], outputs: ["onLazyLoad", "onScroll", "onScrollIndexChange"] }, { kind: "component", type: Search, selector: "svg[data-p-icon=\"search\"]" }, { kind: "component", type: Spinner, selector: "svg[data-p-icon=\"spinner\"]" }, { kind: "directive", type: InputText, selector: "[pInputText]", inputs: ["hostName", "pInputTextPT", "pInputTextUnstyled", "pSize", "variant", "fluid", "invalid"] }, { kind: "component", type: IconField, selector: "p-iconfield, p-icon-field", inputs: ["hostName", "iconPosition"] }, { kind: "component", type: InputIcon, selector: "p-inputicon", inputs: ["hostName"] }, { kind: "component", type: UITreeNode, selector: "p-treenode", inputs: ["rowNode", "node", "parentNode", "root", "index", "firstChild", "lastChild", "level", "indentation", "itemSize", "loadingMode"] }, { kind: "ngmodule", type: AutoFocusModule }, { kind: "directive", type: i2.AutoFocus, selector: "[pAutoFocus]", inputs: ["pAutoFocus"] }, { kind: "directive", type: Bind, selector: "[pBind]", inputs: ["pBind"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
2160
|
+
}
|
|
2161
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: Tree, decorators: [{
|
|
2162
|
+
type: Component,
|
|
2163
|
+
args: [{
|
|
2164
|
+
selector: 'p-tree',
|
|
2165
|
+
standalone: true,
|
|
2166
|
+
imports: [NgTemplateOutlet, Scroller, Search, Spinner, InputText, IconField, InputIcon, UITreeNode, AutoFocusModule, Bind],
|
|
2167
|
+
template: `
|
|
2168
|
+
@if (showLoadingMask()) {
|
|
2169
|
+
<div [class]="cx('mask')" [pBind]="ptm('mask')" animate.enter="p-overlay-mask-enter-active" animate.leave="p-overlay-mask-leave-active">
|
|
2170
|
+
@if (loadingIcon()) {
|
|
2171
|
+
<i [class]="cn(cx('loadingIcon'), 'pi-spin' + loadingIcon())" [pBind]="ptm('loadingIcon')"></i>
|
|
2172
|
+
}
|
|
2173
|
+
@if (!loadingIcon()) {
|
|
2174
|
+
@if (!loadingIconTemplate()) {
|
|
2175
|
+
<svg data-p-icon="spinner" [class]="cn(cx('loadingIcon'), 'animate-spin')" [pBind]="ptm('loadingIcon')" />
|
|
2176
|
+
}
|
|
2177
|
+
@if (loadingIconTemplate()) {
|
|
2178
|
+
<span [class]="cx('loadingIcon')" [pBind]="ptm('loadingIcon')">
|
|
2179
|
+
<ng-template *ngTemplateOutlet="loadingIconTemplate()!"></ng-template>
|
|
2180
|
+
</span>
|
|
2181
|
+
}
|
|
2182
|
+
}
|
|
2183
|
+
</div>
|
|
2184
|
+
}
|
|
2185
|
+
<ng-container *ngTemplateOutlet="headerTemplate()"></ng-container>
|
|
2186
|
+
@if (filterTemplate()) {
|
|
2187
|
+
<ng-container *ngTemplateOutlet="filterTemplate()!; context: { $implicit: filterOptions }"></ng-container>
|
|
2188
|
+
} @else {
|
|
2189
|
+
@if (filter()) {
|
|
2190
|
+
<p-iconfield [class]="cx('pcFilterContainer')" [pt]="ptm('pcFilterContainer')" [unstyled]="unstyled()">
|
|
2191
|
+
<input
|
|
2192
|
+
#filter
|
|
2193
|
+
[pAutoFocus]="filterInputAutoFocus()"
|
|
2194
|
+
pInputText
|
|
2195
|
+
type="search"
|
|
2196
|
+
autocomplete="off"
|
|
2197
|
+
[class]="cx('pcFilterInput')"
|
|
2198
|
+
[attr.placeholder]="filterPlaceholder()"
|
|
2199
|
+
(keydown.enter)="$event.preventDefault()"
|
|
2200
|
+
(input)="_filter($event.target?.value)"
|
|
2201
|
+
[pt]="ptm('pcFilterInput')"
|
|
2202
|
+
[unstyled]="unstyled()"
|
|
2203
|
+
/>
|
|
2204
|
+
<p-inputicon [pt]="ptm('pcFilterIconContainer')" [unstyled]="unstyled()">
|
|
2205
|
+
@if (!filterIconTemplate()) {
|
|
2206
|
+
<svg data-p-icon="search" [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')" />
|
|
2207
|
+
}
|
|
2208
|
+
@if (filterIconTemplate()) {
|
|
2209
|
+
<span [class]="cx('filterIcon')" [pBind]="ptm('filterIcon')">
|
|
2210
|
+
<ng-template *ngTemplateOutlet="filterIconTemplate()!"></ng-template>
|
|
2211
|
+
</span>
|
|
2212
|
+
}
|
|
2213
|
+
</p-inputicon>
|
|
2214
|
+
</p-iconfield>
|
|
2215
|
+
}
|
|
2216
|
+
}
|
|
2217
|
+
|
|
2218
|
+
@if (getRootNode()?.length) {
|
|
2219
|
+
@if (virtualScroll()) {
|
|
2220
|
+
<p-scroller
|
|
2221
|
+
#scroller
|
|
2222
|
+
[items]="serializedValue"
|
|
2223
|
+
[tabindex]="-1"
|
|
2224
|
+
[styleClass]="cx('wrapper')"
|
|
2225
|
+
[style]="{ height: scrollerStyleHeight() }"
|
|
2226
|
+
[scrollHeight]="scrollerScrollHeight()"
|
|
2227
|
+
[itemSize]="virtualScrollItemSize()"
|
|
2228
|
+
[lazy]="lazy()"
|
|
2229
|
+
(onScroll)="onScroll.emit($event)"
|
|
2230
|
+
(onScrollIndexChange)="onScrollIndexChange.emit($event)"
|
|
2231
|
+
(onLazyLoad)="onLazyLoad.emit($event)"
|
|
2232
|
+
[options]="virtualScrollOptions()"
|
|
2233
|
+
[pt]="ptm('virtualScroller')"
|
|
2234
|
+
hostName="tree"
|
|
2235
|
+
[attr.data-p]="wrapperDataP"
|
|
2236
|
+
>
|
|
2237
|
+
<ng-template #content let-items let-scrollerOptions="options">
|
|
2238
|
+
@if (items) {
|
|
2239
|
+
<ul
|
|
2240
|
+
#content
|
|
2241
|
+
[class]="cn(cx('rootChildren'), scrollerOptions.contentStyleClass)"
|
|
2242
|
+
[style]="scrollerOptions.contentStyle"
|
|
2243
|
+
role="tree"
|
|
2244
|
+
[attr.aria-label]="ariaLabel()"
|
|
2245
|
+
[attr.aria-labelledby]="ariaLabelledBy()"
|
|
2246
|
+
[pBind]="ptm('rootChildren')"
|
|
2247
|
+
>
|
|
2248
|
+
@for (rowNode of items; track trackBy()($index, rowNode); let firstChild = $first; let lastChild = $last; let idx = $index) {
|
|
2249
|
+
<p-treenode
|
|
2250
|
+
#treeNode
|
|
2251
|
+
[level]="rowNode.level"
|
|
2252
|
+
[rowNode]="rowNode"
|
|
2253
|
+
[node]="rowNode.node"
|
|
2254
|
+
[parentNode]="rowNode.parent"
|
|
2255
|
+
[firstChild]="firstChild"
|
|
2256
|
+
[lastChild]="lastChild"
|
|
2257
|
+
[index]="getIndex(scrollerOptions, idx)"
|
|
2258
|
+
[itemSize]="scrollerOptions.itemSize"
|
|
2259
|
+
[indentation]="indentation()"
|
|
2260
|
+
[loadingMode]="loadingMode()"
|
|
2261
|
+
[pt]="pt"
|
|
2262
|
+
[unstyled]="unstyled()"
|
|
2263
|
+
/>
|
|
2264
|
+
}
|
|
2265
|
+
</ul>
|
|
2266
|
+
}
|
|
2267
|
+
</ng-template>
|
|
2268
|
+
@if (loaderTemplate()) {
|
|
2269
|
+
<ng-template #loader let-scrollerOptions="options">
|
|
2270
|
+
<ng-container *ngTemplateOutlet="loaderTemplate()!; context: { options: scrollerOptions }"></ng-container>
|
|
2271
|
+
</ng-template>
|
|
2272
|
+
}
|
|
2273
|
+
</p-scroller>
|
|
2274
|
+
}
|
|
2275
|
+
@if (!virtualScroll()) {
|
|
2276
|
+
<div #wrapper [class]="cx('wrapper')" [style.max-height]="scrollHeight()" [pBind]="ptm('wrapper')" [attr.data-p]="wrapperDataP">
|
|
2277
|
+
@if (getRootNode()) {
|
|
2278
|
+
<ul #content [class]="cx('rootChildren')" role="tree" [attr.aria-label]="ariaLabel()" [attr.aria-labelledby]="ariaLabelledBy()" [pBind]="ptm('rootChildren')">
|
|
2279
|
+
@for (node of getRootNode(); track trackBy().bind(this)($index, node); let firstChild = $first; let lastChild = $last; let idx = $index) {
|
|
2280
|
+
<p-treenode [node]="node" [firstChild]="firstChild" [lastChild]="lastChild" [index]="idx" [level]="0" [loadingMode]="loadingMode()" [pt]="pt" [unstyled]="unstyled()" />
|
|
2281
|
+
}
|
|
2282
|
+
</ul>
|
|
2283
|
+
}
|
|
2284
|
+
</div>
|
|
2285
|
+
}
|
|
2286
|
+
}
|
|
2287
|
+
|
|
2288
|
+
@if (showEmptyMessage) {
|
|
2289
|
+
<div [class]="cx('emptyMessage')" [pBind]="ptm('emptyMessage')">
|
|
2290
|
+
@if (!emptyTemplate()) {
|
|
2291
|
+
{{ emptyMessageLabel }}
|
|
2292
|
+
}
|
|
2293
|
+
@if (emptyTemplate()) {
|
|
2294
|
+
<ng-template *ngTemplateOutlet="emptyTemplate()!"></ng-template>
|
|
2295
|
+
}
|
|
2296
|
+
</div>
|
|
2297
|
+
}
|
|
2298
|
+
<ng-container *ngTemplateOutlet="footerTemplate()"></ng-container>
|
|
2299
|
+
`,
|
|
2300
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
2301
|
+
encapsulation: ViewEncapsulation.None,
|
|
2302
|
+
providers: [TreeStyle, { provide: TREE_INSTANCE, useExisting: Tree }, { provide: PARENT_INSTANCE, useExisting: Tree }],
|
|
2303
|
+
host: {
|
|
2304
|
+
'[class]': "cx('root')",
|
|
2305
|
+
'[attr.data-p]': 'containerDataP',
|
|
2306
|
+
'(drop)': 'onDrop($event)',
|
|
2307
|
+
'(dragover)': 'onDragOver($event)',
|
|
2308
|
+
'(dragenter)': 'onDragEnter()',
|
|
2309
|
+
'(dragleave)': 'onDragLeave($event)'
|
|
2310
|
+
},
|
|
2311
|
+
hostDirectives: [Bind]
|
|
2312
|
+
}]
|
|
2313
|
+
}], ctorParameters: () => [], propDecorators: { value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }], selectionMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectionMode", required: false }] }], loadingMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingMode", required: false }] }], selection: [{ type: i0.Input, args: [{ isSignal: true, alias: "selection", required: false }] }, { type: i0.Output, args: ["selectionChange"] }], collapsedKeys: [{ type: i0.Input, args: [{ isSignal: true, alias: "collapsedKeys", required: false }] }, { type: i0.Output, args: ["collapsedKeysChange"] }], selectionKeys: [{ type: i0.Input, args: [{ isSignal: true, alias: "selectionKeys", required: false }] }, { type: i0.Output, args: ["selectionKeysChange"] }], contextMenu: [{ type: i0.Input, args: [{ isSignal: true, alias: "contextMenu", required: false }] }], contextMenuSelection: [{ type: i0.Input, args: [{ isSignal: true, alias: "contextMenuSelection", required: false }] }, { type: i0.Output, args: ["contextMenuSelectionChange"] }], draggableScope: [{ type: i0.Input, args: [{ isSignal: true, alias: "draggableScope", required: false }] }], droppableScope: [{ type: i0.Input, args: [{ isSignal: true, alias: "droppableScope", required: false }] }], draggableNodes: [{ type: i0.Input, args: [{ isSignal: true, alias: "draggableNodes", required: false }] }], droppableNodes: [{ type: i0.Input, args: [{ isSignal: true, alias: "droppableNodes", required: false }] }], metaKeySelection: [{ type: i0.Input, args: [{ isSignal: true, alias: "metaKeySelection", required: false }] }], propagateSelectionUp: [{ type: i0.Input, args: [{ isSignal: true, alias: "propagateSelectionUp", required: false }] }], propagateSelectionDown: [{ type: i0.Input, args: [{ isSignal: true, alias: "propagateSelectionDown", required: false }] }], loading: [{ type: i0.Input, args: [{ isSignal: true, alias: "loading", required: false }] }], loadingIcon: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingIcon", required: false }] }], emptyMessage: [{ type: i0.Input, args: [{ isSignal: true, alias: "emptyMessage", required: false }] }], ariaLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaLabel", required: false }] }], togglerAriaLabel: [{ type: i0.Input, args: [{ isSignal: true, alias: "togglerAriaLabel", required: false }] }], ariaLabelledBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "ariaLabelledBy", required: false }] }], validateDrop: [{ type: i0.Input, args: [{ isSignal: true, alias: "validateDrop", required: false }] }], filter: [{ type: i0.Input, args: [{ isSignal: true, alias: "filter", required: false }] }], filterInputAutoFocus: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterInputAutoFocus", required: false }] }], filterBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterBy", required: false }] }], filterMode: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterMode", required: false }] }], filterPlaceholder: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterPlaceholder", required: false }] }], filterLocale: [{ type: i0.Input, args: [{ isSignal: true, alias: "filterLocale", required: false }] }], scrollHeight: [{ type: i0.Input, args: [{ isSignal: true, alias: "scrollHeight", required: false }] }], lazy: [{ type: i0.Input, args: [{ isSignal: true, alias: "lazy", required: false }] }], virtualScroll: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScroll", required: false }] }], virtualScrollItemSize: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScrollItemSize", required: false }] }], virtualScrollOptions: [{ type: i0.Input, args: [{ isSignal: true, alias: "virtualScrollOptions", required: false }] }], indentation: [{ type: i0.Input, args: [{ isSignal: true, alias: "indentation", required: false }] }], trackBy: [{ type: i0.Input, args: [{ isSignal: true, alias: "trackBy", required: false }] }], highlightOnSelect: [{ type: i0.Input, args: [{ isSignal: true, alias: "highlightOnSelect", required: false }] }], onNodeSelect: [{ type: i0.Output, args: ["onNodeSelect"] }], onNodeUnselect: [{ type: i0.Output, args: ["onNodeUnselect"] }], onNodeExpand: [{ type: i0.Output, args: ["onNodeExpand"] }], onNodeCollapse: [{ type: i0.Output, args: ["onNodeCollapse"] }], onNodeContextMenuSelect: [{ type: i0.Output, args: ["onNodeContextMenuSelect"] }], onNodeDoubleClick: [{ type: i0.Output, args: ["onNodeDoubleClick"] }], onNodeDrop: [{ type: i0.Output, args: ["onNodeDrop"] }], onLazyLoad: [{ type: i0.Output, args: ["onLazyLoad"] }], onScroll: [{ type: i0.Output, args: ["onScroll"] }], onScrollIndexChange: [{ type: i0.Output, args: ["onScrollIndexChange"] }], onFilter: [{ type: i0.Output, args: ["onFilter"] }], filterTemplate: [{ type: i0.ContentChild, args: ['filter', { ...{ descendants: false }, isSignal: true }] }], nodeTemplate: [{ type: i0.ContentChild, args: ['node', { ...{ descendants: false }, isSignal: true }] }], headerTemplate: [{ type: i0.ContentChild, args: ['header', { ...{ descendants: false }, isSignal: true }] }], footerTemplate: [{ type: i0.ContentChild, args: ['footer', { ...{ descendants: false }, isSignal: true }] }], loaderTemplate: [{ type: i0.ContentChild, args: ['loader', { ...{ descendants: false }, isSignal: true }] }], emptyTemplate: [{ type: i0.ContentChild, args: ['empty', { ...{ descendants: false }, isSignal: true }] }], togglerIconTemplate: [{ type: i0.ContentChild, args: ['togglericon', { ...{ descendants: false }, isSignal: true }] }], checkboxIconTemplate: [{ type: i0.ContentChild, args: ['checkboxicon', { ...{ descendants: false }, isSignal: true }] }], loadingIconTemplate: [{ type: i0.ContentChild, args: ['loadingicon', { ...{ descendants: false }, isSignal: true }] }], filterIconTemplate: [{ type: i0.ContentChild, args: ['filtericon', { ...{ descendants: false }, isSignal: true }] }], filterViewChild: [{ type: i0.ViewChild, args: ['filter', { isSignal: true }] }], scroller: [{ type: i0.ViewChild, args: ['scroller', { isSignal: true }] }], wrapperViewChild: [{ type: i0.ViewChild, args: ['wrapper', { isSignal: true }] }], contentViewChild: [{ type: i0.ViewChild, args: ['content', { isSignal: true }] }] } });
|
|
2314
|
+
class TreeModule {
|
|
2315
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
2316
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, imports: [Tree], exports: [Tree] });
|
|
2317
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, imports: [Tree] });
|
|
2318
|
+
}
|
|
2319
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "22.0.3", ngImport: i0, type: TreeModule, decorators: [{
|
|
2320
|
+
type: NgModule,
|
|
2321
|
+
args: [{
|
|
2322
|
+
imports: [Tree],
|
|
2323
|
+
exports: [Tree]
|
|
2324
|
+
}]
|
|
2325
|
+
}] });
|
|
2326
|
+
|
|
2327
|
+
/**
|
|
2328
|
+
* Generated bundle index. Do not edit.
|
|
2329
|
+
*/
|
|
2330
|
+
|
|
2331
|
+
export { Tree, TreeClasses, TreeModule, TreeStyle };
|
|
2332
|
+
//# sourceMappingURL=primenglab-tree.mjs.map
|