@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
114 lines • 15.6 kB
JavaScript
import { Component, Input, ViewChild } from '@angular/core';
import { AbstractViewWithHeadersComponent } from '../abstract/view-with-headers';
import { HeaderType } from '../../header/models/header-type';
import { Net } from '../../process/net';
import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
import { FormControl } from "@angular/forms";
import { debounceTime, filter, map } from "rxjs/operators";
import * as i0 from "@angular/core";
import * as i1 from "@angular/material/dialog";
import * as i2 from "./workflow-view.service";
import * as i3 from "../../logger/services/logger.service";
import * as i4 from "../../process/process.service";
import * as i5 from "@angular/router";
export class AbstractWorkflowViewComponent extends AbstractViewWithHeadersComponent {
_dialog;
_workflowViewService;
_log;
_processService;
footerSize;
showDeleteMenu = false;
workflowHeader;
headerType = HeaderType.WORKFLOW;
workflows$;
loading$;
fullTextFormControl;
viewport;
constructor(_dialog, _workflowViewService, _log, _processService, _activatedRoute) {
super(_workflowViewService, _activatedRoute);
this._dialog = _dialog;
this._workflowViewService = _workflowViewService;
this._log = _log;
this._processService = _processService;
this.workflows$ = this._workflowViewService.workflows$;
this.loading$ = this._workflowViewService.loading$;
this.footerSize = 0;
this.fullTextFormControl = new FormControl();
}
ngOnInit() {
this.fullTextFormControl.valueChanges.pipe(debounceTime(600), filter(newValue => typeof newValue === 'string'), map((newValue) => newValue.trim())).subscribe((fulltext) => {
if (fulltext.length === 0) {
this._workflowViewService.clearSearchTitle();
}
else {
this._workflowViewService.setSearchTitle(fulltext);
}
});
}
ngAfterViewInit() {
this.initializeHeader(this.workflowHeader);
}
importSidemenuNet(component) {
const dialogRef = this._dialog.open(component, {
width: '40%',
minWidth: '300px',
panelClass: "dialog-responsive",
});
dialogRef.afterClosed().subscribe(event => {
if (event.data?.net !== undefined) {
this._workflowViewService.reload();
if (event.data?.net) {
this._processService.updateNet(new Net(event.data.net));
}
}
else {
this._log.debug('');
}
});
}
trackBy(i) {
return i;
}
loadNextPage() {
if (!this.viewport) {
return;
}
this._workflowViewService.nextPage(this.viewport.getRenderedRange(), this.viewport.getDataLength());
}
calculateListHeight(preciseHeight) {
if (!this.viewport) {
return;
}
const element = this.viewport.getElementRef().nativeElement;
if (preciseHeight !== null && preciseHeight !== undefined) {
element.style.height = preciseHeight + 'px';
}
else {
const viewportHeight = window.innerHeight - element.offsetTop - this.footerSize;
if (element.style.height !== viewportHeight + 'px') {
this._log.info('Virtual scroll height change to: ' + viewportHeight);
element.style.height = viewportHeight + 'px';
}
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractWorkflowViewComponent, deps: [{ token: i1.MatDialog }, { token: i2.WorkflowViewService }, { token: i3.LoggerService }, { token: i4.ProcessService }, { token: i5.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractWorkflowViewComponent, selector: "ncc-abstract-workflow-view", inputs: { footerSize: "footerSize", showDeleteMenu: "showDeleteMenu" }, viewQueries: [{ propertyName: "workflowHeader", first: true, predicate: ["header"], descendants: true }, { propertyName: "viewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }], usesInheritance: true, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractWorkflowViewComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-workflow-view',
template: ''
}]
}], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.WorkflowViewService }, { type: i3.LoggerService }, { type: i4.ProcessService }, { type: i5.ActivatedRoute }], propDecorators: { footerSize: [{
type: Input
}], showDeleteMenu: [{
type: Input
}], workflowHeader: [{
type: ViewChild,
args: ['header']
}], viewport: [{
type: ViewChild,
args: [CdkVirtualScrollViewport]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-workflow-view.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/view/workflow-view/abstract-workflow-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component, Input, OnInit, ViewChild} from '@angular/core';\nimport {WorkflowViewService} from './workflow-view.service';\nimport {AbstractHeaderComponent} from '../../header/abstract-header.component';\nimport {AbstractViewWithHeadersComponent} from '../abstract/view-with-headers';\nimport {HeaderType} from '../../header/models/header-type';\nimport {Observable} from 'rxjs';\nimport {Net} from '../../process/net';\nimport {CdkVirtualScrollViewport} from '@angular/cdk/scrolling';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {ProcessService} from '../../process/process.service';\nimport { ActivatedRoute } from '@angular/router';\nimport {MatDialog} from '@angular/material/dialog';\nimport {FormControl} from \"@angular/forms\";\nimport {debounceTime, filter, map, take, tap} from \"rxjs/operators\";\nimport {TranslateService} from \"@ngx-translate/core\";\n\n@Component({\n    selector: 'ncc-abstract-workflow-view',\n    template: ''\n})\nexport abstract class AbstractWorkflowViewComponent extends AbstractViewWithHeadersComponent implements OnInit, AfterViewInit {\n\n    @Input() public footerSize: number;\n    @Input() showDeleteMenu = false;\n    @ViewChild('header') public workflowHeader: AbstractHeaderComponent;\n\n    public readonly headerType = HeaderType.WORKFLOW;\n    public workflows$: Observable<Array<Net>>;\n    public loading$: Observable<boolean>;\n    public fullTextFormControl: FormControl;\n\n    @ViewChild(CdkVirtualScrollViewport) public viewport: CdkVirtualScrollViewport;\n\n    protected constructor(protected _dialog: MatDialog,\n                          protected _workflowViewService: WorkflowViewService,\n                          protected _log: LoggerService,\n                          protected _processService: ProcessService,\n                          _activatedRoute?: ActivatedRoute) {\n        super(_workflowViewService, _activatedRoute);\n        this.workflows$ = this._workflowViewService.workflows$;\n        this.loading$ = this._workflowViewService.loading$;\n        this.footerSize = 0;\n        this.fullTextFormControl = new FormControl();\n    }\n\n    ngOnInit(): void {\n        this.fullTextFormControl.valueChanges.pipe(\n            debounceTime(600),\n            filter(newValue => typeof newValue === 'string'),\n            map((newValue: string) => newValue.trim())\n        ).subscribe((fulltext: string) => {\n            if (fulltext.length === 0) {\n                this._workflowViewService.clearSearchTitle();\n            } else {\n                this._workflowViewService.setSearchTitle(fulltext);\n            }\n        });\n    }\n\n    ngAfterViewInit(): void {\n        this.initializeHeader(this.workflowHeader);\n    }\n\n    public importSidemenuNet(component) {\n        const dialogRef = this._dialog.open(component, {\n            width: '40%',\n            minWidth: '300px',\n            panelClass: \"dialog-responsive\",\n        });\n        dialogRef.afterClosed().subscribe(event => {\n            if (event.data?.net !== undefined) {\n                this._workflowViewService.reload();\n                if (event.data?.net) {\n                    this._processService.updateNet(new Net(event.data.net));\n                }\n            } else {\n                this._log.debug('');\n            }\n        });\n    }\n\n    public trackBy(i): any {\n        return i;\n    }\n\n    public loadNextPage(): void {\n        if (!this.viewport) {\n            return;\n        }\n        this._workflowViewService.nextPage(this.viewport.getRenderedRange(), this.viewport.getDataLength());\n    }\n\n    protected calculateListHeight(preciseHeight?: number): void {\n        if (!this.viewport) {\n            return;\n        }\n        const element = this.viewport.getElementRef().nativeElement;\n        if (preciseHeight !== null && preciseHeight !== undefined) {\n            element.style.height = preciseHeight + 'px';\n        } else {\n            const viewportHeight = window.innerHeight - element.offsetTop - this.footerSize;\n            if (element.style.height !== viewportHeight + 'px') {\n                this._log.info('Virtual scroll height change to: ' + viewportHeight);\n                element.style.height = viewportHeight + 'px';\n            }\n        }\n    }\n\n}\n"]}