UNPKG

ng-alertbar

Version:

A configurable alertbar for Angular

349 lines 26.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, EventEmitter, Input, Output } from '@angular/core'; import { DomSanitizer } from '@angular/platform-browser'; import { Subject, timer } from 'rxjs'; import { filter, mapTo, switchMap, take, takeUntil } from 'rxjs/operators'; import { slide } from './animations'; import { defaults } from './defaults'; import { NgAlertbarService } from './ng-alertbar.service'; /** @type {?} */ const ALERT_LEAVE_ANIMATION_DURATION = 200; export class NgAlertbarComponent { /** * @param {?} alertBarService * @param {?} domSanitizer */ constructor(alertBarService, domSanitizer) { this.alertBarService = alertBarService; this.domSanitizer = domSanitizer; this.queue = []; this.queuePop = new Subject(); this.queueing = defaults.queueingEnabled; this.lifeTime = defaults.lifeTimeMs; this.showDelay = defaults.showDelayMs; this.backgroundColor = defaults.backgroundColor; this.borderColor = defaults.borderColor; this.textColor = defaults.textColor; this.widthMode = defaults.widthMode; this.closeButton = defaults.closeButtonEnabled; this.html = defaults.useHtml; this.open = new EventEmitter(); this.close = new EventEmitter(); this.show = false; this.destroy = new Subject(); } /** * @return {?} */ get isFullWidth() { if (this.tempWidthMode) { return this.tempWidthMode === 'full'; } return this.widthMode === 'full'; } /** * @return {?} */ get showCloseButton() { if (this.tempCloseButton != null) { return this.tempCloseButton; } return this.closeButton; } /** * @return {?} */ get useHtml() { if (this.tempHtml != null) { return this.tempHtml; } return this.html; } /** * @return {?} */ get htmlMessage() { return this.domSanitizer.bypassSecurityTrustHtml(this.message); } /** * The trigger stream after waiting the specified showDelay since the alert was triggered * @return {?} */ get openTriggerPostDelay$() { return this.alertBarService.trigger$.pipe(switchMap((/** * @param {?} trigger * @return {?} */ trigger => { /** @type {?} */ const options = trigger.options; /** @type {?} */ const showDelay = (options && options.showDelay) || this.showDelay; return timer(showDelay).pipe(mapTo(trigger)); })), takeUntil(this.destroy)); } /** * The trigger stream after waiting the specified lifetime since the alert opened * @return {?} */ get postAlertLifetime$() { return this.open.pipe(filter((/** * @param {?} __0 * @return {?} */ ({ options }) => this.shouldAlertAutoClose(options))), switchMap((/** * @param {?} __0 * @return {?} */ ({ options }) => { /** @type {?} */ const lifeTime = (options && options.lifeTime) || this.lifeTime; return timer(lifeTime); })), takeUntil(this.destroy)); } /** * The service cancel trigger * @return {?} */ get cancelTrigger$() { return this.alertBarService.cancel$.pipe(takeUntil(this.destroy)); } /** * Timer representing the delay taken for an alert to animate when exiting * @return {?} */ get alertLeaveTimer() { return timer(ALERT_LEAVE_ANIMATION_DURATION).pipe(take(1)); } /** * @return {?} */ ngOnInit() { this.openTriggerPostDelay$.subscribe((/** * @param {?} trigger * @return {?} */ trigger => this.onTrigger(trigger))); this.queuePop.subscribe((/** * @param {?} trigger * @return {?} */ trigger => this.showAlert(trigger))); this.postAlertLifetime$.subscribe((/** * @return {?} */ () => this.onClose())); this.cancelTrigger$.subscribe((/** * @return {?} */ () => this.onClose())); } /** * @return {?} */ ngOnDestroy() { this.destroy.next(); } /** * @private * @param {?} trigger * @return {?} */ onTrigger(trigger) { if (this.queueing && !(trigger.options && trigger.options.bypassQueue) && this.show) { this.queue.push(trigger); return; } this.showAlert(trigger); } /** * Sets up temp variables and shows the alert * @private * @param {?} trigger The trigger to display * @return {?} */ showAlert(trigger) { this.clearTempOptions(); // Clear previous temporary options this.assignTempOptions(trigger.options); this.message = trigger.message; this.show = true; this.open.emit(trigger); } /** * Closes any open alert. If there are any alerts waiting in the queue, * the alert is popped off the queue and emitted for opening * @return {?} */ onClose() { this.closeAlert(); if (this.queue.length > 0) { this.alertLeaveTimer.subscribe((/** * @return {?} */ () => { this.queuePop.next(this.queue.shift()); })); } } /** * @private * @return {?} */ closeAlert() { this.show = false; this.close.emit(); } /** * Clears out any temporary config options so that they * do not persist beyond their single use * @private * @return {?} */ clearTempOptions() { this.tempBackgroundColor = null; this.tempBorderColor = null; this.tempTextColor = null; this.tempWidthMode = null; this.tempCloseButton = null; this.tempHtml = null; } /** * Assigns the options included in the trigger to the temporary * config variables so they can apply for the upcoming alert * @private * @param {?} options The options passed in the trigger * @return {?} */ assignTempOptions(options) { if (!options) { return; } this.tempBackgroundColor = options.backgroundColor; this.tempBorderColor = options.borderColor; this.tempTextColor = options.textColor; this.tempWidthMode = options.widthMode; this.tempCloseButton = options.closeButton; this.tempHtml = options.html; } /** * @private * @param {?} options * @return {?} */ shouldAlertAutoClose(options) { if (options && options.lifeTime != null) { return options.lifeTime > 0; } return this.lifeTime > 0; // Fallback to component setting } } NgAlertbarComponent.decorators = [ { type: Component, args: [{ selector: 'ng-alertbar', template: ` <div *ngIf="show" [@slide] class="ng-alert-bar-wrapper"> <div class="ng-alert-bar" [class.full-width]="isFullWidth" [style.background]="tempBackgroundColor || backgroundColor" [style.border-color]="tempBorderColor || borderColor" > <span class="ng-alert-bar-text" [style.color]="tempTextColor || textColor"> <span *ngIf="!useHtml; else htmlMessageContainer">{{ message }}</span> <ng-template #htmlMessageContainer><span [innerHTML]="htmlMessage"></span></ng-template> <span *ngIf="showCloseButton" class="ng-alert-close" (click)="onClose()">&times;</span> </span> </div> </div> `, animations: [slide], styles: [".ng-alert-bar-wrapper{position:absolute;top:0;left:0;width:100%;text-align:center;pointer-events:none}.ng-alert-bar{pointer-events:all}.ng-alert-bar:not(.full-width){display:inline-block}.ng-alert-close{font-size:1.1em;margin-left:.25rem;vertical-align:middle;cursor:pointer}"] }] } ]; /** @nocollapse */ NgAlertbarComponent.ctorParameters = () => [ { type: NgAlertbarService }, { type: DomSanitizer } ]; NgAlertbarComponent.propDecorators = { queueing: [{ type: Input }], lifeTime: [{ type: Input }], showDelay: [{ type: Input }], backgroundColor: [{ type: Input }], borderColor: [{ type: Input }], textColor: [{ type: Input }], widthMode: [{ type: Input }], closeButton: [{ type: Input }], html: [{ type: Input }], open: [{ type: Output }], close: [{ type: Output }] }; if (false) { /** * @type {?} * @private */ NgAlertbarComponent.prototype.queue; /** * @type {?} * @private */ NgAlertbarComponent.prototype.queuePop; /** @type {?} */ NgAlertbarComponent.prototype.queueing; /** @type {?} */ NgAlertbarComponent.prototype.lifeTime; /** @type {?} */ NgAlertbarComponent.prototype.showDelay; /** @type {?} */ NgAlertbarComponent.prototype.backgroundColor; /** @type {?} */ NgAlertbarComponent.prototype.tempBackgroundColor; /** @type {?} */ NgAlertbarComponent.prototype.borderColor; /** @type {?} */ NgAlertbarComponent.prototype.tempBorderColor; /** @type {?} */ NgAlertbarComponent.prototype.textColor; /** @type {?} */ NgAlertbarComponent.prototype.tempTextColor; /** @type {?} */ NgAlertbarComponent.prototype.widthMode; /** @type {?} */ NgAlertbarComponent.prototype.tempWidthMode; /** @type {?} */ NgAlertbarComponent.prototype.closeButton; /** @type {?} */ NgAlertbarComponent.prototype.tempCloseButton; /** @type {?} */ NgAlertbarComponent.prototype.html; /** @type {?} */ NgAlertbarComponent.prototype.tempHtml; /** @type {?} */ NgAlertbarComponent.prototype.open; /** @type {?} */ NgAlertbarComponent.prototype.close; /** @type {?} */ NgAlertbarComponent.prototype.show; /** @type {?} */ NgAlertbarComponent.prototype.message; /** * @type {?} * @private */ NgAlertbarComponent.prototype.destroy; /** * @type {?} * @private */ NgAlertbarComponent.prototype.alertBarService; /** * @type {?} * @private */ NgAlertbarComponent.prototype.domSanitizer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-alertbar.component.js","sourceRoot":"ng://ng-alertbar/","sources":["lib/ng-alertbar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { Subject, timer } from 'rxjs';\nimport { filter, mapTo, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { slide } from './animations';\nimport { defaults } from './defaults';\nimport { AlertOptions, AlertTrigger } from './interface';\nimport { NgAlertbarService } from './ng-alertbar.service';\n\nconst ALERT_LEAVE_ANIMATION_DURATION = 200;\n\n@Component({\n  selector: 'ng-alertbar',\n  template: `\n    <div *ngIf=\"show\" [@slide] class=\"ng-alert-bar-wrapper\">\n      <div\n        class=\"ng-alert-bar\"\n        [class.full-width]=\"isFullWidth\"\n        [style.background]=\"tempBackgroundColor || backgroundColor\"\n        [style.border-color]=\"tempBorderColor || borderColor\"\n      >\n        <span class=\"ng-alert-bar-text\" [style.color]=\"tempTextColor || textColor\">\n          <span *ngIf=\"!useHtml; else htmlMessageContainer\">{{ message }}</span>\n          <ng-template #htmlMessageContainer><span [innerHTML]=\"htmlMessage\"></span></ng-template>\n          <span *ngIf=\"showCloseButton\" class=\"ng-alert-close\" (click)=\"onClose()\">&times;</span>\n        </span>\n      </div>\n    </div>\n  `,\n  styleUrls: ['./ng-alertbar.component.css'],\n  animations: [slide]\n})\nexport class NgAlertbarComponent implements OnInit, OnDestroy {\n  private queue: AlertTrigger[] = [];\n  private queuePop = new Subject<AlertTrigger>();\n\n  @Input() queueing = defaults.queueingEnabled;\n  @Input() lifeTime = defaults.lifeTimeMs;\n  @Input() showDelay = defaults.showDelayMs;\n\n  @Input() backgroundColor = defaults.backgroundColor;\n  tempBackgroundColor: string;\n  @Input() borderColor = defaults.borderColor;\n  tempBorderColor: string;\n  @Input() textColor = defaults.textColor;\n  tempTextColor: string;\n\n  @Input() widthMode = defaults.widthMode;\n  tempWidthMode: 'full' | 'partial';\n  @Input() closeButton = defaults.closeButtonEnabled;\n  tempCloseButton: boolean;\n  @Input() html = defaults.useHtml;\n  tempHtml: boolean;\n\n  @Output() open = new EventEmitter<AlertTrigger>();\n  @Output() close = new EventEmitter<void>();\n\n  show = false;\n  message: string;\n  private destroy = new Subject<void>();\n\n  get isFullWidth() {\n    if (this.tempWidthMode) {\n      return this.tempWidthMode === 'full';\n    }\n    return this.widthMode === 'full';\n  }\n\n  get showCloseButton() {\n    if (this.tempCloseButton != null) {\n      return this.tempCloseButton;\n    }\n    return this.closeButton;\n  }\n\n  get useHtml() {\n    if (this.tempHtml != null) {\n      return this.tempHtml;\n    }\n    return this.html;\n  }\n\n  get htmlMessage() {\n    return this.domSanitizer.bypassSecurityTrustHtml(this.message);\n  }\n\n  /**\n   * The trigger stream after waiting the specified showDelay since the alert was triggered\n   */\n  get openTriggerPostDelay$() {\n    return this.alertBarService.trigger$.pipe(\n      switchMap(trigger => {\n        const options = trigger.options;\n        const showDelay = (options && options.showDelay) || this.showDelay;\n        return timer(showDelay).pipe(mapTo(trigger));\n      }),\n      takeUntil(this.destroy)\n    );\n  }\n\n  /**\n   * The trigger stream after waiting the specified lifetime since the alert opened\n   */\n  get postAlertLifetime$() {\n    return this.open.pipe(\n      filter(({ options }) => this.shouldAlertAutoClose(options)),\n      switchMap(({ options }) => {\n        const lifeTime = (options && options.lifeTime) || this.lifeTime;\n        return timer(lifeTime);\n      }),\n      takeUntil(this.destroy)\n    );\n  }\n\n  /**\n   * The service cancel trigger\n   */\n  get cancelTrigger$() {\n    return this.alertBarService.cancel$.pipe(takeUntil(this.destroy));\n  }\n\n  /**\n   * Timer representing the delay taken for an alert to animate when exiting\n   */\n  get alertLeaveTimer() {\n    return timer(ALERT_LEAVE_ANIMATION_DURATION).pipe(take(1));\n  }\n\n  constructor(private alertBarService: NgAlertbarService, private domSanitizer: DomSanitizer) {}\n\n  ngOnInit() {\n    this.openTriggerPostDelay$.subscribe(trigger => this.onTrigger(trigger));\n    this.queuePop.subscribe(trigger => this.showAlert(trigger));\n    this.postAlertLifetime$.subscribe(() => this.onClose());\n    this.cancelTrigger$.subscribe(() => this.onClose());\n  }\n\n  ngOnDestroy() {\n    this.destroy.next();\n  }\n\n  private onTrigger(trigger: AlertTrigger) {\n    if (this.queueing && !(trigger.options && trigger.options.bypassQueue) && this.show) {\n      this.queue.push(trigger);\n      return;\n    }\n    this.showAlert(trigger);\n  }\n\n  /**\n   * Sets up temp variables and shows the alert\n   * @param trigger The trigger to display\n   */\n  private showAlert(trigger: AlertTrigger) {\n    this.clearTempOptions(); // Clear previous temporary options\n    this.assignTempOptions(trigger.options);\n    this.message = trigger.message;\n    this.show = true;\n    this.open.emit(trigger);\n  }\n\n  /**\n   * Closes any open alert. If there are any alerts waiting in the queue,\n   * the alert is popped off the queue and emitted for opening\n   */\n  onClose() {\n    this.closeAlert();\n    if (this.queue.length > 0) {\n      this.alertLeaveTimer.subscribe(() => {\n        this.queuePop.next(this.queue.shift());\n      });\n    }\n  }\n\n  private closeAlert() {\n    this.show = false;\n    this.close.emit();\n  }\n\n  /**\n   * Clears out any temporary config options so that they\n   * do not persist beyond their single use\n   */\n  private clearTempOptions(): void {\n    this.tempBackgroundColor = null;\n    this.tempBorderColor = null;\n    this.tempTextColor = null;\n    this.tempWidthMode = null;\n    this.tempCloseButton = null;\n    this.tempHtml = null;\n  }\n\n  /**\n   * Assigns the options included in the trigger to the temporary\n   * config variables so they can apply for the upcoming alert\n   * @param options The options passed in the trigger\n   */\n  private assignTempOptions(options: AlertOptions) {\n    if (!options) {\n      return;\n    }\n    this.tempBackgroundColor = options.backgroundColor;\n    this.tempBorderColor = options.borderColor;\n    this.tempTextColor = options.textColor;\n    this.tempWidthMode = options.widthMode;\n    this.tempCloseButton = options.closeButton;\n    this.tempHtml = options.html;\n  }\n\n  private shouldAlertAutoClose(options: AlertOptions) {\n    if (options && options.lifeTime != null) {\n      return options.lifeTime > 0;\n    }\n    return this.lifeTime > 0; // Fallback to component setting\n  }\n}\n"]}