@stratio/egeo
Version:
184 lines • 15.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-alerts/alert-box/st-alert-box.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/*
* © 2017 Stratio Big Data Inc., Sucursal en España.
*
* This software is licensed under the Apache License, Version 2.0.
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the terms of the License for more details.
*
* SPDX-License-Identifier: Apache-2.0.
*/
import { Component, Input, ChangeDetectorRef, ChangeDetectionStrategy, Output, EventEmitter } from '@angular/core';
import { STALERT_SEVERITY, StAlert } from '../st-alerts.model';
/**
* @description {Component} [Alert Box]
*
* Alert box is made to let the user know errors or information about he is trying to do.
*
* @example
*
* {html}
*
* ```
* <st-alert-box [alert]="alert" [showInConsole]="showInConsole"></st-alert-box>
*
* ```
*/
export class StAlertBoxComponent {
/**
* @param {?} _cd
*/
constructor(_cd) {
this._cd = _cd;
/**
* \@Input {boolean} [showInConsole=false] Display logs in console
*/
this.showInConsole = false;
/**
* \@Output {StAlertLink} [clickLink=] Event emitted when link is clicked
*/
this.clickLink = new EventEmitter();
/**
* \@Output {boolean} [close=] Event emitted when alert is closed
*/
this.close = new EventEmitter();
this.opacity = 0;
}
/**
* @return {?}
*/
ngOnInit() {
this.alert.opacity.subscribe((/**
* @param {?} opacity
* @return {?}
*/
opacity => this.changeOpacity(opacity)));
this.alert.notify();
if (this.showInConsole) {
this.notifyConsole();
}
this.severityColorValue = this.getSeverityColor();
this.iconValue = this.getIcon();
}
/**
* @return {?}
*/
closeAlert() {
this.alert.cancel();
this.close.emit(true);
}
/**
* @return {?}
*/
getIcon() {
switch (this.alert.severity) {
case STALERT_SEVERITY.ERROR: return 'icon-circle-alert';
case STALERT_SEVERITY.WARNING: return 'icon-alert';
case STALERT_SEVERITY.SUCCESS: return 'icon-circle-check';
case STALERT_SEVERITY.INFO: return 'icon-info';
default: return '';
}
}
/**
* @return {?}
*/
getSeverityColor() {
switch (this.alert.severity) {
case STALERT_SEVERITY.ERROR: return 'sth-alert-box-error';
case STALERT_SEVERITY.WARNING: return 'sth-alert-box-warning';
case STALERT_SEVERITY.SUCCESS: return 'sth-alert-box-success';
case STALERT_SEVERITY.INFO: return 'sth-alert-box-info';
default: return '';
}
}
/**
* @return {?}
*/
goTo() {
this.clickLink.emit(this.alert.link);
}
/**
* @param {?} opacity
* @return {?}
*/
changeOpacity(opacity) {
this.opacity = opacity;
this._cd.markForCheck();
}
/**
* @private
* @return {?}
*/
notifyConsole() {
switch (this.alert.severity) {
case STALERT_SEVERITY.ERROR:
console.error(`ERROR-${this.alert.title}: ${this.alert.message}`);
break;
case STALERT_SEVERITY.WARNING:
console.warn(`WARNING-${this.alert.title}: ${this.alert.message}`);
break;
case STALERT_SEVERITY.SUCCESS:
console.log(`SUCCESS-${this.alert.title}: ${this.alert.message}`);
break;
default:
console.error(`ERROR: severity not found for ${this.alert.title}: ${this.alert.message}`);
break;
}
}
}
StAlertBoxComponent.decorators = [
{ type: Component, args: [{
selector: 'st-alert-box',
template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<div class=\"sth-alert-box\" [ngClass]=\"severityColorValue\" [ngStyle]=\"{opacity: opacity}\">\n <div class=\"sth-alert-box-content\">\n <div class=\"sth-alert-box-close-button\">\n <i (click)=\"closeAlert()\" class=\"icon-cross\"></i>\n </div>\n <header class=\"sth-alert-box-header\">\n <i class=\"status-icon\" [ngClass]=\"iconValue\"></i>\n <span>{{alert.title}}</span>\n </header>\n <div class=\"sth-alert-box-body\">\n <p>{{alert.message}}</p>\n </div>\n </div>\n <footer *ngIf=\"alert.link\" class=\"sth-alert-box-footer\">\n <a (click)=\"goTo()\">{{alert.link.title}}</a>\n </footer>\n</div>\n",
changeDetection: ChangeDetectionStrategy.OnPush
}] }
];
/** @nocollapse */
StAlertBoxComponent.ctorParameters = () => [
{ type: ChangeDetectorRef }
];
StAlertBoxComponent.propDecorators = {
alert: [{ type: Input }],
showInConsole: [{ type: Input }],
clickLink: [{ type: Output }],
close: [{ type: Output }]
};
if (false) {
/**
* \@Input {StAlert} [alert=] Data of the alert
* @type {?}
*/
StAlertBoxComponent.prototype.alert;
/**
* \@Input {boolean} [showInConsole=false] Display logs in console
* @type {?}
*/
StAlertBoxComponent.prototype.showInConsole;
/**
* \@Output {StAlertLink} [clickLink=] Event emitted when link is clicked
* @type {?}
*/
StAlertBoxComponent.prototype.clickLink;
/**
* \@Output {boolean} [close=] Event emitted when alert is closed
* @type {?}
*/
StAlertBoxComponent.prototype.close;
/** @type {?} */
StAlertBoxComponent.prototype.iconValue;
/** @type {?} */
StAlertBoxComponent.prototype.opacity;
/** @type {?} */
StAlertBoxComponent.prototype.severityColorValue;
/**
* @type {?}
* @private
*/
StAlertBoxComponent.prototype._cd;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-alert-box.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-alerts/alert-box/st-alert-box.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport {\n   Component,\n   Input,\n   OnInit,\n   ChangeDetectorRef,\n   ChangeDetectionStrategy, Output, EventEmitter\n} from '@angular/core';\n\nimport { STALERT_SEVERITY, StAlert, StAlertLink } from '../st-alerts.model';\n\n@Component({\n   selector: 'st-alert-box',\n   templateUrl: './st-alert-box.component.html',\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\n/**\n * @description {Component} [Alert Box]\n *\n * Alert box is made to let the user know errors or information about he is trying to do.\n *\n * @example\n *\n * {html}\n *\n * ```\n * <st-alert-box [alert]=\"alert\" [showInConsole]=\"showInConsole\"></st-alert-box>\n *\n * ```\n */\nexport class StAlertBoxComponent implements OnInit {\n   /** @Input {StAlert} [alert=] Data of the alert */\n   @Input() alert: StAlert;\n   /** @Input {boolean} [showInConsole=false] Display logs in console */\n   @Input() showInConsole: boolean = false;\n   /** @Output {StAlertLink} [clickLink=] Event emitted when link is clicked */\n   @Output() clickLink: EventEmitter<StAlertLink> = new EventEmitter();\n   /** @Output {boolean} [close=] Event emitted when alert is closed */\n   @Output() close: EventEmitter<boolean> = new EventEmitter();\n\n   public iconValue: string;\n   public opacity: number = 0;\n   public severityColorValue: string;\n\n   constructor(private _cd: ChangeDetectorRef) {\n   }\n\n   ngOnInit(): void {\n      this.alert.opacity.subscribe(opacity => this.changeOpacity(opacity));\n      this.alert.notify();\n      if (this.showInConsole) {\n         this.notifyConsole();\n      }\n      this.severityColorValue = this.getSeverityColor();\n      this.iconValue = this.getIcon();\n   }\n\n   closeAlert(): void {\n      this.alert.cancel();\n      this.close.emit(true);\n   }\n\n   getIcon(): string {\n      switch (this.alert.severity) {\n         case STALERT_SEVERITY.ERROR: return 'icon-circle-alert';\n         case STALERT_SEVERITY.WARNING: return 'icon-alert';\n         case STALERT_SEVERITY.SUCCESS: return 'icon-circle-check';\n         case STALERT_SEVERITY.INFO: return 'icon-info';\n         default: return '';\n      }\n   }\n\n   getSeverityColor(): string {\n      switch (this.alert.severity) {\n         case STALERT_SEVERITY.ERROR: return 'sth-alert-box-error';\n         case STALERT_SEVERITY.WARNING: return 'sth-alert-box-warning';\n         case STALERT_SEVERITY.SUCCESS: return 'sth-alert-box-success';\n         case STALERT_SEVERITY.INFO: return 'sth-alert-box-info';\n         default: return '';\n      }\n   }\n\n   goTo(): void {\n      this.clickLink.emit(this.alert.link);\n   }\n\n   changeOpacity(opacity: number): void {\n      this.opacity = opacity;\n      this._cd.markForCheck();\n   }\n\n   private notifyConsole(): void {\n      switch (this.alert.severity) {\n         case STALERT_SEVERITY.ERROR: console.error(`ERROR-${this.alert.title}: ${this.alert.message}`); break;\n         case STALERT_SEVERITY.WARNING: console.warn(`WARNING-${this.alert.title}: ${this.alert.message}`); break;\n         case STALERT_SEVERITY.SUCCESS: console.log(`SUCCESS-${this.alert.title}: ${this.alert.message}`); break;\n         default: console.error(`ERROR: severity not found for ${this.alert.title}: ${this.alert.message}`); break;\n      }\n   }\n}\n"]}