UNPKG

@harbor/ui

Version:

Harbor shared UI components based on Clarity and Angular6

136 lines (135 loc) 15.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, EventEmitter, Output } from '@angular/core'; import { TranslateService } from '@ngx-translate/core'; import { ConfirmationAcknowledgement } from './confirmation-state-message'; export class ConfirmationDialogComponent { /** * @param {?} translate */ constructor(translate) { this.translate = translate; this.opened = false; this.dialogTitle = ''; this.dialogContent = ''; this.confirmAction = new EventEmitter(); this.cancelAction = new EventEmitter(); this.isDelete = false; } /** * @param {?} msg * @return {?} */ open(msg) { this.dialogTitle = msg.title; this.message = msg; this.translate.get(this.dialogTitle).subscribe((res) => this.dialogTitle = res); this.translate.get(msg.message, { 'param': msg.param }).subscribe((res) => { this.dialogContent = res; }); // Open dialog this.buttons = msg.buttons; this.opened = true; } /** * @param {?} list * @return {?} */ colorChange(list) { if (!list.loading && !list.errorState) { return 'green'; } else if (!list.loading && list.errorState) { return 'red'; } else { return '#666'; } } /** * @param {?} errorSpan * @return {?} */ toggleErrorTitle(errorSpan) { errorSpan.style.display = (errorSpan.style.display === 'none') ? 'block' : 'none'; } /** * @return {?} */ close() { this.opened = false; } /** * @return {?} */ cancel() { if (!this.message) { // Inproper condition this.close(); return; } /** @type {?} */ let data = this.message.data ? this.message.data : {}; /** @type {?} */ let target = this.message.targetId ? this.message.targetId : 0 /* EMPTY */; this.cancelAction.emit(new ConfirmationAcknowledgement(2 /* CANCEL */, data, target)); this.isDelete = false; this.close(); } /** * @return {?} */ confirm() { if (!this.message) { // Inproper condition // Inproper condition this.close(); return; } /** @type {?} */ let data = this.message.data ? this.message.data : {}; /** @type {?} */ let target = this.message.targetId ? this.message.targetId : 0 /* EMPTY */; /** @type {?} */ let message = new ConfirmationAcknowledgement(1 /* CONFIRMED */, data, target); this.confirmAction.emit(message); this.close(); } } ConfirmationDialogComponent.decorators = [ { type: Component, args: [{ selector: 'confirmation-dialog', template: "<clr-modal [(clrModalOpen)]=\"opened\" [clrModalClosable]=\"false\" [clrModalStaticBackdrop]=\"true\">\n <h3 class=\"modal-title\" class=\"confirmation-title\" style=\"margin-top: 0px;\">{{dialogTitle}}</h3>\n <div class=\"modal-body\">\n <div class=\"confirmation-icon-inline\">\n <clr-icon shape=\"warning\" class=\"is-warning\" size=\"64\"></clr-icon>\n </div>\n <div class=\"confirmation-content\">{{dialogContent}}</div>\n </div>\n <div class=\"modal-footer\" [ngSwitch]=\"buttons\">\n <ng-template [ngSwitchCase]=\"0\">\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancel()\">{{'BUTTON.CANCEL' | translate}}</button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"confirm()\">{{'BUTTON.CONFIRM' | translate}}</button>\n </ng-template>\n <ng-template [ngSwitchCase]=\"1\">\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancel()\">{{'BUTTON.NO' | translate}}</button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"confirm()\">{{ 'BUTTON.YES' | translate}}</button>\n </ng-template>\n <ng-template [ngSwitchCase]=\"2\">\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancel()\" [hidden]=\"isDelete\">{{'BUTTON.CANCEL' | translate}}</button>\n <button type=\"button\" class=\"btn btn-danger\" (click)=\"confirm()\" [hidden]=\"isDelete\">{{'BUTTON.DELETE' | translate}}</button>\n </ng-template>\n <ng-template [ngSwitchCase]=\"3\">\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"cancel()\">{{'BUTTON.CLOSE' | translate}}</button>\n </ng-template>\n <ng-template [ngSwitchCase]=\"4\">\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"cancel()\" [hidden]=\"isDelete\">{{'BUTTON.CANCEL' | translate}}</button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"confirm()\" [hidden]=\"isDelete\">{{'BUTTON.REPLICATE' | translate}}</button>\n </ng-template>\n </div>\n</clr-modal>", styles: [".confirmation-icon-inline{display:inline-block}.confirmation-title{line-height:24px;color:#000;font-size:22px}.confirmation-content{font-size:14px;color:#565656;line-height:24px;display:inline-block;vertical-align:middle;width:80%;white-space:pre-wrap}.batchInfoUl{padding:20px;list-style-type:none}.batchInfoUl li{line-height:24px;border-bottom:1px solid #e8e8e8}.batchInfoUl li span:first-child{padding-right:20px;width:240px;display:inline-block;color:#666;text-overflow:ellipsis;overflow:hidden;vertical-align:middle}.batchInfoUl li span:last-child{width:220px;display:inline-block;color:#666}.batchInfoUl li span i{display:inline-block;line-height:1.2em;font-size:.8em;color:#999}.batchInfoUl li span a{cursor:pointer;text-decoration:underline}"] }] } ]; /** @nocollapse */ ConfirmationDialogComponent.ctorParameters = () => [ { type: TranslateService } ]; ConfirmationDialogComponent.propDecorators = { confirmAction: [{ type: Output }], cancelAction: [{ type: Output }] }; if (false) { /** @type {?} */ ConfirmationDialogComponent.prototype.opened; /** @type {?} */ ConfirmationDialogComponent.prototype.dialogTitle; /** @type {?} */ ConfirmationDialogComponent.prototype.dialogContent; /** @type {?} */ ConfirmationDialogComponent.prototype.message; /** @type {?} */ ConfirmationDialogComponent.prototype.buttons; /** @type {?} */ ConfirmationDialogComponent.prototype.confirmAction; /** @type {?} */ ConfirmationDialogComponent.prototype.cancelAction; /** @type {?} */ ConfirmationDialogComponent.prototype.isDelete; /** @type {?} */ ConfirmationDialogComponent.prototype.translate; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirmation-dialog.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/confirmation-dialog/confirmation-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) 2017 VMware, Inc. All Rights Reserved.\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//    http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\nimport {Component, EventEmitter, Output} from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\n\nimport { ConfirmationMessage } from './confirmation-message';\nimport { ConfirmationAcknowledgement } from './confirmation-state-message';\nimport { ConfirmationState, ConfirmationTargets, ConfirmationButtons } from '../shared/shared.const';\n\nimport {BatchInfo} from './confirmation-batch-message';\n\n@Component({\n    selector: 'confirmation-dialog',\n    templateUrl: './confirmation-dialog.component.html',\n    styleUrls: [ './confirmation-dialog.component.scss' ]\n})\n\nexport class ConfirmationDialogComponent {\n    opened = false;\n    dialogTitle = '';\n    dialogContent = '';\n    message: ConfirmationMessage;\n    buttons: ConfirmationButtons;\n\n    @Output() confirmAction = new EventEmitter<ConfirmationAcknowledgement>();\n    @Output() cancelAction = new EventEmitter<ConfirmationAcknowledgement>();\n    isDelete = false;\n\n    constructor(\n        private translate: TranslateService) {}\n\n    open(msg: ConfirmationMessage): void {\n        this.dialogTitle = msg.title;\n        this.message = msg;\n        this.translate.get(this.dialogTitle).subscribe((res: string) => this.dialogTitle = res);\n        this.translate.get(msg.message, { 'param': msg.param }).subscribe((res: string) => {\n            this.dialogContent = res;\n        });\n        // Open dialog\n        this.buttons = msg.buttons;\n        this.opened = true;\n    }\n\n\n    colorChange(list: BatchInfo) {\n        if (!list.loading && !list.errorState) {\n            return 'green';\n        } else if (!list.loading && list.errorState) {\n            return 'red';\n        } else {\n            return '#666';\n        }\n    }\n\n    toggleErrorTitle(errorSpan: any) {\n        errorSpan.style.display = (errorSpan.style.display === 'none') ? 'block' : 'none';\n    }\n\n    close(): void {\n        this.opened = false;\n    }\n\n    cancel(): void {\n        if (!this.message) {\n            // Inproper condition\n            this.close();\n            return;\n        }\n\n        let data: any = this.message.data ? this.message.data : {};\n        let target = this.message.targetId ? this.message.targetId : ConfirmationTargets.EMPTY;\n        this.cancelAction.emit(new ConfirmationAcknowledgement(\n            ConfirmationState.CANCEL,\n            data,\n            target\n        ));\n        this.isDelete = false;\n        this.close();\n    }\n\n    confirm(): void {\n        if (!this.message) {// Inproper condition\n            this.close();\n            return;\n        }\n\n        let data: any = this.message.data ? this.message.data : {};\n        let target = this.message.targetId ? this.message.targetId : ConfirmationTargets.EMPTY;\n        let message = new ConfirmationAcknowledgement(\n            ConfirmationState.CONFIRMED,\n            data,\n            target\n        );\n        this.confirmAction.emit(message);\n        this.close();\n    }\n}\n"]}