@ng-nest/ui 15.0.4 → 15.0.6
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/anchor/anchor.component.d.ts +5 -5
- package/api/api.component.d.ts +1 -1
- package/auto-complete/auto-complete.component.d.ts +1 -1
- package/avatar/avatar.component.d.ts +3 -3
- package/back-top/back-top.component.d.ts +2 -2
- package/badge/badge.component.d.ts +2 -2
- package/border/border.component.d.ts +1 -1
- package/button/button.component.d.ts +2 -2
- package/button/buttons.component.d.ts +1 -1
- package/calendar/calendar.component.d.ts +2 -2
- package/card/card.component.d.ts +2 -2
- package/carousel/carousel-panel.component.d.ts +2 -2
- package/carousel/carousel.component.d.ts +4 -4
- package/cascade/cascade.component.d.ts +1 -1
- package/checkbox/checkbox.component.d.ts +3 -3
- package/collapse/collapse-panel.component.d.ts +2 -2
- package/collapse/collapse.component.d.ts +2 -2
- package/color/color.component.d.ts +1 -1
- package/color-picker/color-picker-portal.component.d.ts +4 -4
- package/color-picker/color-picker.component.d.ts +1 -1
- package/comment/comment-reply.component.d.ts +2 -2
- package/comment/comment.component.d.ts +2 -2
- package/container/aside.component.d.ts +1 -1
- package/container/container.component.d.ts +1 -1
- package/container/footer.component.d.ts +1 -1
- package/container/header.component.d.ts +1 -1
- package/container/main.component.d.ts +1 -1
- package/core/config/config.d.ts +3 -0
- package/core/functions/chunk.d.ts +1 -0
- package/core/functions/flex.d.ts +1 -1
- package/core/functions/group-by.d.ts +1 -0
- package/core/functions/guid.d.ts +4 -0
- package/core/functions/public-api.d.ts +4 -0
- package/core/{util → functions}/resize.d.ts +0 -0
- package/core/util/public-api.d.ts +0 -4
- package/date-picker/date-picker.component.d.ts +1 -1
- package/date-picker/date-range.component.d.ts +1 -1
- package/dialog/dialog.component.d.ts +2 -2
- package/drawer/drawer.component.d.ts +2 -2
- package/dropdown/dropdown-portal.component.d.ts +6 -2
- package/dropdown/dropdown.component.d.ts +3 -3
- package/esm2020/anchor/anchor.component.mjs +1 -2
- package/esm2020/api/api.component.mjs +1 -1
- package/esm2020/auto-complete/auto-complete.component.mjs +1 -1
- package/esm2020/avatar/avatar.component.mjs +1 -1
- package/esm2020/back-top/back-top.component.mjs +1 -1
- package/esm2020/badge/badge.component.mjs +1 -1
- package/esm2020/base-form/base-form.component.mjs +3 -3
- package/esm2020/border/border.component.mjs +1 -1
- package/esm2020/button/button.component.mjs +1 -1
- package/esm2020/button/buttons.component.mjs +1 -1
- package/esm2020/calendar/calendar.component.mjs +1 -1
- package/esm2020/card/card.component.mjs +1 -1
- package/esm2020/carousel/carousel-panel.component.mjs +1 -1
- package/esm2020/carousel/carousel.component.mjs +1 -1
- package/esm2020/cascade/cascade.component.mjs +1 -1
- package/esm2020/checkbox/checkbox.component.mjs +1 -1
- package/esm2020/collapse/collapse-panel.component.mjs +1 -1
- package/esm2020/collapse/collapse.component.mjs +1 -1
- package/esm2020/color/color.component.mjs +1 -1
- package/esm2020/color-picker/color-picker-portal.component.mjs +1 -1
- package/esm2020/color-picker/color-picker.component.mjs +1 -1
- package/esm2020/comment/comment-reply.component.mjs +1 -1
- package/esm2020/comment/comment.component.mjs +1 -1
- package/esm2020/container/aside.component.mjs +1 -1
- package/esm2020/container/container.component.mjs +1 -1
- package/esm2020/container/footer.component.mjs +1 -1
- package/esm2020/container/header.component.mjs +1 -1
- package/esm2020/container/main.component.mjs +1 -1
- package/esm2020/core/config/config.mjs +1 -1
- package/esm2020/core/functions/chunk.mjs +14 -0
- package/esm2020/core/functions/flex.mjs +2 -2
- package/esm2020/core/functions/group-by.mjs +10 -0
- package/esm2020/core/functions/guid.mjs +10 -0
- package/esm2020/core/functions/order-by.mjs +24 -3
- package/esm2020/core/functions/public-api.mjs +5 -1
- package/esm2020/core/functions/resize.mjs +17 -0
- package/esm2020/core/util/public-api.mjs +1 -5
- package/esm2020/date-picker/date-picker-portal.component.mjs +2 -2
- package/esm2020/date-picker/date-picker.component.mjs +1 -1
- package/esm2020/date-picker/date-range.component.mjs +1 -1
- package/esm2020/date-picker/picker-date.component.mjs +3 -3
- package/esm2020/date-picker/picker-month.component.mjs +3 -3
- package/esm2020/date-picker/picker-year.component.mjs +3 -3
- package/esm2020/dialog/dialog.component.mjs +2 -2
- package/esm2020/drawer/drawer.component.mjs +1 -1
- package/esm2020/dropdown/dropdown-portal.component.mjs +16 -4
- package/esm2020/dropdown/dropdown.component.mjs +1 -1
- package/esm2020/find/find.component.mjs +1 -1
- package/esm2020/form/control.component.mjs +2 -2
- package/esm2020/form/form.component.mjs +8 -1
- package/esm2020/highlight/highlight.component.mjs +2 -2
- package/esm2020/i18n/i18n.property.mjs +1 -1
- package/esm2020/i18n/languages/en_GB.mjs +44 -18
- package/esm2020/i18n/languages/en_US.mjs +8 -2
- package/esm2020/i18n/languages/zh_CN.mjs +8 -2
- package/esm2020/i18n/languages/zh_TW.mjs +9 -3
- package/esm2020/icon/icon.component.mjs +1 -1
- package/esm2020/image/image-preview.component.mjs +1 -1
- package/esm2020/image/image.component.mjs +1 -1
- package/esm2020/inner/inner.component.mjs +1 -1
- package/esm2020/input/input-group.component.mjs +1 -1
- package/esm2020/input/input.component.mjs +3 -3
- package/esm2020/input-number/input-number.component.mjs +1 -1
- package/esm2020/link/link.component.mjs +1 -1
- package/esm2020/list/list-option.component.mjs +1 -1
- package/esm2020/list/list.component.mjs +2 -2
- package/esm2020/loading/loading.component.mjs +2 -2
- package/esm2020/menu/menu-node.component.mjs +1 -1
- package/esm2020/menu/menu.component.mjs +3 -3
- package/esm2020/message/message.component.mjs +1 -1
- package/esm2020/message-box/message-box.component.mjs +1 -1
- package/esm2020/notification/notification.component.mjs +1 -1
- package/esm2020/pagination/pagination.component.mjs +33 -4
- package/esm2020/pagination/pagination.property.mjs +15 -3
- package/esm2020/popconfirm/popconfirm.component.mjs +1 -1
- package/esm2020/popover/popover-portal.component.mjs +1 -1
- package/esm2020/progress/progress.component.mjs +1 -1
- package/esm2020/radio/radio.component.mjs +1 -1
- package/esm2020/rate/rate.component.mjs +1 -1
- package/esm2020/result/result.component.mjs +1 -1
- package/esm2020/select/select.component.mjs +3 -3
- package/esm2020/skeleton/skeleton.component.mjs +1 -1
- package/esm2020/slider/slider.component.mjs +1 -1
- package/esm2020/slider-select/slider-select.component.mjs +1 -1
- package/esm2020/steps/steps.component.mjs +1 -1
- package/esm2020/switch/switch.component.mjs +1 -1
- package/esm2020/table/table-body.component.mjs +6 -6
- package/esm2020/table/table-foot.component.mjs +1 -1
- package/esm2020/table/table-head.component.mjs +46 -7
- package/esm2020/table/table.component.mjs +16 -5
- package/esm2020/table/table.module.mjs +5 -1
- package/esm2020/table/table.property.mjs +23 -2
- package/esm2020/tabs/tab-content.component.mjs +1 -1
- package/esm2020/tabs/tab.component.mjs +3 -3
- package/esm2020/tabs/tabs.component.mjs +3 -3
- package/esm2020/tag/tag.component.mjs +1 -1
- package/esm2020/text-retract/text-retract.component.mjs +1 -1
- package/esm2020/textarea/textarea.component.mjs +1 -1
- package/esm2020/time-picker/time-picker-frame.component.mjs +188 -55
- package/esm2020/time-picker/time-picker-portal.component.mjs +30 -8
- package/esm2020/time-picker/time-picker.component.mjs +36 -9
- package/esm2020/time-picker/time-picker.module.mjs +8 -4
- package/esm2020/time-picker/time-picker.property.mjs +37 -3
- package/esm2020/timeline/timeline.component.mjs +1 -1
- package/esm2020/tooltip/tooltip-portal.component.mjs +3 -3
- package/esm2020/transfer/transfer.component.mjs +130 -20
- package/esm2020/transfer/transfer.module.mjs +16 -4
- package/esm2020/transfer/transfer.property.mjs +11 -2
- package/esm2020/tree/tree-node.component.mjs +1 -1
- package/esm2020/tree/tree.component.mjs +1 -1
- package/esm2020/tree-file/tree-file.component.mjs +1 -1
- package/esm2020/tree-select/tree-select.component.mjs +1 -1
- package/esm2020/upload/upload-portal.component.mjs +5 -1
- package/esm2020/upload/upload.component.mjs +1 -1
- package/fesm2015/ng-nest-ui-anchor.mjs +0 -2
- package/fesm2015/ng-nest-ui-anchor.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-api.mjs +0 -1
- package/fesm2015/ng-nest-ui-api.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-auto-complete.mjs +0 -1
- package/fesm2015/ng-nest-ui-auto-complete.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-avatar.mjs +0 -1
- package/fesm2015/ng-nest-ui-avatar.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-back-top.mjs +0 -1
- package/fesm2015/ng-nest-ui-back-top.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-badge.mjs +0 -1
- package/fesm2015/ng-nest-ui-badge.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-base-form.mjs +2 -3
- package/fesm2015/ng-nest-ui-base-form.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-border.mjs +0 -1
- package/fesm2015/ng-nest-ui-border.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-button.mjs +0 -1
- package/fesm2015/ng-nest-ui-button.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-calendar.mjs +0 -1
- package/fesm2015/ng-nest-ui-calendar.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-card.mjs +0 -1
- package/fesm2015/ng-nest-ui-card.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-carousel.mjs +0 -1
- package/fesm2015/ng-nest-ui-carousel.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-cascade.mjs +0 -1
- package/fesm2015/ng-nest-ui-cascade.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-checkbox.mjs +0 -1
- package/fesm2015/ng-nest-ui-checkbox.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-collapse.mjs +0 -1
- package/fesm2015/ng-nest-ui-collapse.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-color-picker.mjs +0 -1
- package/fesm2015/ng-nest-ui-color-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-color.mjs +0 -1
- package/fesm2015/ng-nest-ui-color.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-comment.mjs +0 -1
- package/fesm2015/ng-nest-ui-comment.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-container.mjs +0 -1
- package/fesm2015/ng-nest-ui-container.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-core.mjs +76 -56
- package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-date-picker.mjs +5 -5
- package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-dialog.mjs +1 -2
- package/fesm2015/ng-nest-ui-dialog.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-drawer.mjs +0 -1
- package/fesm2015/ng-nest-ui-drawer.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-dropdown.mjs +15 -4
- package/fesm2015/ng-nest-ui-dropdown.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-find.mjs +0 -1
- package/fesm2015/ng-nest-ui-find.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-form.mjs +8 -2
- package/fesm2015/ng-nest-ui-form.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-highlight.mjs +1 -2
- package/fesm2015/ng-nest-ui-highlight.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-i18n.mjs +65 -22
- package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-icon.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-image.mjs +0 -1
- package/fesm2015/ng-nest-ui-image.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-inner.mjs +0 -1
- package/fesm2015/ng-nest-ui-inner.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-input-number.mjs +0 -1
- package/fesm2015/ng-nest-ui-input-number.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-input.mjs +2 -3
- package/fesm2015/ng-nest-ui-input.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-link.mjs +0 -1
- package/fesm2015/ng-nest-ui-link.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-list.mjs +1 -2
- package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-loading.mjs +1 -2
- package/fesm2015/ng-nest-ui-loading.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-menu.mjs +2 -3
- package/fesm2015/ng-nest-ui-menu.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-message-box.mjs +0 -1
- package/fesm2015/ng-nest-ui-message-box.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-message.mjs +0 -1
- package/fesm2015/ng-nest-ui-message.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-notification.mjs +0 -1
- package/fesm2015/ng-nest-ui-notification.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-pagination.mjs +46 -6
- package/fesm2015/ng-nest-ui-pagination.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-popconfirm.mjs +0 -1
- package/fesm2015/ng-nest-ui-popconfirm.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-popover.mjs +0 -1
- package/fesm2015/ng-nest-ui-popover.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-progress.mjs +0 -1
- package/fesm2015/ng-nest-ui-progress.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-radio.mjs +0 -1
- package/fesm2015/ng-nest-ui-radio.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-rate.mjs +0 -1
- package/fesm2015/ng-nest-ui-rate.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-result.mjs +0 -1
- package/fesm2015/ng-nest-ui-result.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-select.mjs +2 -2
- package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-skeleton.mjs +0 -1
- package/fesm2015/ng-nest-ui-skeleton.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-slider-select.mjs +0 -1
- package/fesm2015/ng-nest-ui-slider-select.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-slider.mjs +0 -1
- package/fesm2015/ng-nest-ui-slider.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-steps.mjs +0 -1
- package/fesm2015/ng-nest-ui-steps.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-switch.mjs +0 -1
- package/fesm2015/ng-nest-ui-switch.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-table.mjs +89 -16
- package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tabs.mjs +4 -5
- package/fesm2015/ng-nest-ui-tabs.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tag.mjs +0 -1
- package/fesm2015/ng-nest-ui-tag.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-text-retract.mjs +0 -1
- package/fesm2015/ng-nest-ui-text-retract.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-textarea.mjs +0 -1
- package/fesm2015/ng-nest-ui-textarea.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-time-picker.mjs +292 -81
- package/fesm2015/ng-nest-ui-time-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-timeline.mjs +0 -1
- package/fesm2015/ng-nest-ui-timeline.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tooltip.mjs +2 -3
- package/fesm2015/ng-nest-ui-tooltip.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-transfer.mjs +158 -27
- package/fesm2015/ng-nest-ui-transfer.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tree-file.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tree-select.mjs +0 -1
- package/fesm2015/ng-nest-ui-tree-select.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tree.mjs +0 -1
- package/fesm2015/ng-nest-ui-tree.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-upload.mjs +4 -0
- package/fesm2015/ng-nest-ui-upload.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-anchor.mjs +0 -2
- package/fesm2020/ng-nest-ui-anchor.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-api.mjs +0 -1
- package/fesm2020/ng-nest-ui-api.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-auto-complete.mjs +0 -1
- package/fesm2020/ng-nest-ui-auto-complete.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-avatar.mjs +0 -1
- package/fesm2020/ng-nest-ui-avatar.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-back-top.mjs +0 -1
- package/fesm2020/ng-nest-ui-back-top.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-badge.mjs +0 -1
- package/fesm2020/ng-nest-ui-badge.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-base-form.mjs +2 -3
- package/fesm2020/ng-nest-ui-base-form.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-border.mjs +0 -1
- package/fesm2020/ng-nest-ui-border.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-button.mjs +0 -1
- package/fesm2020/ng-nest-ui-button.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-calendar.mjs +0 -1
- package/fesm2020/ng-nest-ui-calendar.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-card.mjs +0 -1
- package/fesm2020/ng-nest-ui-card.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-carousel.mjs +0 -1
- package/fesm2020/ng-nest-ui-carousel.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-cascade.mjs +0 -1
- package/fesm2020/ng-nest-ui-cascade.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-checkbox.mjs +0 -1
- package/fesm2020/ng-nest-ui-checkbox.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-collapse.mjs +0 -1
- package/fesm2020/ng-nest-ui-collapse.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-color-picker.mjs +0 -1
- package/fesm2020/ng-nest-ui-color-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-color.mjs +0 -1
- package/fesm2020/ng-nest-ui-color.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-comment.mjs +0 -1
- package/fesm2020/ng-nest-ui-comment.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-container.mjs +0 -1
- package/fesm2020/ng-nest-ui-container.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-core.mjs +76 -56
- package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-date-picker.mjs +5 -5
- package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-dialog.mjs +1 -2
- package/fesm2020/ng-nest-ui-dialog.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-drawer.mjs +0 -1
- package/fesm2020/ng-nest-ui-drawer.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-dropdown.mjs +15 -4
- package/fesm2020/ng-nest-ui-dropdown.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-find.mjs +0 -1
- package/fesm2020/ng-nest-ui-find.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-form.mjs +8 -2
- package/fesm2020/ng-nest-ui-form.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-highlight.mjs +1 -2
- package/fesm2020/ng-nest-ui-highlight.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-i18n.mjs +65 -22
- package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-icon.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-image.mjs +0 -1
- package/fesm2020/ng-nest-ui-image.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-inner.mjs +0 -1
- package/fesm2020/ng-nest-ui-inner.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-input-number.mjs +0 -1
- package/fesm2020/ng-nest-ui-input-number.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-input.mjs +2 -3
- package/fesm2020/ng-nest-ui-input.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-link.mjs +0 -1
- package/fesm2020/ng-nest-ui-link.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-list.mjs +1 -2
- package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-loading.mjs +1 -2
- package/fesm2020/ng-nest-ui-loading.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-menu.mjs +2 -3
- package/fesm2020/ng-nest-ui-menu.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-message-box.mjs +0 -1
- package/fesm2020/ng-nest-ui-message-box.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-message.mjs +0 -1
- package/fesm2020/ng-nest-ui-message.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-notification.mjs +0 -1
- package/fesm2020/ng-nest-ui-notification.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-pagination.mjs +46 -6
- package/fesm2020/ng-nest-ui-pagination.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-popconfirm.mjs +0 -1
- package/fesm2020/ng-nest-ui-popconfirm.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-popover.mjs +0 -1
- package/fesm2020/ng-nest-ui-popover.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-progress.mjs +0 -1
- package/fesm2020/ng-nest-ui-progress.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-radio.mjs +0 -1
- package/fesm2020/ng-nest-ui-radio.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-rate.mjs +0 -1
- package/fesm2020/ng-nest-ui-rate.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-result.mjs +0 -1
- package/fesm2020/ng-nest-ui-result.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-select.mjs +2 -2
- package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-skeleton.mjs +0 -1
- package/fesm2020/ng-nest-ui-skeleton.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-slider-select.mjs +0 -1
- package/fesm2020/ng-nest-ui-slider-select.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-slider.mjs +0 -1
- package/fesm2020/ng-nest-ui-slider.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-steps.mjs +0 -1
- package/fesm2020/ng-nest-ui-steps.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-switch.mjs +0 -1
- package/fesm2020/ng-nest-ui-switch.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-table.mjs +89 -16
- package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tabs.mjs +4 -5
- package/fesm2020/ng-nest-ui-tabs.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tag.mjs +0 -1
- package/fesm2020/ng-nest-ui-tag.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-text-retract.mjs +0 -1
- package/fesm2020/ng-nest-ui-text-retract.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-textarea.mjs +0 -1
- package/fesm2020/ng-nest-ui-textarea.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-time-picker.mjs +291 -78
- package/fesm2020/ng-nest-ui-time-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-timeline.mjs +0 -1
- package/fesm2020/ng-nest-ui-timeline.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tooltip.mjs +2 -3
- package/fesm2020/ng-nest-ui-tooltip.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-transfer.mjs +155 -25
- package/fesm2020/ng-nest-ui-transfer.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tree-file.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tree-select.mjs +0 -1
- package/fesm2020/ng-nest-ui-tree-select.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tree.mjs +0 -1
- package/fesm2020/ng-nest-ui-tree.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-upload.mjs +4 -0
- package/fesm2020/ng-nest-ui-upload.mjs.map +1 -1
- package/find/find.component.d.ts +1 -1
- package/form/form.component.d.ts +1 -0
- package/highlight/highlight.component.d.ts +3 -3
- package/i18n/i18n.property.d.ts +6 -0
- package/i18n/languages/en_GB.d.ts +26 -0
- package/i18n/languages/en_US.d.ts +6 -0
- package/i18n/languages/zh_CN.d.ts +6 -0
- package/i18n/languages/zh_TW.d.ts +6 -0
- package/icon/icon.component.d.ts +2 -2
- package/image/image-preview.component.d.ts +2 -2
- package/image/image.component.d.ts +2 -2
- package/inner/inner.component.d.ts +1 -1
- package/input/input-group.component.d.ts +2 -2
- package/input/input.component.d.ts +5 -5
- package/input-number/input-number.component.d.ts +1 -1
- package/link/link.component.d.ts +2 -2
- package/list/list-option.component.d.ts +2 -2
- package/list/list.component.d.ts +7 -7
- package/loading/loading.component.d.ts +2 -2
- package/menu/menu-node.component.d.ts +2 -2
- package/menu/menu.component.d.ts +3 -3
- package/message/message.component.d.ts +2 -2
- package/message-box/message-box.component.d.ts +2 -2
- package/notification/notification.component.d.ts +2 -2
- package/package.json +1 -1
- package/pagination/pagination.component.d.ts +5 -3
- package/pagination/pagination.property.d.ts +13 -3
- package/popconfirm/popconfirm.component.d.ts +2 -2
- package/popover/popover-portal.component.d.ts +2 -2
- package/progress/progress.component.d.ts +2 -2
- package/radio/radio.component.d.ts +3 -3
- package/rate/rate.component.d.ts +3 -3
- package/result/result.component.d.ts +2 -2
- package/select/select.component.d.ts +1 -1
- package/skeleton/skeleton.component.d.ts +2 -2
- package/slider/slider.component.d.ts +4 -4
- package/slider-select/slider-select.component.d.ts +6 -6
- package/steps/steps.component.d.ts +2 -2
- package/switch/switch.component.d.ts +1 -1
- package/table/table-body.component.d.ts +3 -3
- package/table/table-foot.component.d.ts +3 -3
- package/table/table-head.component.d.ts +12 -4
- package/table/table.component.d.ts +15 -13
- package/table/table.module.d.ts +4 -3
- package/table/table.property.d.ts +26 -1
- package/tabs/tab-content.component.d.ts +1 -1
- package/tabs/tabs.component.d.ts +1 -1
- package/tag/tag.component.d.ts +2 -2
- package/text-retract/text-retract.component.d.ts +2 -2
- package/textarea/textarea.component.d.ts +4 -4
- package/time-picker/time-picker-frame.component.d.ts +30 -23
- package/time-picker/time-picker-portal.component.d.ts +13 -3
- package/time-picker/time-picker.component.d.ts +6 -3
- package/time-picker/time-picker.module.d.ts +2 -1
- package/time-picker/time-picker.property.d.ts +38 -2
- package/timeline/timeline.component.d.ts +2 -2
- package/tooltip/tooltip-portal.component.d.ts +3 -3
- package/transfer/transfer.component.d.ts +14 -4
- package/transfer/transfer.module.d.ts +4 -1
- package/transfer/transfer.property.d.ts +29 -4
- package/tree/tree-node.component.d.ts +2 -2
- package/tree/tree.component.d.ts +3 -3
- package/tree-file/tree-file.component.d.ts +2 -2
- package/tree-select/tree-select.component.d.ts +1 -1
- package/upload/upload-portal.component.d.ts +6 -6
- package/upload/upload.component.d.ts +3 -3
- package/core/util/chunk.d.ts +0 -1
- package/core/util/group-by.d.ts +0 -1
- package/core/util/guid.d.ts +0 -4
- package/esm2020/core/util/chunk.mjs +0 -14
- package/esm2020/core/util/group-by.mjs +0 -10
- package/esm2020/core/util/guid.mjs +0 -10
- package/esm2020/core/util/resize.mjs +0 -17
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy } from '@angular/core';
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild } from '@angular/core';
|
|
2
2
|
import { XTransferPrefix, XTransferProperty } from './transfer.property';
|
|
3
|
-
import { XIsChange, XIsEmpty, XSetData, XRemove, XIsArray, XIsObject, XIsObjectArray, XIsBoolean, XIsFunction } from '@ng-nest/ui/core';
|
|
3
|
+
import { XIsChange, XIsEmpty, XSetData, XRemove, XIsArray, XIsObject, XIsObjectArray, XIsBoolean, XIsFunction, XIsUndefined } from '@ng-nest/ui/core';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
|
-
import { map, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { debounceTime, distinctUntilChanged, map, takeUntil } from 'rxjs/operators';
|
|
6
6
|
import { transferArrayItem, moveItemInArray } from '@angular/cdk/drag-drop';
|
|
7
7
|
import { XValueAccessor } from '@ng-nest/ui/base-form';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
@@ -14,8 +14,11 @@ import * as i5 from "@angular/cdk/drag-drop";
|
|
|
14
14
|
import * as i6 from "@ng-nest/ui/outlet";
|
|
15
15
|
import * as i7 from "@ng-nest/ui/checkbox";
|
|
16
16
|
import * as i8 from "@ng-nest/ui/button";
|
|
17
|
-
import * as i9 from "@ng-nest/ui/
|
|
18
|
-
import * as i10 from "@ng-nest/ui/
|
|
17
|
+
import * as i9 from "@ng-nest/ui/input";
|
|
18
|
+
import * as i10 from "@ng-nest/ui/tree";
|
|
19
|
+
import * as i11 from "@ng-nest/ui/table";
|
|
20
|
+
import * as i12 from "@ng-nest/ui/keyword";
|
|
21
|
+
import * as i13 from "@ng-nest/ui/link";
|
|
19
22
|
export class XTransferComponent extends XTransferProperty {
|
|
20
23
|
constructor(renderer, elementRef, cdr, configService, i18n) {
|
|
21
24
|
super();
|
|
@@ -40,6 +43,9 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
40
43
|
disabledButton: true
|
|
41
44
|
};
|
|
42
45
|
this.searchInput = '';
|
|
46
|
+
this.searchInputLeftChange = new Subject();
|
|
47
|
+
this.searchInputRightChange = new Subject();
|
|
48
|
+
this.searchDebounceTime = 200;
|
|
43
49
|
this.locale = {};
|
|
44
50
|
this._unSubject = new Subject();
|
|
45
51
|
this.treeActivatedId = [];
|
|
@@ -77,6 +83,8 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
77
83
|
this.setListStyle();
|
|
78
84
|
this.setHiddenCheckAll();
|
|
79
85
|
this.getTableCheckColumn();
|
|
86
|
+
this.setFooterTpl();
|
|
87
|
+
this.setTableHeadSearchTpl();
|
|
80
88
|
this.i18n.localeChange
|
|
81
89
|
.pipe(map((x) => x.transfer), takeUntil(this._unSubject))
|
|
82
90
|
.subscribe((x) => {
|
|
@@ -84,6 +92,16 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
84
92
|
XIsEmpty(this.titles) && this.setTitles();
|
|
85
93
|
this.cdr.markForCheck();
|
|
86
94
|
});
|
|
95
|
+
this.searchInputLeftChange
|
|
96
|
+
.pipe(debounceTime(this.searchDebounceTime), distinctUntilChanged(), takeUntil(this._unSubject))
|
|
97
|
+
.subscribe(() => {
|
|
98
|
+
this.setSearchInputChange(this.left);
|
|
99
|
+
});
|
|
100
|
+
this.searchInputRightChange
|
|
101
|
+
.pipe(debounceTime(this.searchDebounceTime), distinctUntilChanged(), takeUntil(this._unSubject))
|
|
102
|
+
.subscribe(() => {
|
|
103
|
+
this.setSearchInputChange(this.right);
|
|
104
|
+
});
|
|
87
105
|
}
|
|
88
106
|
ngOnChanges(changes) {
|
|
89
107
|
const { data } = changes;
|
|
@@ -93,8 +111,52 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
93
111
|
this._unSubject.next();
|
|
94
112
|
this._unSubject.unsubscribe();
|
|
95
113
|
}
|
|
96
|
-
|
|
97
|
-
|
|
114
|
+
onSearchInputChange(source) {
|
|
115
|
+
if (source.direction === 'left') {
|
|
116
|
+
this.searchInputLeftChange.next(source.searchInput);
|
|
117
|
+
}
|
|
118
|
+
else if (source.direction === 'right') {
|
|
119
|
+
this.searchInputRightChange.next(source.searchInput);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
setSearchInputChange(source) {
|
|
123
|
+
if (XIsUndefined(source.searchInput))
|
|
124
|
+
return;
|
|
125
|
+
if (XIsEmpty(source.searchInput)) {
|
|
126
|
+
source.list = [...source.searchList];
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
switch (this.type) {
|
|
130
|
+
case 'list':
|
|
131
|
+
source.list = source.searchList?.filter((x) => x.label.indexOf(source.searchInput) >= 0);
|
|
132
|
+
break;
|
|
133
|
+
case 'tree':
|
|
134
|
+
if (source.direction === 'right') {
|
|
135
|
+
source.list = source.searchList?.filter((x) => x.label.indexOf(source.searchInput) >= 0);
|
|
136
|
+
}
|
|
137
|
+
else if (source.direction === 'left') {
|
|
138
|
+
let searchList = source.searchList?.filter((x) => x.label.indexOf(source.searchInput) >= 0);
|
|
139
|
+
let parents = [];
|
|
140
|
+
const findParent = (item) => {
|
|
141
|
+
if (!item.pid)
|
|
142
|
+
return;
|
|
143
|
+
let parent = source.searchList?.find((x) => x.id === item.pid);
|
|
144
|
+
if (parent && !parents.some((x) => x.id === parent.id)) {
|
|
145
|
+
parents.push(parent);
|
|
146
|
+
findParent(parent);
|
|
147
|
+
}
|
|
148
|
+
};
|
|
149
|
+
for (let item of searchList) {
|
|
150
|
+
findParent(item);
|
|
151
|
+
}
|
|
152
|
+
source.list = [...searchList, ...parents];
|
|
153
|
+
}
|
|
154
|
+
break;
|
|
155
|
+
case 'table':
|
|
156
|
+
break;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
this.setListCount(this.type, source);
|
|
98
160
|
this.cdr.detectChanges();
|
|
99
161
|
}
|
|
100
162
|
checkedAllChange($event, source) {
|
|
@@ -137,9 +199,13 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
137
199
|
let checkedItems = from.list?.filter((x) => !x.disabled && x.checked);
|
|
138
200
|
let j = 0;
|
|
139
201
|
checkedItems.forEach((x) => {
|
|
140
|
-
|
|
202
|
+
let index = from.list?.indexOf(x);
|
|
141
203
|
x.checked = false;
|
|
142
204
|
transferArrayItem(from.list, to.list, index, j);
|
|
205
|
+
if (this.search) {
|
|
206
|
+
index = from.searchList?.indexOf(x);
|
|
207
|
+
transferArrayItem(from.searchList, to.searchList, index, j);
|
|
208
|
+
}
|
|
143
209
|
j++;
|
|
144
210
|
});
|
|
145
211
|
from.list = [...from.list];
|
|
@@ -171,6 +237,9 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
171
237
|
}
|
|
172
238
|
else {
|
|
173
239
|
checkedItems = XRemove(from.list, (x) => !x.disabled && x.checked);
|
|
240
|
+
if (this.search) {
|
|
241
|
+
XRemove(from.searchList, (x) => !x.disabled && x.checked);
|
|
242
|
+
}
|
|
174
243
|
for (let item of checkedItems) {
|
|
175
244
|
let node = to.list?.find((x) => x.id === item.id);
|
|
176
245
|
if (node) {
|
|
@@ -296,6 +365,21 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
296
365
|
this.setCheckedCount('table', source);
|
|
297
366
|
this.setButtonDisabled(source);
|
|
298
367
|
}
|
|
368
|
+
onInverse(source) {
|
|
369
|
+
for (let item of source.list) {
|
|
370
|
+
if (!item.disabled) {
|
|
371
|
+
item.checked = !item.checked;
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
let type = `${this.type}`;
|
|
375
|
+
if (type === 'tree' && source.direction === 'right') {
|
|
376
|
+
type = 'list';
|
|
377
|
+
}
|
|
378
|
+
this.setCheckedCount(type, source);
|
|
379
|
+
this.setCheckedAll(source);
|
|
380
|
+
this.setButtonDisabled(source);
|
|
381
|
+
this.cdr.detectChanges();
|
|
382
|
+
}
|
|
299
383
|
getTableCheckColumn() {
|
|
300
384
|
if (this.type !== 'table' || XIsEmpty(this.tableColumns))
|
|
301
385
|
return;
|
|
@@ -341,14 +425,14 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
341
425
|
}
|
|
342
426
|
this.onChange(this.value);
|
|
343
427
|
}
|
|
344
|
-
setSearchList(...
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
428
|
+
setSearchList(...sources) {
|
|
429
|
+
if (this.search) {
|
|
430
|
+
for (let source of sources) {
|
|
431
|
+
if (XIsEmpty(source.searchInput)) {
|
|
432
|
+
source.searchList = [...source.list];
|
|
433
|
+
}
|
|
434
|
+
}
|
|
435
|
+
}
|
|
352
436
|
}
|
|
353
437
|
setData() {
|
|
354
438
|
if (this.type === 'table') {
|
|
@@ -483,11 +567,37 @@ export class XTransferComponent extends XTransferProperty {
|
|
|
483
567
|
this.right.hiddenCheckAll = this.hiddenCheckAll[1];
|
|
484
568
|
this.cdr.detectChanges();
|
|
485
569
|
}
|
|
570
|
+
setFooterTpl() {
|
|
571
|
+
if (XIsUndefined(this.footerTpl))
|
|
572
|
+
return;
|
|
573
|
+
if (this.footerTpl.length > 0) {
|
|
574
|
+
this.left.footerTpl = this.footerTpl[0];
|
|
575
|
+
}
|
|
576
|
+
if (this.footerTpl.length > 1) {
|
|
577
|
+
this.right.footerTpl = this.footerTpl[1];
|
|
578
|
+
}
|
|
579
|
+
}
|
|
580
|
+
setTableHeadSearchTpl() {
|
|
581
|
+
if (XIsUndefined(this.tableHeadSearchTpl))
|
|
582
|
+
return;
|
|
583
|
+
if (this.tableHeadSearchTpl.length > 0) {
|
|
584
|
+
this.left.tableHeadSearchTpl = this.tableHeadSearchTpl[0];
|
|
585
|
+
}
|
|
586
|
+
if (this.tableHeadSearchTpl.length > 1) {
|
|
587
|
+
this.right.tableHeadSearchTpl = this.tableHeadSearchTpl[1];
|
|
588
|
+
}
|
|
589
|
+
}
|
|
486
590
|
}
|
|
487
591
|
/** @nocollapse */ XTransferComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XTransferComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }, { token: i2.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
488
|
-
/** @nocollapse */ XTransferComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XTransferComponent, selector: "x-transfer", providers: [XValueAccessor(XTransferComponent)], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #transfer class=\"x-transfer\" cdkDropListGroup [ngClass]=\"classMap\">\r\n <div class=\"x-transfer-box\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: left }\"></ng-container>\r\n <div [ngStyle]=\"left.listStyle!\" class=\"x-transfer-list\">\r\n <ng-container [ngSwitch]=\"type\">\r\n <ul\r\n *ngSwitchCase=\"'list'\"\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"left.list\"\r\n [cdkDropListDisabled]=\"!drag && type === 'list'\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of left.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: left }\"></ng-container>\r\n </li>\r\n </ul>\r\n <x-tree\r\n *ngSwitchCase=\"'tree'\"\r\n [data]=\"left.list!\"\r\n multiple\r\n allowManyActivated\r\n [(activatedId)]=\"treeActivatedId\"\r\n (nodeClick)=\"onTreeNodeClick($event)\"\r\n ></x-tree>\r\n <x-table\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"tableData\"\r\n [columns]=\"tableColumns!\"\r\n [(size)]=\"tableSize\"\r\n [(index)]=\"tableIndex\"\r\n (indexChange)=\"getTableData()\"\r\n [query]=\"tableQuery\"\r\n [total]=\"tableTotal\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, left)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, left)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n ></x-table>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"x-transfer-buttons\">\r\n <x-button type=\"primary\" icon=\"fto-chevron-right\" [disabled]=\"left.disabledButton\" (click)=\"move(left, right)\"></x-button>\r\n <x-button type=\"primary\" icon=\"fto-chevron-left\" [disabled]=\"right.disabledButton\" (click)=\"move(right, left)\"></x-button>\r\n </div>\r\n <div class=\"x-transfer-box\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: right }\"></ng-container>\r\n <div [ngSwitch]=\"type\" [ngStyle]=\"right.listStyle!\" class=\"x-transfer-list\">\r\n <x-table\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"right.list!\"\r\n [columns]=\"tableColumns!\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, right)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, right)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showPagination=\"false\"\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n ></x-table>\r\n <ul\r\n *ngSwitchDefault\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"right.list\"\r\n [cdkDropListDisabled]=\"!drag || (drag && type !== 'list')\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of right.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: right }\"></ng-container>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #sourceTitleTpl let-source=\"source\">\r\n <div class=\"x-transfer-title\">\r\n <x-checkbox\r\n *ngIf=\"source.title && !source.hiddenCheckAll\"\r\n [data]=\"[titleTpl ? '' : source.title]\"\r\n [(ngModel)]=\"source.checkedAll\"\r\n (ngModelChange)=\"checkedAllChange($event, source)\"\r\n [indeterminate]=\"source.indeterminate\"\r\n ></x-checkbox>\r\n <span *ngIf=\"source.title && source.hiddenCheckAll\">{{ source.title }}</span>\r\n <ng-container *xOutlet=\"titleTpl; context: { $title: source.title, $checkedCount: source.checkedCount, $count: source.count }\"\r\n ><span class=\"x-transfer-total\">{{ source.checkedCount }} / {{ source.count }}</span></ng-container\r\n >\r\n </div>\r\n <!-- <div class=\"x-transfer-search\" *ngIf=\"search\">\r\n <x-input\r\n icon=\"fto-search\"\r\n [(ngModel)]=\"source.searchInput\"\r\n (ngModelChange)=\"searchInputChange(source)\"\r\n clearable\r\n ></x-input>\r\n </div> -->\r\n</ng-template>\r\n\r\n<ng-template #sourceNodeTpl let-node=\"node\" let-source=\"source\">\r\n <x-checkbox\r\n [data]=\"[{ id: node.id, label: nodeTpl ? nodeTpl : node.label, node: node }]\"\r\n [disabled]=\"node.disabled\"\r\n [(ngModel)]=\"node.checked\"\r\n (ngModelChange)=\"checkedChange($event, source)\"\r\n ></x-checkbox>\r\n</ng-template>\r\n", styles: [".x-transfer{margin:0;padding:0;display:inline-flex;align-items:center}.x-transfer-title{padding:.25rem .5625rem;display:flex;align-items:center;justify-content:space-between;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-top-left-radius:var(--x-border-radius);border-top-right-radius:var(--x-border-radius);border-bottom:none;background-color:var(--x-background);color:var(--x-text-300)}.x-transfer-total{margin-left:.325rem}.x-transfer-list{display:flex;flex-direction:column;height:18rem;width:12rem;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-bottom-left-radius:var(--x-border-radius);border-bottom-right-radius:var(--x-border-radius);overflow:auto}.x-transfer-item{padding:.125rem .25rem;border-radius:var(--x-border-radius);display:flex;align-items:center;border:.0625rem dashed transparent;transition:border-color var(--x-animation-duration-base),background-color var(--x-animation-duration-base),color var(--x-animation-duration-base)}.x-transfer-droplist{height:100%;padding:.25rem}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item:hover{background-color:transparent}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item.cdk-drag-placeholder{border-color:var(--x-primary);color:var(--x-primary);background-color:var(--x-background);opacity:.8}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item:not(.cdk-drag-placeholder){transition:transform var(--x-animation-duration-base) cubic-bezier(0,0,.2,1)}.x-transfer-buttons{margin:0 1rem;display:flex;flex-direction:column}.x-transfer-buttons>x-button:not(:first-child){margin-top:.5rem}.x-transfer-search{padding:.5rem;border-bottom:.0625rem solid var(--x-border)}body>li.x-transfer-item.cdk-drag-preview{padding:.125rem .25rem;border-radius:var(--x-border-radius);display:flex;align-items:center;border:.0625rem dashed transparent;border-color:var(--x-border);color:var(--x-text-400);background-color:var(--x-background-a100);opacity:.9}body>li.x-transfer-item.cdk-drag-animating{transition:transform var(--x-animation-duration-base) cubic-bezier(0,0,.2,1)}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i5.CdkDropListGroup, selector: "[cdkDropListGroup]", inputs: ["cdkDropListGroupDisabled"], exportAs: ["cdkDropListGroup"] }, { kind: "directive", type: i5.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i6.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i7.XCheckboxComponent, selector: "x-checkbox" }, { kind: "component", type: i8.XButtonComponent, selector: "x-button" }, { kind: "component", type: i9.XTreeComponent, selector: "x-tree" }, { kind: "component", type: i10.XTableComponent, selector: "x-table" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
592
|
+
/** @nocollapse */ XTransferComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XTransferComponent, selector: "x-transfer", providers: [XValueAccessor(XTransferComponent)], viewQueries: [{ propertyName: "leftTableCom", first: true, predicate: ["leftTableCom"], descendants: true }, { propertyName: "rightTableCom", first: true, predicate: ["rightTableCom"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #transfer class=\"x-transfer\" cdkDropListGroup [ngClass]=\"classMap\">\r\n <div class=\"x-transfer-box\" [class.x-transfer-has-footer]=\"left.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: left }\"></ng-container>\r\n <div [ngStyle]=\"left.listStyle!\" class=\"x-transfer-list\">\r\n <ng-container [ngSwitch]=\"type\">\r\n <ul\r\n *ngSwitchCase=\"'list'\"\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"left.list\"\r\n [cdkDropListDisabled]=\"!drag && type === 'list'\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of left.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: left }\"></ng-container>\r\n </li>\r\n </ul>\r\n <x-tree\r\n *ngSwitchCase=\"'tree'\"\r\n [data]=\"left.list!\"\r\n multiple\r\n allowManyActivated\r\n [(activatedId)]=\"treeActivatedId\"\r\n (nodeClick)=\"onTreeNodeClick($event)\"\r\n [labelTpl]=\"treeLabelTpl\"\r\n ></x-tree>\r\n <ng-template #treeLabelTpl let-node=\"$node\">\r\n <span class=\"x-transfer-tree-label\" x-keyword [text]=\"left.searchInput!\">{{ node.label }}</span>\r\n </ng-template>\r\n <x-table\r\n #leftTableCom\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"tableData\"\r\n [columns]=\"tableColumns!\"\r\n [(size)]=\"tableSize\"\r\n [(index)]=\"tableIndex\"\r\n (indexChange)=\"getTableData()\"\r\n [query]=\"tableQuery\"\r\n [total]=\"tableTotal\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, left)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, left)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n [headSearchTpl]=\"left.tableHeadSearchTpl\"\r\n ></x-table>\r\n </ng-container>\r\n </div>\r\n <div class=\"x-transfer-footer\" *ngIf=\"left.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"left.footerTpl; context: { $source: left }\"></ng-container>\r\n </div>\r\n </div>\r\n <div class=\"x-transfer-buttons\">\r\n <x-button type=\"primary\" icon=\"fto-chevron-right\" [disabled]=\"left.disabledButton\" (click)=\"move(left, right)\"></x-button>\r\n <x-button type=\"primary\" icon=\"fto-chevron-left\" [disabled]=\"right.disabledButton\" (click)=\"move(right, left)\"></x-button>\r\n </div>\r\n <div class=\"x-transfer-box\" [class.x-transfer-has-footer]=\"right.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: right }\"></ng-container>\r\n <div [ngSwitch]=\"type\" [ngStyle]=\"right.listStyle!\" class=\"x-transfer-list\">\r\n <x-table\r\n #rightTableCom\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"right.list!\"\r\n [columns]=\"tableColumns!\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, right)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, right)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showPagination=\"false\"\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n [headSearchTpl]=\"right.tableHeadSearchTpl\"\r\n ></x-table>\r\n <ul\r\n *ngSwitchDefault\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"right.list\"\r\n [cdkDropListDisabled]=\"!drag || (drag && type !== 'list')\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of right.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: right }\"></ng-container>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"x-transfer-footer\" *ngIf=\"right.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"right.footerTpl; context: { $source: right }\"></ng-container>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #sourceTitleTpl let-source=\"source\">\r\n <div class=\"x-transfer-title\">\r\n <div class=\"x-transfer-title-left\">\r\n <x-checkbox\r\n *ngIf=\"source.title && !source.hiddenCheckAll\"\r\n [data]=\"[titleTpl ? '' : source.title]\"\r\n [(ngModel)]=\"source.checkedAll\"\r\n (ngModelChange)=\"checkedAllChange($event, source)\"\r\n [indeterminate]=\"source.indeterminate\"\r\n ></x-checkbox>\r\n <span *ngIf=\"source.title && source.hiddenCheckAll\">{{ source.title }}</span>\r\n <x-link *ngIf=\"inverse && type === 'list'\" class=\"x-transfer-inverse\" type=\"primary\" (click)=\"onInverse(source)\">{{\r\n 'transfer.inverse' | xI18n\r\n }}</x-link>\r\n </div>\r\n <ng-container *xOutlet=\"titleTpl; context: { $title: source.title, $checkedCount: source.checkedCount, $count: source.count }\"\r\n ><span class=\"x-transfer-total\">{{ source.checkedCount }} / {{ source.count }}</span></ng-container\r\n >\r\n </div>\r\n <div class=\"x-transfer-search\" *ngIf=\"search && type !== 'table'\">\r\n <x-input icon=\"fto-search\" [(ngModel)]=\"source.searchInput\" (ngModelChange)=\"onSearchInputChange(source)\" clearable></x-input>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #sourceNodeTpl let-node=\"node\" let-source=\"source\">\r\n <x-checkbox\r\n [data]=\"[{ id: node.id, label: nodeTpl ? nodeTpl : labelTpl, node: node }]\"\r\n [disabled]=\"node.disabled\"\r\n [(ngModel)]=\"node.checked\"\r\n (ngModelChange)=\"checkedChange($event, source)\"\r\n ></x-checkbox>\r\n <ng-template #labelTpl>\r\n <span x-keyword [text]=\"source.searchInput!\">{{ node.label }}</span>\r\n </ng-template>\r\n</ng-template>\r\n", styles: [".x-transfer{margin:0;padding:0;display:inline-flex;align-items:center}.x-transfer-title{padding:.25rem .5625rem;display:flex;align-items:center;justify-content:space-between;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-top-left-radius:var(--x-border-radius);border-top-right-radius:var(--x-border-radius);background-color:var(--x-background);color:var(--x-text-300)}.x-transfer-title-left{display:inline-flex;align-items:center}.x-transfer-inverse{margin:0 .5rem}.x-transfer-total{margin-left:.325rem}.x-transfer-box{min-width:12rem}.x-transfer-list{display:flex;flex-direction:column;height:18rem;width:100%;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-top:none;border-bottom-left-radius:var(--x-border-radius);border-bottom-right-radius:var(--x-border-radius);overflow:auto}.x-transfer-item{padding:.125rem .25rem;border-radius:var(--x-border-radius);display:flex;align-items:center;border:.0625rem dashed transparent;transition:border-color var(--x-animation-duration-base),background-color var(--x-animation-duration-base),color var(--x-animation-duration-base)}.x-transfer-droplist{height:100%;padding:.25rem}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item:hover{background-color:transparent}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item.cdk-drag-placeholder{border-color:var(--x-primary);color:var(--x-primary);background-color:var(--x-background);opacity:.8}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item:not(.cdk-drag-placeholder){transition:transform var(--x-animation-duration-base) cubic-bezier(0,0,.2,1)}.x-transfer-buttons{margin:0 1rem;display:flex;flex-direction:column}.x-transfer-buttons>x-button:not(:first-child){margin-top:.5rem}.x-transfer-search{padding:.5rem;border-left:var(--x-border-width) var(--x-border-style) var(--x-border);border-right:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-transfer-search x-input{width:100%}.x-transfer-tree-label{flex:1}.x-transfer-footer{padding:.25rem .5625rem;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-bottom-left-radius:var(--x-border-radius);border-bottom-right-radius:var(--x-border-radius)}.x-transfer-has-footer .x-transfer-list{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:none}body>li.x-transfer-item.cdk-drag-preview{padding:.125rem .25rem;border-radius:var(--x-border-radius);display:flex;align-items:center;border:.0625rem dashed transparent;border-color:var(--x-border);color:var(--x-text-400);background-color:var(--x-background-a100);opacity:.9}body>li.x-transfer-item.cdk-drag-animating{transition:transform var(--x-animation-duration-base) cubic-bezier(0,0,.2,1)}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i5.CdkDropListGroup, selector: "[cdkDropListGroup]", inputs: ["cdkDropListGroupDisabled"], exportAs: ["cdkDropListGroup"] }, { kind: "directive", type: i5.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i6.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i7.XCheckboxComponent, selector: "x-checkbox" }, { kind: "component", type: i8.XButtonComponent, selector: "x-button" }, { kind: "component", type: i9.XInputComponent, selector: "x-input" }, { kind: "component", type: i10.XTreeComponent, selector: "x-tree" }, { kind: "component", type: i11.XTableComponent, selector: "x-table" }, { kind: "directive", type: i12.XKeywordDirective, selector: "[x-keyword]" }, { kind: "component", type: i13.XLinkComponent, selector: "x-link" }, { kind: "pipe", type: i2.XI18nPipe, name: "xI18n" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
489
593
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XTransferComponent, decorators: [{
|
|
490
594
|
type: Component,
|
|
491
|
-
args: [{ selector: `${XTransferPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XTransferComponent)], template: "<div #transfer class=\"x-transfer\" cdkDropListGroup [ngClass]=\"classMap\">\r\n <div class=\"x-transfer-box\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: left }\"></ng-container>\r\n <div [ngStyle]=\"left.listStyle!\" class=\"x-transfer-list\">\r\n <ng-container [ngSwitch]=\"type\">\r\n <ul\r\n *ngSwitchCase=\"'list'\"\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"left.list\"\r\n [cdkDropListDisabled]=\"!drag && type === 'list'\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of left.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: left }\"></ng-container>\r\n </li>\r\n </ul>\r\n <x-tree\r\n *ngSwitchCase=\"'tree'\"\r\n [data]=\"left.list!\"\r\n multiple\r\n allowManyActivated\r\n [(activatedId)]=\"treeActivatedId\"\r\n (nodeClick)=\"onTreeNodeClick($event)\"\r\n ></x-tree>\r\n <x-table\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"tableData\"\r\n [columns]=\"tableColumns!\"\r\n [(size)]=\"tableSize\"\r\n [(index)]=\"tableIndex\"\r\n (indexChange)=\"getTableData()\"\r\n [query]=\"tableQuery\"\r\n [total]=\"tableTotal\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, left)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, left)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n ></x-table>\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"x-transfer-buttons\">\r\n <x-button type=\"primary\" icon=\"fto-chevron-right\" [disabled]=\"left.disabledButton\" (click)=\"move(left, right)\"></x-button>\r\n <x-button type=\"primary\" icon=\"fto-chevron-left\" [disabled]=\"right.disabledButton\" (click)=\"move(right, left)\"></x-button>\r\n </div>\r\n <div class=\"x-transfer-box\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: right }\"></ng-container>\r\n <div [ngSwitch]=\"type\" [ngStyle]=\"right.listStyle!\" class=\"x-transfer-list\">\r\n <x-table\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"right.list!\"\r\n [columns]=\"tableColumns!\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, right)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, right)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showPagination=\"false\"\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n ></x-table>\r\n <ul\r\n *ngSwitchDefault\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"right.list\"\r\n [cdkDropListDisabled]=\"!drag || (drag && type !== 'list')\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of right.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: right }\"></ng-container>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #sourceTitleTpl let-source=\"source\">\r\n <div class=\"x-transfer-title\">\r\n <x-checkbox\r\n
|
|
492
|
-
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }, { type: i2.XI18nService }]; }
|
|
493
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transfer.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/transfer/transfer.component.ts","../../../../../lib/ng-nest/ui/transfer/transfer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport { XTransferPrefix, XTransferNode, XTransferSource, XTransferProperty, XTransferType } from './transfer.property';\r\nimport {\r\n  XIsChange,\r\n  XIsEmpty,\r\n  XSetData,\r\n  XConfigService,\r\n  XRemove,\r\n  XIsArray,\r\n  XIsObject,\r\n  XIsObjectArray,\r\n  XIsBoolean,\r\n  XIsFunction,\r\n  XResultList\r\n} from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { transferArrayItem, moveItemInArray, CdkDragDrop, CdkDrag } from '@angular/cdk/drag-drop';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XI18nService, XI18nTransfer } from '@ng-nest/ui/i18n';\r\nimport { XTreeNode } from '@ng-nest/ui/tree';\r\nimport { XTableColumn } from '@ng-nest/ui/table';\r\n\r\n@Component({\r\n  selector: `${XTransferPrefix}`,\r\n  templateUrl: './transfer.component.html',\r\n  styleUrls: ['./transfer.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XTransferComponent)]\r\n})\r\nexport class XTransferComponent extends XTransferProperty implements OnInit, OnChanges, OnDestroy {\r\n  nodes: XTransferNode[] = [];\r\n  left: XTransferSource = {\r\n    list: [],\r\n    searchList: [],\r\n    checkedCount: 0,\r\n    direction: 'left',\r\n    disabledButton: true\r\n  };\r\n  right: XTransferSource = {\r\n    list: [],\r\n    searchList: [],\r\n    checkedCount: 0,\r\n    direction: 'right',\r\n    disabledButton: true\r\n  };\r\n  searchInput: string = '';\r\n  locale: XI18nTransfer = {};\r\n  private get localTitle() {\r\n    if (this.type === 'tree') {\r\n      return this.locale.treeTitle;\r\n    } else {\r\n      return this.locale.listTitle;\r\n    }\r\n  }\r\n  private _unSubject = new Subject<void>();\r\n  treeActivatedId: any[] = [];\r\n  tableData: XTransferNode[] = [];\r\n  tableCheckboxColumn?: XTableColumn;\r\n  isObjectArray = false;\r\n  override writeValue(value: any[]): void {\r\n    this.value = value;\r\n    if (XIsArray(value)) {\r\n      this.treeActivatedId = [...value];\r\n      if (XIsObjectArray(value)) {\r\n        this.isObjectArray = true;\r\n      }\r\n    }\r\n    this.setList(this.nodes);\r\n  }\r\n\r\n  get values() {\r\n    if (this.isObjectArray) {\r\n      return this.value.map((x) => x.id);\r\n    } else {\r\n      return this.value;\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public override cdr: ChangeDetectorRef,\r\n    public configService: XConfigService,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setTitles();\r\n    this.setListStyle();\r\n    this.setHiddenCheckAll();\r\n    this.getTableCheckColumn();\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.transfer as XI18nTransfer),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        XIsEmpty(this.titles) && this.setTitles();\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data } = changes;\r\n    XIsChange(data) && this.setData();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  searchInputChange(source: XTransferSource) {\r\n    source.list = source.searchList?.filter((x) => x.label.indexOf(source.searchInput) >= 0);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  checkedAllChange($event: boolean, source: XTransferSource) {\r\n    let list: XTransferNode[] = (source.list?.filter((x) => !x.disabled) as XTransferNode[]).map((x) => {\r\n      x.checked = $event;\r\n      return x;\r\n    });\r\n    if (this.type === 'tree' && source.direction === 'left') {\r\n      this.treeActivatedId = $event ? source.list!.map((x) => x.id)! : source.list!.filter((x) => x.disabled).map((x) => x.id);\r\n    }\r\n    source.checkedCount = $event ? list.length : 0;\r\n    source.indeterminate = $event;\r\n    this.setButtonDisabled(source);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  checkedChange($event: boolean, source: XTransferSource) {\r\n    if (!$event) (source.checkedCount as number)--;\r\n    else (source.checkedCount as number)++;\r\n    this.setCheckedAll(source);\r\n    this.setButtonDisabled(source);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  move(from: XTransferSource, to: XTransferSource) {\r\n    if (from.disabledButton) return;\r\n    switch (this.type) {\r\n      case 'list':\r\n        this.moveList(from, to);\r\n        break;\r\n      case 'tree':\r\n        this.moveTree(from, to);\r\n        break;\r\n      case 'table':\r\n        this.moveTable(from, to);\r\n    }\r\n  }\r\n\r\n  private moveList(from: XTransferSource, to: XTransferSource) {\r\n    let checkedItems = from.list?.filter((x) => !x.disabled && x.checked)!;\r\n    let j = 0;\r\n    checkedItems.forEach((x) => {\r\n      const index = from.list?.indexOf(x) as number;\r\n      x.checked = false;\r\n      transferArrayItem(from.list!, to.list!, index, j);\r\n      j++;\r\n    });\r\n    from.list = [...from.list!];\r\n    to.list = [...to.list!];\r\n    this.setCheckedCount('list', from, to);\r\n    this.setListCount('list', from, to);\r\n    this.setCheckedAll(from, to);\r\n    this.setButtonDisabled(from, to);\r\n    this.setSearchList(from, to);\r\n    this.setValue();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private moveTree(from: XTransferSource, to: XTransferSource) {\r\n    let checkedItems: XTransferNode[] = [];\r\n    if (to.direction === 'right') {\r\n      checkedItems = from.list?.filter((x) => !x.disabled && !XIsEmpty(this.treeActivatedId) && this.treeActivatedId.includes(x.id))!;\r\n      checkedItems.forEach((x: XTreeNode) => {\r\n        x.disabled = true;\r\n        x.change && x.change();\r\n      });\r\n      to.list?.unshift(\r\n        ...checkedItems.map((x) => {\r\n          let res = { ...x };\r\n          res.checked = false;\r\n          res.disabled = false;\r\n          return res;\r\n        })\r\n      );\r\n      this.setCheckedCount('tree', from);\r\n      this.setCheckedCount('list', to);\r\n    } else {\r\n      checkedItems = XRemove(from.list!, (x) => !x.disabled && x.checked!);\r\n      for (let item of checkedItems) {\r\n        let node: XTreeNode = to.list?.find((x) => x.id === item.id)!;\r\n        if (node) {\r\n          node.checked = false;\r\n          node.disabled = false;\r\n          const idx = this.treeActivatedId.findIndex((x) => x === node.id);\r\n          if (idx >= 0) {\r\n            this.treeActivatedId.splice(idx, 1);\r\n          }\r\n          node.change && node.change();\r\n        }\r\n      }\r\n      this.setCheckedCount('tree', to);\r\n      this.setCheckedCount('list', from);\r\n    }\r\n    this.setCheckedAll(from, to);\r\n    this.setListCount('list', from, to);\r\n    this.setButtonDisabled(from, to);\r\n    this.setSearchList(from, to);\r\n    this.setValue();\r\n  }\r\n\r\n  private moveTable(from: XTransferSource, to: XTransferSource) {\r\n    let checkedItems: XTransferNode[] = [];\r\n    if (to.direction === 'right') {\r\n      checkedItems = from.list?.filter((x) => !x.disabled && x.checked)!;\r\n      to.list = [\r\n        ...checkedItems.map((x) => {\r\n          const res = { ...x };\r\n          x.disabled = true;\r\n          x.checked = true;\r\n          res.disabled = false;\r\n          res.checked = false;\r\n          return res;\r\n        }),\r\n        ...to.list!\r\n      ];\r\n      this.tableData = [...from.list!];\r\n      this.setCheckedCount('table', from);\r\n      this.setCheckedCount('list', to);\r\n    } else {\r\n      checkedItems = XRemove(from.list!, (x) => !x.disabled && x.checked!);\r\n      const ids = checkedItems.map((x) => x.id);\r\n      for (let item of to.list!) {\r\n        if (ids.includes(item.id)) {\r\n          item.checked = false;\r\n          item.disabled = false;\r\n        }\r\n      }\r\n      from.list = [...from.list!];\r\n      this.tableData = [...to.list!];\r\n      this.setCheckedCount('table', to);\r\n      this.setCheckedCount('list', from);\r\n    }\r\n    this.setListCount('table', from, to);\r\n    this.setCheckedAll(from, to);\r\n    this.setButtonDisabled(from, to);\r\n    this.setSearchList(from, to);\r\n    this.setValue();\r\n  }\r\n\r\n  dropCdk(event: CdkDragDrop<XTransferNode[] | undefined, any>) {\r\n    const ev = event as CdkDragDrop<XTransferNode[]>;\r\n    if (ev.previousContainer === ev.container) {\r\n      moveItemInArray(ev.container.data, ev.previousIndex, ev.currentIndex);\r\n    } else {\r\n      transferArrayItem(ev.previousContainer.data, ev.container.data, ev.previousIndex, ev.currentIndex);\r\n      this.setCheckedCount('list', this.left, this.right);\r\n      this.setCheckedAll(this.left, this.right);\r\n      this.setListCount('list', this.left, this.right);\r\n      this.setButtonDisabled(this.left, this.right);\r\n    }\r\n    this.setSearchList(this.left, this.right);\r\n    this.setValue();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  predicate(item: CdkDrag<XTransferNode>) {\r\n    return !item.data.disabled;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XTransferNode) {\r\n    return item.id;\r\n  }\r\n\r\n  setListCount(type: XTransferType = 'list', ...sources: XTransferSource[]) {\r\n    if (['list', 'tree'].includes(type)) {\r\n      for (let source of sources) {\r\n        source.count = source.list?.filter((x) => !x.disabled).length;\r\n      }\r\n    } else if (type === 'table') {\r\n      for (let source of sources) {\r\n        if (source.direction === 'left') {\r\n          source.count = this.tableTotal - this.right.list!.length || 0;\r\n        } else {\r\n          source.count = source.list?.filter((x) => !x.disabled).length;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  onTreeNodeClick(_node: XTreeNode) {\r\n    this.setCheckedCount('tree', this.left);\r\n    this.setCheckedAll(this.left);\r\n    this.setButtonDisabled(this.left);\r\n  }\r\n\r\n  onTableCheckedRow(row: XTransferNode, source: XTransferSource) {\r\n    if (!this.tableCheckboxColumn) return;\r\n    let checked = row[this.tableCheckboxColumn.id];\r\n    row.checked = checked;\r\n    this.setCheckedCount('table', source);\r\n    this.setCheckedAll(source);\r\n    this.setButtonDisabled(source);\r\n  }\r\n\r\n  onTableCheckedAll(row: { [prop: string]: boolean }, source: XTransferSource) {\r\n    if (!this.tableCheckboxColumn) return;\r\n    let checked = row[this.tableCheckboxColumn.id];\r\n    for (let item of source.list!) {\r\n      if (!item.disabled) {\r\n        item.checked = checked;\r\n      }\r\n    }\r\n    this.setCheckedCount('table', source);\r\n    this.setButtonDisabled(source);\r\n  }\r\n\r\n  private getTableCheckColumn() {\r\n    if (this.type !== 'table' || XIsEmpty(this.tableColumns)) return;\r\n    this.tableCheckboxColumn = this.tableColumns?.find((x) => x.rowChecked);\r\n  }\r\n\r\n  private setCheckedAll(...sources: XTransferSource[]) {\r\n    for (let source of sources) {\r\n      if ((source.checkedCount as number) > 0) {\r\n        if (source.checkedCount === source.list?.filter((x) => !x.disabled).length) {\r\n          source.checkedAll = true;\r\n        } else {\r\n          source.checkedAll = false;\r\n          source.indeterminate = true;\r\n        }\r\n      } else {\r\n        source.checkedAll = false;\r\n        source.indeterminate = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setCheckedCount(type: XTransferType = 'list', ...sources: XTransferSource[]) {\r\n    for (let source of sources) {\r\n      if (['table', 'list'].includes(type)) {\r\n        source.checkedCount = source.list?.filter((x) => !x.disabled && x.checked).length;\r\n      } else if (type === 'tree') {\r\n        source.checkedCount = source.list?.filter(\r\n          (x) => !x.disabled && !XIsEmpty(this.treeActivatedId) && this.treeActivatedId.includes(x.id)\r\n        ).length;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setButtonDisabled(...sources: XTransferSource[]) {\r\n    for (let source of sources) source.disabledButton = source.checkedCount === 0;\r\n  }\r\n\r\n  private setValue() {\r\n    if (this.isObjectArray) {\r\n      this.value = this.right.list!;\r\n    } else {\r\n      this.value = this.right.list?.map((x) => x.id)!;\r\n    }\r\n    this.onChange(this.value);\r\n  }\r\n\r\n  private setSearchList(..._sources: XTransferSource[]) {\r\n    // if (this.search) {\r\n    //   for (let source of sources) {\r\n    //     if (XIsEmpty(source.searchInput)) {\r\n    //       source.searchList = [...(source.list as XTransferNode[])];\r\n    //     }\r\n    //   }\r\n    // }\r\n  }\r\n\r\n  private setData() {\r\n    if (this.type === 'table') {\r\n      this.getTableData();\r\n      return;\r\n    }\r\n    XSetData<XTransferNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.setList(x);\r\n    });\r\n  }\r\n\r\n  private setList(data: XTransferNode[]) {\r\n    if (XIsEmpty(data)) return;\r\n    switch (this.type) {\r\n      case 'list':\r\n        this.nodes = data;\r\n        if (!XIsEmpty(this.values)) {\r\n          this.left.list = this.nodes.filter((x) => this.values.indexOf(x.id) < 0);\r\n          this.right.list = this.nodes.filter((x) => this.values.indexOf(x.id) >= 0);\r\n        } else {\r\n          this.left.list = [...this.nodes];\r\n        }\r\n        this.setSearchList(this.left, this.right);\r\n        this.setListCount(this.type, this.left, this.right);\r\n        break;\r\n      case 'tree':\r\n        this.nodes = data;\r\n        this.setTreeNodeDisabled();\r\n        this.left.list = [...this.nodes];\r\n        if (!XIsEmpty(this.values)) {\r\n          this.right.list = this.nodes\r\n            .filter((x) => this.values.indexOf(x.id) >= 0)\r\n            .map((x) => {\r\n              let res = { ...x };\r\n              res.checked = false;\r\n              res.disabled = false;\r\n              return res;\r\n            });\r\n        }\r\n        this.setSearchList(this.left, this.right);\r\n        this.setListCount(this.type, this.left, this.right);\r\n        break;\r\n      case 'table':\r\n        this.nodes = data;\r\n        this.setTableDataDisabled();\r\n        this.left.list = [...this.nodes];\r\n        if (!XIsEmpty(this.values)) {\r\n          if (this.isObjectArray) {\r\n            this.right.list = [\r\n              ...this.value.map((x) => {\r\n                let res = { ...x };\r\n                res.disabled = false;\r\n                res.checked = false;\r\n                return res;\r\n              })\r\n            ];\r\n          } else {\r\n            this.right.list = [...this.value];\r\n          }\r\n        }\r\n        this.setSearchList(this.left, this.right);\r\n        this.setListCount(this.type, this.left, this.right);\r\n        break;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getTableData() {\r\n    if (XIsFunction(this.data)) {\r\n      (this.data as Function)(this.tableIndex, this.tableSize, this.tableQuery).subscribe((x: XResultList<XTransferNode>) => {\r\n        this.tableTotal = x.total!;\r\n        this.tableData = x.list!;\r\n        this.setList(x.list!);\r\n      });\r\n    }\r\n  }\r\n\r\n  private setTitles() {\r\n    let titles: string[] = [];\r\n    if (XIsEmpty(this.titles)) {\r\n      titles = [this.localTitle!, this.locale.selectedTitle!];\r\n    } else {\r\n      titles = this.titles;\r\n    }\r\n    if (titles.length > 0) this.left.title = titles[0];\r\n    if (titles.length > 1) this.right.title = titles[1];\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setListStyle() {\r\n    if (XIsEmpty(this.listStyle)) return;\r\n    let styles: object[] = [];\r\n    if (XIsObject(this.listStyle)) {\r\n      styles = [this.listStyle, this.listStyle];\r\n    } else if (XIsObjectArray(this.listStyle)) {\r\n      styles = this.listStyle as object[];\r\n    }\r\n    if (styles.length > 0) this.left.listStyle = styles[0];\r\n    if (styles.length > 1) this.right.listStyle = styles[1];\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setTreeNodeDisabled() {\r\n    if (!XIsEmpty(this.values) && this.nodes) {\r\n      for (let item of this.nodes) {\r\n        let hasIn = this.values.indexOf(item.id) >= 0;\r\n        item.disabled = hasIn;\r\n        item.checked = hasIn;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setTableDataDisabled() {\r\n    if (!XIsEmpty(this.values) && this.nodes) {\r\n      for (let item of this.nodes) {\r\n        let hasIn = this.values.indexOf(item.id) >= 0;\r\n        item.disabled = hasIn;\r\n        item.checked = hasIn;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setHiddenCheckAll() {\r\n    if (XIsEmpty(this.hiddenCheckAll)) return;\r\n    if (this.hiddenCheckAll!.length > 0 && XIsBoolean(this.hiddenCheckAll![0])) this.left.hiddenCheckAll = this.hiddenCheckAll![0];\r\n    if (this.hiddenCheckAll!.length > 1 && XIsBoolean(this.hiddenCheckAll![1])) this.right.hiddenCheckAll = this.hiddenCheckAll![1];\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div #transfer class=\"x-transfer\" cdkDropListGroup [ngClass]=\"classMap\">\r\n  <div class=\"x-transfer-box\">\r\n    <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: left }\"></ng-container>\r\n    <div [ngStyle]=\"left.listStyle!\" class=\"x-transfer-list\">\r\n      <ng-container [ngSwitch]=\"type\">\r\n        <ul\r\n          *ngSwitchCase=\"'list'\"\r\n          cdkDropList\r\n          (cdkDropListDropped)=\"dropCdk($event)\"\r\n          [cdkDropListData]=\"left.list\"\r\n          [cdkDropListDisabled]=\"!drag && type === 'list'\"\r\n          [cdkDropListEnterPredicate]=\"predicate\"\r\n          class=\"x-transfer-droplist\"\r\n        >\r\n          <li class=\"x-transfer-item\" *ngFor=\"let node of left.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n            <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: left }\"></ng-container>\r\n          </li>\r\n        </ul>\r\n        <x-tree\r\n          *ngSwitchCase=\"'tree'\"\r\n          [data]=\"left.list!\"\r\n          multiple\r\n          allowManyActivated\r\n          [(activatedId)]=\"treeActivatedId\"\r\n          (nodeClick)=\"onTreeNodeClick($event)\"\r\n        ></x-tree>\r\n        <x-table\r\n          *ngSwitchCase=\"'table'\"\r\n          [data]=\"tableData\"\r\n          [columns]=\"tableColumns!\"\r\n          [(size)]=\"tableSize\"\r\n          [(index)]=\"tableIndex\"\r\n          (indexChange)=\"getTableData()\"\r\n          [query]=\"tableQuery\"\r\n          [total]=\"tableTotal\"\r\n          (activatedRowChange)=\"onTableCheckedRow($event, left)\"\r\n          (headCheckboxChange)=\"onTableCheckedAll($event, left)\"\r\n          hiddenWrapBorder\r\n          hiddenPaginationBorder\r\n          showEllipsis=\"false\"\r\n          showTotal=\"false\"\r\n          paginationPosition=\"bottom-center\"\r\n          allowSelectRow=\"false\"\r\n        ></x-table>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n  <div class=\"x-transfer-buttons\">\r\n    <x-button type=\"primary\" icon=\"fto-chevron-right\" [disabled]=\"left.disabledButton\" (click)=\"move(left, right)\"></x-button>\r\n    <x-button type=\"primary\" icon=\"fto-chevron-left\" [disabled]=\"right.disabledButton\" (click)=\"move(right, left)\"></x-button>\r\n  </div>\r\n  <div class=\"x-transfer-box\">\r\n    <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: right }\"></ng-container>\r\n    <div [ngSwitch]=\"type\" [ngStyle]=\"right.listStyle!\" class=\"x-transfer-list\">\r\n      <x-table\r\n        *ngSwitchCase=\"'table'\"\r\n        [data]=\"right.list!\"\r\n        [columns]=\"tableColumns!\"\r\n        (activatedRowChange)=\"onTableCheckedRow($event, right)\"\r\n        (headCheckboxChange)=\"onTableCheckedAll($event, right)\"\r\n        hiddenWrapBorder\r\n        hiddenPaginationBorder\r\n        showPagination=\"false\"\r\n        showEllipsis=\"false\"\r\n        showTotal=\"false\"\r\n        paginationPosition=\"bottom-center\"\r\n        allowSelectRow=\"false\"\r\n      ></x-table>\r\n      <ul\r\n        *ngSwitchDefault\r\n        cdkDropList\r\n        (cdkDropListDropped)=\"dropCdk($event)\"\r\n        [cdkDropListData]=\"right.list\"\r\n        [cdkDropListDisabled]=\"!drag || (drag && type !== 'list')\"\r\n        [cdkDropListEnterPredicate]=\"predicate\"\r\n        class=\"x-transfer-droplist\"\r\n      >\r\n        <li class=\"x-transfer-item\" *ngFor=\"let node of right.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n          <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: right }\"></ng-container>\r\n        </li>\r\n      </ul>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #sourceTitleTpl let-source=\"source\">\r\n  <div class=\"x-transfer-title\">\r\n    <x-checkbox\r\n      *ngIf=\"source.title && !source.hiddenCheckAll\"\r\n      [data]=\"[titleTpl ? '' : source.title]\"\r\n      [(ngModel)]=\"source.checkedAll\"\r\n      (ngModelChange)=\"checkedAllChange($event, source)\"\r\n      [indeterminate]=\"source.indeterminate\"\r\n    ></x-checkbox>\r\n    <span *ngIf=\"source.title && source.hiddenCheckAll\">{{ source.title }}</span>\r\n    <ng-container *xOutlet=\"titleTpl; context: { $title: source.title, $checkedCount: source.checkedCount, $count: source.count }\"\r\n      ><span class=\"x-transfer-total\">{{ source.checkedCount }} / {{ source.count }}</span></ng-container\r\n    >\r\n  </div>\r\n  <!-- <div class=\"x-transfer-search\" *ngIf=\"search\">\r\n    <x-input\r\n      icon=\"fto-search\"\r\n      [(ngModel)]=\"source.searchInput\"\r\n      (ngModelChange)=\"searchInputChange(source)\"\r\n      clearable\r\n    ></x-input>\r\n  </div> -->\r\n</ng-template>\r\n\r\n<ng-template #sourceNodeTpl let-node=\"node\" let-source=\"source\">\r\n  <x-checkbox\r\n    [data]=\"[{ id: node.id, label: nodeTpl ? nodeTpl : node.label, node: node }]\"\r\n    [disabled]=\"node.disabled\"\r\n    [(ngModel)]=\"node.checked\"\r\n    (ngModelChange)=\"checkedChange($event, source)\"\r\n  ></x-checkbox>\r\n</ng-template>\r\n"]}
|
|
595
|
+
args: [{ selector: `${XTransferPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XTransferComponent)], template: "<div #transfer class=\"x-transfer\" cdkDropListGroup [ngClass]=\"classMap\">\r\n <div class=\"x-transfer-box\" [class.x-transfer-has-footer]=\"left.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: left }\"></ng-container>\r\n <div [ngStyle]=\"left.listStyle!\" class=\"x-transfer-list\">\r\n <ng-container [ngSwitch]=\"type\">\r\n <ul\r\n *ngSwitchCase=\"'list'\"\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"left.list\"\r\n [cdkDropListDisabled]=\"!drag && type === 'list'\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of left.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: left }\"></ng-container>\r\n </li>\r\n </ul>\r\n <x-tree\r\n *ngSwitchCase=\"'tree'\"\r\n [data]=\"left.list!\"\r\n multiple\r\n allowManyActivated\r\n [(activatedId)]=\"treeActivatedId\"\r\n (nodeClick)=\"onTreeNodeClick($event)\"\r\n [labelTpl]=\"treeLabelTpl\"\r\n ></x-tree>\r\n <ng-template #treeLabelTpl let-node=\"$node\">\r\n <span class=\"x-transfer-tree-label\" x-keyword [text]=\"left.searchInput!\">{{ node.label }}</span>\r\n </ng-template>\r\n <x-table\r\n #leftTableCom\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"tableData\"\r\n [columns]=\"tableColumns!\"\r\n [(size)]=\"tableSize\"\r\n [(index)]=\"tableIndex\"\r\n (indexChange)=\"getTableData()\"\r\n [query]=\"tableQuery\"\r\n [total]=\"tableTotal\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, left)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, left)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n [headSearchTpl]=\"left.tableHeadSearchTpl\"\r\n ></x-table>\r\n </ng-container>\r\n </div>\r\n <div class=\"x-transfer-footer\" *ngIf=\"left.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"left.footerTpl; context: { $source: left }\"></ng-container>\r\n </div>\r\n </div>\r\n <div class=\"x-transfer-buttons\">\r\n <x-button type=\"primary\" icon=\"fto-chevron-right\" [disabled]=\"left.disabledButton\" (click)=\"move(left, right)\"></x-button>\r\n <x-button type=\"primary\" icon=\"fto-chevron-left\" [disabled]=\"right.disabledButton\" (click)=\"move(right, left)\"></x-button>\r\n </div>\r\n <div class=\"x-transfer-box\" [class.x-transfer-has-footer]=\"right.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: right }\"></ng-container>\r\n <div [ngSwitch]=\"type\" [ngStyle]=\"right.listStyle!\" class=\"x-transfer-list\">\r\n <x-table\r\n #rightTableCom\r\n *ngSwitchCase=\"'table'\"\r\n [data]=\"right.list!\"\r\n [columns]=\"tableColumns!\"\r\n (activatedRowChange)=\"onTableCheckedRow($event, right)\"\r\n (headCheckboxChange)=\"onTableCheckedAll($event, right)\"\r\n hiddenWrapBorder\r\n hiddenPaginationBorder\r\n showPagination=\"false\"\r\n showEllipsis=\"false\"\r\n showTotal=\"false\"\r\n paginationPosition=\"bottom-center\"\r\n allowSelectRow=\"false\"\r\n [headSearchTpl]=\"right.tableHeadSearchTpl\"\r\n ></x-table>\r\n <ul\r\n *ngSwitchDefault\r\n cdkDropList\r\n (cdkDropListDropped)=\"dropCdk($event)\"\r\n [cdkDropListData]=\"right.list\"\r\n [cdkDropListDisabled]=\"!drag || (drag && type !== 'list')\"\r\n [cdkDropListEnterPredicate]=\"predicate\"\r\n class=\"x-transfer-droplist\"\r\n >\r\n <li class=\"x-transfer-item\" *ngFor=\"let node of right.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: right }\"></ng-container>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"x-transfer-footer\" *ngIf=\"right.footerTpl\">\r\n <ng-container *ngTemplateOutlet=\"right.footerTpl; context: { $source: right }\"></ng-container>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #sourceTitleTpl let-source=\"source\">\r\n <div class=\"x-transfer-title\">\r\n <div class=\"x-transfer-title-left\">\r\n <x-checkbox\r\n *ngIf=\"source.title && !source.hiddenCheckAll\"\r\n [data]=\"[titleTpl ? '' : source.title]\"\r\n [(ngModel)]=\"source.checkedAll\"\r\n (ngModelChange)=\"checkedAllChange($event, source)\"\r\n [indeterminate]=\"source.indeterminate\"\r\n ></x-checkbox>\r\n <span *ngIf=\"source.title && source.hiddenCheckAll\">{{ source.title }}</span>\r\n <x-link *ngIf=\"inverse && type === 'list'\" class=\"x-transfer-inverse\" type=\"primary\" (click)=\"onInverse(source)\">{{\r\n 'transfer.inverse' | xI18n\r\n }}</x-link>\r\n </div>\r\n <ng-container *xOutlet=\"titleTpl; context: { $title: source.title, $checkedCount: source.checkedCount, $count: source.count }\"\r\n ><span class=\"x-transfer-total\">{{ source.checkedCount }} / {{ source.count }}</span></ng-container\r\n >\r\n </div>\r\n <div class=\"x-transfer-search\" *ngIf=\"search && type !== 'table'\">\r\n <x-input icon=\"fto-search\" [(ngModel)]=\"source.searchInput\" (ngModelChange)=\"onSearchInputChange(source)\" clearable></x-input>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #sourceNodeTpl let-node=\"node\" let-source=\"source\">\r\n <x-checkbox\r\n [data]=\"[{ id: node.id, label: nodeTpl ? nodeTpl : labelTpl, node: node }]\"\r\n [disabled]=\"node.disabled\"\r\n [(ngModel)]=\"node.checked\"\r\n (ngModelChange)=\"checkedChange($event, source)\"\r\n ></x-checkbox>\r\n <ng-template #labelTpl>\r\n <span x-keyword [text]=\"source.searchInput!\">{{ node.label }}</span>\r\n </ng-template>\r\n</ng-template>\r\n", styles: [".x-transfer{margin:0;padding:0;display:inline-flex;align-items:center}.x-transfer-title{padding:.25rem .5625rem;display:flex;align-items:center;justify-content:space-between;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-top-left-radius:var(--x-border-radius);border-top-right-radius:var(--x-border-radius);background-color:var(--x-background);color:var(--x-text-300)}.x-transfer-title-left{display:inline-flex;align-items:center}.x-transfer-inverse{margin:0 .5rem}.x-transfer-total{margin-left:.325rem}.x-transfer-box{min-width:12rem}.x-transfer-list{display:flex;flex-direction:column;height:18rem;width:100%;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-top:none;border-bottom-left-radius:var(--x-border-radius);border-bottom-right-radius:var(--x-border-radius);overflow:auto}.x-transfer-item{padding:.125rem .25rem;border-radius:var(--x-border-radius);display:flex;align-items:center;border:.0625rem dashed transparent;transition:border-color var(--x-animation-duration-base),background-color var(--x-animation-duration-base),color var(--x-animation-duration-base)}.x-transfer-droplist{height:100%;padding:.25rem}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item:hover{background-color:transparent}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item.cdk-drag-placeholder{border-color:var(--x-primary);color:var(--x-primary);background-color:var(--x-background);opacity:.8}.x-transfer-droplist.cdk-drop-list-dragging .x-transfer-item:not(.cdk-drag-placeholder){transition:transform var(--x-animation-duration-base) cubic-bezier(0,0,.2,1)}.x-transfer-buttons{margin:0 1rem;display:flex;flex-direction:column}.x-transfer-buttons>x-button:not(:first-child){margin-top:.5rem}.x-transfer-search{padding:.5rem;border-left:var(--x-border-width) var(--x-border-style) var(--x-border);border-right:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-transfer-search x-input{width:100%}.x-transfer-tree-label{flex:1}.x-transfer-footer{padding:.25rem .5625rem;border:var(--x-border-width) var(--x-border-style) var(--x-border);border-bottom-left-radius:var(--x-border-radius);border-bottom-right-radius:var(--x-border-radius)}.x-transfer-has-footer .x-transfer-list{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:none}body>li.x-transfer-item.cdk-drag-preview{padding:.125rem .25rem;border-radius:var(--x-border-radius);display:flex;align-items:center;border:.0625rem dashed transparent;border-color:var(--x-border);color:var(--x-text-400);background-color:var(--x-background-a100);opacity:.9}body>li.x-transfer-item.cdk-drag-animating{transition:transform var(--x-animation-duration-base) cubic-bezier(0,0,.2,1)}\n"] }]
|
|
596
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }, { type: i2.XI18nService }]; }, propDecorators: { leftTableCom: [{
|
|
597
|
+
type: ViewChild,
|
|
598
|
+
args: ['leftTableCom']
|
|
599
|
+
}], rightTableCom: [{
|
|
600
|
+
type: ViewChild,
|
|
601
|
+
args: ['rightTableCom']
|
|
602
|
+
}] } });
|
|
603
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transfer.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/transfer/transfer.component.ts","../../../../../lib/ng-nest/ui/transfer/transfer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  OnDestroy,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { XTransferPrefix, XTransferNode, XTransferSource, XTransferProperty, XTransferType } from './transfer.property';\r\nimport {\r\n  XIsChange,\r\n  XIsEmpty,\r\n  XSetData,\r\n  XConfigService,\r\n  XRemove,\r\n  XIsArray,\r\n  XIsObject,\r\n  XIsObjectArray,\r\n  XIsBoolean,\r\n  XIsFunction,\r\n  XResultList,\r\n  XIsUndefined\r\n} from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, map, takeUntil } from 'rxjs/operators';\r\nimport { transferArrayItem, moveItemInArray, CdkDragDrop, CdkDrag } from '@angular/cdk/drag-drop';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\nimport { XI18nService, XI18nTransfer } from '@ng-nest/ui/i18n';\r\nimport { XTreeNode } from '@ng-nest/ui/tree';\r\nimport { XTableColumn, XTableComponent } from '@ng-nest/ui/table';\r\n\r\n@Component({\r\n  selector: `${XTransferPrefix}`,\r\n  templateUrl: './transfer.component.html',\r\n  styleUrls: ['./transfer.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XTransferComponent)]\r\n})\r\nexport class XTransferComponent extends XTransferProperty implements OnInit, OnChanges, OnDestroy {\r\n  @ViewChild('leftTableCom') leftTableCom?: XTableComponent;\r\n  @ViewChild('rightTableCom') rightTableCom?: XTableComponent;\r\n  nodes: XTransferNode[] = [];\r\n  left: XTransferSource = {\r\n    list: [],\r\n    searchList: [],\r\n    checkedCount: 0,\r\n    direction: 'left',\r\n    disabledButton: true\r\n  };\r\n  right: XTransferSource = {\r\n    list: [],\r\n    searchList: [],\r\n    checkedCount: 0,\r\n    direction: 'right',\r\n    disabledButton: true\r\n  };\r\n  searchInput: string = '';\r\n  searchInputLeftChange = new Subject<string>();\r\n  searchInputRightChange = new Subject<string>();\r\n  searchDebounceTime = 200;\r\n  locale: XI18nTransfer = {};\r\n  private get localTitle() {\r\n    if (this.type === 'tree') {\r\n      return this.locale.treeTitle;\r\n    } else {\r\n      return this.locale.listTitle;\r\n    }\r\n  }\r\n  private _unSubject = new Subject<void>();\r\n  treeActivatedId: any[] = [];\r\n  tableData: XTransferNode[] = [];\r\n  tableCheckboxColumn?: XTableColumn;\r\n  isObjectArray = false;\r\n  override writeValue(value: any[]): void {\r\n    this.value = value;\r\n    if (XIsArray(value)) {\r\n      this.treeActivatedId = [...value];\r\n      if (XIsObjectArray(value)) {\r\n        this.isObjectArray = true;\r\n      }\r\n    }\r\n    this.setList(this.nodes);\r\n  }\r\n\r\n  get values() {\r\n    if (this.isObjectArray) {\r\n      return this.value.map((x) => x.id);\r\n    } else {\r\n      return this.value;\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef<HTMLElement>,\r\n    public override cdr: ChangeDetectorRef,\r\n    public configService: XConfigService,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setTitles();\r\n    this.setListStyle();\r\n    this.setHiddenCheckAll();\r\n    this.getTableCheckColumn();\r\n    this.setFooterTpl();\r\n    this.setTableHeadSearchTpl();\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.transfer as XI18nTransfer),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        XIsEmpty(this.titles) && this.setTitles();\r\n        this.cdr.markForCheck();\r\n      });\r\n    this.searchInputLeftChange\r\n      .pipe(debounceTime(this.searchDebounceTime), distinctUntilChanged(), takeUntil(this._unSubject))\r\n      .subscribe(() => {\r\n        this.setSearchInputChange(this.left);\r\n      });\r\n    this.searchInputRightChange\r\n      .pipe(debounceTime(this.searchDebounceTime), distinctUntilChanged(), takeUntil(this._unSubject))\r\n      .subscribe(() => {\r\n        this.setSearchInputChange(this.right);\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data } = changes;\r\n    XIsChange(data) && this.setData();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  onSearchInputChange(source: XTransferSource) {\r\n    if (source.direction === 'left') {\r\n      this.searchInputLeftChange.next(source.searchInput!);\r\n    } else if (source.direction === 'right') {\r\n      this.searchInputRightChange.next(source.searchInput!);\r\n    }\r\n  }\r\n\r\n  setSearchInputChange(source: XTransferSource) {\r\n    if (XIsUndefined(source.searchInput)) return;\r\n    if (XIsEmpty(source.searchInput)) {\r\n      source.list = [...source.searchList!];\r\n    } else {\r\n      switch (this.type) {\r\n        case 'list':\r\n          source.list = source.searchList?.filter((x) => x.label.indexOf(source.searchInput) >= 0);\r\n          break;\r\n        case 'tree':\r\n          if (source.direction === 'right') {\r\n            source.list = source.searchList?.filter((x) => x.label.indexOf(source.searchInput) >= 0);\r\n          } else if (source.direction === 'left') {\r\n            let searchList = source.searchList?.filter((x) => x.label.indexOf(source.searchInput) >= 0)!;\r\n            let parents: XTransferNode[] = [];\r\n            const findParent = (item: XTransferNode) => {\r\n              if (!item.pid) return;\r\n              let parent = source.searchList?.find((x) => x.id === item.pid);\r\n              if (parent && !parents.some((x) => x.id === parent!.id)) {\r\n                parents.push(parent);\r\n                findParent(parent);\r\n              }\r\n            };\r\n            for (let item of searchList) {\r\n              findParent(item);\r\n            }\r\n            source.list = [...searchList, ...parents];\r\n          }\r\n          break;\r\n        case 'table':\r\n          break;\r\n      }\r\n    }\r\n    this.setListCount(this.type, source);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  checkedAllChange($event: boolean, source: XTransferSource) {\r\n    let list: XTransferNode[] = (source.list?.filter((x) => !x.disabled) as XTransferNode[]).map((x) => {\r\n      x.checked = $event;\r\n      return x;\r\n    });\r\n    if (this.type === 'tree' && source.direction === 'left') {\r\n      this.treeActivatedId = $event ? source.list!.map((x) => x.id)! : source.list!.filter((x) => x.disabled).map((x) => x.id);\r\n    }\r\n    source.checkedCount = $event ? list.length : 0;\r\n    source.indeterminate = $event;\r\n    this.setButtonDisabled(source);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  checkedChange($event: boolean, source: XTransferSource) {\r\n    if (!$event) (source.checkedCount as number)--;\r\n    else (source.checkedCount as number)++;\r\n    this.setCheckedAll(source);\r\n    this.setButtonDisabled(source);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  move(from: XTransferSource, to: XTransferSource) {\r\n    if (from.disabledButton) return;\r\n    switch (this.type) {\r\n      case 'list':\r\n        this.moveList(from, to);\r\n        break;\r\n      case 'tree':\r\n        this.moveTree(from, to);\r\n        break;\r\n      case 'table':\r\n        this.moveTable(from, to);\r\n    }\r\n  }\r\n\r\n  private moveList(from: XTransferSource, to: XTransferSource) {\r\n    let checkedItems = from.list?.filter((x) => !x.disabled && x.checked)!;\r\n    let j = 0;\r\n    checkedItems.forEach((x) => {\r\n      let index = from.list?.indexOf(x) as number;\r\n      x.checked = false;\r\n      transferArrayItem(from.list!, to.list!, index, j);\r\n      if (this.search) {\r\n        index = from.searchList?.indexOf(x) as number;\r\n        transferArrayItem(from.searchList!, to.searchList!, index, j);\r\n      }\r\n      j++;\r\n    });\r\n    from.list = [...from.list!];\r\n    to.list = [...to.list!];\r\n    this.setCheckedCount('list', from, to);\r\n    this.setListCount('list', from, to);\r\n    this.setCheckedAll(from, to);\r\n    this.setButtonDisabled(from, to);\r\n    this.setSearchList(from, to);\r\n    this.setValue();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private moveTree(from: XTransferSource, to: XTransferSource) {\r\n    let checkedItems: XTransferNode[] = [];\r\n    if (to.direction === 'right') {\r\n      checkedItems = from.list?.filter((x) => !x.disabled && !XIsEmpty(this.treeActivatedId) && this.treeActivatedId.includes(x.id))!;\r\n      checkedItems.forEach((x: XTreeNode) => {\r\n        x.disabled = true;\r\n        x.change && x.change();\r\n      });\r\n      to.list?.unshift(\r\n        ...checkedItems.map((x) => {\r\n          let res = { ...x };\r\n          res.checked = false;\r\n          res.disabled = false;\r\n          return res;\r\n        })\r\n      );\r\n      this.setCheckedCount('tree', from);\r\n      this.setCheckedCount('list', to);\r\n    } else {\r\n      checkedItems = XRemove(from.list!, (x) => !x.disabled && x.checked!);\r\n      if (this.search) {\r\n        XRemove(from.searchList!, (x) => !x.disabled && x.checked!);\r\n      }\r\n      for (let item of checkedItems) {\r\n        let node: XTreeNode = to.list?.find((x) => x.id === item.id)!;\r\n        if (node) {\r\n          node.checked = false;\r\n          node.disabled = false;\r\n          const idx = this.treeActivatedId.findIndex((x) => x === node.id);\r\n          if (idx >= 0) {\r\n            this.treeActivatedId.splice(idx, 1);\r\n          }\r\n          node.change && node.change();\r\n        }\r\n      }\r\n      this.setCheckedCount('tree', to);\r\n      this.setCheckedCount('list', from);\r\n    }\r\n    this.setCheckedAll(from, to);\r\n    this.setListCount('list', from, to);\r\n    this.setButtonDisabled(from, to);\r\n    this.setSearchList(from, to);\r\n    this.setValue();\r\n  }\r\n\r\n  private moveTable(from: XTransferSource, to: XTransferSource) {\r\n    let checkedItems: XTransferNode[] = [];\r\n    if (to.direction === 'right') {\r\n      checkedItems = from.list?.filter((x) => !x.disabled && x.checked)!;\r\n      to.list = [\r\n        ...checkedItems.map((x) => {\r\n          const res = { ...x };\r\n          x.disabled = true;\r\n          x.checked = true;\r\n          res.disabled = false;\r\n          res.checked = false;\r\n          return res;\r\n        }),\r\n        ...to.list!\r\n      ];\r\n      this.tableData = [...from.list!];\r\n      this.setCheckedCount('table', from);\r\n      this.setCheckedCount('list', to);\r\n    } else {\r\n      checkedItems = XRemove(from.list!, (x) => !x.disabled && x.checked!);\r\n      const ids = checkedItems.map((x) => x.id);\r\n      for (let item of to.list!) {\r\n        if (ids.includes(item.id)) {\r\n          item.checked = false;\r\n          item.disabled = false;\r\n        }\r\n      }\r\n      from.list = [...from.list!];\r\n      this.tableData = [...to.list!];\r\n      this.setCheckedCount('table', to);\r\n      this.setCheckedCount('list', from);\r\n    }\r\n    this.setListCount('table', from, to);\r\n    this.setCheckedAll(from, to);\r\n    this.setButtonDisabled(from, to);\r\n    this.setSearchList(from, to);\r\n    this.setValue();\r\n  }\r\n\r\n  dropCdk(event: CdkDragDrop<XTransferNode[] | undefined, any>) {\r\n    const ev = event as CdkDragDrop<XTransferNode[]>;\r\n    if (ev.previousContainer === ev.container) {\r\n      moveItemInArray(ev.container.data, ev.previousIndex, ev.currentIndex);\r\n    } else {\r\n      transferArrayItem(ev.previousContainer.data, ev.container.data, ev.previousIndex, ev.currentIndex);\r\n      this.setCheckedCount('list', this.left, this.right);\r\n      this.setCheckedAll(this.left, this.right);\r\n      this.setListCount('list', this.left, this.right);\r\n      this.setButtonDisabled(this.left, this.right);\r\n    }\r\n    this.setSearchList(this.left, this.right);\r\n    this.setValue();\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  predicate(item: CdkDrag<XTransferNode>) {\r\n    return !item.data.disabled;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XTransferNode) {\r\n    return item.id;\r\n  }\r\n\r\n  setListCount(type: XTransferType = 'list', ...sources: XTransferSource[]) {\r\n    if (['list', 'tree'].includes(type)) {\r\n      for (let source of sources) {\r\n        source.count = source.list?.filter((x) => !x.disabled).length;\r\n      }\r\n    } else if (type === 'table') {\r\n      for (let source of sources) {\r\n        if (source.direction === 'left') {\r\n          source.count = this.tableTotal - this.right.list!.length || 0;\r\n        } else {\r\n          source.count = source.list?.filter((x) => !x.disabled).length;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  onTreeNodeClick(_node: XTreeNode) {\r\n    this.setCheckedCount('tree', this.left);\r\n    this.setCheckedAll(this.left);\r\n    this.setButtonDisabled(this.left);\r\n  }\r\n\r\n  onTableCheckedRow(row: XTransferNode, source: XTransferSource) {\r\n    if (!this.tableCheckboxColumn) return;\r\n    let checked = row[this.tableCheckboxColumn.id];\r\n    row.checked = checked;\r\n    this.setCheckedCount('table', source);\r\n    this.setCheckedAll(source);\r\n    this.setButtonDisabled(source);\r\n  }\r\n\r\n  onTableCheckedAll(row: { [prop: string]: boolean }, source: XTransferSource) {\r\n    if (!this.tableCheckboxColumn) return;\r\n    let checked = row[this.tableCheckboxColumn.id];\r\n    for (let item of source.list!) {\r\n      if (!item.disabled) {\r\n        item.checked = checked;\r\n      }\r\n    }\r\n    this.setCheckedCount('table', source);\r\n    this.setButtonDisabled(source);\r\n  }\r\n\r\n  onInverse(source: XTransferSource) {\r\n    for (let item of source.list!) {\r\n      if (!item.disabled) {\r\n        item.checked = !item.checked;\r\n      }\r\n    }\r\n    let type = `${this.type}` as XTransferType;\r\n    if (type === 'tree' && source.direction === 'right') {\r\n      type = 'list';\r\n    }\r\n    this.setCheckedCount(type, source);\r\n    this.setCheckedAll(source);\r\n    this.setButtonDisabled(source);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private getTableCheckColumn() {\r\n    if (this.type !== 'table' || XIsEmpty(this.tableColumns)) return;\r\n    this.tableCheckboxColumn = this.tableColumns?.find((x) => x.rowChecked);\r\n  }\r\n\r\n  private setCheckedAll(...sources: XTransferSource[]) {\r\n    for (let source of sources) {\r\n      if ((source.checkedCount as number) > 0) {\r\n        if (source.checkedCount === source.list?.filter((x) => !x.disabled).length) {\r\n          source.checkedAll = true;\r\n        } else {\r\n          source.checkedAll = false;\r\n          source.indeterminate = true;\r\n        }\r\n      } else {\r\n        source.checkedAll = false;\r\n        source.indeterminate = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setCheckedCount(type: XTransferType = 'list', ...sources: XTransferSource[]) {\r\n    for (let source of sources) {\r\n      if (['table', 'list'].includes(type)) {\r\n        source.checkedCount = source.list?.filter((x) => !x.disabled && x.checked).length;\r\n      } else if (type === 'tree') {\r\n        source.checkedCount = source.list?.filter(\r\n          (x) => !x.disabled && !XIsEmpty(this.treeActivatedId) && this.treeActivatedId.includes(x.id)\r\n        ).length;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setButtonDisabled(...sources: XTransferSource[]) {\r\n    for (let source of sources) source.disabledButton = source.checkedCount === 0;\r\n  }\r\n\r\n  private setValue() {\r\n    if (this.isObjectArray) {\r\n      this.value = this.right.list!;\r\n    } else {\r\n      this.value = this.right.list?.map((x) => x.id)!;\r\n    }\r\n    this.onChange(this.value);\r\n  }\r\n\r\n  private setSearchList(...sources: XTransferSource[]) {\r\n    if (this.search) {\r\n      for (let source of sources) {\r\n        if (XIsEmpty(source.searchInput)) {\r\n          source.searchList = [...(source.list as XTransferNode[])];\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private setData() {\r\n    if (this.type === 'table') {\r\n      this.getTableData();\r\n      return;\r\n    }\r\n    XSetData<XTransferNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.setList(x);\r\n    });\r\n  }\r\n\r\n  private setList(data: XTransferNode[]) {\r\n    if (XIsEmpty(data)) return;\r\n    switch (this.type) {\r\n      case 'list':\r\n        this.nodes = data;\r\n        if (!XIsEmpty(this.values)) {\r\n          this.left.list = this.nodes.filter((x) => this.values.indexOf(x.id) < 0);\r\n          this.right.list = this.nodes.filter((x) => this.values.indexOf(x.id) >= 0);\r\n        } else {\r\n          this.left.list = [...this.nodes];\r\n        }\r\n        this.setSearchList(this.left, this.right);\r\n        this.setListCount(this.type, this.left, this.right);\r\n        break;\r\n      case 'tree':\r\n        this.nodes = data;\r\n        this.setTreeNodeDisabled();\r\n        this.left.list = [...this.nodes];\r\n        if (!XIsEmpty(this.values)) {\r\n          this.right.list = this.nodes\r\n            .filter((x) => this.values.indexOf(x.id) >= 0)\r\n            .map((x) => {\r\n              let res = { ...x };\r\n              res.checked = false;\r\n              res.disabled = false;\r\n              return res;\r\n            });\r\n        }\r\n        this.setSearchList(this.left, this.right);\r\n        this.setListCount(this.type, this.left, this.right);\r\n        break;\r\n      case 'table':\r\n        this.nodes = data;\r\n        this.setTableDataDisabled();\r\n        this.left.list = [...this.nodes];\r\n        if (!XIsEmpty(this.values)) {\r\n          if (this.isObjectArray) {\r\n            this.right.list = [\r\n              ...this.value.map((x) => {\r\n                let res = { ...x };\r\n                res.disabled = false;\r\n                res.checked = false;\r\n                return res;\r\n              })\r\n            ];\r\n          } else {\r\n            this.right.list = [...this.value];\r\n          }\r\n        }\r\n        this.setSearchList(this.left, this.right);\r\n        this.setListCount(this.type, this.left, this.right);\r\n        break;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getTableData() {\r\n    if (XIsFunction(this.data)) {\r\n      (this.data as Function)(this.tableIndex, this.tableSize, this.tableQuery).subscribe((x: XResultList<XTransferNode>) => {\r\n        this.tableTotal = x.total!;\r\n        this.tableData = x.list!;\r\n        this.setList(x.list!);\r\n      });\r\n    }\r\n  }\r\n\r\n  private setTitles() {\r\n    let titles: string[] = [];\r\n    if (XIsEmpty(this.titles)) {\r\n      titles = [this.localTitle!, this.locale.selectedTitle!];\r\n    } else {\r\n      titles = this.titles;\r\n    }\r\n    if (titles.length > 0) this.left.title = titles[0];\r\n    if (titles.length > 1) this.right.title = titles[1];\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setListStyle() {\r\n    if (XIsEmpty(this.listStyle)) return;\r\n    let styles: object[] = [];\r\n    if (XIsObject(this.listStyle)) {\r\n      styles = [this.listStyle, this.listStyle];\r\n    } else if (XIsObjectArray(this.listStyle)) {\r\n      styles = this.listStyle as object[];\r\n    }\r\n    if (styles.length > 0) this.left.listStyle = styles[0];\r\n    if (styles.length > 1) this.right.listStyle = styles[1];\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setTreeNodeDisabled() {\r\n    if (!XIsEmpty(this.values) && this.nodes) {\r\n      for (let item of this.nodes) {\r\n        let hasIn = this.values.indexOf(item.id) >= 0;\r\n        item.disabled = hasIn;\r\n        item.checked = hasIn;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setTableDataDisabled() {\r\n    if (!XIsEmpty(this.values) && this.nodes) {\r\n      for (let item of this.nodes) {\r\n        let hasIn = this.values.indexOf(item.id) >= 0;\r\n        item.disabled = hasIn;\r\n        item.checked = hasIn;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setHiddenCheckAll() {\r\n    if (XIsEmpty(this.hiddenCheckAll)) return;\r\n    if (this.hiddenCheckAll!.length > 0 && XIsBoolean(this.hiddenCheckAll![0])) this.left.hiddenCheckAll = this.hiddenCheckAll![0];\r\n    if (this.hiddenCheckAll!.length > 1 && XIsBoolean(this.hiddenCheckAll![1])) this.right.hiddenCheckAll = this.hiddenCheckAll![1];\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setFooterTpl() {\r\n    if (XIsUndefined(this.footerTpl)) return;\r\n    if (this.footerTpl!.length > 0) {\r\n      this.left.footerTpl = this.footerTpl![0];\r\n    }\r\n    if (this.footerTpl!.length > 1) {\r\n      this.right.footerTpl = this.footerTpl![1];\r\n    }\r\n  }\r\n\r\n  private setTableHeadSearchTpl() {\r\n    if (XIsUndefined(this.tableHeadSearchTpl)) return;\r\n    if (this.tableHeadSearchTpl!.length > 0) {\r\n      this.left.tableHeadSearchTpl = this.tableHeadSearchTpl![0];\r\n    }\r\n    if (this.tableHeadSearchTpl!.length > 1) {\r\n      this.right.tableHeadSearchTpl = this.tableHeadSearchTpl![1];\r\n    }\r\n  }\r\n}\r\n","<div #transfer class=\"x-transfer\" cdkDropListGroup [ngClass]=\"classMap\">\r\n  <div class=\"x-transfer-box\" [class.x-transfer-has-footer]=\"left.footerTpl\">\r\n    <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: left }\"></ng-container>\r\n    <div [ngStyle]=\"left.listStyle!\" class=\"x-transfer-list\">\r\n      <ng-container [ngSwitch]=\"type\">\r\n        <ul\r\n          *ngSwitchCase=\"'list'\"\r\n          cdkDropList\r\n          (cdkDropListDropped)=\"dropCdk($event)\"\r\n          [cdkDropListData]=\"left.list\"\r\n          [cdkDropListDisabled]=\"!drag && type === 'list'\"\r\n          [cdkDropListEnterPredicate]=\"predicate\"\r\n          class=\"x-transfer-droplist\"\r\n        >\r\n          <li class=\"x-transfer-item\" *ngFor=\"let node of left.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n            <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: left }\"></ng-container>\r\n          </li>\r\n        </ul>\r\n        <x-tree\r\n          *ngSwitchCase=\"'tree'\"\r\n          [data]=\"left.list!\"\r\n          multiple\r\n          allowManyActivated\r\n          [(activatedId)]=\"treeActivatedId\"\r\n          (nodeClick)=\"onTreeNodeClick($event)\"\r\n          [labelTpl]=\"treeLabelTpl\"\r\n        ></x-tree>\r\n        <ng-template #treeLabelTpl let-node=\"$node\">\r\n          <span class=\"x-transfer-tree-label\" x-keyword [text]=\"left.searchInput!\">{{ node.label }}</span>\r\n        </ng-template>\r\n        <x-table\r\n          #leftTableCom\r\n          *ngSwitchCase=\"'table'\"\r\n          [data]=\"tableData\"\r\n          [columns]=\"tableColumns!\"\r\n          [(size)]=\"tableSize\"\r\n          [(index)]=\"tableIndex\"\r\n          (indexChange)=\"getTableData()\"\r\n          [query]=\"tableQuery\"\r\n          [total]=\"tableTotal\"\r\n          (activatedRowChange)=\"onTableCheckedRow($event, left)\"\r\n          (headCheckboxChange)=\"onTableCheckedAll($event, left)\"\r\n          hiddenWrapBorder\r\n          hiddenPaginationBorder\r\n          showEllipsis=\"false\"\r\n          showTotal=\"false\"\r\n          paginationPosition=\"bottom-center\"\r\n          allowSelectRow=\"false\"\r\n          [headSearchTpl]=\"left.tableHeadSearchTpl\"\r\n        ></x-table>\r\n      </ng-container>\r\n    </div>\r\n    <div class=\"x-transfer-footer\" *ngIf=\"left.footerTpl\">\r\n      <ng-container *ngTemplateOutlet=\"left.footerTpl; context: { $source: left }\"></ng-container>\r\n    </div>\r\n  </div>\r\n  <div class=\"x-transfer-buttons\">\r\n    <x-button type=\"primary\" icon=\"fto-chevron-right\" [disabled]=\"left.disabledButton\" (click)=\"move(left, right)\"></x-button>\r\n    <x-button type=\"primary\" icon=\"fto-chevron-left\" [disabled]=\"right.disabledButton\" (click)=\"move(right, left)\"></x-button>\r\n  </div>\r\n  <div class=\"x-transfer-box\" [class.x-transfer-has-footer]=\"right.footerTpl\">\r\n    <ng-container *ngTemplateOutlet=\"sourceTitleTpl; context: { source: right }\"></ng-container>\r\n    <div [ngSwitch]=\"type\" [ngStyle]=\"right.listStyle!\" class=\"x-transfer-list\">\r\n      <x-table\r\n        #rightTableCom\r\n        *ngSwitchCase=\"'table'\"\r\n        [data]=\"right.list!\"\r\n        [columns]=\"tableColumns!\"\r\n        (activatedRowChange)=\"onTableCheckedRow($event, right)\"\r\n        (headCheckboxChange)=\"onTableCheckedAll($event, right)\"\r\n        hiddenWrapBorder\r\n        hiddenPaginationBorder\r\n        showPagination=\"false\"\r\n        showEllipsis=\"false\"\r\n        showTotal=\"false\"\r\n        paginationPosition=\"bottom-center\"\r\n        allowSelectRow=\"false\"\r\n        [headSearchTpl]=\"right.tableHeadSearchTpl\"\r\n      ></x-table>\r\n      <ul\r\n        *ngSwitchDefault\r\n        cdkDropList\r\n        (cdkDropListDropped)=\"dropCdk($event)\"\r\n        [cdkDropListData]=\"right.list\"\r\n        [cdkDropListDisabled]=\"!drag || (drag && type !== 'list')\"\r\n        [cdkDropListEnterPredicate]=\"predicate\"\r\n        class=\"x-transfer-droplist\"\r\n      >\r\n        <li class=\"x-transfer-item\" *ngFor=\"let node of right.list; trackBy: trackByNode\" cdkDrag [cdkDragData]=\"node\">\r\n          <ng-container *ngTemplateOutlet=\"sourceNodeTpl; context: { node: node, source: right }\"></ng-container>\r\n        </li>\r\n      </ul>\r\n    </div>\r\n    <div class=\"x-transfer-footer\" *ngIf=\"right.footerTpl\">\r\n      <ng-container *ngTemplateOutlet=\"right.footerTpl; context: { $source: right }\"></ng-container>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #sourceTitleTpl let-source=\"source\">\r\n  <div class=\"x-transfer-title\">\r\n    <div class=\"x-transfer-title-left\">\r\n      <x-checkbox\r\n        *ngIf=\"source.title && !source.hiddenCheckAll\"\r\n        [data]=\"[titleTpl ? '' : source.title]\"\r\n        [(ngModel)]=\"source.checkedAll\"\r\n        (ngModelChange)=\"checkedAllChange($event, source)\"\r\n        [indeterminate]=\"source.indeterminate\"\r\n      ></x-checkbox>\r\n      <span *ngIf=\"source.title && source.hiddenCheckAll\">{{ source.title }}</span>\r\n      <x-link *ngIf=\"inverse && type === 'list'\" class=\"x-transfer-inverse\" type=\"primary\" (click)=\"onInverse(source)\">{{\r\n        'transfer.inverse' | xI18n\r\n      }}</x-link>\r\n    </div>\r\n    <ng-container *xOutlet=\"titleTpl; context: { $title: source.title, $checkedCount: source.checkedCount, $count: source.count }\"\r\n      ><span class=\"x-transfer-total\">{{ source.checkedCount }} / {{ source.count }}</span></ng-container\r\n    >\r\n  </div>\r\n  <div class=\"x-transfer-search\" *ngIf=\"search && type !== 'table'\">\r\n    <x-input icon=\"fto-search\" [(ngModel)]=\"source.searchInput\" (ngModelChange)=\"onSearchInputChange(source)\" clearable></x-input>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #sourceNodeTpl let-node=\"node\" let-source=\"source\">\r\n  <x-checkbox\r\n    [data]=\"[{ id: node.id, label: nodeTpl ? nodeTpl : labelTpl, node: node }]\"\r\n    [disabled]=\"node.disabled\"\r\n    [(ngModel)]=\"node.checked\"\r\n    (ngModelChange)=\"checkedChange($event, source)\"\r\n  ></x-checkbox>\r\n  <ng-template #labelTpl>\r\n    <span x-keyword [text]=\"source.searchInput!\">{{ node.label }}</span>\r\n  </ng-template>\r\n</ng-template>\r\n"]}
|