UNPKG

@stratio/egeo

Version:
422 lines 38.9 kB
/** * @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'; var StForegroundNotificationsComponent = /** @class */ (function () { function StForegroundNotificationsComponent(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 = []; } Object.defineProperty(StForegroundNotificationsComponent.prototype, "visible", { get: /** * @return {?} */ function () { return this._visible; }, /** @Input {boolean} [visible=false] When true the notification is shown */ set: /** * \@Input {boolean} [visible=false] When true the notification is shown * @param {?} value * @return {?} */ function (value) { if (value !== undefined) { this._visible = value; this.visibleChange.emit(this._visible); } this.cd.markForCheck(); }, enumerable: true, configurable: true }); /** * @return {?} */ StForegroundNotificationsComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; if (this.autoCloseTime) { if (this.notifications.length === 1 && this.notifications[0].status === 'success') { setTimeout((/** * @return {?} */ function () { return _this.onClose(); }), this.autoCloseTime); } } this.fillStatusNotifications(); }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { /** @type {?} */ var 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 {?} */ StForegroundNotificationsComponent.prototype.ngOnChanges = /** * @return {?} */ function () { if (this.notifications && this.notifications.length < this.currentNotification) { this.currentNotification = this.notifications.length; } this.listStatusNotifications = []; this.fillStatusNotifications(); }; /** * @param {?} htmlElement * @return {?} */ StForegroundNotificationsComponent.prototype.addStyleLinks = /** * @param {?} htmlElement * @return {?} */ function (htmlElement) { var _this = this; /** @type {?} */ var links = htmlElement.querySelectorAll('a'); if (links.constructor !== Array) { links = ((/** @type {?} */ (Object))).values(links); } links.forEach((/** * @param {?} element * @param {?} index * @return {?} */ function (element, index) { /** @type {?} */ var 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 {?} */ StForegroundNotificationsComponent.prototype.checkOneLine = /** * @return {?} */ function () { /** @type {?} */ var element = this.elemRef.nativeElement.querySelectorAll('.foreground-notification__content'); /** @type {?} */ var 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 {?} */ StForegroundNotificationsComponent.prototype.checkStatus = /** * @return {?} */ function () { this.statusValue = this.getStatus(); this.statusIconValue = this.getStatusIcon(); this.statusNotificationsValue = this.getStatusNotifications(); this.cd.detectChanges(); }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.decrementPage = /** * @return {?} */ function () { var _this = this; this.currentNotification = this.getIndexCurrentNotification(); setTimeout((/** * @return {?} */ function () { _this.checkOneLine(); _this.cd.detectChanges(); })); this.status = this.notifications[this.getIndexCurrentNotification()].status; }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.fillStatusNotifications = /** * @return {?} */ function () { var _this = this; if (this.notifications && this.notifications.length > 0) { this.status = this.notifications[this.getIndexCurrentNotification()].status; this.checkStatus(); } this.notifications.forEach((/** * @return {?} */ function () { _this.listStatusNotifications.push(new StatusNotification(false, false)); })); }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.getIndexCurrentNotification = /** * @return {?} */ function () { return this.currentNotification - 1; }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.getStatus = /** * @return {?} */ function () { switch (this.status) { case 'success': case 'warning': case 'critical': case 'running': return this.status; default: return 'default'; } }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.getStatusIcon = /** * @return {?} */ function () { 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 {?} */ StForegroundNotificationsComponent.prototype.getStatusNotifications = /** * @return {?} */ function () { return (this.notifications.length > 1) ? 'more-lines' : ''; }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.incrementPage = /** * @return {?} */ function () { var _this = this; this.currentNotification = this.currentNotification + 1; setTimeout((/** * @return {?} */ function () { _this.checkOneLine(); _this.cd.detectChanges(); })); this.status = this.notifications[this.getIndexCurrentNotification()].status; }; /** * @param {?} event * @return {?} */ StForegroundNotificationsComponent.prototype.onClickLinkHtmlTemplate = /** * @param {?} event * @return {?} */ function (event) { this.clickLinkTemplate.emit(event); }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.onClose = /** * @return {?} */ function () { this.visible = false; this.cd.markForCheck(); }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.removeStyleNotification = /** * @return {?} */ function () { /** @type {?} */ var element = this.elemRef.nativeElement.querySelectorAll('.foreground-notification__content'); this.renderer.removeClass(element[this.getIndexCurrentNotification()], 'limit-one-line'); this.cd.markForCheck(); }; /** * @return {?} */ StForegroundNotificationsComponent.prototype.showTextComplete = /** * @return {?} */ function () { /** @type {?} */ var 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 = function () { return [ { type: ChangeDetectorRef }, { type: ElementRef }, { type: Renderer2 } ]; }; StForegroundNotificationsComponent.propDecorators = { visible: [{ type: Input }], autoCloseTime: [{ type: Input }], notifications: [{ type: Input }], clickLinkTemplate: [{ type: Output }], visibleChange: [{ type: Output }] }; return StForegroundNotificationsComponent; }()); export { StForegroundNotificationsComponent }; 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":"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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 { 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 {boolean} [visible=false] 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"]}