@stratio/egeo
Version:
376 lines • 36.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-foreground-notifications/st-foreground-notifications.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 { ChangeDetectorRef, Component, Input, EventEmitter, Output, ElementRef, Renderer2, ChangeDetectionStrategy } from '@angular/core';
import { StatusNotification } from './st-foreground-notifications.model';
/**
* @description {Component} [Foreground notifications]
*
* Foreground notifications are made to let the user know info about a process she is performing in real time.
*
* @example
*
* {html}
*
* ```
* <st-foreground-notifications [notifications]="notifications" [(visible)]="true" [autoCloseTime]="1000"></st-foreground-notifications>
*
* ```
*/
export class StForegroundNotificationsComponent {
/**
* @param {?} cd
* @param {?} elemRef
* @param {?} renderer
*/
constructor(cd, elemRef, renderer) {
this.cd = cd;
this.elemRef = elemRef;
this.renderer = renderer;
/**
* \@Input {StNotificationElement []} [notifications='[]'] Array of notifications
*/
this.notifications = [];
/**
* \@output {clickLinkTemplate} [click] Event emitted when user click in a href link
*/
this.clickLinkTemplate = new EventEmitter();
/**
* \@output {visibleChange} [click] Event emitted when set param visible
*/
this.visibleChange = new EventEmitter();
this.currentNotification = 1;
this.showLinkMore = false;
this.status = 'default';
this._visible = false;
this.listStatusNotifications = [];
}
/**
* \@Input {bollean} [visible=flase] When true the notification is shown
* @param {?} value
* @return {?}
*/
set visible(value) {
if (value !== undefined) {
this._visible = value;
this.visibleChange.emit(this._visible);
}
this.cd.markForCheck();
}
/**
* @return {?}
*/
get visible() {
return this._visible;
}
/**
* @return {?}
*/
ngOnInit() {
if (this.autoCloseTime) {
if (this.notifications.length === 1 && this.notifications[0].status === 'success') {
setTimeout((/**
* @return {?}
*/
() => this.onClose()), this.autoCloseTime);
}
}
this.fillStatusNotifications();
}
/**
* @return {?}
*/
ngAfterViewInit() {
/** @type {?} */
let htmlElement = this.elemRef.nativeElement.querySelector('.foreground-notification__html');
if (htmlElement !== null) {
this.addStyleLinks(htmlElement);
}
if (this.notifications && this.notifications.length > 0) {
this.checkOneLine();
}
this.cd.detectChanges();
}
/**
* @return {?}
*/
ngOnChanges() {
if (this.notifications && this.notifications.length < this.currentNotification) {
this.currentNotification = this.notifications.length;
}
this.listStatusNotifications = [];
this.fillStatusNotifications();
}
/**
* @param {?} htmlElement
* @return {?}
*/
addStyleLinks(htmlElement) {
/** @type {?} */
let links = htmlElement.querySelectorAll('a');
if (links.constructor !== Array) {
links = ((/** @type {?} */ (Object))).values(links);
}
links.forEach((/**
* @param {?} element
* @param {?} index
* @return {?}
*/
(element, index) => {
/** @type {?} */
let nameEventEmitter = (this.notifications[this.getIndexCurrentNotification()]).nameEvents[index];
if (nameEventEmitter) {
element.addEventListener('click', this.onClickLinkHtmlTemplate.bind(this, nameEventEmitter));
this.renderer.setStyle(element, 'text-decoration', 'underline');
this.renderer.setStyle(element, 'cursor', 'pointer');
}
}));
}
/**
* @return {?}
*/
checkOneLine() {
/** @type {?} */
let element = this.elemRef.nativeElement.querySelectorAll('.foreground-notification__content');
/** @type {?} */
let currentIndex = this.getIndexCurrentNotification();
if (this.listStatusNotifications && this.listStatusNotifications.length > 0) {
if (element[currentIndex].offsetHeight > 40) {
this.listStatusNotifications[currentIndex].showMore = !this.listStatusNotifications[currentIndex].completeText;
if (this.listStatusNotifications[currentIndex].showMore) {
this.listStatusNotifications[currentIndex].completeText = false;
this.renderer.addClass(element[currentIndex], 'limit-one-line');
}
}
else {
this.listStatusNotifications[currentIndex].completeText = true;
if (!this.listStatusNotifications[currentIndex].showMore) {
this.removeStyleNotification();
}
}
}
this.checkStatus();
}
/**
* @return {?}
*/
checkStatus() {
this.statusValue = this.getStatus();
this.statusIconValue = this.getStatusIcon();
this.statusNotificationsValue = this.getStatusNotifications();
this.cd.detectChanges();
}
/**
* @return {?}
*/
decrementPage() {
this.currentNotification = this.getIndexCurrentNotification();
setTimeout((/**
* @return {?}
*/
() => {
this.checkOneLine();
this.cd.detectChanges();
}));
this.status = this.notifications[this.getIndexCurrentNotification()].status;
}
/**
* @return {?}
*/
fillStatusNotifications() {
if (this.notifications && this.notifications.length > 0) {
this.status = this.notifications[this.getIndexCurrentNotification()].status;
this.checkStatus();
}
this.notifications.forEach((/**
* @return {?}
*/
() => {
this.listStatusNotifications.push(new StatusNotification(false, false));
}));
}
/**
* @return {?}
*/
getIndexCurrentNotification() {
return this.currentNotification - 1;
}
/**
* @return {?}
*/
getStatus() {
switch (this.status) {
case 'success':
case 'warning':
case 'critical':
case 'running':
return this.status;
default:
return 'default';
}
}
/**
* @return {?}
*/
getStatusIcon() {
switch (this.status) {
case 'success':
return 'icon-circle-check';
case 'warning':
return 'icon-alert';
case 'critical':
return 'icon-info1';
case 'running':
return 'icon-info1';
default:
return 'default';
}
}
/**
* @return {?}
*/
getStatusNotifications() {
return (this.notifications.length > 1) ? 'more-lines' : '';
}
/**
* @return {?}
*/
incrementPage() {
this.currentNotification = this.currentNotification + 1;
setTimeout((/**
* @return {?}
*/
() => {
this.checkOneLine();
this.cd.detectChanges();
}));
this.status = this.notifications[this.getIndexCurrentNotification()].status;
}
/**
* @param {?} event
* @return {?}
*/
onClickLinkHtmlTemplate(event) {
this.clickLinkTemplate.emit(event);
}
/**
* @return {?}
*/
onClose() {
this.visible = false;
this.cd.markForCheck();
}
/**
* @return {?}
*/
removeStyleNotification() {
/** @type {?} */
let element = this.elemRef.nativeElement.querySelectorAll('.foreground-notification__content');
this.renderer.removeClass(element[this.getIndexCurrentNotification()], 'limit-one-line');
this.cd.markForCheck();
}
/**
* @return {?}
*/
showTextComplete() {
/** @type {?} */
let currentIndex = this.getIndexCurrentNotification();
if (this.listStatusNotifications && this.listStatusNotifications.length > 0) {
this.listStatusNotifications[currentIndex].showMore = false;
this.listStatusNotifications[currentIndex].completeText = true;
}
this.removeStyleNotification();
this.cd.markForCheck();
}
}
StForegroundNotificationsComponent.decorators = [
{ type: Component, args: [{
selector: 'st-foreground-notifications',
template: "<!--\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\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 SPDX-License-Identifier: Apache-2.0.\n-->\n<div class=\"foreground-notification__component\">\n <div class=\"foreground-notification__pagination\" [ngClass]=\"statusValue\" *ngIf=\"notifications.length > 1\">\n <button class=\"decrement-notification\" [disabled]=\"currentNotification === 1\" (click)=\"decrementPage()\"><i class=\"icon-arrow2_left\"></i></button>\n <span>{{currentNotification}}</span>\n <span>of</span>\n <span>{{notifications.length}}</span>\n <button class=\"increment-notification\" [disabled]=\"currentNotification === notifications.length \" (click)=\"incrementPage()\"><i class=\"icon-arrow2_right\"></i></button>\n </div>\n\n <div *ngIf=\"notifications.length > 0\" class=\"foreground-notification\" [ngClass]=\"[statusValue, statusNotificationsValue]\">\n <div class=\"foreground-notification__container\">\n <i class=\"status\" [ngClass]=\"statusIconValue\"></i>\n <div class=\"foreground-notification__content\" *ngFor=\"let notification of notifications; let index=index\">\n <span class=\"foreground-notification__html\" *ngIf=\"notification.html && index === currentNotification - 1\" [innerHtml]=\"notifications[currentNotification - 1].html\"></span>\n <span *ngIf=\"!notification.html && index === getIndexCurrentNotification()\">\n {{notifications[getIndexCurrentNotification()].text}}\n </span>\n <a class=\"link-more\" *ngIf=\"listStatusNotifications[index] && listStatusNotifications[index].showMore && index === currentNotification - 1\" (click)=\"showTextComplete()\">...More</a>\n </div>\n </div>\n\n <i class=\"close icon-cross\" (click)=\"onClose()\"></i>\n </div>\n</div>\n",
host: {
'[class.visible]': '_visible'
},
changeDetection: ChangeDetectionStrategy.OnPush,
styles: ["@charset \"UTF-8\";:host{display:flex;flex-direction:column;opacity:0;padding-left:15px;padding-right:15px;padding-top:4px;pointer-events:none;transition-duration:1s;transition-property:opacity}:host .foreground-notification{display:flex;font-size:14px;padding:8px 15px;position:relative;text-align:justify;width:auto;align-items:center}:host .foreground-notification .close{cursor:pointer;font-size:18px;flex-direction:row-reverse;margin-left:auto;right:11px;top:11px}:host .foreground-notification .link-more{cursor:pointer;padding-left:10px;padding-right:60px;text-decoration:underline}:host .foreground-notification.critical,:host .foreground-notification.running,:host .foreground-notification.success,:host .foreground-notification.warning{border-radius:4px}:host .foreground-notification.more-lines{border-top-left-radius:0;border-bottom-left-radius:0}:host .foreground-notification__component{display:flex;flex-direction:row;justify-content:center;min-height:40px}:host .foreground-notification__pagination{align-items:center;border-top-left-radius:4px;border-bottom-left-radius:4px;color:#fff;display:flex;font-size:1rem;height:40px;padding:5px}:host .foreground-notification__pagination.critical{background-color:#b2212a}:host .foreground-notification__pagination.success{background-color:#0a885a}:host .foreground-notification__pagination.warning{background-color:#ec7e13}:host .foreground-notification__pagination.running{background-color:#065eb2}:host .foreground-notification__pagination.default{border:0;color:#111;box-shadow:0 1px 4px 1px rgba(124,124,124,.15)}:host .foreground-notification__pagination span:nth-child(2){margin-left:5px}:host .foreground-notification__pagination span:nth-child(3){margin-left:5px;margin-right:5px}:host .foreground-notification__pagination span:nth-child(4){margin-right:5px}:host .foreground-notification__pagination i{cursor:pointer}:host .foreground-notification__container{align-items:flex-start;display:flex;justify-content:center;margin-right:60px;text-align:justify;width:100%}:host .foreground-notification__container i{font-size:18px;margin-right:10px}:host .foreground-notification__pagination.more-lines{margin:0;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}:host .foreground-notification__content{display:flex}:host .foreground-notification__content.limit-one-line span{display:-webkit-box;line-height:16px;max-height:16px;overflow:hidden;padding:4px 0;text-overflow:ellipsis;-webkit-line-clamp:1}:host.visible{opacity:1;pointer-events:all;transition-duration:1s;transition-property:opacity}"]
}] }
];
/** @nocollapse */
StForegroundNotificationsComponent.ctorParameters = () => [
{ type: ChangeDetectorRef },
{ type: ElementRef },
{ type: Renderer2 }
];
StForegroundNotificationsComponent.propDecorators = {
visible: [{ type: Input }],
autoCloseTime: [{ type: Input }],
notifications: [{ type: Input }],
clickLinkTemplate: [{ type: Output }],
visibleChange: [{ type: Output }]
};
if (false) {
/**
* \@Input {autoCloseTime} [autoCloseTime='1000'] Defines the time in milliseconds for autoclose the notification.
* The autoclose only applies if only have one notification and status is success
* @type {?}
*/
StForegroundNotificationsComponent.prototype.autoCloseTime;
/**
* \@Input {StNotificationElement []} [notifications='[]'] Array of notifications
* @type {?}
*/
StForegroundNotificationsComponent.prototype.notifications;
/**
* \@output {clickLinkTemplate} [click] Event emitted when user click in a href link
* @type {?}
*/
StForegroundNotificationsComponent.prototype.clickLinkTemplate;
/**
* \@output {visibleChange} [click] Event emitted when set param visible
* @type {?}
*/
StForegroundNotificationsComponent.prototype.visibleChange;
/** @type {?} */
StForegroundNotificationsComponent.prototype.currentNotification;
/** @type {?} */
StForegroundNotificationsComponent.prototype.statusIconValue;
/** @type {?} */
StForegroundNotificationsComponent.prototype.statusNotificationsValue;
/** @type {?} */
StForegroundNotificationsComponent.prototype.statusValue;
/** @type {?} */
StForegroundNotificationsComponent.prototype.showLinkMore;
/** @type {?} */
StForegroundNotificationsComponent.prototype.status;
/** @type {?} */
StForegroundNotificationsComponent.prototype._visible;
/** @type {?} */
StForegroundNotificationsComponent.prototype.listStatusNotifications;
/**
* @type {?}
* @private
*/
StForegroundNotificationsComponent.prototype.cd;
/**
* @type {?}
* @private
*/
StForegroundNotificationsComponent.prototype.elemRef;
/**
* @type {?}
* @private
*/
StForegroundNotificationsComponent.prototype.renderer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-foreground-notifications.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-foreground-notifications/st-foreground-notifications.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAUA,OAAO,EAAiB,iBAAiB,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,UAAU,EAAU,SAAS,EAClG,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,kBAAkB,EAAyB,MAAM,qCAAqC,CAAC;AAWhG;;;;;;;;;;;;;GAaG;AAGH,MAAM,OAAO,kCAAkC;;;;;;IAuC5C,YAAoB,EAAqB,EAAU,OAAmB,EAAU,QAAmB;QAA/E,OAAE,GAAF,EAAE,CAAmB;QAAU,YAAO,GAAP,OAAO,CAAY;QAAU,aAAQ,GAAR,QAAQ,CAAW;;;;QAlB1F,kBAAa,GAA6B,EAAE,CAAC;;;;QAG5C,sBAAiB,GAAsB,IAAI,YAAY,EAAE,CAAC;;;;QAG1D,kBAAa,GAA0B,IAAI,YAAY,EAAE,CAAC;QAE7D,wBAAmB,GAAW,CAAC,CAAC;QAIhC,iBAAY,GAAY,KAAK,CAAC;QAC9B,WAAM,GAAW,SAAS,CAAC;QAE3B,aAAQ,GAAY,KAAK,CAAC;QAC1B,4BAAuB,GAA8B,EAAE,CAAC;IAEwC,CAAC;;;;;;IApCxG,IACI,OAAO,CAAC,KAAc;QACvB,IAAI,KAAK,KAAK,SAAS,EAAE;YACtB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACzC;QACD,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;;;;IACD,IAAI,OAAO;QACR,OAAO,IAAI,CAAC,QAAQ,CAAC;IACxB,CAAC;;;;IA4BD,QAAQ;QACL,IAAI,IAAI,CAAC,aAAa,EAAE;YACrB,IAAK,IAAI,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,SAAS,EAAE;gBACjF,UAAU;;;gBAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,GAAE,IAAI,CAAC,aAAa,CAAC,CAAC;aACvD;SACH;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;IAClC,CAAC;;;;IAED,eAAe;;YACR,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,gCAAgC,CAAC;QAC5F,IAAI,WAAW,KAAK,IAAI,EAAE;YACvB,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;SAClC;QACD,IAAK,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACvD,IAAI,CAAC,YAAY,EAAE,CAAC;SACtB;QAED,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;;;;IAED,WAAW;QACR,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,mBAAmB,EAAE;YAC7E,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;SACvD;QACD,IAAI,CAAC,uBAAuB,GAAG,EAAE,CAAC;QAClC,IAAI,CAAC,uBAAuB,EAAE,CAAC;IAClC,CAAC;;;;;IAED,aAAa,CAAC,WAAgB;;YACvB,KAAK,GAAG,WAAW,CAAC,gBAAgB,CAAC,GAAG,CAAC;QAC7C,IAAI,KAAK,CAAC,WAAW,KAAK,KAAK,EAAE;YAC9B,KAAK,GAAG,CAAC,mBAAK,MAAM,EAAA,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SACtC;QACD,KAAK,CAAC,OAAO;;;;;QAAC,CAAC,OAAY,EAAE,KAAU,EAAE,EAAE;;gBACpC,gBAAgB,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,2BAA2B,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC;YACjG,IAAI,gBAAgB,EAAE;gBACnB,OAAO,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC,CAAC;gBAC7F,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,CAAC,CAAC;gBAChE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;aACvD;QACJ,CAAC,EAAC,CAAC;IACN,CAAC;;;;IAED,YAAY;;YACL,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,mCAAmC,CAAC;;YAC1F,YAAY,GAAG,IAAI,CAAC,2BAA2B,EAAE;QAErD,IAAI,IAAI,CAAC,uBAAuB,IAAI,IAAI,CAAC,uBAAuB,CAAC,MAAM,GAAG,CAAC,EAAE;YAC1E,IAAI,OAAO,CAAC,YAAY,CAAC,CAAC,YAAY,GAAG,EAAE,EAAE;gBAC1C,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC;gBAE/G,IAAI,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE;oBACtD,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,YAAY,GAAG,KAAK,CAAC;oBAChE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,gBAAgB,CAAC,CAAC;iBAClE;aACH;iBAAM;gBACJ,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC;gBAC/D,IAAI,CAAC,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,QAAQ,EAAE;oBACvD,IAAI,CAAC,uBAAuB,EAAE,CAAC;iBACjC;aACH;SACH;QACD,IAAI,CAAC,WAAW,EAAE,CAAC;IACtB,CAAC;;;;IAED,WAAW;QACR,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QACpC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QAC5C,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAE9D,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;;;;IAED,aAAa;QACV,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,2BAA2B,EAAE,CAAC;QAC9D,UAAU;;;QAAC,GAAG,EAAE;YACb,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,EAAC,CAAC;QACH,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,2BAA2B,EAAE,CAAC,CAAC,MAAM,CAAC;IAC/E,CAAC;;;;IAED,uBAAuB;QACpB,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACtD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,2BAA2B,EAAE,CAAC,CAAC,MAAM,CAAC;YAC5E,IAAI,CAAC,WAAW,EAAE,CAAC;SACrB;QAED,IAAI,CAAC,aAAa,CAAC,OAAO;;;QAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,kBAAkB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;QAC3E,CAAC,EAAC,CAAC;IACN,CAAC;;;;IAED,2BAA2B;QACxB,OAAO,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC;IACvC,CAAC;;;;IAED,SAAS;QACN,QAAQ,IAAI,CAAC,MAAM,EAAE;YAClB,KAAK,SAAS,CAAC;YACf,KAAK,SAAS,CAAC;YACf,KAAK,UAAU,CAAC;YAChB,KAAK,SAAS;gBACX,OAAO,IAAI,CAAC,MAAM,CAAC;YACtB;gBACG,OAAO,SAAS,CAAC;SACtB;IACJ,CAAC;;;;IAED,aAAa;QACV,QAAQ,IAAI,CAAC,MAAM,EAAE;YAClB,KAAK,SAAS;gBACX,OAAO,mBAAmB,CAAC;YAC9B,KAAK,SAAS;gBACX,OAAO,YAAY,CAAC;YACvB,KAAK,UAAU;gBACZ,OAAO,YAAY,CAAC;YACvB,KAAK,SAAS;gBACX,OAAO,YAAY,CAAC;YACvB;gBACG,OAAO,SAAS,CAAC;SACtB;IACJ,CAAC;;;;IAED,sBAAsB;QACnB,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;IAC9D,CAAC;;;;IAED,aAAa;QACV,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC;QACxD,UAAU;;;QAAC,GAAG,EAAE;YACb,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,EAAC,CAAC;QACH,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,2BAA2B,EAAE,CAAC,CAAC,MAAM,CAAC;IAC/E,CAAC;;;;;IAED,uBAAuB,CAAC,KAAa;QAClC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;;;;IAED,OAAO;QACJ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;;;;IAED,uBAAuB;;YAChB,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,mCAAmC,CAAC;QAC9F,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,2BAA2B,EAAE,CAAC,EAAE,gBAAgB,CAAC,CAAC;QACzF,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;;;;IAED,gBAAgB;;YACT,YAAY,GAAG,IAAI,CAAC,2BAA2B,EAAE;QACrD,IAAI,IAAI,CAAC,uBAAuB,IAAI,IAAI,CAAC,uBAAuB,CAAC,MAAM,GAAG,CAAC,EAAE;YAC1E,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC;YAC5D,IAAI,CAAC,uBAAuB,CAAC,YAAY,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC;SACjE;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;;;YAnOH,SAAS,SAAC;gBACR,QAAQ,EAAE,6BAA6B;gBACvC,omEAA+C;gBAE/C,IAAI,EAAE;oBACH,iBAAiB,EAAE,UAAU;iBAC/B;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aACjD;;;;YAbuB,iBAAiB;YAA0C,UAAU;YAAU,SAAS;;;sBAiC5G,KAAK;4BAeL,KAAK;4BAGL,KAAK;gCAGL,MAAM;4BAGN,MAAM;;;;;;;;IATP,2DAA+B;;;;;IAG/B,2DAAsD;;;;;IAGtD,+DAAoE;;;;;IAGpE,2DAAoE;;IAEpE,iEAAuC;;IACvC,6DAA+B;;IAC/B,sEAAwC;;IACxC,yDAA2B;;IAC3B,0DAAqC;;IACrC,oDAAkC;;IAElC,sDAAiC;;IACjC,qEAA+D;;;;;IAEnD,gDAA6B;;;;;IAAE,qDAA2B;;;;;IAAE,sDAA2B","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 { AfterViewInit, ChangeDetectorRef, Component, Input, EventEmitter, Output, ElementRef, OnInit, Renderer2,\n   OnChanges, ChangeDetectionStrategy } from '@angular/core';\n\nimport { StatusNotification, StNotificationElement } from './st-foreground-notifications.model';\n\n@Component({\n   selector: 'st-foreground-notifications',\n   templateUrl: 'st-foreground-notifications.html',\n   styleUrls: ['st-foreground-notifications.scss'],\n   host: {\n      '[class.visible]': '_visible'\n   },\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\n/**\n * @description {Component} [Foreground notifications]\n *\n * Foreground notifications are made to let the user know info about a process she is performing in real time.\n *\n * @example\n *\n * {html}\n *\n * ```\n * <st-foreground-notifications [notifications]=\"notifications\" [(visible)]=\"true\" [autoCloseTime]=\"1000\"></st-foreground-notifications>\n *\n * ```\n */\n\n\nexport class StForegroundNotificationsComponent implements AfterViewInit, OnChanges, OnInit {\n\n   /** @Input {bollean} [visible=flase] When true the notification is shown */\n   @Input()\n   set visible(value: boolean) {\n      if (value !== undefined) {\n         this._visible = value;\n         this.visibleChange.emit(this._visible);\n      }\n      this.cd.markForCheck();\n   }\n   get visible(): boolean {\n      return this._visible;\n   }\n\n   /** @Input {autoCloseTime} [autoCloseTime='1000'] Defines the time in milliseconds for autoclose the notification.\n    *  The autoclose only applies if only have one notification and status is success\n    */\n   @Input() autoCloseTime: number;\n\n   /** @Input {StNotificationElement []} [notifications='[]'] Array of notifications */\n   @Input() notifications?: StNotificationElement[] = [];\n\n    /** @output {clickLinkTemplate} [click] Event emitted when user click in a href link */\n   @Output() clickLinkTemplate: EventEmitter<any> = new EventEmitter();\n\n   /** @output {visibleChange} [click] Event emitted when set param visible */\n   @Output() visibleChange: EventEmitter<boolean> = new EventEmitter();\n\n   public currentNotification: number = 1;\n   public statusIconValue: string;\n   public statusNotificationsValue: string;\n   public statusValue: string;\n   public showLinkMore: boolean = false;\n   public status: string = 'default';\n\n   public _visible: boolean = false;\n   public listStatusNotifications: Array<StatusNotification> = [];\n\n   constructor(private cd: ChangeDetectorRef, private elemRef: ElementRef, private renderer: Renderer2) { }\n\n   ngOnInit(): void {\n      if (this.autoCloseTime) {\n         if ( this.notifications.length === 1 && this.notifications[0].status === 'success') {\n            setTimeout(() => this.onClose(), this.autoCloseTime);\n         }\n      }\n      this.fillStatusNotifications();\n   }\n\n   ngAfterViewInit(): void {\n      let htmlElement = this.elemRef.nativeElement.querySelector('.foreground-notification__html');\n      if (htmlElement !== null) {\n         this.addStyleLinks(htmlElement);\n      }\n      if ( this.notifications && this.notifications.length > 0) {\n         this.checkOneLine();\n      }\n\n      this.cd.detectChanges();\n   }\n\n   ngOnChanges(): void {\n      if (this.notifications && this.notifications.length < this.currentNotification) {\n         this.currentNotification = this.notifications.length;\n      }\n      this.listStatusNotifications = [];\n      this.fillStatusNotifications();\n   }\n\n   addStyleLinks(htmlElement: any): void {\n      let links = htmlElement.querySelectorAll('a');\n      if (links.constructor !== Array) {\n         links = (<any>Object).values(links);\n      }\n      links.forEach((element: any, index: any) => {\n         let nameEventEmitter = (this.notifications[this.getIndexCurrentNotification()]).nameEvents[index];\n         if (nameEventEmitter) {\n            element.addEventListener('click', this.onClickLinkHtmlTemplate.bind(this, nameEventEmitter));\n            this.renderer.setStyle(element, 'text-decoration', 'underline');\n            this.renderer.setStyle(element, 'cursor', 'pointer');\n         }\n      });\n   }\n\n   checkOneLine(): void {\n      let element = this.elemRef.nativeElement.querySelectorAll('.foreground-notification__content');\n      let currentIndex = this.getIndexCurrentNotification();\n\n      if (this.listStatusNotifications && this.listStatusNotifications.length > 0) {\n         if (element[currentIndex].offsetHeight > 40) {\n            this.listStatusNotifications[currentIndex].showMore = !this.listStatusNotifications[currentIndex].completeText;\n\n            if (this.listStatusNotifications[currentIndex].showMore) {\n               this.listStatusNotifications[currentIndex].completeText = false;\n               this.renderer.addClass(element[currentIndex], 'limit-one-line');\n            }\n         } else {\n            this.listStatusNotifications[currentIndex].completeText = true;\n            if (!this.listStatusNotifications[currentIndex].showMore) {\n               this.removeStyleNotification();\n            }\n         }\n      }\n      this.checkStatus();\n   }\n\n   checkStatus(): void {\n      this.statusValue = this.getStatus();\n      this.statusIconValue = this.getStatusIcon();\n      this.statusNotificationsValue = this.getStatusNotifications();\n\n      this.cd.detectChanges();\n   }\n\n   decrementPage(): void {\n      this.currentNotification = this.getIndexCurrentNotification();\n      setTimeout(() => {\n         this.checkOneLine();\n         this.cd.detectChanges();\n      });\n      this.status = this.notifications[this.getIndexCurrentNotification()].status;\n   }\n\n   fillStatusNotifications(): void {\n      if (this.notifications && this.notifications.length > 0) {\n         this.status = this.notifications[this.getIndexCurrentNotification()].status;\n         this.checkStatus();\n      }\n\n      this.notifications.forEach(() => {\n         this.listStatusNotifications.push(new StatusNotification(false, false));\n      });\n   }\n\n   getIndexCurrentNotification(): number {\n      return this.currentNotification - 1;\n   }\n\n   getStatus(): string {\n      switch (this.status) {\n         case 'success':\n         case 'warning':\n         case 'critical':\n         case 'running':\n            return this.status;\n         default:\n            return 'default';\n      }\n   }\n\n   getStatusIcon(): string {\n      switch (this.status) {\n         case 'success':\n            return 'icon-circle-check';\n         case 'warning':\n            return 'icon-alert';\n         case 'critical':\n            return 'icon-info1';\n         case 'running':\n            return 'icon-info1';\n         default:\n            return 'default';\n      }\n   }\n\n   getStatusNotifications(): string {\n      return (this.notifications.length > 1) ? 'more-lines' : '';\n   }\n\n   incrementPage(): void {\n      this.currentNotification = this.currentNotification + 1;\n      setTimeout(() => {\n         this.checkOneLine();\n         this.cd.detectChanges();\n      });\n      this.status = this.notifications[this.getIndexCurrentNotification()].status;\n   }\n\n   onClickLinkHtmlTemplate(event: string): void {\n      this.clickLinkTemplate.emit(event);\n   }\n\n   onClose(): void {\n      this.visible = false;\n      this.cd.markForCheck();\n   }\n\n   removeStyleNotification(): void {\n      let element = this.elemRef.nativeElement.querySelectorAll('.foreground-notification__content');\n      this.renderer.removeClass(element[this.getIndexCurrentNotification()], 'limit-one-line');\n      this.cd.markForCheck();\n   }\n\n   showTextComplete(): void {\n      let currentIndex = this.getIndexCurrentNotification();\n      if (this.listStatusNotifications && this.listStatusNotifications.length > 0) {\n         this.listStatusNotifications[currentIndex].showMore = false;\n         this.listStatusNotifications[currentIndex].completeText = true;\n      }\n      this.removeStyleNotification();\n      this.cd.markForCheck();\n   }\n}\n\n\n"]}