@netgrif/components
Version:
Netgrif Application Engine frontend Angular components
114 lines • 22.4 kB
JavaScript
import { Component, Inject } from '@angular/core';
import { AbstractTabbedSingleTaskViewComponent, AllowedNetsService, AllowedNetsServiceFactory, ChangedFieldsService, FinishTaskService, NAE_BASE_FILTER, NAE_TAB_DATA, NAE_TASK_OPERATIONS, NAE_VIEW_ID_SEGMENT, FrontActionService, RedirectService, SearchService, SubjectTaskOperations, TaskDataService, TaskEventService, TaskRequestStateService, TaskViewService, ViewIdService, extractFieldValueFromData, SimpleFilter, FilterType, MergeOperator } from '@netgrif/components-core';
import { AsyncPipe } from "@angular/common";
import * as i0 from "@angular/core";
import * as i1 from "@netgrif/components-core";
import * as i2 from "@angular/router";
import * as i3 from "@angular/common";
import * as i4 from "@ngbracket/ngx-layout";
import * as i5 from "@angular/material/button";
import * as i6 from "../../../../../panel/task-panel-single/single-task.component";
import * as i7 from "@ngx-translate/core";
function baseFilterFactory(injectedTabData) {
const requestBody = injectedTabData.baseFilter.getRequestBody();
if (requestBody.transitionId === undefined) {
const viewDataGroups = injectedTabData.navigationItemTaskData?.slice(4, injectedTabData.navigationItemTaskData.length);
if (viewDataGroups !== undefined) {
const viewTransitionId = extractFieldValueFromData(viewDataGroups, "transition_id");
if (viewTransitionId !== undefined) {
return {
filter: injectedTabData.baseFilter.merge(new SimpleFilter('', FilterType.TASK, { transitionId: viewTransitionId?.split(",") }), MergeOperator.AND)
};
}
}
}
return {
filter: injectedTabData.baseFilter
};
}
const localAllowedNetsFactory = (factory) => {
return factory.createWithAllNets();
};
export class DefaultTabbedSingleTaskViewComponent extends AbstractTabbedSingleTaskViewComponent {
_router;
hidePanelHeader = true;
hideActionRow = false;
showPageHeader = true;
showPageFooter = false;
actionRowJustifyContent = "center";
showFinishButton = true;
showCloseButton = true;
constructor(taskViewService, injectedTabData, activatedRoute, _router) {
super(taskViewService, injectedTabData, activatedRoute);
this._router = _router;
}
ngOnInit() {
this._router.routeReuseStrategy.shouldReuseRoute = () => false;
}
closeTab() {
this._injectedTabData.tabViewRef.closeTabIndex(this._injectedTabData.tabViewRef.currentlySelectedTab());
}
getFinishTitle() {
return (this.finishTitle === '' || this.finishTitle) ? this.finishTitle : 'tasks.view.finish';
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultTabbedSingleTaskViewComponent, deps: [{ token: i1.TaskViewService }, { token: NAE_TAB_DATA }, { token: i2.ActivatedRoute }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DefaultTabbedSingleTaskViewComponent, selector: "nc-default-tabbed-single-task-view", providers: [
TaskViewService,
SearchService,
RedirectService,
ChangedFieldsService,
{
provide: NAE_BASE_FILTER,
useFactory: baseFilterFactory,
deps: [NAE_TAB_DATA]
},
{ provide: NAE_VIEW_ID_SEGMENT, useValue: 'publicTaskView' },
{ provide: AllowedNetsServiceFactory, useClass: AllowedNetsServiceFactory },
{
provide: AllowedNetsService,
useFactory: localAllowedNetsFactory,
deps: [AllowedNetsServiceFactory]
},
ViewIdService,
TaskDataService,
FrontActionService,
FinishTaskService,
TaskRequestStateService,
TaskEventService,
{ provide: NAE_TASK_OPERATIONS, useClass: SubjectTaskOperations },
AsyncPipe
], usesInheritance: true, ngImport: i0, template: "<div class=\"task-tab-background full-height\">\n <div fxLayout=\"column\" fxLayoutAlign=\"start stretch\" class=\"content-margin full-height\" >\n <nc-single-task [task$]=\"task$\" [loading$]=\"loading$\" [selectedHeaders$]=\"selectedHeaders$\"\n [actionRowJustifyContent]=\"actionRowJustifyContent\" [hideActionRow]=\"hideActionRow\" [hidePanelHeader]=\"hidePanelHeader\"\n [showPageHeader]=\"showPageHeader\" [showPageFooter]=\"showPageFooter\" [actionButtonTemplates]='[closeButton, finishButton]' fxFlex></nc-single-task>\n </div>\n</div>\n\n<ng-template #closeButton >\n <button *ngIf=\"showCloseButton\" (click)=\"closeTab()\" mat-stroked-button color=\"primary\">\n {{ 'tasks.view.closeTab' | translate | uppercase }}</button>\n</ng-template>\n\n<ng-template #finishButton let-finish=\"finish\">\n <button *ngIf=\"showFinishButton\" (click)=\"finish()\" mat-stroked-button color=\"primary\" >\n {{ getFinishTitle() | translate | uppercase }}</button>\n</ng-template>\n", styles: [".task-tab-background{height:100%;width:100%;overflow:auto;background-color:transparent}.content-margin{margin:8px 24px 0}.full-height{height:calc(100% - 8px)}@media screen and (max-width: 599.99px){.content-margin{margin:8px 12px 0}}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.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: i4.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: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.SingleTaskComponent, selector: "nc-single-task" }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DefaultTabbedSingleTaskViewComponent, decorators: [{
type: Component,
args: [{ selector: 'nc-default-tabbed-single-task-view', providers: [
TaskViewService,
SearchService,
RedirectService,
ChangedFieldsService,
{
provide: NAE_BASE_FILTER,
useFactory: baseFilterFactory,
deps: [NAE_TAB_DATA]
},
{ provide: NAE_VIEW_ID_SEGMENT, useValue: 'publicTaskView' },
{ provide: AllowedNetsServiceFactory, useClass: AllowedNetsServiceFactory },
{
provide: AllowedNetsService,
useFactory: localAllowedNetsFactory,
deps: [AllowedNetsServiceFactory]
},
ViewIdService,
TaskDataService,
FrontActionService,
FinishTaskService,
TaskRequestStateService,
TaskEventService,
{ provide: NAE_TASK_OPERATIONS, useClass: SubjectTaskOperations },
AsyncPipe
], template: "<div class=\"task-tab-background full-height\">\n <div fxLayout=\"column\" fxLayoutAlign=\"start stretch\" class=\"content-margin full-height\" >\n <nc-single-task [task$]=\"task$\" [loading$]=\"loading$\" [selectedHeaders$]=\"selectedHeaders$\"\n [actionRowJustifyContent]=\"actionRowJustifyContent\" [hideActionRow]=\"hideActionRow\" [hidePanelHeader]=\"hidePanelHeader\"\n [showPageHeader]=\"showPageHeader\" [showPageFooter]=\"showPageFooter\" [actionButtonTemplates]='[closeButton, finishButton]' fxFlex></nc-single-task>\n </div>\n</div>\n\n<ng-template #closeButton >\n <button *ngIf=\"showCloseButton\" (click)=\"closeTab()\" mat-stroked-button color=\"primary\">\n {{ 'tasks.view.closeTab' | translate | uppercase }}</button>\n</ng-template>\n\n<ng-template #finishButton let-finish=\"finish\">\n <button *ngIf=\"showFinishButton\" (click)=\"finish()\" mat-stroked-button color=\"primary\" >\n {{ getFinishTitle() | translate | uppercase }}</button>\n</ng-template>\n", styles: [".task-tab-background{height:100%;width:100%;overflow:auto;background-color:transparent}.content-margin{margin:8px 24px 0}.full-height{height:calc(100% - 8px)}@media screen and (max-width: 599.99px){.content-margin{margin:8px 12px 0}}\n"] }]
}], ctorParameters: () => [{ type: i1.TaskViewService }, { type: undefined, decorators: [{
type: Inject,
args: [NAE_TAB_DATA]
}] }, { type: i2.ActivatedRoute }, { type: i2.Router }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-tabbed-single-task-view.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/tabbed/default-tabbed-single-task-view/default-tabbed-single-task-view.component.ts","../../../../../../../../../projects/netgrif-components/src/lib/navigation/group-navigation-component-resolver/default-components/tabbed/default-tabbed-single-task-view/default-tabbed-single-task-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, OnInit} from '@angular/core';\nimport {ActivatedRoute, Router} from \"@angular/router\";\nimport {\n    AbstractTabbedSingleTaskViewComponent,\n    AllowedNetsService,\n    AllowedNetsServiceFactory,\n    ChangedFieldsService,\n    FinishTaskService,\n    NAE_BASE_FILTER,\n    NAE_TAB_DATA,\n    NAE_TASK_OPERATIONS,\n    NAE_VIEW_ID_SEGMENT,\n    FrontActionService,\n    RedirectService,\n    SearchService,\n    SubjectTaskOperations,\n    TaskDataService,\n    TaskEventService,\n    TaskRequestStateService,\n    TaskViewService,\n    ViewIdService,\n    TaskSearchRequestBody,\n    DataGroup,\n    extractFieldValueFromData,\n    SimpleFilter,\n    FilterType,\n    MergeOperator\n} from '@netgrif/components-core';\nimport {AsyncPipe} from \"@angular/common\";\nimport {\n    InjectedTabbedTaskViewDataWithNavigationItemTaskData\n} from \"../../model/injected-tabbed-task-view-data-with-navigation-item-task-data\";\n\nfunction baseFilterFactory(injectedTabData: InjectedTabbedTaskViewDataWithNavigationItemTaskData) {\n    const requestBody = injectedTabData.baseFilter.getRequestBody() as TaskSearchRequestBody\n    if (requestBody.transitionId === undefined) {\n        const viewDataGroups: Array<DataGroup> = injectedTabData.navigationItemTaskData?.slice(4, injectedTabData.navigationItemTaskData.length);\n        if (viewDataGroups !== undefined) {\n            const viewTransitionId = extractFieldValueFromData<string>(viewDataGroups, \"transition_id\");\n            if (viewTransitionId !== undefined) {\n                return {\n                    filter: injectedTabData.baseFilter.merge(new SimpleFilter('', FilterType.TASK, {transitionId: viewTransitionId?.split(\",\")}), MergeOperator.AND)\n                };\n            }\n        }\n    }\n    return {\n        filter: injectedTabData.baseFilter\n    };\n}\n\nconst localAllowedNetsFactory = (factory: AllowedNetsServiceFactory) => {\n    return factory.createWithAllNets();\n};\n\n@Component({\n    selector: 'nc-default-tabbed-single-task-view',\n    templateUrl: './default-tabbed-single-task-view.component.html',\n    styleUrls: ['./default-tabbed-single-task-view.component.scss'],\n    providers: [\n        TaskViewService,\n        SearchService,\n        RedirectService,\n        ChangedFieldsService,\n        {\n            provide: NAE_BASE_FILTER,\n            useFactory: baseFilterFactory,\n            deps: [NAE_TAB_DATA]\n        },\n        {provide: NAE_VIEW_ID_SEGMENT, useValue: 'publicTaskView'},\n        {provide: AllowedNetsServiceFactory, useClass: AllowedNetsServiceFactory},\n        {\n            provide: AllowedNetsService,\n            useFactory: localAllowedNetsFactory,\n            deps: [AllowedNetsServiceFactory]\n        },\n        ViewIdService,\n        TaskDataService,\n        FrontActionService,\n        FinishTaskService,\n        TaskRequestStateService,\n        TaskEventService,\n        {provide: NAE_TASK_OPERATIONS, useClass: SubjectTaskOperations},\n        AsyncPipe\n    ]\n})\nexport class DefaultTabbedSingleTaskViewComponent extends AbstractTabbedSingleTaskViewComponent implements OnInit {\n\n    hidePanelHeader = true;\n    hideActionRow = false;\n    showPageHeader: boolean = true;\n    showPageFooter: boolean = false;\n    actionRowJustifyContent: \"center\" = \"center\";\n    showFinishButton: boolean = true;\n    showCloseButton: boolean = true;\n\n    constructor(taskViewService: TaskViewService,\n                @Inject(NAE_TAB_DATA) injectedTabData: InjectedTabbedTaskViewDataWithNavigationItemTaskData,\n                activatedRoute: ActivatedRoute,\n                protected _router: Router) {\n        super(taskViewService, injectedTabData, activatedRoute);\n    }\n\n    ngOnInit(): void {\n        this._router.routeReuseStrategy.shouldReuseRoute = () => false;\n    }\n\n    closeTab() {\n        this._injectedTabData.tabViewRef.closeTabIndex(this._injectedTabData.tabViewRef.currentlySelectedTab());\n    }\n\n    public getFinishTitle(): string {\n        return (this.finishTitle === '' || this.finishTitle) ? this.finishTitle : 'tasks.view.finish';\n    }\n}\n","<div class=\"task-tab-background full-height\">\n    <div fxLayout=\"column\" fxLayoutAlign=\"start stretch\" class=\"content-margin full-height\" >\n        <nc-single-task [task$]=\"task$\" [loading$]=\"loading$\" [selectedHeaders$]=\"selectedHeaders$\"\n                        [actionRowJustifyContent]=\"actionRowJustifyContent\"  [hideActionRow]=\"hideActionRow\" [hidePanelHeader]=\"hidePanelHeader\"\n                        [showPageHeader]=\"showPageHeader\" [showPageFooter]=\"showPageFooter\" [actionButtonTemplates]='[closeButton, finishButton]' fxFlex></nc-single-task>\n    </div>\n</div>\n\n<ng-template #closeButton >\n    <button *ngIf=\"showCloseButton\" (click)=\"closeTab()\" mat-stroked-button color=\"primary\">\n        {{ 'tasks.view.closeTab' | translate | uppercase }}</button>\n</ng-template>\n\n<ng-template #finishButton let-finish=\"finish\">\n    <button *ngIf=\"showFinishButton\" (click)=\"finish()\" mat-stroked-button color=\"primary\" >\n        {{ getFinishTitle() | translate | uppercase }}</button>\n</ng-template>\n"]}