UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

134 lines 19.3 kB
import { Component, Input, Optional } from '@angular/core'; import { toMoment } from '../../resources/types/nae-date-type'; import { DATE_TIME_FORMAT_STRING } from '../../moment/time-formats'; import { CaseMetaField } from '../../header/case-header/case-menta-enum'; import { AbstractPanelWithImmediateDataComponent } from '../abstract/panel-with-immediate-data'; import { take } from 'rxjs/operators'; import { getImmediateData } from '../../utility/get-immediate-data'; import { PermissionType } from '../../process/permissions'; import { FormControl } from '@angular/forms'; import * as i0 from "@angular/core"; import * as i1 from "../../resources/engine-endpoint/case-resource.service"; import * as i2 from "../../view/case-view/service/case-view-service"; import * as i3 from "../../snack-bar/services/snack-bar.service"; import * as i4 from "@ngx-translate/core"; import * as i5 from "../../logger/services/logger.service"; import * as i6 from "../../user/services/user.service"; import * as i7 from "@angular/common"; import * as i8 from "../../authorization/permission/permission.service"; import * as i9 from "../../header/services/overflow.service"; export class AbstractCasePanelComponent extends AbstractPanelWithImmediateDataComponent { _caseResourceService; _caseViewService; _snackBarService; _translateService; _log; _userService; _currencyPipe; _permissionService; _overflowService; case_; approval; responsiveBody = true; first; last; showCasePanelIcon = true; showDeleteMenu = false; textEllipsis = false; _approvalFormControl; constructor(_caseResourceService, _caseViewService, _snackBarService, _translateService, _log, _userService, _currencyPipe, _permissionService, _overflowService) { super(_translateService, _currencyPipe, _overflowService); this._caseResourceService = _caseResourceService; this._caseViewService = _caseViewService; this._snackBarService = _snackBarService; this._translateService = _translateService; this._log = _log; this._userService = _userService; this._currencyPipe = _currencyPipe; this._permissionService = _permissionService; this._overflowService = _overflowService; this._approvalFormControl = new FormControl(); } get approvalFormControl() { return this._approvalFormControl; } show(event) { event.stopPropagation(); return false; } getFeaturedMetaValue(selectedHeader) { switch (selectedHeader.fieldIdentifier) { case CaseMetaField.MONGO_ID: return { value: this.case_.stringId, icon: undefined, type: 'meta' }; case CaseMetaField.VISUAL_ID: return { value: this.case_.visualId, icon: undefined, type: 'meta' }; case CaseMetaField.TITLE: return { value: this.case_.title, icon: undefined, type: 'meta' }; case CaseMetaField.AUTHOR: return { value: this.case_.author.fullName, icon: 'account_circle', type: 'meta' }; case CaseMetaField.CREATION_DATE: return { value: toMoment(this.case_.creationDate).format(DATE_TIME_FORMAT_STRING), icon: 'event', type: 'meta' }; } } getFeaturedImmediateValue(selectedHeader) { const immediate = getImmediateData(this.case_, selectedHeader.fieldIdentifier); return this.parseImmediateValue(immediate); } deleteCase() { this._caseResourceService.deleteCase(this.case_.stringId).pipe(take(1)).subscribe((data) => { if (data.success) { this._snackBarService.openSuccessSnackBar(data.outcome.message === undefined ? this._translateService.instant('tasks.snackbar.caseDeleteSuccess') : data.outcome.message); this._caseViewService.reload(); } else if (data.error) { this.throwError(this._translateService.instant('tasks.snackbar.caseDeleteFailed')); } }, error => { this.throwError(this._translateService.instant('tasks.snackbar.caseDeleteFailed')); }); } canDelete() { return this._permissionService.hasCasePermission(this.case_, PermissionType.DELETE); } throwError(message) { this._snackBarService.openErrorSnackBar(message); this._log.error(message); } getMinWidth() { return (this._overflowService && this._overflowService.overflowMode) ? `${this._overflowService.columnWidth}px` : '0'; } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractCasePanelComponent, deps: [{ token: i1.CaseResourceService }, { token: i2.CaseViewService }, { token: i3.SnackBarService }, { token: i4.TranslateService }, { token: i5.LoggerService }, { token: i6.UserService }, { token: i7.CurrencyPipe }, { token: i8.PermissionService }, { token: i9.OverflowService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractCasePanelComponent, selector: "ncc-abstract-case-panel", inputs: { case_: "case_", approval: "approval", responsiveBody: "responsiveBody", first: "first", last: "last", showCasePanelIcon: "showCasePanelIcon", showDeleteMenu: "showDeleteMenu", textEllipsis: "textEllipsis" }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractCasePanelComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-case-panel', template: '' }] }], ctorParameters: () => [{ type: i1.CaseResourceService }, { type: i2.CaseViewService }, { type: i3.SnackBarService }, { type: i4.TranslateService }, { type: i5.LoggerService }, { type: i6.UserService }, { type: i7.CurrencyPipe }, { type: i8.PermissionService }, { type: i9.OverflowService, decorators: [{ type: Optional }] }], propDecorators: { case_: [{ type: Input }], approval: [{ type: Input }], responsiveBody: [{ type: Input }], first: [{ type: Input }], last: [{ type: Input }], showCasePanelIcon: [{ type: Input }], showDeleteMenu: [{ type: Input }], textEllipsis: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-case-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/panel/case-panel/abstract-case-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, Optional} from '@angular/core';\nimport {Observable} from 'rxjs';\nimport {Case} from '../../resources/interface/case';\nimport {toMoment} from '../../resources/types/nae-date-type';\nimport {HeaderColumn} from '../../header/models/header-column';\nimport {DATE_TIME_FORMAT_STRING} from '../../moment/time-formats';\nimport {CaseMetaField} from '../../header/case-header/case-menta-enum';\nimport {CaseResourceService} from '../../resources/engine-endpoint/case-resource.service';\nimport {CaseViewService} from '../../view/case-view/service/case-view-service';\nimport {SnackBarService} from '../../snack-bar/services/snack-bar.service';\nimport {TranslateService} from '@ngx-translate/core';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {OverflowService} from '../../header/services/overflow.service';\nimport {AbstractPanelWithImmediateDataComponent} from '../abstract/panel-with-immediate-data';\nimport {UserService} from '../../user/services/user.service';\nimport {take} from 'rxjs/operators';\nimport {getImmediateData} from '../../utility/get-immediate-data';\nimport {FeaturedValue} from '../abstract/featured-value';\nimport {EventOutcomeMessageResource} from '../../resources/interface/message-resource';\nimport {CurrencyPipe} from '@angular/common';\nimport {PermissionService} from '../../authorization/permission/permission.service';\nimport {PermissionType} from '../../process/permissions';\nimport {FormControl} from '@angular/forms';\n\n@Component({\n    selector: 'ncc-abstract-case-panel',\n    template: ''\n})\nexport abstract class AbstractCasePanelComponent extends AbstractPanelWithImmediateDataComponent {\n\n\n    @Input() public case_: Case;\n    @Input() public approval: boolean;\n    @Input() responsiveBody = true;\n    @Input() first: boolean;\n    @Input() last: boolean;\n    @Input() showCasePanelIcon = true;\n    @Input() showDeleteMenu = false;\n    @Input() textEllipsis = false;\n    protected _approvalFormControl: FormControl<boolean | string>;\n\n    protected constructor(protected _caseResourceService: CaseResourceService,\n                          protected _caseViewService: CaseViewService,\n                          protected _snackBarService: SnackBarService,\n                          protected _translateService: TranslateService,\n                          protected _log: LoggerService,\n                          protected _userService: UserService,\n                          protected _currencyPipe: CurrencyPipe,\n                          protected _permissionService: PermissionService,\n                          @Optional() protected _overflowService: OverflowService,) {\n        super(_translateService, _currencyPipe, _overflowService);\n        this._approvalFormControl = new FormControl();\n    }\n\n    get approvalFormControl(): FormControl<boolean | string> {\n        return this._approvalFormControl;\n    }\n\n    public show(event: MouseEvent): boolean {\n        event.stopPropagation();\n        return false;\n    }\n\n    protected getFeaturedMetaValue(selectedHeader: HeaderColumn): FeaturedValue {\n        switch (selectedHeader.fieldIdentifier) {\n            case CaseMetaField.MONGO_ID:\n                return {value: this.case_.stringId, icon: undefined, type: 'meta'};\n            case CaseMetaField.VISUAL_ID:\n                return {value: this.case_.visualId, icon: undefined, type: 'meta'};\n            case CaseMetaField.TITLE:\n                return {value: this.case_.title, icon: undefined, type: 'meta'};\n            case CaseMetaField.AUTHOR:\n                return {value: this.case_.author.fullName, icon: 'account_circle', type: 'meta'};\n            case CaseMetaField.CREATION_DATE:\n                return {\n                    value: toMoment(this.case_.creationDate).format(DATE_TIME_FORMAT_STRING),\n                    icon: 'event',\n                    type: 'meta'\n                };\n        }\n    }\n\n    protected getFeaturedImmediateValue(selectedHeader: HeaderColumn): FeaturedValue {\n        const immediate = getImmediateData(this.case_, selectedHeader.fieldIdentifier);\n        return this.parseImmediateValue(immediate);\n    }\n\n    public deleteCase() {\n        this._caseResourceService.deleteCase(this.case_.stringId).pipe(take(1)).subscribe((data: EventOutcomeMessageResource) => {\n            if (data.success) {\n                this._snackBarService.openSuccessSnackBar(data.outcome.message === undefined\n                    ? this._translateService.instant('tasks.snackbar.caseDeleteSuccess')\n                    : data.outcome.message);\n                this._caseViewService.reload();\n            } else if (data.error) {\n                this.throwError(this._translateService.instant('tasks.snackbar.caseDeleteFailed'));\n            }\n        }, error => {\n            this.throwError(this._translateService.instant('tasks.snackbar.caseDeleteFailed'));\n        });\n    }\n\n    public canDelete(): boolean {\n        return this._permissionService.hasCasePermission(this.case_, PermissionType.DELETE);\n    }\n\n    private throwError(message: string) {\n        this._snackBarService.openErrorSnackBar(message);\n        this._log.error(message);\n    }\n\n    public getMinWidth() {\n        return (this._overflowService && this._overflowService.overflowMode) ? `${this._overflowService.columnWidth}px` : '0';\n    }\n}\n"]}