ontimize-web-ngx 15.0.0-beta.5 → 15.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/app-header/o-app-header.component.mjs +4 -4
- package/esm2020/lib/components/app-header/o-app-header.module.mjs +5 -5
- package/esm2020/lib/components/app-sidenav/image/o-app-sidenav-image.component.mjs +4 -4
- package/esm2020/lib/components/app-sidenav/menu-group/o-app-sidenav-menu-group.component.mjs +4 -4
- package/esm2020/lib/components/app-sidenav/menu-item/o-app-sidenav-menu-item.component.mjs +4 -4
- package/esm2020/lib/components/app-sidenav/o-app-sidenav.component.mjs +4 -4
- package/esm2020/lib/components/app-sidenav/o-app-sidenav.module.mjs +5 -5
- package/esm2020/lib/components/bar-menu/locale-menu-item/o-locale-bar-menu-item.component.mjs +4 -4
- package/esm2020/lib/components/bar-menu/menu-group/o-bar-menu-group.component.mjs +4 -4
- package/esm2020/lib/components/bar-menu/menu-item/o-bar-menu-item.component.mjs +4 -4
- package/esm2020/lib/components/bar-menu/menu-nested/o-bar-menu-nested.component.mjs +4 -4
- package/esm2020/lib/components/bar-menu/menu-separator/o-bar-menu-separator.component.mjs +4 -4
- package/esm2020/lib/components/bar-menu/o-bar-menu-base.class.mjs +4 -4
- package/esm2020/lib/components/bar-menu/o-bar-menu.component.mjs +4 -4
- package/esm2020/lib/components/bar-menu/o-bar-menu.module.mjs +5 -5
- package/esm2020/lib/components/bar-menu/o-base-menu-item.class.mjs +4 -4
- package/esm2020/lib/components/breadcrumb/o-breadcrumb.component.mjs +4 -4
- package/esm2020/lib/components/breadcrumb/o-breadcrumb.module.mjs +5 -5
- package/esm2020/lib/components/button/o-button.component.mjs +4 -4
- package/esm2020/lib/components/button/o-button.module.mjs +5 -5
- package/esm2020/lib/components/button-toggle/o-button-toggle-group/o-button-toggle-group.component.mjs +4 -4
- package/esm2020/lib/components/button-toggle/o-button-toggle.component.mjs +4 -4
- package/esm2020/lib/components/button-toggle/o-button-toggle.module.mjs +5 -5
- package/esm2020/lib/components/card-menu-item/o-card-menu-item.component.mjs +4 -4
- package/esm2020/lib/components/card-menu-item/o-card-menu-item.module.mjs +5 -5
- package/esm2020/lib/components/container/column/o-column.component.mjs +4 -4
- package/esm2020/lib/components/container/column/o-column.module.mjs +5 -5
- package/esm2020/lib/components/container/column-collapsible/o-column-collapsible.component.mjs +4 -4
- package/esm2020/lib/components/container/column-collapsible/o-column-collapsible.module.mjs +5 -5
- package/esm2020/lib/components/container/o-container-collapsible-component.class.mjs +4 -4
- package/esm2020/lib/components/container/o-container-component.class.mjs +4 -4
- package/esm2020/lib/components/container/row/o-row.component.mjs +4 -4
- package/esm2020/lib/components/container/row/o-row.module.mjs +5 -5
- package/esm2020/lib/components/container/row-collapsible/o-row-collapsible.component.mjs +4 -4
- package/esm2020/lib/components/container/row-collapsible/o-row-collapsible.module.mjs +5 -5
- package/esm2020/lib/components/contextmenu/context-menu/o-context-menu-content.component.mjs +4 -4
- package/esm2020/lib/components/contextmenu/context-menu/o-wrapper-content-menu/o-wrapper-content-menu.component.mjs +4 -4
- package/esm2020/lib/components/contextmenu/context-menu-group/o-context-menu-group.component.mjs +4 -4
- package/esm2020/lib/components/contextmenu/context-menu-item/o-context-menu-item.component.mjs +4 -4
- package/esm2020/lib/components/contextmenu/context-menu-separator/o-context-menu-separator.component.mjs +4 -4
- package/esm2020/lib/components/contextmenu/o-content-menu-base-item.class.mjs +4 -4
- package/esm2020/lib/components/contextmenu/o-context-menu-overlay.service.mjs +4 -4
- package/esm2020/lib/components/contextmenu/o-context-menu.component.mjs +4 -4
- package/esm2020/lib/components/contextmenu/o-context-menu.directive.mjs +4 -4
- package/esm2020/lib/components/contextmenu/o-context-menu.module.mjs +5 -5
- package/esm2020/lib/components/contextmenu/o-context-menu.service.mjs +4 -4
- package/esm2020/lib/components/dual-list-selector/dual-list-selector-item/date/o-dual-list-selector-date-item.component.mjs +4 -4
- package/esm2020/lib/components/dual-list-selector/o-dual-list-selector.component.mjs +4 -4
- package/esm2020/lib/components/dual-list-selector/o-dual-list-selector.module.mjs +5 -5
- package/esm2020/lib/components/expandable-container/o-expandable-container.component.mjs +4 -4
- package/esm2020/lib/components/expandable-container/o-expandable-container.module.mjs +5 -5
- package/esm2020/lib/components/filter-builder/filter-builder-menu/filter-builder-menu.component.mjs +4 -4
- package/esm2020/lib/components/filter-builder/o-filter-builder-clear.directive.mjs +4 -4
- package/esm2020/lib/components/filter-builder/o-filter-builder-query.directive.mjs +4 -4
- package/esm2020/lib/components/filter-builder/o-filter-builder.component.mjs +4 -4
- package/esm2020/lib/components/filter-builder/o-filter-builder.module.mjs +5 -5
- package/esm2020/lib/components/form/guards/o-form-can-deactivate.guard.mjs +4 -4
- package/esm2020/lib/components/form/navigation/o-form-confirm-exit.service.mjs +4 -4
- package/esm2020/lib/components/form/navigation/o-form-navigation.component.mjs +13 -22
- package/esm2020/lib/components/form/navigation/o-form.navigation.class.mjs +5 -2
- package/esm2020/lib/components/form/o-form.component.mjs +4 -4
- package/esm2020/lib/components/form/o-form.module.mjs +5 -5
- package/esm2020/lib/components/form/services/o-form-message.service.mjs +4 -4
- package/esm2020/lib/components/form/toolbar/o-form-toolbar.component.mjs +4 -4
- package/esm2020/lib/components/form/toolbar/o-form-toolbar.module.mjs +5 -5
- package/esm2020/lib/components/form-container/o-form-container.component.mjs +4 -4
- package/esm2020/lib/components/form-container/o-form-container.module.mjs +5 -5
- package/esm2020/lib/components/grid/grid-item/o-grid-item.component.mjs +4 -4
- package/esm2020/lib/components/grid/grid-item/o-grid-item.directive.mjs +4 -4
- package/esm2020/lib/components/grid/o-grid.component.mjs +11 -11
- package/esm2020/lib/components/grid/o-grid.module.mjs +9 -7
- package/esm2020/lib/components/grid/skeketon/o-grid-skeleton/o-grid-skeleton.component.mjs +26 -0
- package/esm2020/lib/components/image/fullscreen/fullscreen-dialog.component.mjs +4 -4
- package/esm2020/lib/components/image/o-image.component.mjs +5 -5
- package/esm2020/lib/components/image/o-image.module.mjs +5 -5
- package/esm2020/lib/components/index.mjs +2 -1
- package/esm2020/lib/components/input/checkbox/o-checkbox.component.mjs +4 -4
- package/esm2020/lib/components/input/checkbox/o-checkbox.module.mjs +5 -5
- package/esm2020/lib/components/input/combo/combo-renderer/boolean/o-combo-renderer-boolean.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-renderer/currency/o-combo-renderer-currency.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-renderer/date/o-combo-renderer-date.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-renderer/icon/o-combo-renderer-icon.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-renderer/integer/o-combo-renderer-integer.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-renderer/o-combo-renderer.class.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-renderer/percentage/o-combo-renderer-percentage.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-renderer/real/o-combo-renderer-real.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/combo-search/o-combo-search.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/o-combo.component.mjs +4 -4
- package/esm2020/lib/components/input/combo/o-combo.module.mjs +5 -5
- package/esm2020/lib/components/input/currency-input/o-currency-input.component.mjs +4 -4
- package/esm2020/lib/components/input/currency-input/o-currency-input.module.mjs +5 -5
- package/esm2020/lib/components/input/date-input/o-date-input.component.mjs +4 -4
- package/esm2020/lib/components/input/date-input/o-date-input.module.mjs +5 -5
- package/esm2020/lib/components/input/date-range/o-daterange-input.component.mjs +4 -4
- package/esm2020/lib/components/input/date-range/o-daterange-input.directive.mjs +4 -4
- package/esm2020/lib/components/input/date-range/o-daterange-input.module.mjs +5 -5
- package/esm2020/lib/components/input/date-range/o-daterange-picker.component.mjs +4 -4
- package/esm2020/lib/components/input/email-input/o-email-input.component.mjs +4 -4
- package/esm2020/lib/components/input/email-input/o-email-input.module.mjs +5 -5
- package/esm2020/lib/components/input/file-input/o-file-input.component.mjs +7 -7
- package/esm2020/lib/components/input/file-input/o-file-input.module.mjs +5 -5
- package/esm2020/lib/components/input/hour-input/o-hour-input.component.mjs +4 -4
- package/esm2020/lib/components/input/hour-input/o-hour-input.module.mjs +5 -5
- package/esm2020/lib/components/input/html-input/o-html-input.component.mjs +4 -4
- package/esm2020/lib/components/input/html-input/o-html-input.module.mjs +5 -5
- package/esm2020/lib/components/input/integer-input/o-integer-input.component.mjs +4 -4
- package/esm2020/lib/components/input/integer-input/o-integer-input.module.mjs +5 -5
- package/esm2020/lib/components/input/listpicker/listpicker-renderer/currency/o-list-picker-renderer-currency.component.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/listpicker-renderer/date/o-list-picker-renderer-date.component.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/listpicker-renderer/integer/o-list-picker-renderer-integer.component.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/listpicker-renderer/o-list-picker-renderer.class.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/listpicker-renderer/percentage/o-list-picker-renderer-percentage.component.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/listpicker-renderer/real/o-list-picker-renderer-real.component.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/o-list-picker-dialog.component.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/o-list-picker.component.mjs +4 -4
- package/esm2020/lib/components/input/listpicker/o-list-picker.module.mjs +5 -5
- package/esm2020/lib/components/input/nif-input/o-nif-input.component.mjs +4 -4
- package/esm2020/lib/components/input/nif-input/o-nif-input.module.mjs +5 -5
- package/esm2020/lib/components/input/o-boolean-form-data-component.class.mjs +4 -4
- package/esm2020/lib/components/input/o-form-service-component.class.mjs +4 -4
- package/esm2020/lib/components/input/password-input/o-password-input.component.mjs +4 -4
- package/esm2020/lib/components/input/password-input/o-password-input.module.mjs +5 -5
- package/esm2020/lib/components/input/percent-input/o-percent-input.component.mjs +4 -4
- package/esm2020/lib/components/input/percent-input/o-percent-input.module.mjs +5 -5
- package/esm2020/lib/components/input/phone-input/data/country-code.mjs +4 -4
- package/esm2020/lib/components/input/phone-input/o-phone-input.component.mjs +4 -4
- package/esm2020/lib/components/input/phone-input/o-phone-input.module.mjs +5 -5
- package/esm2020/lib/components/input/radio/o-radio.component.mjs +4 -4
- package/esm2020/lib/components/input/radio/o-radio.module.mjs +5 -5
- package/esm2020/lib/components/input/real-input/o-real-input.component.mjs +4 -4
- package/esm2020/lib/components/input/real-input/o-real-input.module.mjs +5 -5
- package/esm2020/lib/components/input/search-input/o-search-input.component.mjs +4 -4
- package/esm2020/lib/components/input/search-input/o-search-input.module.mjs +5 -5
- package/esm2020/lib/components/input/slide-toggle/o-slide-toggle.component.mjs +4 -4
- package/esm2020/lib/components/input/slide-toggle/o-slide-toggle.module.mjs +5 -5
- package/esm2020/lib/components/input/slider/o-slider.component.mjs +4 -4
- package/esm2020/lib/components/input/slider/o-slider.module.mjs +5 -5
- package/esm2020/lib/components/input/text-input/o-text-input.component.mjs +4 -4
- package/esm2020/lib/components/input/text-input/o-text-input.module.mjs +5 -5
- package/esm2020/lib/components/input/textarea-input/o-textarea-input.component.mjs +4 -4
- package/esm2020/lib/components/input/textarea-input/o-textarea-input.module.mjs +5 -5
- package/esm2020/lib/components/input/time-input/o-time-input.component.mjs +4 -4
- package/esm2020/lib/components/input/time-input/o-time-input.module.mjs +5 -5
- package/esm2020/lib/components/language-selector/o-language-selector.component.mjs +4 -4
- package/esm2020/lib/components/language-selector/o-language-selector.module.mjs +5 -5
- package/esm2020/lib/components/list/list-item/o-list-item.component.mjs +4 -4
- package/esm2020/lib/components/list/list-item/o-list-item.directive.mjs +4 -4
- package/esm2020/lib/components/list/o-list.component.mjs +14 -15
- package/esm2020/lib/components/list/o-list.module.mjs +12 -8
- package/esm2020/lib/components/list/renderers/avatar/o-list-item-avatar.component.mjs +4 -4
- package/esm2020/lib/components/list/renderers/card/o-list-item-card.component.mjs +4 -4
- package/esm2020/lib/components/list/renderers/card-image/o-list-item-card-image.component.mjs +4 -4
- package/esm2020/lib/components/list/renderers/o-list-item-card-renderer.class.mjs +4 -4
- package/esm2020/lib/components/list/renderers/o-list-item-text-renderer.class.mjs +4 -4
- package/esm2020/lib/components/list/renderers/text/o-list-item-text.component.mjs +4 -4
- package/esm2020/lib/components/list/skeleton/o-list-skeleton/o-list-skeleton.component.mjs +26 -0
- package/esm2020/lib/components/material/ckeditor/ck-editor.component.mjs +4 -4
- package/esm2020/lib/components/material/ckeditor/ck-editor.module.mjs +5 -5
- package/esm2020/lib/components/o-data-toolbar/o-data-toolbar.component.mjs +4 -4
- package/esm2020/lib/components/o-data-toolbar/o-data-toolbar.module.mjs +5 -5
- package/esm2020/lib/components/o-form-data-component.class.mjs +4 -4
- package/esm2020/lib/components/o-service-base-component.class.mjs +10 -10
- package/esm2020/lib/components/o-service-component.class.mjs +17 -11
- package/esm2020/lib/components/o-skeleton.component.mjs +21 -0
- package/esm2020/lib/components/table/column/calculated/o-table-column-calculated.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/boolean/o-table-cell-editor-boolean.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/date/o-table-cell-editor-date.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/email/o-table-cell-editor-email.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/integer/o-table-cell-editor-integer.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/o-base-table-cell-editor.class.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/real/o-table-cell-editor-real.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/text/o-table-cell-editor-text.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-editor/time/o-table-cell-editor-time.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/action/o-table-cell-renderer-action.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/boolean/o-table-cell-renderer-boolean.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/currency/o-table-cell-renderer-currency.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/date/o-table-cell-renderer-date.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/image/o-table-cell-renderer-image.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/integer/o-table-cell-renderer-integer.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/o-base-table-cell-renderer.class.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/percentage/o-table-cell-renderer-percentage.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/real/o-table-cell-renderer-real.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/service/o-table-cell-renderer-service.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/time/o-table-cell-renderer-time.component.mjs +4 -4
- package/esm2020/lib/components/table/column/cell-renderer/translate/o-table-cell-renderer-translate.component.mjs +4 -4
- package/esm2020/lib/components/table/column/o-table-column.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/contextmenu/o-table-context-menu.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/default-o-table.datasource.mjs +2 -2
- package/esm2020/lib/components/table/extensions/dialog/apply-configuration/o-table-apply-configuration-dialog.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/dialog/export/o-table-export-dialog.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/dialog/filter-by-column/o-table-filter-by-column-data-dialog.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/dialog/group-by-columns/o-table-group-by-columns-dialog.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/dialog/o-table-base-dialog.class.mjs +4 -4
- package/esm2020/lib/components/table/extensions/dialog/store-configuration/o-table-store-configuration-dialog.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/dialog/visible-columns/o-table-visible-columns-dialog.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/export-button/o-table-export-button.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/export-button/o-table-export-button.service.mjs +4 -4
- package/esm2020/lib/components/table/extensions/footer/aggregate/o-table-column-aggregate.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/footer/expanded/o-table-expanded-footer.directive.mjs +4 -4
- package/esm2020/lib/components/table/extensions/footer/paginator/o-table-mat-paginator-intl.mjs +4 -4
- package/esm2020/lib/components/table/extensions/footer/paginator/o-table-paginator.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-button/o-table-button.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-buttons/o-table-buttons.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-column-resizer/o-table-column-resizer.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-column-select-all/o-table-column-select-all.directive.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-columns-filter/columns/o-table-columns-filter-column.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-columns-filter/o-table-columns-filter.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-columns-grouping/columns/o-table-columns-grouping-column.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-columns-grouping/o-table-columns-grouping.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-header/o-table-header.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-header-column-filter-icon/o-table-header-column-filter-icon.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-header-select-all/o-table-header-select-all.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-insertable-row/o-table-insertable-row.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-menu/o-table-menu.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-option/o-table-option.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/header/table-quickfilter/o-table-quickfilter.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/o-table-datasource.service.mjs +4 -4
- package/esm2020/lib/components/table/extensions/o-table-strategy.service.mjs +4 -4
- package/esm2020/lib/components/table/extensions/pipes/o-table-row-class.pipe.mjs +4 -4
- package/esm2020/lib/components/table/extensions/row/o-table-row.directive.mjs +4 -4
- package/esm2020/lib/components/table/extensions/row/table-row-expandable/o-table-row-expandable.component.mjs +4 -4
- package/esm2020/lib/components/table/extensions/skeleton/o-table-skeleton/o-table-skeleton.component.mjs +26 -0
- package/esm2020/lib/components/table/extensions/sort/o-mat-sort-header.mjs +4 -4
- package/esm2020/lib/components/table/extensions/sort/o-mat-sort-module.mjs +5 -5
- package/esm2020/lib/components/table/extensions/sort/o-mat-sort.mjs +4 -4
- package/esm2020/lib/components/table/o-table.component.mjs +37 -38
- package/esm2020/lib/components/table/o-table.module.mjs +14 -7
- package/esm2020/lib/components/tree/header/index.mjs +2 -0
- package/esm2020/lib/components/tree/header/tree-menu/o-tree-menu.component.mjs +33 -0
- package/esm2020/lib/components/tree/index.mjs +5 -0
- package/esm2020/lib/components/tree/o-tree-dao.service.mjs +43 -0
- package/esm2020/lib/components/tree/o-tree.component.mjs +523 -0
- package/esm2020/lib/components/tree/o-tree.datasource.mjs +79 -0
- package/esm2020/lib/components/tree/o-tree.module.mjs +24 -0
- package/esm2020/lib/components/tree/tree-node/tree-node.component.mjs +49 -0
- package/esm2020/lib/components/user-info/o-user-info.component.mjs +4 -4
- package/esm2020/lib/components/user-info/o-user-info.module.mjs +5 -5
- package/esm2020/lib/components/user-info/user-info-configuration/o-user-info-configuration.directive.mjs +4 -4
- package/esm2020/lib/components/user-info/user-info-configuration-item/o-user-info-configuration-item.directive.mjs +4 -4
- package/esm2020/lib/config/o-modules.mjs +12 -10
- package/esm2020/lib/directives/keyboard-listener.directive.mjs +4 -4
- package/esm2020/lib/directives/locker.directive.mjs +4 -4
- package/esm2020/lib/directives/o-file-drag-and-drop.directive.mjs +4 -4
- package/esm2020/lib/directives/o-hidden.directive.mjs +4 -4
- package/esm2020/lib/directives/o-mat-error.directive.mjs +4 -4
- package/esm2020/lib/directives/o-mat-prefix.directive.mjs +4 -4
- package/esm2020/lib/directives/o-mat-suffix.directive.mjs +4 -4
- package/esm2020/lib/directives/o-tab-group.directive.mjs +4 -4
- package/esm2020/lib/i18n/i18n.mjs +6 -3
- package/esm2020/lib/layouts/app-layout/app-layout-header/o-app-layout-header.component.mjs +4 -4
- package/esm2020/lib/layouts/app-layout/app-layout-sidenav/o-app-layout-sidenav.component.mjs +4 -4
- package/esm2020/lib/layouts/app-layout/o-app-layout.component.mjs +4 -4
- package/esm2020/lib/layouts/app-layout/o-app-layout.module.mjs +5 -5
- package/esm2020/lib/layouts/card-menu-layout/o-card-menu-layout.component.mjs +4 -4
- package/esm2020/lib/layouts/card-menu-layout/o-card-menu-layout.module.mjs +5 -5
- package/esm2020/lib/layouts/form-layout/dialog/o-form-layout-dialog.component.mjs +4 -4
- package/esm2020/lib/layouts/form-layout/dialog/options/o-form-layout-dialog-options.directive.mjs +4 -4
- package/esm2020/lib/layouts/form-layout/directives/o-form-layout-manager-content.directive.mjs +4 -4
- package/esm2020/lib/layouts/form-layout/guards/o-form-layout-can-activate-child.guard.mjs +4 -4
- package/esm2020/lib/layouts/form-layout/o-form-layout-manager.component.mjs +4 -4
- package/esm2020/lib/layouts/form-layout/o-form-layout-manager.module.mjs +5 -5
- package/esm2020/lib/layouts/form-layout/split-pane/o-form-layout-split-pane.component.mjs +6 -8
- package/esm2020/lib/layouts/form-layout/split-pane/options/o-form-layout-split-pane-options.directive.mjs +4 -4
- package/esm2020/lib/layouts/form-layout/tabgroup/o-form-layout-tabgroup.component.mjs +5 -5
- package/esm2020/lib/layouts/form-layout/tabgroup/options/o-form-layout-tabgroup-options.directive.mjs +4 -4
- package/esm2020/lib/ontimize-web-ngx.module.mjs +6 -5
- package/esm2020/lib/pipes/columns-filter.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-currency.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-icon.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-integer.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-moment.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-percentage.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-real.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-safe.pipe.mjs +4 -4
- package/esm2020/lib/pipes/o-translate.pipe.mjs +8 -8
- package/esm2020/lib/pipes/order-by.pipe.mjs +4 -4
- package/esm2020/lib/services/app-menu.service.mjs +4 -4
- package/esm2020/lib/services/appearance.service.mjs +4 -4
- package/esm2020/lib/services/auth-guard.service.mjs +4 -4
- package/esm2020/lib/services/auth.service.mjs +4 -4
- package/esm2020/lib/services/currency.service.mjs +4 -4
- package/esm2020/lib/services/dialog.service.mjs +4 -4
- package/esm2020/lib/services/icon.service.mjs +4 -4
- package/esm2020/lib/services/local-storage.service.mjs +4 -4
- package/esm2020/lib/services/login-storage.service.mjs +4 -4
- package/esm2020/lib/services/moment.service.mjs +4 -4
- package/esm2020/lib/services/navigation.service.mjs +4 -4
- package/esm2020/lib/services/number.service.mjs +4 -4
- package/esm2020/lib/services/o-auth.service.mjs +4 -4
- package/esm2020/lib/services/o-breadcrumb.service.mjs +4 -4
- package/esm2020/lib/services/o-error-dialog-manager.service.mjs +4 -4
- package/esm2020/lib/services/o-form-layout-manager.service.mjs +4 -4
- package/esm2020/lib/services/o-modules-info.service.mjs +4 -4
- package/esm2020/lib/services/o-user-info.service.mjs +4 -4
- package/esm2020/lib/services/ontimize/ontimize-base-service.class.mjs +4 -4
- package/esm2020/lib/services/ontimize/ontimize-ee.service.mjs +4 -4
- package/esm2020/lib/services/ontimize/ontimize-export-3xx.service.mjs +4 -4
- package/esm2020/lib/services/ontimize/ontimize-export.service.mjs +4 -4
- package/esm2020/lib/services/ontimize/ontimize-file.service.mjs +4 -4
- package/esm2020/lib/services/ontimize/ontimize-service-response.adapter.mjs +4 -4
- package/esm2020/lib/services/ontimize/ontimize.service.mjs +4 -4
- package/esm2020/lib/services/ontimize-export-data-base-provider.service.mjs +4 -4
- package/esm2020/lib/services/ontimize-export-data-provider-3x.service.mjs +4 -4
- package/esm2020/lib/services/ontimize-export-data-provider.service.mjs +4 -4
- package/esm2020/lib/services/ontimize-icon-registry.service.mjs +4 -4
- package/esm2020/lib/services/parser/o-service-response.parser.mjs +4 -4
- package/esm2020/lib/services/permissions/o-permissions.module.mjs +5 -7
- package/esm2020/lib/services/permissions/ontimize-ee-permissions.service.mjs +4 -4
- package/esm2020/lib/services/permissions/ontimize-permissions.service.mjs +4 -4
- package/esm2020/lib/services/permissions/permissions-can-activate.guard.mjs +4 -4
- package/esm2020/lib/services/permissions/permissions.service.mjs +20 -10
- package/esm2020/lib/services/remote-config.service.mjs +5 -5
- package/esm2020/lib/services/share-can-activate-child.service.mjs +4 -4
- package/esm2020/lib/services/snackbar.service.mjs +4 -4
- package/esm2020/lib/services/state/o-component-state.service.mjs +10 -10
- package/esm2020/lib/services/state/o-filter-builder-component-state.service.mjs +4 -4
- package/esm2020/lib/services/state/o-form-layout-manager-component-state.service.mjs +4 -4
- package/esm2020/lib/services/state/o-grid-component-state.service.mjs +4 -4
- package/esm2020/lib/services/state/o-list-component-state.service.mjs +4 -4
- package/esm2020/lib/services/state/o-table-component-state.service.mjs +4 -4
- package/esm2020/lib/services/state/o-tree-component-state.class.mjs +4 -0
- package/esm2020/lib/services/state/o-tree-component-state.service.mjs +50 -0
- package/esm2020/lib/services/translate/o-translate.parser.mjs +4 -4
- package/esm2020/lib/services/translate/o-translate.service.mjs +4 -4
- package/esm2020/lib/shared/components/dialog/o-dialog-internal.component.mjs +4 -4
- package/esm2020/lib/shared/components/dialog/o-dialog.component.mjs +4 -4
- package/esm2020/lib/shared/components/error403/o-error-403.component.mjs +4 -4
- package/esm2020/lib/shared/components/filter/load-filter/o-load-filter-dialog.component.mjs +4 -4
- package/esm2020/lib/shared/components/filter/store-filter/o-store-filter-dialog.component.mjs +4 -4
- package/esm2020/lib/shared/components/snackbar/o-snackbar-base.class.mjs +4 -4
- package/esm2020/lib/shared/components/snackbar/o-snackbar.component.mjs +4 -4
- package/esm2020/lib/shared/components/validation/o-error.component.mjs +4 -4
- package/esm2020/lib/shared/components/validation/o-validator.component.mjs +4 -4
- package/esm2020/lib/shared/material/custom.material.module.mjs +5 -5
- package/esm2020/lib/shared/material/date/ontimize-moment-date-adapter.mjs +4 -4
- package/esm2020/lib/shared/shared.module.mjs +5 -5
- package/esm2020/lib/util/util.mjs +11 -8
- package/fesm2015/ontimize-web-ngx.mjs +7405 -6605
- package/fesm2015/ontimize-web-ngx.mjs.map +1 -1
- package/fesm2020/ontimize-web-ngx.mjs +6431 -5636
- package/fesm2020/ontimize-web-ngx.mjs.map +1 -1
- package/lib/components/grid/o-grid.module.d.ts +8 -6
- package/lib/components/grid/skeketon/o-grid-skeleton/o-grid-skeleton.component.d.ts +11 -0
- package/lib/components/index.d.ts +1 -0
- package/lib/components/input/file-input/o-file-input.component.d.ts +1 -1
- package/lib/components/list/o-list.module.d.ts +8 -6
- package/lib/components/list/skeleton/o-list-skeleton/o-list-skeleton.component.d.ts +11 -0
- package/lib/components/o-service-component.class.d.ts +2 -1
- package/lib/components/o-skeleton.component.d.ts +14 -0
- package/lib/components/table/extensions/skeleton/o-table-skeleton/o-table-skeleton.component.d.ts +11 -0
- package/lib/components/table/o-table.component.d.ts +3 -1
- package/lib/components/table/o-table.module.d.ts +14 -12
- package/lib/components/tree/header/index.d.ts +1 -0
- package/lib/components/tree/header/tree-menu/o-tree-menu.component.d.ts +13 -0
- package/lib/components/tree/index.d.ts +4 -0
- package/lib/components/tree/o-tree-dao.service.d.ts +18 -0
- package/lib/components/tree/o-tree.component.d.ts +111 -0
- package/lib/components/tree/o-tree.datasource.d.ts +22 -0
- package/lib/components/tree/o-tree.module.d.ts +14 -0
- package/lib/components/tree/tree-node/tree-node.component.d.ts +14 -0
- package/lib/i18n/i18n.d.ts +3 -0
- package/lib/layouts/form-layout/split-pane/o-form-layout-split-pane.component.d.ts +2 -3
- package/lib/ontimize-web-ngx.module.d.ts +2 -1
- package/lib/services/state/o-tree-component-state.class.d.ts +3 -0
- package/lib/services/state/o-tree-component-state.service.d.ts +13 -0
- package/lib/util/util.d.ts +1 -1
- package/package.json +3 -2
- package/theme.scss +20 -4
- package/theming/ontimize-style-v8.scss +2 -1
- package/theming/ontimize-style.scss +18 -0
- package/theming/styles/density.scss +6 -2
- package/theming/themes/ontimize-black-yellow.scss +13 -3
|
@@ -0,0 +1,523 @@
|
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
|
2
|
+
import { SelectionModel } from '@angular/cdk/collections';
|
|
3
|
+
import { FlatTreeControl } from '@angular/cdk/tree';
|
|
4
|
+
import { Component, ContentChild, ElementRef, EventEmitter, forwardRef, Inject, Injector, Optional, TemplateRef, ViewEncapsulation } from '@angular/core';
|
|
5
|
+
import { of, Subscription } from 'rxjs';
|
|
6
|
+
import { BooleanInputConverter } from '../../decorators/input-converter';
|
|
7
|
+
import { Codes } from '../../util/codes';
|
|
8
|
+
import { FilterExpressionUtils } from '../../util/filter-expression.utils';
|
|
9
|
+
import { ServiceUtils } from '../../util/service.utils';
|
|
10
|
+
import { Util } from '../../util/util';
|
|
11
|
+
import { OFormComponent } from '../form/o-form.component';
|
|
12
|
+
import { AbstractOServiceComponent } from '../o-service-component.class';
|
|
13
|
+
import { OTreeDao } from './o-tree-dao.service';
|
|
14
|
+
import { OTreeDataSource } from './o-tree.datasource';
|
|
15
|
+
import { OTreeNodeComponent } from './tree-node/tree-node.component';
|
|
16
|
+
import * as i0 from "@angular/core";
|
|
17
|
+
import * as i1 from "@angular/common";
|
|
18
|
+
import * as i2 from "../input/search-input/o-search-input.component";
|
|
19
|
+
import * as i3 from "@angular/flex-layout/flex";
|
|
20
|
+
import * as i4 from "@angular/material/button";
|
|
21
|
+
import * as i5 from "@angular/material/checkbox";
|
|
22
|
+
import * as i6 from "@angular/material/icon";
|
|
23
|
+
import * as i7 from "@angular/material/menu";
|
|
24
|
+
import * as i8 from "@angular/material/progress-bar";
|
|
25
|
+
import * as i9 from "@angular/material/tree";
|
|
26
|
+
import * as i10 from "./header/tree-menu/o-tree-menu.component";
|
|
27
|
+
import * as i11 from "../../pipes/o-translate.pipe";
|
|
28
|
+
import * as i12 from "../form/o-form.component";
|
|
29
|
+
export const DEFAULT_INPUTS_O_TREE = [
|
|
30
|
+
'oattr: attr',
|
|
31
|
+
'service',
|
|
32
|
+
'entity',
|
|
33
|
+
'columns',
|
|
34
|
+
'keys',
|
|
35
|
+
'parentKeys: parent-keys',
|
|
36
|
+
'queryMethod: query-method',
|
|
37
|
+
'insertButton: insert-button',
|
|
38
|
+
'refreshButton: refresh-button',
|
|
39
|
+
'deleteButton: delete-button',
|
|
40
|
+
'visibleColumns: visible-columns',
|
|
41
|
+
'selectAllCheckbox: select-all-checkbox',
|
|
42
|
+
'separator',
|
|
43
|
+
'parentColumn: parent-column',
|
|
44
|
+
'sortColumn: sort-column',
|
|
45
|
+
'selectAllCheckboxVisible: select-all-checkbox-visible',
|
|
46
|
+
'filterCaseSensitive: filter-case-sensitive',
|
|
47
|
+
'quickFilter: quick-filter',
|
|
48
|
+
'quickFilterPlaceholder: quick-filter-placeholder',
|
|
49
|
+
'quickFilterColumns: quick-filter-columns',
|
|
50
|
+
'detailMode: detail-mode',
|
|
51
|
+
'detailFormRoute: detail-form-route',
|
|
52
|
+
'showButtonsText: show-buttons-text',
|
|
53
|
+
'rootTitle: root-title',
|
|
54
|
+
'recursive',
|
|
55
|
+
'route'
|
|
56
|
+
];
|
|
57
|
+
export const DEFAULT_OUTPUTS_O_TREE = ['onNodeSelected', 'onNodeExpanded', 'onNodeCollapsed', 'onLoadNextLevel', 'onDataLoaded'];
|
|
58
|
+
export class OTreeComponent extends AbstractOServiceComponent {
|
|
59
|
+
getTreeNodeChildren(node) {
|
|
60
|
+
if (node.level === 0 && Util.isDefined(this.rootTitle)) {
|
|
61
|
+
return this.rootNodes;
|
|
62
|
+
}
|
|
63
|
+
else if (node.treeNode) {
|
|
64
|
+
if (Util.isDefined(node.treeNode.rootTitle) && !Util.isDefined(node.rootNode)) {
|
|
65
|
+
let rootNode = {
|
|
66
|
+
id: this.dataSource.data.length + 1, rootNode: true, label: this.translateService.get(node.treeNode.rootTitle), level: node.level + 1, expandable: true, data: node.data, isLoading: false, treeNode: node.treeNode
|
|
67
|
+
};
|
|
68
|
+
this.daoTree.flatNodeMap.set(rootNode, node);
|
|
69
|
+
return [rootNode];
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
return node.treeNode.childQueryData(node);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
return this.childreNodes.filter((item) => item[this.parentKeys] === node[this.keys]);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
getRecursiveChildrenNode(node) {
|
|
80
|
+
if (node.level === 0 && Util.isDefined(this.rootTitle)) {
|
|
81
|
+
return this.rootNodes;
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
return this.childQueryData(node);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
getComponentFilter(existingFilter = {}) {
|
|
88
|
+
let filter = existingFilter;
|
|
89
|
+
if (this.recursive && this.parentColumn !== undefined) {
|
|
90
|
+
const parentItemExpr = FilterExpressionUtils.buildExpressionFromObject(filter);
|
|
91
|
+
const parentNotNullExpr = FilterExpressionUtils.buildExpressionIsNull(this.parentColumn);
|
|
92
|
+
const filterExpr = FilterExpressionUtils.buildComplexExpression(parentItemExpr, parentNotNullExpr, FilterExpressionUtils.OP_AND);
|
|
93
|
+
filter = {};
|
|
94
|
+
filter[FilterExpressionUtils.FILTER_EXPRESSION_KEY] = filterExpr;
|
|
95
|
+
}
|
|
96
|
+
return super.getComponentFilter(filter);
|
|
97
|
+
}
|
|
98
|
+
set nodeTemplate(value) {
|
|
99
|
+
if (value != null) {
|
|
100
|
+
this.leafNodeTemplate = value;
|
|
101
|
+
this.parentNodeTemplate = value;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
get showTreeMenuButton() {
|
|
105
|
+
const staticOpt = this.selectAllCheckbox;
|
|
106
|
+
return staticOpt;
|
|
107
|
+
}
|
|
108
|
+
constructor(injector, elRef, form) {
|
|
109
|
+
super(injector, elRef, form);
|
|
110
|
+
this.injector = injector;
|
|
111
|
+
this.getLevel = (node) => node.level;
|
|
112
|
+
this.isExpandable = (node) => node.expandable;
|
|
113
|
+
this.getChildren = (node) => {
|
|
114
|
+
if (this.recursive) {
|
|
115
|
+
return this.getRecursiveChildrenNode(node);
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
return this.getTreeNodeChildren(node);
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
this.hasChild = (_, _nodeData) => _nodeData.expandable;
|
|
122
|
+
this.hasNoContent = (_, _nodeData) => _nodeData.label === '';
|
|
123
|
+
this.refreshButton = true;
|
|
124
|
+
this.deleteButton = false;
|
|
125
|
+
this.showButtonsText = false;
|
|
126
|
+
this.separator = Codes.HYPHEN_SEPARATOR;
|
|
127
|
+
this.selectAllCheckboxVisible = false;
|
|
128
|
+
this.selectAllCheckbox = false;
|
|
129
|
+
this.recursive = false;
|
|
130
|
+
this._quickFilter = false;
|
|
131
|
+
this.paginationControls = false;
|
|
132
|
+
this.childreNodes = [];
|
|
133
|
+
this.nodesArray = [];
|
|
134
|
+
this.ancestors = [];
|
|
135
|
+
this.checklistSelection = new SelectionModel(true, [], true, (sm1, sm2) => sm1.id === sm2.id);
|
|
136
|
+
this.onNodeSelected = new EventEmitter();
|
|
137
|
+
this.onNodeExpanded = new EventEmitter();
|
|
138
|
+
this.onNodeCollapsed = new EventEmitter();
|
|
139
|
+
this.onLoadNextLevel = new EventEmitter();
|
|
140
|
+
this.rootNodes = [];
|
|
141
|
+
this.visibleColumnsArray = [];
|
|
142
|
+
this.enabledDeleteButton = false;
|
|
143
|
+
this.subscription = new Subscription();
|
|
144
|
+
this.transformer = (node, level, parentNode) => {
|
|
145
|
+
const nodeChildren = this.childreNodes.filter((item) => item[this.parentColumn] === node[this.keys]);
|
|
146
|
+
const flatNode = {
|
|
147
|
+
'id': this.getNodeId(node, parentNode),
|
|
148
|
+
'label': this.getItemText(node),
|
|
149
|
+
'level': level,
|
|
150
|
+
treeNode: this.treeNode,
|
|
151
|
+
'expandable': Util.isDefined(this.treeNode) || !!nodeChildren?.length || this.recursive,
|
|
152
|
+
'data': node,
|
|
153
|
+
'isLoading': false,
|
|
154
|
+
'route': this.route
|
|
155
|
+
};
|
|
156
|
+
this.daoTree.flatNodeMap.set(flatNode, parentNode);
|
|
157
|
+
nodeChildren.forEach(node => this.transformer(node, level + 1));
|
|
158
|
+
return flatNode;
|
|
159
|
+
};
|
|
160
|
+
this.daoTree = this.injector.get(OTreeDao);
|
|
161
|
+
}
|
|
162
|
+
ngOnInit() {
|
|
163
|
+
this.setTreeControl();
|
|
164
|
+
this.initialize();
|
|
165
|
+
this.initializeParams();
|
|
166
|
+
this.subscription.add(this.selection.changed.subscribe(() => (this.enabledDeleteButton = !this.selection.isEmpty())));
|
|
167
|
+
}
|
|
168
|
+
initialize() {
|
|
169
|
+
super.initialize();
|
|
170
|
+
this.initializeDao();
|
|
171
|
+
}
|
|
172
|
+
initializeDao() {
|
|
173
|
+
if (this.staticData) {
|
|
174
|
+
this.queryOnBind = false;
|
|
175
|
+
this.queryOnInit = false;
|
|
176
|
+
this.setDataArray(this.staticData);
|
|
177
|
+
}
|
|
178
|
+
else {
|
|
179
|
+
this.configureService();
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
initializeParams() {
|
|
183
|
+
if (!this.visibleColumns) {
|
|
184
|
+
this.visibleColumns = this.columns;
|
|
185
|
+
}
|
|
186
|
+
if (!Util.isDefined(this.quickFilterColumns)) {
|
|
187
|
+
this.quickFilterColumns = this.visibleColumns;
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
ngAfterViewInit() {
|
|
191
|
+
this.visibleColumnsArray = Util.parseArray(this.visibleColumns, true);
|
|
192
|
+
this.quickFilterColArray = Util.parseArray(this.quickFilterColumns, true);
|
|
193
|
+
this.setDatasource();
|
|
194
|
+
this.afterViewInit();
|
|
195
|
+
if (this.queryOnInit) {
|
|
196
|
+
this.queryData();
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
ngOnDestroy() {
|
|
200
|
+
this.destroy();
|
|
201
|
+
this.subscription.unsubscribe();
|
|
202
|
+
}
|
|
203
|
+
registerTreeNode(oTreeNode) {
|
|
204
|
+
}
|
|
205
|
+
checkboxClicked(event) {
|
|
206
|
+
event.stopPropagation();
|
|
207
|
+
}
|
|
208
|
+
leafNodeClicked(event, node) {
|
|
209
|
+
this.nodeClicked(node, event);
|
|
210
|
+
}
|
|
211
|
+
parentNodeClicked(event, node) {
|
|
212
|
+
this.nodeClicked(node, event);
|
|
213
|
+
}
|
|
214
|
+
nodeClicked(node, event) {
|
|
215
|
+
event.stopPropagation();
|
|
216
|
+
event.preventDefault();
|
|
217
|
+
if (this.detailMode !== Codes.DETAIL_MODE_NONE && !this.isRootNode(node)) {
|
|
218
|
+
this.navigateToViewDetail(node);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
isRootNode(node) {
|
|
222
|
+
return Util.isDefined(node.rootNode) && node.rootNode;
|
|
223
|
+
}
|
|
224
|
+
onClickToggleButton(event, node) {
|
|
225
|
+
event.stopPropagation();
|
|
226
|
+
if (this.treeControl.isExpanded(node)) {
|
|
227
|
+
this.onNodeExpanded.emit(node);
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
this.onNodeCollapsed.emit(node);
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
toggleNode(node, expand) {
|
|
234
|
+
node.isLoading = true;
|
|
235
|
+
if (expand && node.expandable) {
|
|
236
|
+
const children = this.getChildren(node);
|
|
237
|
+
if (Util.isArray(children)) {
|
|
238
|
+
this.dataSource.updateTree(node, children, expand);
|
|
239
|
+
}
|
|
240
|
+
else {
|
|
241
|
+
this.updateAsyncTree(children, node, expand);
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
this.dataSource.updateTree(node, [], expand);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
updateAsyncTree(children, node, expand) {
|
|
249
|
+
children.subscribe((res) => {
|
|
250
|
+
let data;
|
|
251
|
+
if (res.isSuccessful()) {
|
|
252
|
+
const arrData = (res.data !== undefined) ? res.data : [];
|
|
253
|
+
data = Util.isArray(arrData) ? arrData : [];
|
|
254
|
+
}
|
|
255
|
+
this.dataSource.updateTree(node, data, expand);
|
|
256
|
+
}, err => {
|
|
257
|
+
node.isLoading = false;
|
|
258
|
+
if (Util.isDefined(this.queryFallbackFunction)) {
|
|
259
|
+
this.queryFallbackFunction(err);
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
this.oErrorDialogManager.openErrorDialog(err);
|
|
263
|
+
console.error(err);
|
|
264
|
+
}
|
|
265
|
+
});
|
|
266
|
+
}
|
|
267
|
+
todoLeafItemSelectionToggle(node) {
|
|
268
|
+
this.todoItemSelectionToggle(node);
|
|
269
|
+
}
|
|
270
|
+
todoItemSelectionToggle(node) {
|
|
271
|
+
this.checklistSelection.toggle(node);
|
|
272
|
+
const descendants = this.treeControl.getDescendants(node);
|
|
273
|
+
this.checklistSelection.isSelected(node)
|
|
274
|
+
? this.checklistSelection.select(...descendants)
|
|
275
|
+
: this.checklistSelection.deselect(...descendants);
|
|
276
|
+
descendants.every((child) => this.checklistSelection.isSelected(child));
|
|
277
|
+
this.onNodeSelected.emit(node.data);
|
|
278
|
+
}
|
|
279
|
+
descendantsAllSelected(node) {
|
|
280
|
+
let descAllSelected = false;
|
|
281
|
+
const descendants = this.treeControl.getDescendants(node);
|
|
282
|
+
if (node.expandable) {
|
|
283
|
+
if (this.treeControl.isExpanded(node) && descendants.length > 0) {
|
|
284
|
+
descAllSelected = descendants.every((child) => this.checklistSelection.isSelected(child));
|
|
285
|
+
descAllSelected ? this.checklistSelection.select(node) : this.checklistSelection.deselect(node);
|
|
286
|
+
return descAllSelected;
|
|
287
|
+
}
|
|
288
|
+
else {
|
|
289
|
+
return this.checklistSelection.isSelected(node);
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
else {
|
|
293
|
+
return this.checklistSelection.isSelected(node);
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
descendantsPartiallySelected(node) {
|
|
297
|
+
let result = false;
|
|
298
|
+
const descendants = this.treeControl.getDescendants(node);
|
|
299
|
+
if (node.expandable) {
|
|
300
|
+
if (descendants.length > 0) {
|
|
301
|
+
result = descendants.some((child) => this.checklistSelection.isSelected(child));
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
return result && !this.descendantsAllSelected(node);
|
|
305
|
+
}
|
|
306
|
+
setTreeControl() {
|
|
307
|
+
if (!Util.isDefined(this.treeControl)) {
|
|
308
|
+
this.treeControl = new FlatTreeControl(this.getLevel, this.isExpandable);
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
setDatasource() {
|
|
312
|
+
if (!Util.isDefined(this.dataSource)) {
|
|
313
|
+
this.dataSource = new OTreeDataSource(this, this.treeControl, this.injector);
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
getParentNodes(node, index, tree) {
|
|
317
|
+
let parentNode = this.daoTree.flatNodeMap.get(node);
|
|
318
|
+
if (Util.isDefined(parentNode)) {
|
|
319
|
+
const existingNode = tree.findIndex(x => x['id'] === parentNode['id']) > -1;
|
|
320
|
+
if (Util.isDefined(parentNode)) {
|
|
321
|
+
if (!existingNode) {
|
|
322
|
+
tree.splice(index, 0, parentNode);
|
|
323
|
+
return this.getParentNodes(parentNode, index, tree);
|
|
324
|
+
}
|
|
325
|
+
else {
|
|
326
|
+
return this.getParentNodes(parentNode, index, tree);
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
else {
|
|
330
|
+
return tree;
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
else {
|
|
334
|
+
return tree;
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
filterData(value, loadMore) {
|
|
338
|
+
let filteredTreeData = [];
|
|
339
|
+
if (value) {
|
|
340
|
+
for (let [nestedNode] of this.daoTree.flatNodeMap) {
|
|
341
|
+
if (nestedNode.label.toLocaleLowerCase().indexOf(value.toLocaleLowerCase()) > -1) {
|
|
342
|
+
filteredTreeData.push(nestedNode);
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
;
|
|
346
|
+
let index = 0;
|
|
347
|
+
while (index < filteredTreeData.length) {
|
|
348
|
+
let node = filteredTreeData[index];
|
|
349
|
+
const parentNodes = this.getParentNodes(node, index, filteredTreeData);
|
|
350
|
+
if (!Util.isArrayEmpty(parentNodes)) {
|
|
351
|
+
filteredTreeData = parentNodes;
|
|
352
|
+
}
|
|
353
|
+
index++;
|
|
354
|
+
}
|
|
355
|
+
this.dataSource.data = filteredTreeData;
|
|
356
|
+
}
|
|
357
|
+
else {
|
|
358
|
+
filteredTreeData = this.dataResponseArray;
|
|
359
|
+
this.setDataArray(filteredTreeData);
|
|
360
|
+
}
|
|
361
|
+
if (value) {
|
|
362
|
+
let rootNodes = filteredTreeData.filter(node => node.level == 0);
|
|
363
|
+
this.expandNodesWithNodes(rootNodes);
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
expandNodesWithNodes(treeData) {
|
|
367
|
+
treeData.filter(node => node.expandable).forEach(node => {
|
|
368
|
+
const descendants = this.treeControl.getDescendants(node);
|
|
369
|
+
if (descendants.length > 0) {
|
|
370
|
+
this.treeControl.expand(node);
|
|
371
|
+
this.expandNodesWithNodes(descendants);
|
|
372
|
+
}
|
|
373
|
+
});
|
|
374
|
+
}
|
|
375
|
+
getDataArray() {
|
|
376
|
+
return this.daoTree.data;
|
|
377
|
+
}
|
|
378
|
+
setDataArray(data) {
|
|
379
|
+
this.daoTree.flatNodeMap.clear();
|
|
380
|
+
this.daoTree.setDataArray(data);
|
|
381
|
+
if (this.recursive) {
|
|
382
|
+
this.childreNodes = data.filter((item) => item[this.parentColumn] != null);
|
|
383
|
+
this.rootNodes = data.filter((item) => !Util.isDefined(item[this.parentColumn]) || item[this.parentColumn] === null);
|
|
384
|
+
}
|
|
385
|
+
this.rootNodes = data;
|
|
386
|
+
let level = 0;
|
|
387
|
+
let rootNode;
|
|
388
|
+
if (Util.isDefined(this.rootTitle)) {
|
|
389
|
+
level = +1;
|
|
390
|
+
rootNode = { id: 0, label: this.translateService.get(this.rootTitle), rootNode: true, level: 0, expandable: true, data: {}, isLoading: false };
|
|
391
|
+
this.daoTree.flatNodeMap.set(rootNode, null);
|
|
392
|
+
this.dataSource.data = [rootNode];
|
|
393
|
+
this.treeControl.expand(rootNode);
|
|
394
|
+
}
|
|
395
|
+
else {
|
|
396
|
+
this.dataSource.data = this.rootNodes.map(node => this.transformer(node, level));
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
onSelectCheckboxChange(visible) {
|
|
400
|
+
this.selectAllCheckboxVisible = visible;
|
|
401
|
+
}
|
|
402
|
+
sort(array) {
|
|
403
|
+
if (this.sortColumn != null) {
|
|
404
|
+
array.sort((a, b) => a.data[this.sortColumn].localeCompare(b.data[this.sortColumn]));
|
|
405
|
+
array
|
|
406
|
+
.filter((node) => !!this.treeControl.getDescendants(node))
|
|
407
|
+
.forEach((node) => this.sort(this.treeControl.getDescendants(node)));
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
getItemText(item) {
|
|
411
|
+
return this.visibleColumnsArray
|
|
412
|
+
.filter((col) => item[col] != null && `${item[col]}`.length > 0)
|
|
413
|
+
.map((col) => item[col])
|
|
414
|
+
.join(this.separator);
|
|
415
|
+
}
|
|
416
|
+
getItemKey(item) {
|
|
417
|
+
return this.keysArray.map((col) => item[col]).join(';');
|
|
418
|
+
}
|
|
419
|
+
filterByQuickFilterColumns(item, quickfilter) {
|
|
420
|
+
const caseSensitive = this.isFilterCaseSensitive();
|
|
421
|
+
const regExpStr = new RegExp(Util.escapeSpecialCharacter(Util.normalizeString(quickfilter, !caseSensitive)));
|
|
422
|
+
return this.getQuickFilterColumns().some((col) => regExpStr.test(Util.normalizeString(item.data[col] + '', !caseSensitive)));
|
|
423
|
+
}
|
|
424
|
+
add(e) {
|
|
425
|
+
super.insertDetail();
|
|
426
|
+
}
|
|
427
|
+
getNodeId(item, parentNode) {
|
|
428
|
+
let id = '';
|
|
429
|
+
this.keysArray.forEach(key => {
|
|
430
|
+
id += item[key];
|
|
431
|
+
});
|
|
432
|
+
if (Util.isDefined(this.parentKeys) && Util.isDefined(parentNode)) {
|
|
433
|
+
id += parentNode.id;
|
|
434
|
+
}
|
|
435
|
+
return this.keys + ':' + id;
|
|
436
|
+
}
|
|
437
|
+
childQueryData(node) {
|
|
438
|
+
let queryMethodName = this.queryMethod;
|
|
439
|
+
if (!this.dataService || !(queryMethodName in this.dataService) || !this.entity) {
|
|
440
|
+
return of({ data: [] });
|
|
441
|
+
}
|
|
442
|
+
const parentItem = ServiceUtils.getParentKeysFromForm(this._pKeysEquiv, this.form);
|
|
443
|
+
let filter;
|
|
444
|
+
if (this.recursive) {
|
|
445
|
+
filter = parentItem ?? {};
|
|
446
|
+
filter[this.parentColumn] = node.data[this.keysArray[0]];
|
|
447
|
+
}
|
|
448
|
+
else {
|
|
449
|
+
filter = ServiceUtils.getFilterUsingParentKeys(node.data, node.treeNode._pKeysEquiv);
|
|
450
|
+
}
|
|
451
|
+
let queryArguments = [filter, this.colArray, this.entity];
|
|
452
|
+
return this.dataService[queryMethodName](...queryArguments);
|
|
453
|
+
}
|
|
454
|
+
navigateToViewDetail(node) {
|
|
455
|
+
if (Util.isDefined(node.route)) {
|
|
456
|
+
let route = undefined;
|
|
457
|
+
let nodeRoute = node.route;
|
|
458
|
+
let routeArray = nodeRoute.split(Codes.ROUTE_SEPARATOR);
|
|
459
|
+
for (let i = 0, len = routeArray.length; i < len; i++) {
|
|
460
|
+
if (routeArray[i].startsWith(Codes.ROUTE_VARIABLE_CHAR)) {
|
|
461
|
+
routeArray[i] = node.data[routeArray[i].substring(1)];
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
route = routeArray.join(Codes.ROUTE_SEPARATOR);
|
|
465
|
+
if (Util.isDefined(route)) {
|
|
466
|
+
const extras = {
|
|
467
|
+
relativeTo: this.actRoute
|
|
468
|
+
};
|
|
469
|
+
this.router.navigate([route], extras);
|
|
470
|
+
}
|
|
471
|
+
}
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
OTreeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTreeComponent, deps: [{ token: i0.Injector }, { token: i0.ElementRef }, { token: forwardRef(() => OFormComponent), optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
475
|
+
OTreeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: OTreeComponent, selector: "o-tree", inputs: { oattr: ["attr", "oattr"], service: "service", entity: "entity", columns: "columns", keys: "keys", parentKeys: ["parent-keys", "parentKeys"], queryMethod: ["query-method", "queryMethod"], insertButton: ["insert-button", "insertButton"], refreshButton: ["refresh-button", "refreshButton"], deleteButton: ["delete-button", "deleteButton"], visibleColumns: ["visible-columns", "visibleColumns"], selectAllCheckbox: ["select-all-checkbox", "selectAllCheckbox"], separator: "separator", parentColumn: ["parent-column", "parentColumn"], sortColumn: ["sort-column", "sortColumn"], selectAllCheckboxVisible: ["select-all-checkbox-visible", "selectAllCheckboxVisible"], filterCaseSensitive: ["filter-case-sensitive", "filterCaseSensitive"], quickFilter: ["quick-filter", "quickFilter"], quickFilterPlaceholder: ["quick-filter-placeholder", "quickFilterPlaceholder"], quickFilterColumns: ["quick-filter-columns", "quickFilterColumns"], detailMode: ["detail-mode", "detailMode"], detailFormRoute: ["detail-form-route", "detailFormRoute"], showButtonsText: ["show-buttons-text", "showButtonsText"], rootTitle: ["root-title", "rootTitle"], recursive: "recursive", route: "route" }, outputs: { onNodeSelected: "onNodeSelected", onNodeExpanded: "onNodeExpanded", onNodeCollapsed: "onNodeCollapsed", onLoadNextLevel: "onLoadNextLevel", onDataLoaded: "onDataLoaded" }, host: { properties: { "class.o-tree": "true" } }, providers: [OTreeDao], queries: [{ propertyName: "leafNodeTemplate", first: true, predicate: ["leafNodeTemplate"], descendants: true, read: TemplateRef }, { propertyName: "parentNodeTemplate", first: true, predicate: ["parentNodeTemplate"], descendants: true, read: TemplateRef }, { propertyName: "nodeTemplate", first: true, predicate: ["nodeTemplate"], descendants: true, read: TemplateRef }, { propertyName: "treeNode", first: true, predicate: i0.forwardRef(function () { return OTreeNodeComponent; }) }], usesInheritance: true, ngImport: i0, template: "<div fxLayout=\"column\" fxFlex>\n\n <div *ngIf=\"hasControls()\" fxLayout=\"row\" fxLayoutAlign=\"start center\">\n\n <div class=\"buttons\">\n <ng-container *ngIf=\"showButtonsText;else showButtonsWithoutText\">\n\n <button *ngIf=\"insertButton\" type=\"button\" mat-stroked-button aria-label=\"Insert\" (click)=\"add($event)\">\n <mat-icon svgIcon=\"ontimize:add\"></mat-icon>\n <span>{{ 'INSERT' | oTranslate }}</span>\n </button>\n\n <button *ngIf=\"refreshButton\" type=\"button\" mat-stroked-button aria-label=\"Refresh\" (click)=\"reloadData()\">\n <mat-icon svgIcon=\"ontimize:autorenew\"></mat-icon>\n <span>{{ 'REFRESH' | oTranslate }}</span>\n </button>\n\n <button *ngIf=\"deleteButton\" type=\"button\" mat-stroked-button aria-label=\"Delete\" [disabled]=\"!enabledDeleteButton\"\n [class.disabled]=\"!enabledDeleteButton\">\n <mat-icon svgIcon=\"ontimize:delete\"></mat-icon>\n <span>{{ 'DELETE' | oTranslate }}</span>\n </button>\n\n </ng-container>\n\n <ng-template #showButtonsWithoutText>\n <button *ngIf=\"insertButton\" type=\"button\" mat-icon-button aria-label=\"Insert\" (click)=\"add($event)\">\n <mat-icon svgIcon=\"ontimize:add\"></mat-icon>\n </button>\n\n <button *ngIf=\"refreshButton\" type=\"button\" mat-icon-button aria-label=\"Refresh\" (click)=\"reloadData()\">\n <mat-icon svgIcon=\"ontimize:autorenew\"></mat-icon>\n </button>\n\n <button *ngIf=\"deleteButton\" type=\"button\" mat-icon-button aria-label=\"Delete\" [disabled]=\"!enabledDeleteButton\"\n [class.disabled]=\"!enabledDeleteButton\">\n <mat-icon svgIcon=\"ontimize:delete\"></mat-icon>\n </button>\n </ng-template>\n\n <ng-content select=\"[o-tree-button]\"></ng-content>\n </div>\n <div fxFlex>\n <span fxLayoutAlign=\"center center\" class=\"title\">{{ title | oTranslate }}</span>\n </div>\n <o-search-input *ngIf=\"quickFilter\" [filter-case-sensitive]=\"filterCaseSensitive\" [show-case-sensitive-checkbox]=\"showCaseSensitiveCheckbox()\"\n [columns]=\"quickFilterColumns\" [placeholder]=\"quickFilterPlaceholder\" appearance=\"outline\" float-label=\"never\" show-menu=\"no\">\n </o-search-input>\n <button type=\"button\" *ngIf=\"showTreeMenuButton\" mat-icon-button class=\"o-tree-menu-button\" [matMenuTriggerFor]=\"treeMenu.matMenu\"\n (click)=\"$event.stopPropagation()\">\n <mat-icon svgIcon=\"ontimize:more_vert\"></mat-icon>\n </button>\n <o-tree-menu #treeMenu [select-all-checkbox]=\"selectAllCheckbox\" [select-all-checkbox-visible]=\"selectAllCheckboxVisible\"\n (onSelectCheckboxChange)=\"onSelectCheckboxChange($event)\"></o-tree-menu>\n\n </div>\n\n <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n\n <!-- This is the tree node template for leaf nodes -->\n <mat-tree-node *matTreeNodeDef=\"let node\" (click)=\"leafNodeClicked($event,node)\" matTreeNodeToggle matTreeNodePadding>\n <!-- use a disabled button to provide padding for tree leaf -->\n <button mat-icon-button disabled></button>\n\n <ng-container *ngIf=\"selectAllCheckboxVisible; else simpleLeafNodeTpl\">\n <div class=\"node-wrapper\">\n <mat-checkbox *ngIf=\"selectAllCheckboxVisible; else simpleLeafNodeTpl\" [checked]=\"checklistSelection.isSelected(node)\"\n (click)=\"checkboxClicked($event)\" (change)=\"todoLeafItemSelectionToggle(node)\">\n </mat-checkbox>\n <ng-container [ngTemplateOutlet]=\"leafNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </div>\n </ng-container>\n <ng-template #simpleLeafNodeTpl>\n <ng-container [ngTemplateOutlet]=\"leafNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </ng-template>\n\n </mat-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <mat-tree-node *matTreeNodeDef=\"let node; when: hasChild\" (click)=\"parentNodeClicked($event, node)\" matTreeNodePadding>\n <button mat-icon-button [attr.aria-label]=\"'toggle ' + node.label\" matTreeNodeToggle (click)=\"onClickToggleButton($event, node)\">\n <mat-icon class=\"mat-icon-rtl-mirror\">\n {{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}}\n </mat-icon>\n </button>\n\n <ng-container *ngIf=\"selectAllCheckboxVisible; else simpleParentNodeTpl\">\n <div class=\"node-wrapper\">\n <mat-checkbox *ngIf=\"selectAllCheckboxVisible; else simpleParentNodeTpl\" (click)=\"checkboxClicked($event)\"\n (change)=\"todoItemSelectionToggle(node)\" [checked]=\"descendantsAllSelected(node)\" [indeterminate]=\"descendantsPartiallySelected(node)\">\n </mat-checkbox>\n <ng-container [ngTemplateOutlet]=\"parentNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </div>\n </ng-container>\n\n <ng-template #simpleParentNodeTpl>\n <ng-container [ngTemplateOutlet]=\"parentNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </ng-template>\n </mat-tree-node>\n </mat-tree>\n</div>\n\n<ng-template let-node #leafNodeFulltemplate>\n <ng-container *ngIf=\"leafNodeTemplate; else defaultLeafNodeTpl\" [ngTemplateOutlet]=\"leafNodeTemplate\"\n [ngTemplateOutletContext]=\"{$implicit:node.data}\">\n </ng-container>\n\n <ng-template #defaultLeafNodeTpl>\n {{node.label}}\n </ng-template>\n</ng-template>\n\n<ng-template let-node #parentNodeFulltemplate>\n <ng-container *ngIf=\"parentNodeTemplate; else defaultParentNodeTpl\" [ngTemplateOutlet]=\"parentNodeTemplate\"\n [ngTemplateOutletContext]=\"{$implicit:node.data}\">\n </ng-container>\n\n <ng-template #defaultParentNodeTpl>\n <span>{{node.label}}</span>\n <mat-progress-bar *ngIf=\"node.isLoading\" mode=\"indeterminate\" fxFlex></mat-progress-bar>\n </ng-template>\n</ng-template>\n", styles: [".o-tree .mat-mdc-progress-bar{margin-left:30px}.o-tree .node-wrapper{align-items:center}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.OSearchInputComponent, selector: "o-search-input", inputs: ["placeholder", "label", "width", "float-label", "appearance", "columns", "filter-case-sensitive", "show-case-sensitive-checkbox", "show-menu"], outputs: ["onSearch"] }, { kind: "directive", type: i3.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i3.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i3.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i8.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: i9.MatTreeNodeDef, selector: "[matTreeNodeDef]", inputs: ["matTreeNodeDefWhen", "matTreeNode"] }, { kind: "directive", type: i9.MatTreeNodePadding, selector: "[matTreeNodePadding]", inputs: ["matTreeNodePadding", "matTreeNodePaddingIndent"] }, { kind: "directive", type: i9.MatTreeNodeToggle, selector: "[matTreeNodeToggle]", inputs: ["matTreeNodeToggleRecursive"] }, { kind: "component", type: i9.MatTree, selector: "mat-tree", exportAs: ["matTree"] }, { kind: "directive", type: i9.MatTreeNode, selector: "mat-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["matTreeNode"] }, { kind: "component", type: i10.OTreeMenuComponent, selector: "o-tree-menu", inputs: ["select-all-checkbox", "select-all-checkbox-visible"], outputs: ["onSelectCheckboxChange"] }, { kind: "pipe", type: i11.OTranslatePipe, name: "oTranslate" }], encapsulation: i0.ViewEncapsulation.None });
|
|
476
|
+
__decorate([
|
|
477
|
+
BooleanInputConverter(),
|
|
478
|
+
__metadata("design:type", Boolean)
|
|
479
|
+
], OTreeComponent.prototype, "refreshButton", void 0);
|
|
480
|
+
__decorate([
|
|
481
|
+
BooleanInputConverter(),
|
|
482
|
+
__metadata("design:type", Boolean)
|
|
483
|
+
], OTreeComponent.prototype, "deleteButton", void 0);
|
|
484
|
+
__decorate([
|
|
485
|
+
BooleanInputConverter(),
|
|
486
|
+
__metadata("design:type", Boolean)
|
|
487
|
+
], OTreeComponent.prototype, "showButtonsText", void 0);
|
|
488
|
+
__decorate([
|
|
489
|
+
BooleanInputConverter(),
|
|
490
|
+
__metadata("design:type", Boolean)
|
|
491
|
+
], OTreeComponent.prototype, "selectAllCheckboxVisible", void 0);
|
|
492
|
+
__decorate([
|
|
493
|
+
BooleanInputConverter(),
|
|
494
|
+
__metadata("design:type", Boolean)
|
|
495
|
+
], OTreeComponent.prototype, "selectAllCheckbox", void 0);
|
|
496
|
+
__decorate([
|
|
497
|
+
BooleanInputConverter(),
|
|
498
|
+
__metadata("design:type", Boolean)
|
|
499
|
+
], OTreeComponent.prototype, "recursive", void 0);
|
|
500
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OTreeComponent, decorators: [{
|
|
501
|
+
type: Component,
|
|
502
|
+
args: [{ selector: 'o-tree', inputs: DEFAULT_INPUTS_O_TREE, outputs: DEFAULT_OUTPUTS_O_TREE, encapsulation: ViewEncapsulation.None, host: {
|
|
503
|
+
'[class.o-tree]': 'true'
|
|
504
|
+
}, providers: [OTreeDao], template: "<div fxLayout=\"column\" fxFlex>\n\n <div *ngIf=\"hasControls()\" fxLayout=\"row\" fxLayoutAlign=\"start center\">\n\n <div class=\"buttons\">\n <ng-container *ngIf=\"showButtonsText;else showButtonsWithoutText\">\n\n <button *ngIf=\"insertButton\" type=\"button\" mat-stroked-button aria-label=\"Insert\" (click)=\"add($event)\">\n <mat-icon svgIcon=\"ontimize:add\"></mat-icon>\n <span>{{ 'INSERT' | oTranslate }}</span>\n </button>\n\n <button *ngIf=\"refreshButton\" type=\"button\" mat-stroked-button aria-label=\"Refresh\" (click)=\"reloadData()\">\n <mat-icon svgIcon=\"ontimize:autorenew\"></mat-icon>\n <span>{{ 'REFRESH' | oTranslate }}</span>\n </button>\n\n <button *ngIf=\"deleteButton\" type=\"button\" mat-stroked-button aria-label=\"Delete\" [disabled]=\"!enabledDeleteButton\"\n [class.disabled]=\"!enabledDeleteButton\">\n <mat-icon svgIcon=\"ontimize:delete\"></mat-icon>\n <span>{{ 'DELETE' | oTranslate }}</span>\n </button>\n\n </ng-container>\n\n <ng-template #showButtonsWithoutText>\n <button *ngIf=\"insertButton\" type=\"button\" mat-icon-button aria-label=\"Insert\" (click)=\"add($event)\">\n <mat-icon svgIcon=\"ontimize:add\"></mat-icon>\n </button>\n\n <button *ngIf=\"refreshButton\" type=\"button\" mat-icon-button aria-label=\"Refresh\" (click)=\"reloadData()\">\n <mat-icon svgIcon=\"ontimize:autorenew\"></mat-icon>\n </button>\n\n <button *ngIf=\"deleteButton\" type=\"button\" mat-icon-button aria-label=\"Delete\" [disabled]=\"!enabledDeleteButton\"\n [class.disabled]=\"!enabledDeleteButton\">\n <mat-icon svgIcon=\"ontimize:delete\"></mat-icon>\n </button>\n </ng-template>\n\n <ng-content select=\"[o-tree-button]\"></ng-content>\n </div>\n <div fxFlex>\n <span fxLayoutAlign=\"center center\" class=\"title\">{{ title | oTranslate }}</span>\n </div>\n <o-search-input *ngIf=\"quickFilter\" [filter-case-sensitive]=\"filterCaseSensitive\" [show-case-sensitive-checkbox]=\"showCaseSensitiveCheckbox()\"\n [columns]=\"quickFilterColumns\" [placeholder]=\"quickFilterPlaceholder\" appearance=\"outline\" float-label=\"never\" show-menu=\"no\">\n </o-search-input>\n <button type=\"button\" *ngIf=\"showTreeMenuButton\" mat-icon-button class=\"o-tree-menu-button\" [matMenuTriggerFor]=\"treeMenu.matMenu\"\n (click)=\"$event.stopPropagation()\">\n <mat-icon svgIcon=\"ontimize:more_vert\"></mat-icon>\n </button>\n <o-tree-menu #treeMenu [select-all-checkbox]=\"selectAllCheckbox\" [select-all-checkbox-visible]=\"selectAllCheckboxVisible\"\n (onSelectCheckboxChange)=\"onSelectCheckboxChange($event)\"></o-tree-menu>\n\n </div>\n\n <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n\n <!-- This is the tree node template for leaf nodes -->\n <mat-tree-node *matTreeNodeDef=\"let node\" (click)=\"leafNodeClicked($event,node)\" matTreeNodeToggle matTreeNodePadding>\n <!-- use a disabled button to provide padding for tree leaf -->\n <button mat-icon-button disabled></button>\n\n <ng-container *ngIf=\"selectAllCheckboxVisible; else simpleLeafNodeTpl\">\n <div class=\"node-wrapper\">\n <mat-checkbox *ngIf=\"selectAllCheckboxVisible; else simpleLeafNodeTpl\" [checked]=\"checklistSelection.isSelected(node)\"\n (click)=\"checkboxClicked($event)\" (change)=\"todoLeafItemSelectionToggle(node)\">\n </mat-checkbox>\n <ng-container [ngTemplateOutlet]=\"leafNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </div>\n </ng-container>\n <ng-template #simpleLeafNodeTpl>\n <ng-container [ngTemplateOutlet]=\"leafNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </ng-template>\n\n </mat-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <mat-tree-node *matTreeNodeDef=\"let node; when: hasChild\" (click)=\"parentNodeClicked($event, node)\" matTreeNodePadding>\n <button mat-icon-button [attr.aria-label]=\"'toggle ' + node.label\" matTreeNodeToggle (click)=\"onClickToggleButton($event, node)\">\n <mat-icon class=\"mat-icon-rtl-mirror\">\n {{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}}\n </mat-icon>\n </button>\n\n <ng-container *ngIf=\"selectAllCheckboxVisible; else simpleParentNodeTpl\">\n <div class=\"node-wrapper\">\n <mat-checkbox *ngIf=\"selectAllCheckboxVisible; else simpleParentNodeTpl\" (click)=\"checkboxClicked($event)\"\n (change)=\"todoItemSelectionToggle(node)\" [checked]=\"descendantsAllSelected(node)\" [indeterminate]=\"descendantsPartiallySelected(node)\">\n </mat-checkbox>\n <ng-container [ngTemplateOutlet]=\"parentNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </div>\n </ng-container>\n\n <ng-template #simpleParentNodeTpl>\n <ng-container [ngTemplateOutlet]=\"parentNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n </ng-container>\n </ng-template>\n </mat-tree-node>\n </mat-tree>\n</div>\n\n<ng-template let-node #leafNodeFulltemplate>\n <ng-container *ngIf=\"leafNodeTemplate; else defaultLeafNodeTpl\" [ngTemplateOutlet]=\"leafNodeTemplate\"\n [ngTemplateOutletContext]=\"{$implicit:node.data}\">\n </ng-container>\n\n <ng-template #defaultLeafNodeTpl>\n {{node.label}}\n </ng-template>\n</ng-template>\n\n<ng-template let-node #parentNodeFulltemplate>\n <ng-container *ngIf=\"parentNodeTemplate; else defaultParentNodeTpl\" [ngTemplateOutlet]=\"parentNodeTemplate\"\n [ngTemplateOutletContext]=\"{$implicit:node.data}\">\n </ng-container>\n\n <ng-template #defaultParentNodeTpl>\n <span>{{node.label}}</span>\n <mat-progress-bar *ngIf=\"node.isLoading\" mode=\"indeterminate\" fxFlex></mat-progress-bar>\n </ng-template>\n</ng-template>\n", styles: [".o-tree .mat-mdc-progress-bar{margin-left:30px}.o-tree .node-wrapper{align-items:center}\n"] }]
|
|
505
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.ElementRef }, { type: i12.OFormComponent, decorators: [{
|
|
506
|
+
type: Optional
|
|
507
|
+
}, {
|
|
508
|
+
type: Inject,
|
|
509
|
+
args: [forwardRef(() => OFormComponent)]
|
|
510
|
+
}] }]; }, propDecorators: { refreshButton: [], deleteButton: [], showButtonsText: [], selectAllCheckboxVisible: [], selectAllCheckbox: [], recursive: [], leafNodeTemplate: [{
|
|
511
|
+
type: ContentChild,
|
|
512
|
+
args: ['leafNodeTemplate', { read: TemplateRef, static: false }]
|
|
513
|
+
}], parentNodeTemplate: [{
|
|
514
|
+
type: ContentChild,
|
|
515
|
+
args: ['parentNodeTemplate', { read: TemplateRef, static: false }]
|
|
516
|
+
}], nodeTemplate: [{
|
|
517
|
+
type: ContentChild,
|
|
518
|
+
args: ['nodeTemplate', { read: TemplateRef, static: false }]
|
|
519
|
+
}], treeNode: [{
|
|
520
|
+
type: ContentChild,
|
|
521
|
+
args: [forwardRef(() => OTreeNodeComponent), { descendants: false }]
|
|
522
|
+
}] } });
|
|
523
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"o-tree.component.js","sourceRoot":"","sources":["../../../../../projects/ontimize-web-ngx/src/lib/components/tree/o-tree.component.ts","../../../../../projects/ontimize-web-ngx/src/lib/components/tree/o-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\nimport { FlatTreeControl } from '@angular/cdk/tree';\nimport {\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Injector,\n  OnDestroy,\n  OnInit,\n  Optional,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Observable, of, Subscription } from 'rxjs';\n\nimport { BooleanInputConverter } from '../../decorators/input-converter';\nimport { ServiceResponse } from '../../interfaces/service-response.interface';\nimport { OTreeComponentStateService } from '../../services/state/o-tree-component-state.service';\nimport { Codes } from '../../util/codes';\nimport { FilterExpressionUtils } from '../../util/filter-expression.utils';\nimport { ServiceUtils } from '../../util/service.utils';\nimport { Util } from '../../util/util';\nimport { OFormComponent } from '../form/o-form.component';\nimport { AbstractOServiceComponent } from '../o-service-component.class';\nimport { OTreeDao } from './o-tree-dao.service';\nimport { OTreeDataSource } from './o-tree.datasource';\nimport { OTreeNodeComponent } from './tree-node/tree-node.component';\n\nexport type OTreeFlatNode = {\n  id: string | number,\n  label: string;\n  level: number,\n  rootNode?: boolean,\n  expandable: boolean,\n  treeNode?: OTreeNodeComponent,\n  data: any;\n  isLoading?: boolean;\n  route?: string\n\n}\n\nexport const DEFAULT_INPUTS_O_TREE = [\n  // attr [string]: list identifier. It is mandatory if data are provided through the data attribute. Default: entity (if set).\n  'oattr: attr',\n\n  // service [string]: JEE service path. Default: no value.\n  'service',\n\n  // entity [string]: entity of the service. Default: no value.\n  'entity',\n\n  // columns [string]: columns of the entity, separated by ';'. Default: no value.\n  'columns',\n\n  // keys [string]: entity keys, separated by ';'. Default: no value.\n  'keys',\n\n  // parent-keys [string]: parent keys to filter, separated by ';'. Default: no value.\n  'parentKeys: parent-keys',\n\n  // query-method [string]: name of the service method to perform queries. Default: query.\n  'queryMethod: query-method',\n\n  // insert-button [no|yes]: show insert button. Default: yes.\n  'insertButton: insert-button',\n\n  // refresh-button [no|yes]: show refresh button. Default: yes.\n  'refreshButton: refresh-button',\n\n  // delete-button [no|yes]: show delete button when user select items. Default: yes.\n  'deleteButton: delete-button',\n\n  // END OF DEFAULT_INPUTS_O_SERVICE_COMPONENT\n  'visibleColumns: visible-columns',\n  'selectAllCheckbox: select-all-checkbox',\n  'separator',\n  'parentColumn: parent-column',\n  'sortColumn: sort-column',\n  // select-all-checkbox-visible [yes|no|true|false]: show selection check boxes.Default: no.\n  'selectAllCheckboxVisible: select-all-checkbox-visible',\n  // filter [yes|no|true|false]: whether filter is case sensitive. Default: no.\n  'filterCaseSensitive: filter-case-sensitive',\n  // quick-filter [no|yes]: show quick filter. Default: yes.\n  'quickFilter: quick-filter',\n  // quick-filter-placeholder: quick filter placeholder\n  'quickFilterPlaceholder: quick-filter-placeholder',\n  // quick-filter-columns [string]: columns of the filter, separated by ';'. Default: no value.\n  'quickFilterColumns: quick-filter-columns',\n  // detail-mode [none|click|doubleclick]: way to open the detail form of a row. Default: 'click'.\n  'detailMode: detail-mode',\n  // detail-form-route [string]: route of detail form. Default: 'detail'.\n  'detailFormRoute: detail-form-route',\n  // show-buttons-text [yes|no|true|false]: show text of header buttons. Default: yes.\n  'showButtonsText: show-buttons-text',\n  'rootTitle: root-title',\n  'recursive',\n  'route'\n];\n\nexport const DEFAULT_OUTPUTS_O_TREE = ['onNodeSelected', 'onNodeExpanded', 'onNodeCollapsed', 'onLoadNextLevel', 'onDataLoaded'];\n\n@Component({\n  selector: 'o-tree',\n  templateUrl: './o-tree.component.html',\n  styleUrls: ['./o-tree.component.scss'],\n  inputs: DEFAULT_INPUTS_O_TREE,\n  outputs: DEFAULT_OUTPUTS_O_TREE,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[class.o-tree]': 'true'\n  },\n  providers: [OTreeDao]\n})\nexport class OTreeComponent extends AbstractOServiceComponent<OTreeComponentStateService> implements OnInit, OnDestroy, AfterViewInit {\n\n  getLevel = (node: OTreeFlatNode) => node.level;\n\n  isExpandable = (node: OTreeFlatNode) => node.expandable;\n\n  getChildren = (node: OTreeFlatNode): any => {\n    if (this.recursive) {\n      return this.getRecursiveChildrenNode(node);\n    } else {\n      return this.getTreeNodeChildren(node);\n    }\n  }\n\n  getTreeNodeChildren(node: OTreeFlatNode): any {\n    if (node.level === 0 && Util.isDefined(this.rootTitle)) {\n      return this.rootNodes;\n    } else if (node.treeNode) {\n      if (Util.isDefined(node.treeNode.rootTitle) && !Util.isDefined(node.rootNode)) {\n        let rootNode: OTreeFlatNode = {\n          id: this.dataSource.data.length + 1, rootNode: true, label: this.translateService.get(node.treeNode.rootTitle), level: node.level + 1, expandable: true, data: node.data, isLoading: false, treeNode: node.treeNode\n        };\n        this.daoTree.flatNodeMap.set(rootNode, node);\n        return [rootNode];\n      } else {\n        return node.treeNode.childQueryData(node);\n      }\n    } else {\n      return this.childreNodes.filter((item) => item[this.parentKeys] === node[this.keys]);\n    }\n  }\n\n  getRecursiveChildrenNode(node: OTreeFlatNode): any {\n    if (node.level === 0 && Util.isDefined(this.rootTitle)) {\n      return this.rootNodes;\n    } else {\n      return this.childQueryData(node);\n    }\n\n  }\n  getComponentFilter(existingFilter: any = {}): any {\n    let filter = existingFilter;\n    if (this.recursive && this.parentColumn !== undefined) {\n      const parentItemExpr = FilterExpressionUtils.buildExpressionFromObject(filter);\n      const parentNotNullExpr = FilterExpressionUtils.buildExpressionIsNull(this.parentColumn);\n      const filterExpr = FilterExpressionUtils.buildComplexExpression(parentItemExpr, parentNotNullExpr, FilterExpressionUtils.OP_AND);\n      filter = {};\n      filter[FilterExpressionUtils.FILTER_EXPRESSION_KEY] = filterExpr;\n    }\n    return super.getComponentFilter(filter);\n  }\n\n  hasChild = (_: number, _nodeData: OTreeFlatNode) => _nodeData.expandable;\n\n  hasNoContent = (_: number, _nodeData: OTreeFlatNode) => _nodeData.label === '';\n\n\n  dataSource: OTreeDataSource;\n\n  @BooleanInputConverter()\n  refreshButton: boolean = true;\n  @BooleanInputConverter()\n  deleteButton: boolean = false;\n  @BooleanInputConverter()\n  showButtonsText: boolean = false;\n\n  visibleColumns: string;\n  separator: string = Codes.HYPHEN_SEPARATOR;\n  parentColumn: string;\n  sortColumn: string;\n  @BooleanInputConverter()\n  selectAllCheckboxVisible: boolean = false;\n  @BooleanInputConverter()\n  selectAllCheckbox: boolean = false;\n  @BooleanInputConverter()\n  recursive: boolean = false;\n\n  protected _quickFilter: boolean = false;\n  paginationControls = false;\n  quickFilterColumns: string;\n\n  childreNodes: OTreeFlatNode[] = [];\n  nodesArray: OTreeFlatNode[] = [];\n  ancestors: any[] = [];\n  checklistSelection = new SelectionModel<OTreeFlatNode>(true, [], true, (sm1, sm2) => sm1.id === sm2.id);\n\n  onNodeSelected: EventEmitter<any> = new EventEmitter();\n  onNodeExpanded: EventEmitter<any> = new EventEmitter();\n  onNodeCollapsed: EventEmitter<any> = new EventEmitter();\n  onLoadNextLevel: EventEmitter<any> = new EventEmitter();\n  rootTitle: string;\n  rootNodes: OTreeFlatNode[] = [];\n  daoTree: OTreeDao;\n\n  @ContentChild('leafNodeTemplate', { read: TemplateRef, static: false })\n  leafNodeTemplate: TemplateRef<any>;\n\n  @ContentChild('parentNodeTemplate', { read: TemplateRef, static: false })\n  parentNodeTemplate: TemplateRef<any>;\n\n  treeFlattener: any;\n  treeControl: FlatTreeControl<OTreeFlatNode, OTreeFlatNode>;\n\n  @ContentChild('nodeTemplate', { read: TemplateRef, static: false })\n  set nodeTemplate(value: TemplateRef<any>) {\n    if (value != null) {\n      this.leafNodeTemplate = value;\n      this.parentNodeTemplate = value;\n    }\n  }\n\n  @ContentChild(forwardRef(() => OTreeNodeComponent), { descendants: false })\n  treeNode!: OTreeNodeComponent;\n\n  protected visibleColumnsArray: string[] = [];\n  public enabledDeleteButton: boolean = false;\n  protected subscription: Subscription = new Subscription();\n  public route: string;\n  get showTreeMenuButton(): boolean {\n    const staticOpt = this.selectAllCheckbox;\n    return staticOpt;\n  }\n  constructor(\n    public injector: Injector,\n    elRef: ElementRef,\n    @Optional() @Inject(forwardRef(() => OFormComponent)) form: OFormComponent\n  ) {\n    super(injector, elRef, form);\n    this.daoTree = this.injector.get(OTreeDao)\n\n  }\n\n  ngOnInit() {\n    this.setTreeControl();\n    this.initialize();\n    this.initializeParams();\n\n    this.subscription.add(\n      this.selection.changed.subscribe(\n        () => (this.enabledDeleteButton = !this.selection.isEmpty())\n      )\n    );\n  }\n\n\n  public initialize(): void {\n    super.initialize();\n    this.initializeDao();\n  }\n\n  protected initializeDao() {\n\n    if (this.staticData) {\n      this.queryOnBind = false;\n      this.queryOnInit = false;\n      this.setDataArray(this.staticData);\n    } else {\n      this.configureService();\n    }\n  }\n\n  initializeParams(): void {\n    // If visible-columns is not present then visible-columns is all columns\n    if (!this.visibleColumns) {\n      this.visibleColumns = this.columns;\n    }\n\n    if (!Util.isDefined(this.quickFilterColumns)) {\n      this.quickFilterColumns = this.visibleColumns;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.visibleColumnsArray = Util.parseArray(this.visibleColumns, true);\n    this.quickFilterColArray = Util.parseArray(this.quickFilterColumns, true);\n    this.setDatasource();\n    this.afterViewInit();\n    if (this.queryOnInit) {\n      this.queryData();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy();\n    this.subscription.unsubscribe();\n  }\n\n  registerTreeNode(oTreeNode: OTreeNodeComponent) {\n    // this.dataSource.data.forEach()\n  }\n\n  checkboxClicked(event: Event): void {\n    event.stopPropagation();\n  }\n\n  leafNodeClicked(event: Event, node: OTreeFlatNode): void {\n    this.nodeClicked(node, event);\n  }\n\n  parentNodeClicked(event: Event, node: OTreeFlatNode): void {\n    this.nodeClicked(node, event);\n  }\n\n  protected nodeClicked(node: OTreeFlatNode, event: Event) {\n    event.stopPropagation();\n    event.preventDefault();\n    if (this.detailMode !== Codes.DETAIL_MODE_NONE && !this.isRootNode(node)) {\n      /*\n      Se podria mejorar llamando this.viewDetail(node.data);\n      si almacenamos el nodo, actualmente se esta almacenando si existe un tree-node hijo\n      */\n      this.navigateToViewDetail(node);\n    }\n  }\n\n  isRootNode(node: OTreeFlatNode) {\n    return Util.isDefined(node.rootNode) && node.rootNode;\n  }\n\n  onClickToggleButton(event: Event, node) {\n    event.stopPropagation();\n    if (this.treeControl.isExpanded(node)) {\n      this.onNodeExpanded.emit(node);\n    } else {\n      this.onNodeCollapsed.emit(node);\n    }\n  }\n  /**\n  * Toggle the node, remove from display list\n  */\n  toggleNode(node: OTreeFlatNode, expand: boolean) {\n    node.isLoading = true;\n    if (expand && node.expandable) {\n      const children = this.getChildren(node);\n      if (Util.isArray(children)) {\n        this.dataSource.updateTree(node, children, expand);\n      } else {\n        this.updateAsyncTree(children, node, expand);\n      }\n    } else {\n      this.dataSource.updateTree(node, [], expand);\n    }\n\n  }\n\n  private updateAsyncTree(children: any, node: OTreeFlatNode, expand: boolean) {\n    children.subscribe((res: ServiceResponse) => {\n      let data;\n      if (res.isSuccessful()) {\n        const arrData = (res.data !== undefined) ? res.data : [];\n        data = Util.isArray(arrData) ? arrData : [];\n      }\n      this.dataSource.updateTree(node, data, expand);\n    }, err => {\n      node.isLoading = false;\n      if (Util.isDefined(this.queryFallbackFunction)) {\n        this.queryFallbackFunction(err);\n      } else {\n        this.oErrorDialogManager.openErrorDialog(err);\n        console.error(err);\n      }\n    });\n\n  }\n\n  /** Toggle a leaf to-do item selection. Check all the parents to see if they changed */\n  todoLeafItemSelectionToggle(node: OTreeFlatNode): void {\n    this.todoItemSelectionToggle(node);\n  }\n\n  /** Toggle the to-do item selection. Select/deselect all the descendants node */\n  todoItemSelectionToggle(node: OTreeFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    const descendants = this.treeControl.getDescendants(node);\n    this.checklistSelection.isSelected(node)\n      ? this.checklistSelection.select(...descendants)\n      : this.checklistSelection.deselect(...descendants);\n\n    // Force update for the parent\n    descendants.every((child) => this.checklistSelection.isSelected(child));\n    this.onNodeSelected.emit(node.data);\n\n\n  }\n\n\n  /** Whether all the descendants of the node are selected. */\n  descendantsAllSelected(node: OTreeFlatNode): boolean {\n    let descAllSelected = false;\n    const descendants = this.treeControl.getDescendants(node);\n    if (node.expandable) {\n\n      if (this.treeControl.isExpanded(node) && descendants.length > 0) {\n        descAllSelected = descendants.every((child) =>\n          this.checklistSelection.isSelected(child)\n        );\n        descAllSelected ? this.checklistSelection.select(node) : this.checklistSelection.deselect(node);\n        return descAllSelected;\n      } else {\n        return this.checklistSelection.isSelected(node);\n      }\n\n    } else {\n      return this.checklistSelection.isSelected(node);\n    }\n\n  }\n\n  /** Whether part of the descendants are selected */\n  descendantsPartiallySelected(node: OTreeFlatNode): boolean {\n\n    let result = false;\n    const descendants = this.treeControl.getDescendants(node);\n    if (node.expandable) {\n      if (descendants.length > 0) {\n        result = descendants.some((child) =>\n          this.checklistSelection.isSelected(child)\n        );\n      }\n    }\n    return result && !this.descendantsAllSelected(node);\n\n  }\n\n\n  protected setTreeControl() {\n    if (!Util.isDefined(this.treeControl)) {\n      this.treeControl = new FlatTreeControl<OTreeFlatNode>(this.getLevel, this.isExpandable);\n    }\n  }\n  /** */\n\n  protected setDatasource() {\n    if (!Util.isDefined(this.dataSource)) {\n      this.dataSource = new OTreeDataSource(this, this.treeControl, this.injector);\n    }\n\n  }\n\n  getParentNodes(node: OTreeFlatNode, index: number, tree: OTreeFlatNode[]): OTreeFlatNode[] {\n    let parentNode = this.daoTree.flatNodeMap.get(node);\n    if (Util.isDefined(parentNode)) {\n      const existingNode = tree.findIndex(x => x['id'] === parentNode['id']) > -1;\n      if (Util.isDefined(parentNode)) {\n        if (!existingNode) {\n          //if not exist node in tree then, add parent before node\n          tree.splice(index, 0, parentNode)\n          return this.getParentNodes(parentNode, index, tree);\n        } else {\n          //if not exist node in tree then, add parent before node\n          return this.getParentNodes(parentNode, index, tree);\n        }\n      } else {\n        return tree;\n      }\n    } else {\n      return tree;\n    }\n  }\n\n  filterData(value?: string, loadMore?: boolean): void {\n\n    let filteredTreeData = [];\n    if (value) {\n      for (let [nestedNode] of this.daoTree.flatNodeMap) {\n        if (nestedNode.label.toLocaleLowerCase().indexOf(value.toLocaleLowerCase()) > -1) {\n          filteredTreeData.push(nestedNode);\n        }\n      };\n\n      let index = 0;\n      while (index < filteredTreeData.length) {\n        let node = filteredTreeData[index];\n        const parentNodes = this.getParentNodes(node, index, filteredTreeData);\n        if (!Util.isArrayEmpty(parentNodes)) {\n          filteredTreeData = parentNodes;\n        }\n        index++;\n      }\n      this.dataSource.data = filteredTreeData;\n    } else {\n      filteredTreeData = this.dataResponseArray;\n      this.setDataArray(filteredTreeData);\n    }\n\n\n    // Notify the change.\n    if (value) {\n      let rootNodes = filteredTreeData.filter(node => node.level == 0);\n      this.expandNodesWithNodes(rootNodes);\n    }\n\n  }\n  /**\n   * Expands nodes with nodes\n   * @param treeData\n   */\n  expandNodesWithNodes(treeData: OTreeFlatNode[]) {\n    treeData.filter(node => node.expandable).forEach(node => {\n      const descendants = this.treeControl.getDescendants(node);\n      if (descendants.length > 0) {\n        this.treeControl.expand(node);\n        this.expandNodesWithNodes(descendants)\n      }\n    });\n  }\n\n  /**\n    * Gets data tree\n    * @returns\n    */\n  getDataArray() {\n    return this.daoTree.data;\n  }\n\n  setDataArray(data: any): void {\n    this.daoTree.flatNodeMap.clear();\n    this.daoTree.setDataArray(data);\n    if (this.recursive) {\n      this.childreNodes = data.filter(\n        (item: any) => item[this.parentColumn] != null\n      );\n      this.rootNodes = data.filter(\n        (item: any) => !Util.isDefined(item[this.parentColumn]) || item[this.parentColumn] === null\n      );\n    }\n\n    this.rootNodes = data;\n\n    let level = 0;\n    let rootNode: OTreeFlatNode;\n    if (Util.isDefined(this.rootTitle)) {\n      level = +1;\n      rootNode = { id: 0, label: this.translateService.get(this.rootTitle), rootNode: true, level: 0, expandable: true, data: {}, isLoading: false };\n      this.daoTree.flatNodeMap.set(rootNode, null);\n      this.dataSource.data = [rootNode];\n      this.treeControl.expand(rootNode);\n    } else {\n      this.dataSource.data = this.rootNodes.map(node => this.transformer(node, level));\n    }\n\n  }\n\n  transformer = (node: any, level: number, parentNode?: any) => {\n\n    const nodeChildren = this.childreNodes.filter((item) => item[this.parentColumn] === node[this.keys]);\n    const flatNode: OTreeFlatNode =\n    {\n      'id': this.getNodeId(node, parentNode),\n      'label': this.getItemText(node),\n      'level': level,\n      treeNode: this.treeNode,\n      'expandable': Util.isDefined(this.treeNode) || !!nodeChildren?.length || this.recursive,\n      'data': node,\n      'isLoading': false,\n      'route': this.route\n    };\n\n    this.daoTree.flatNodeMap.set(flatNode, parentNode);\n\n    //recursive\n    nodeChildren.forEach(node => this.transformer(node, level + 1));\n    return flatNode;\n\n\n  }\n\n  onSelectCheckboxChange(visible: boolean) {\n    this.selectAllCheckboxVisible = visible;\n  }\n\n  protected sort(array: OTreeFlatNode[]): void {\n    if (this.sortColumn != null) {\n      array.sort((a, b) =>\n        a.data[this.sortColumn].localeCompare(b.data[this.sortColumn])\n      );\n      array\n        .filter((node) => !!this.treeControl.getDescendants(node))\n        .forEach((node) => this.sort(this.treeControl.getDescendants(node)));\n    }\n  }\n\n  protected getItemText(item: any): string {\n    return this.visibleColumnsArray\n      .filter((col) => item[col] != null && `${item[col]}`.length > 0)\n      .map((col) => item[col])\n      .join(this.separator);\n  }\n\n  getItemKey(item: any): string {\n    return this.keysArray.map((col) => item[col]).join(';');\n  }\n\n\n  protected filterByQuickFilterColumns(\n    item: any,\n    quickfilter: string\n  ): boolean {\n    const caseSensitive = this.isFilterCaseSensitive();\n    const regExpStr = new RegExp(\n      Util.escapeSpecialCharacter(\n        Util.normalizeString(quickfilter, !caseSensitive)\n      )\n    );\n    return this.getQuickFilterColumns().some((col) =>\n      regExpStr.test(Util.normalizeString(item.data[col] + '', !caseSensitive))\n    );\n  }\n\n  public add(e?: Event): void {\n    super.insertDetail();\n  }\n\n  protected getNodeId(item: any, parentNode: any) {\n    /** revisarlo:igual con id incremental era mas facil e igual de eficiente */\n    let id = '';\n    this.keysArray.forEach(key => {\n      id += item[key];\n    });\n    if (Util.isDefined(this.parentKeys) && Util.isDefined(parentNode)) {\n      id += parentNode.id;\n    }\n\n    return this.keys + ':' + id;\n  }\n\n\n  public childQueryData(node: OTreeFlatNode): Observable<ServiceResponse> | Observable<any> {\n    let queryMethodName = this.queryMethod;\n    if (!this.dataService || !(queryMethodName in this.dataService) || !this.entity) {\n      return of({ data: [] });\n    }\n    const parentItem = ServiceUtils.getParentKeysFromForm(this._pKeysEquiv, this.form);\n    let filter\n    if (this.recursive) {\n      filter = parentItem ?? {};\n      filter[this.parentColumn] = node.data[this.keysArray[0]]\n    } else {\n      filter = ServiceUtils.getFilterUsingParentKeys(node.data, node.treeNode._pKeysEquiv);\n    }\n\n    let queryArguments = [filter, this.colArray, this.entity];\n\n    return this.dataService[queryMethodName](...queryArguments) as Observable<ServiceResponse>;\n  }\n\n  protected navigateToViewDetail(node: OTreeFlatNode) {\n    if (Util.isDefined(node.route)) {\n      let route = undefined;\n\n      let nodeRoute = node.route;\n      let routeArray = nodeRoute.split(Codes.ROUTE_SEPARATOR);\n      for (let i = 0, len = routeArray.length; i < len; i++) {\n        if (routeArray[i].startsWith(Codes.ROUTE_VARIABLE_CHAR)) {\n          routeArray[i] = node.data[routeArray[i].substring(1)];\n        }\n      }\n      route = routeArray.join(Codes.ROUTE_SEPARATOR);\n\n      if (Util.isDefined(route)) {\n        const extras = {\n          relativeTo: this.actRoute\n        };\n        this.router.navigate([route], extras);\n      }\n    }\n  }\n}\n","<div fxLayout=\"column\" fxFlex>\n\n  <div *ngIf=\"hasControls()\" fxLayout=\"row\" fxLayoutAlign=\"start center\">\n\n    <div class=\"buttons\">\n      <ng-container *ngIf=\"showButtonsText;else showButtonsWithoutText\">\n\n        <button *ngIf=\"insertButton\" type=\"button\" mat-stroked-button aria-label=\"Insert\" (click)=\"add($event)\">\n          <mat-icon svgIcon=\"ontimize:add\"></mat-icon>\n          <span>{{ 'INSERT' | oTranslate }}</span>\n        </button>\n\n        <button *ngIf=\"refreshButton\" type=\"button\" mat-stroked-button aria-label=\"Refresh\" (click)=\"reloadData()\">\n          <mat-icon svgIcon=\"ontimize:autorenew\"></mat-icon>\n          <span>{{ 'REFRESH' | oTranslate }}</span>\n        </button>\n\n        <button *ngIf=\"deleteButton\" type=\"button\" mat-stroked-button aria-label=\"Delete\" [disabled]=\"!enabledDeleteButton\"\n          [class.disabled]=\"!enabledDeleteButton\">\n          <mat-icon svgIcon=\"ontimize:delete\"></mat-icon>\n          <span>{{ 'DELETE' | oTranslate }}</span>\n        </button>\n\n      </ng-container>\n\n      <ng-template #showButtonsWithoutText>\n        <button *ngIf=\"insertButton\" type=\"button\" mat-icon-button aria-label=\"Insert\" (click)=\"add($event)\">\n          <mat-icon svgIcon=\"ontimize:add\"></mat-icon>\n        </button>\n\n        <button *ngIf=\"refreshButton\" type=\"button\" mat-icon-button aria-label=\"Refresh\" (click)=\"reloadData()\">\n          <mat-icon svgIcon=\"ontimize:autorenew\"></mat-icon>\n        </button>\n\n        <button *ngIf=\"deleteButton\" type=\"button\" mat-icon-button aria-label=\"Delete\" [disabled]=\"!enabledDeleteButton\"\n          [class.disabled]=\"!enabledDeleteButton\">\n          <mat-icon svgIcon=\"ontimize:delete\"></mat-icon>\n        </button>\n      </ng-template>\n\n      <ng-content select=\"[o-tree-button]\"></ng-content>\n    </div>\n    <div fxFlex>\n      <span fxLayoutAlign=\"center center\" class=\"title\">{{ title | oTranslate }}</span>\n    </div>\n    <o-search-input *ngIf=\"quickFilter\" [filter-case-sensitive]=\"filterCaseSensitive\" [show-case-sensitive-checkbox]=\"showCaseSensitiveCheckbox()\"\n      [columns]=\"quickFilterColumns\" [placeholder]=\"quickFilterPlaceholder\" appearance=\"outline\" float-label=\"never\" show-menu=\"no\">\n    </o-search-input>\n    <button type=\"button\" *ngIf=\"showTreeMenuButton\" mat-icon-button class=\"o-tree-menu-button\" [matMenuTriggerFor]=\"treeMenu.matMenu\"\n      (click)=\"$event.stopPropagation()\">\n      <mat-icon svgIcon=\"ontimize:more_vert\"></mat-icon>\n    </button>\n    <o-tree-menu #treeMenu [select-all-checkbox]=\"selectAllCheckbox\" [select-all-checkbox-visible]=\"selectAllCheckboxVisible\"\n      (onSelectCheckboxChange)=\"onSelectCheckboxChange($event)\"></o-tree-menu>\n\n  </div>\n\n  <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n\n    <!-- This is the tree node template for leaf nodes -->\n    <mat-tree-node *matTreeNodeDef=\"let node\" (click)=\"leafNodeClicked($event,node)\" matTreeNodeToggle matTreeNodePadding>\n      <!-- use a disabled button to provide padding for tree leaf -->\n      <button mat-icon-button disabled></button>\n\n      <ng-container *ngIf=\"selectAllCheckboxVisible; else simpleLeafNodeTpl\">\n        <div class=\"node-wrapper\">\n          <mat-checkbox *ngIf=\"selectAllCheckboxVisible; else simpleLeafNodeTpl\" [checked]=\"checklistSelection.isSelected(node)\"\n            (click)=\"checkboxClicked($event)\" (change)=\"todoLeafItemSelectionToggle(node)\">\n          </mat-checkbox>\n          <ng-container [ngTemplateOutlet]=\"leafNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n          </ng-container>\n        </div>\n      </ng-container>\n      <ng-template #simpleLeafNodeTpl>\n        <ng-container [ngTemplateOutlet]=\"leafNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n        </ng-container>\n      </ng-template>\n\n    </mat-tree-node>\n    <!-- This is the tree node template for expandable nodes -->\n    <mat-tree-node *matTreeNodeDef=\"let node; when: hasChild\" (click)=\"parentNodeClicked($event, node)\" matTreeNodePadding>\n      <button mat-icon-button [attr.aria-label]=\"'toggle ' + node.label\" matTreeNodeToggle (click)=\"onClickToggleButton($event, node)\">\n        <mat-icon class=\"mat-icon-rtl-mirror\">\n          {{treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'}}\n        </mat-icon>\n      </button>\n\n      <ng-container *ngIf=\"selectAllCheckboxVisible; else simpleParentNodeTpl\">\n        <div class=\"node-wrapper\">\n          <mat-checkbox *ngIf=\"selectAllCheckboxVisible; else simpleParentNodeTpl\" (click)=\"checkboxClicked($event)\"\n            (change)=\"todoItemSelectionToggle(node)\" [checked]=\"descendantsAllSelected(node)\" [indeterminate]=\"descendantsPartiallySelected(node)\">\n          </mat-checkbox>\n          <ng-container [ngTemplateOutlet]=\"parentNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n          </ng-container>\n        </div>\n      </ng-container>\n\n      <ng-template #simpleParentNodeTpl>\n        <ng-container [ngTemplateOutlet]=\"parentNodeFulltemplate\" [ngTemplateOutletContext]=\"{$implicit:node}\">\n        </ng-container>\n      </ng-template>\n    </mat-tree-node>\n  </mat-tree>\n</div>\n\n<ng-template let-node #leafNodeFulltemplate>\n  <ng-container *ngIf=\"leafNodeTemplate; else defaultLeafNodeTpl\" [ngTemplateOutlet]=\"leafNodeTemplate\"\n    [ngTemplateOutletContext]=\"{$implicit:node.data}\">\n  </ng-container>\n\n  <ng-template #defaultLeafNodeTpl>\n    {{node.label}}\n  </ng-template>\n</ng-template>\n\n<ng-template let-node #parentNodeFulltemplate>\n  <ng-container *ngIf=\"parentNodeTemplate; else defaultParentNodeTpl\" [ngTemplateOutlet]=\"parentNodeTemplate\"\n    [ngTemplateOutletContext]=\"{$implicit:node.data}\">\n  </ng-container>\n\n  <ng-template #defaultParentNodeTpl>\n    <span>{{node.label}}</span>\n    <mat-progress-bar *ngIf=\"node.isLoading\" mode=\"indeterminate\" fxFlex></mat-progress-bar>\n  </ng-template>\n</ng-template>\n"]}
|