UNPKG

@netgrif/components

Version:

Netgrif Application Engine frontend Angular components

83 lines 17.3 kB
import { Component, EventEmitter, Input, Output } from '@angular/core'; import { LoadingEmitter } from '@netgrif/components-core'; import { map } from "rxjs/operators"; import * as i0 from "@angular/core"; import * as i1 from "@netgrif/components-core"; import * as i2 from "@ngx-translate/core"; import * as i3 from "@angular/common"; import * as i4 from "@angular/material/button"; import * as i5 from "@angular/material/icon"; export class CreateCaseButtonComponent { _caseViewService; _translateService; caseCreatedEvent = new EventEmitter(); newCaseCreationConfig; disabled; _resolvedCaseButtonTitle; _resolvedCaseButtonIcon; _loading; constructor(_caseViewService, _translateService) { this._caseViewService = _caseViewService; this._translateService = _translateService; this._loading = new LoadingEmitter(); } get resolvedCaseButtonTitle() { return this._resolvedCaseButtonTitle; } get resolvedCaseButtonIcon() { return this._resolvedCaseButtonIcon; } get loading$() { return this._loading; } ngOnInit() { const config = this.newCaseCreationConfig['newCaseButtonConfig']; if (!!config) { this._resolvedCaseButtonIcon = config.createCaseButtonIcon; this._resolvedCaseButtonTitle = this.resolveTranslation(config); } } resolveTranslation(config) { const locale = this._translateService.currentLang; if (!config.createCaseButtonTitle.defaultValue && !config.createCaseButtonTitle.translations) { return ""; } return locale in config.createCaseButtonTitle.translations ? config.createCaseButtonTitle.translations[locale] : config.createCaseButtonTitle.defaultValue; } shouldShowCreateButton() { const blockNets = this.newCaseCreationConfig?.blockNets || []; return this._caseViewService.getNewCaseAllowedNets(blockNets).pipe(map(allowedNets => allowedNets.length > 0)); } createNewCase() { let myCase; this._loading.on(); if (this.newCaseCreationConfig.enableCaseTitle === false && this._caseViewService.getAllowedNetsCount() === 1) { myCase = this._caseViewService.createDefaultNewCase(this.newCaseCreationConfig); } else { myCase = this._caseViewService.createNewCase(this.newCaseCreationConfig); } myCase.subscribe(kaze => { if (this._caseViewService.viewEnabled(kaze)) { this.caseCreatedEvent.next(kaze); } }, error => { }, () => this._loading.off()); return myCase; } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateCaseButtonComponent, deps: [{ token: i1.CaseViewService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreateCaseButtonComponent, selector: "nc-create-case-button", inputs: { newCaseCreationConfig: "newCaseCreationConfig", disabled: "disabled" }, outputs: { caseCreatedEvent: "caseCreatedEvent" }, ngImport: i0, template: "<!-- Button without title -->\n<button *ngIf=\"(!resolvedCaseButtonTitle && (shouldShowCreateButton() | async)); else titleButton\"\n class=\"create-case-mat-mini-fab\"\n mat-mini-fab color=\"primary\" (click)=\"createNewCase()\"\n [class.spinner]=\"loading$ | async\" [disabled]=\"(loading$ | async) || disabled\">\n <mat-icon *ngIf=\"(loading$ | async) === false\" class=\"net-upload\" aria-hidden=\"false\">\n {{ !!resolvedCaseButtonIcon ? resolvedCaseButtonIcon : 'add' }}\n </mat-icon>\n</button>\n\n<!-- Button with title -->\n<ng-template #titleButton>\n <button *ngIf=\"shouldShowCreateButton() | async\" mat-flat-button class=\"height-44\" color=\"primary\"\n (click)=\"createNewCase()\" [class.spinner]=\"loading$ | async\"\n [disabled]=\"(loading$ | async) || disabled\">\n <mat-icon *ngIf=\"!!resolvedCaseButtonIcon && (loading$ | async) === false\" class=\"button-icon\"\n aria-hidden=\"false\">\n {{ resolvedCaseButtonIcon }}\n </mat-icon>\n <span *ngIf=\"(loading$ | async) === false\">{{ resolvedCaseButtonTitle }}</span>\n </button>\n</ng-template>\n", styles: [".button-icon{padding-right:4px;padding-bottom:2px}.height-44{height:44px}.create-case-mat-mini-fab{border-radius:6px;box-shadow:none;height:44px!important;min-width:44px;margin-right:8px;margin-top:2px}@keyframes spinner{to{transform:rotate(360deg)}}.spinner:before{content:\"\";box-sizing:border-box;position:absolute;top:50%;left:50%;width:20px;height:20px;margin-top:-10px;margin-left:-10px;border-radius:50%;border:2px solid #ffffff;border-top-color:#000;animation:spinner .8s linear infinite}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i4.MatMiniFabButton, selector: "button[mat-mini-fab]", exportAs: ["matButton"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreateCaseButtonComponent, decorators: [{ type: Component, args: [{ selector: 'nc-create-case-button', template: "<!-- Button without title -->\n<button *ngIf=\"(!resolvedCaseButtonTitle && (shouldShowCreateButton() | async)); else titleButton\"\n class=\"create-case-mat-mini-fab\"\n mat-mini-fab color=\"primary\" (click)=\"createNewCase()\"\n [class.spinner]=\"loading$ | async\" [disabled]=\"(loading$ | async) || disabled\">\n <mat-icon *ngIf=\"(loading$ | async) === false\" class=\"net-upload\" aria-hidden=\"false\">\n {{ !!resolvedCaseButtonIcon ? resolvedCaseButtonIcon : 'add' }}\n </mat-icon>\n</button>\n\n<!-- Button with title -->\n<ng-template #titleButton>\n <button *ngIf=\"shouldShowCreateButton() | async\" mat-flat-button class=\"height-44\" color=\"primary\"\n (click)=\"createNewCase()\" [class.spinner]=\"loading$ | async\"\n [disabled]=\"(loading$ | async) || disabled\">\n <mat-icon *ngIf=\"!!resolvedCaseButtonIcon && (loading$ | async) === false\" class=\"button-icon\"\n aria-hidden=\"false\">\n {{ resolvedCaseButtonIcon }}\n </mat-icon>\n <span *ngIf=\"(loading$ | async) === false\">{{ resolvedCaseButtonTitle }}</span>\n </button>\n</ng-template>\n", styles: [".button-icon{padding-right:4px;padding-bottom:2px}.height-44{height:44px}.create-case-mat-mini-fab{border-radius:6px;box-shadow:none;height:44px!important;min-width:44px;margin-right:8px;margin-top:2px}@keyframes spinner{to{transform:rotate(360deg)}}.spinner:before{content:\"\";box-sizing:border-box;position:absolute;top:50%;left:50%;width:20px;height:20px;margin-top:-10px;margin-left:-10px;border-radius:50%;border:2px solid #ffffff;border-top-color:#000;animation:spinner .8s linear infinite}\n"] }] }], ctorParameters: () => [{ type: i1.CaseViewService }, { type: i2.TranslateService }], propDecorators: { caseCreatedEvent: [{ type: Output }], newCaseCreationConfig: [{ type: Input }], disabled: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-case-button.component.js","sourceRoot":"","sources":["../../../../../../../../projects/netgrif-components/src/lib/view/case-view/components/create-case-button/create-case-button.component.ts","../../../../../../../../projects/netgrif-components/src/lib/view/case-view/components/create-case-button/create-case-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnInit, Output} from '@angular/core';\nimport {Observable} from 'rxjs';\nimport {\n    Case,\n    CaseViewService,\n    NewCaseCreationConfigurationData,\n    NewCaseButtonConfiguration,\n    LoadingEmitter\n} from '@netgrif/components-core';\nimport {map} from \"rxjs/operators\";\nimport {TranslateService} from '@ngx-translate/core';\n\n@Component({\n    selector: 'nc-create-case-button',\n    templateUrl: './create-case-button.component.html',\n    styleUrls: ['./create-case-button.component.scss']\n})\nexport class CreateCaseButtonComponent implements OnInit {\n\n    @Output() public caseCreatedEvent = new EventEmitter<Case>();\n    @Input() public newCaseCreationConfig: NewCaseCreationConfigurationData;\n    @Input() public disabled: boolean;\n\n    protected _resolvedCaseButtonTitle: string;\n    protected _resolvedCaseButtonIcon: string;\n    protected _loading: LoadingEmitter;\n\n    constructor(protected _caseViewService: CaseViewService,\n                protected _translateService: TranslateService) {\n        this._loading = new LoadingEmitter();\n    }\n\n    get resolvedCaseButtonTitle(): string {\n        return this._resolvedCaseButtonTitle;\n    }\n\n    get resolvedCaseButtonIcon(): string {\n        return this._resolvedCaseButtonIcon;\n    }\n\n    get loading$(): Observable<boolean> {\n        return this._loading;\n    }\n\n    ngOnInit(): void {\n        const config: NewCaseButtonConfiguration = this.newCaseCreationConfig['newCaseButtonConfig'];\n        if (!!config) {\n            this._resolvedCaseButtonIcon = config.createCaseButtonIcon;\n            this._resolvedCaseButtonTitle = this.resolveTranslation(config);\n        }\n    }\n\n    public resolveTranslation(config: NewCaseButtonConfiguration): string {\n        const locale = this._translateService.currentLang;\n        if(!config.createCaseButtonTitle.defaultValue && !config.createCaseButtonTitle.translations) {\n            return \"\";\n        }\n        return locale in config.createCaseButtonTitle.translations\n            ? config.createCaseButtonTitle.translations[locale]\n            : config.createCaseButtonTitle.defaultValue;\n    }\n\n    public shouldShowCreateButton(): Observable<boolean> {\n        const blockNets = this.newCaseCreationConfig?.blockNets || [];\n        return this._caseViewService.getNewCaseAllowedNets(blockNets).pipe(\n            map(allowedNets => allowedNets.length > 0)\n        );\n    }\n\n    public createNewCase(): Observable<Case> {\n        let myCase: Observable<Case>;\n        this._loading.on();\n        if (this.newCaseCreationConfig.enableCaseTitle === false && this._caseViewService.getAllowedNetsCount() === 1) {\n            myCase = this._caseViewService.createDefaultNewCase(this.newCaseCreationConfig);\n        } else {\n            myCase = this._caseViewService.createNewCase(this.newCaseCreationConfig);\n        }\n        myCase.subscribe(kaze => {\n            if (this._caseViewService.viewEnabled(kaze)) {\n                this.caseCreatedEvent.next(kaze);\n            }\n        }, error => {\n        }, () => this._loading.off());\n\n        return myCase;\n    }\n\n}\n","<!-- Button without title -->\n<button *ngIf=\"(!resolvedCaseButtonTitle && (shouldShowCreateButton() | async)); else titleButton\"\n        class=\"create-case-mat-mini-fab\"\n        mat-mini-fab color=\"primary\" (click)=\"createNewCase()\"\n        [class.spinner]=\"loading$ | async\" [disabled]=\"(loading$ | async) || disabled\">\n    <mat-icon *ngIf=\"(loading$ | async) === false\" class=\"net-upload\" aria-hidden=\"false\">\n        {{ !!resolvedCaseButtonIcon ? resolvedCaseButtonIcon : 'add' }}\n    </mat-icon>\n</button>\n\n<!-- Button with title -->\n<ng-template #titleButton>\n    <button *ngIf=\"shouldShowCreateButton() | async\" mat-flat-button class=\"height-44\" color=\"primary\"\n            (click)=\"createNewCase()\" [class.spinner]=\"loading$ | async\"\n            [disabled]=\"(loading$ | async) || disabled\">\n        <mat-icon *ngIf=\"!!resolvedCaseButtonIcon && (loading$ | async) === false\" class=\"button-icon\"\n                  aria-hidden=\"false\">\n            {{ resolvedCaseButtonIcon }}\n        </mat-icon>\n        <span *ngIf=\"(loading$ | async) === false\">{{ resolvedCaseButtonTitle }}</span>\n    </button>\n</ng-template>\n"]}