@harbor/ui
Version:
Harbor shared UI components based on Clarity and Angular6
136 lines (135 loc) • 15.1 kB
JavaScript
/**
* @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"]}