UNPKG

@addapptables/notifier

Version:
184 lines 17.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ChangeDetectionStrategy, EventEmitter, HostListener, Inject, ViewEncapsulation, TemplateRef, ComponentFactoryResolver, ViewChild } from '@angular/core'; import { notifierAnimation } from './animations/notifier.animation'; import { interval, Subject } from 'rxjs'; import { take, tap, takeUntil } from 'rxjs/operators'; import { ADDAPPTABLE_CONFIGURATION_NOTIFIER_DATA, ADDAPPTABLE_NOTIFIER_DATA } from './tokens'; import { NotifierConfiguration } from './models/notifier-configuration.model'; import { Notifier } from './models/notifier.model'; import { PortalInjector } from '@angular/cdk/portal'; import { DynamicDirective } from '@addapptables/core'; import { NotifierPositionType } from './models/notifier-position-enum.model'; export class NotifierComponent { /** * @param {?} configuration * @param {?} data * @param {?} componentFactoryResolver */ constructor(configuration, data, componentFactoryResolver) { this.data = data; this.componentFactoryResolver = componentFactoryResolver; this._state = 'slideInUp'; this._close = new EventEmitter(); this._animationStateChanged = new EventEmitter(); this._style = {}; this.subject = new Subject(); this.seconds = interval(5000); this.configuration = { position: NotifierPositionType.bottomRight, timeout: 5000, classIcon: 'material-icons', iconValue: 'notifications' }; this.configuration = Object.assign({ position: NotifierPositionType.bottomRight, timeout: 5000, classIcon: 'material-icons', iconValue: 'notifications' }, configuration); this.seconds = interval(this.configuration.timeout); } /** * @return {?} */ ngOnInit() { if (this.data.templateOrComponent) { this.resolveComponent(this.data.templateOrComponent, this.appDynamic.viewContainerRef); } } /** * @return {?} */ ngAfterViewInit() { this._timeOut(); } /** * @return {?} */ onMouseOver() { this.subject.next(); this.subject.complete(); } /** * @return {?} */ onMouseLeave() { this.subject = new Subject(); this._timeOut(); } /** * @private * @return {?} */ _timeOut() { this.seconds.pipe(takeUntil(this.subject), take(1), tap((/** * @return {?} */ () => this.close()))).subscribe(); } /** * @return {?} */ close() { this._close.emit(); } /** * @return {?} */ startExitAnimation() { this._state = 'exit'; } /** * @private * @param {?} component * @param {?} viewContainerRef * @return {?} */ resolveComponent(component, viewContainerRef) { if (!component) { return; } viewContainerRef.clear(); if (component instanceof TemplateRef) { viewContainerRef.createEmbeddedView(component, { $implicit: this.data }); } else { /** @type {?} */ const componentFactory = component && this.componentFactoryResolver.resolveComponentFactory(component); /** @type {?} */ const injector = this.createInjector(viewContainerRef.injector); viewContainerRef.createComponent(componentFactory, null, injector); } } /** * @private * @param {?} injector * @return {?} */ createInjector(injector) { /** @type {?} */ const injectionTokens = new WeakMap([ [ADDAPPTABLE_NOTIFIER_DATA, this.data] ]); return new PortalInjector(injector, injectionTokens); } /** * @return {?} */ ngOnDestroy() { this.subject.next(); this.subject.complete(); } } NotifierComponent.decorators = [ { type: Component, args: [{ selector: 'addapptable-notifier', template: "<div [class]=\"'addapptable-notifier '+ data.type\" [@notifierAnimator]=\"_state\" (@notifierAnimator.start)=\"_animationStateChanged.emit($event)\"\n (@notifierAnimator.done)=\"_animationStateChanged.emit($event)\" [ngStyle]=\"_style\">\n <i *ngIf=\"configuration.classIcon\" [class]=\"configuration.classIcon\">{{configuration.iconValue}}</i>\n <button type=\"button\" (click)=\"close()\">x</button>\n <span class=\"message\">\n <ng-template addapptablesDynamic></ng-template>\n <span *ngIf=\"!data.templateOrComponent\">{{data.message}}</span>\n </span>\n</div>", changeDetection: ChangeDetectionStrategy.Default, animations: [notifierAnimation.notifierAnimator], encapsulation: ViewEncapsulation.None, styles: [".addapptable-notifier{margin:1em;display:inline-block;position:fixed;z-index:1031;border-radius:3px;transition:.19s ease-in-out}.addapptable-notifier-success{background-color:#5cb85c;color:#5cb85c}.addapptable-notifier-info{background-color:#20a9d2;color:#20a9d2}.addapptable-notifier-warning{background-color:#e09d3d;color:#e09d3d}.addapptable-notifier-danger{background-color:#d43934;color:#d43934}.addapptable-notifier>i{display:block;left:15px;position:absolute;margin-top:-26px;font-size:20px;background-color:#fff!important;padding:9px;border-radius:50%;max-width:38px;box-shadow:0 16px 38px -12px rgba(0,0,0,.56),0 4px 25px 0 rgba(0,0,0,.12),0 8px 10px -5px rgba(0,0,0,.2)}.addapptable-notifier>button{float:right;min-width:auto;color:#fff!important;text-shadow:none;opacity:.9;box-sizing:border-box;position:relative;cursor:pointer;outline:0;border:none;white-space:nowrap;text-decoration:none;vertical-align:baseline;text-align:center;margin:0;line-height:36px;padding:0 16px;border-radius:4px;overflow:visible;background-color:transparent}.addapptable-notifier .message{display:block;color:#fff;min-width:376px;max-width:500px;padding:1.5em;text-align:justify}"] }] } ]; /** @nocollapse */ NotifierComponent.ctorParameters = () => [ { type: NotifierConfiguration, decorators: [{ type: Inject, args: [ADDAPPTABLE_CONFIGURATION_NOTIFIER_DATA,] }] }, { type: Notifier, decorators: [{ type: Inject, args: [ADDAPPTABLE_NOTIFIER_DATA,] }] }, { type: ComponentFactoryResolver } ]; NotifierComponent.propDecorators = { appDynamic: [{ type: ViewChild, args: [DynamicDirective, { static: true },] }], onMouseOver: [{ type: HostListener, args: ['mouseover',] }], onMouseLeave: [{ type: HostListener, args: ['mouseleave',] }] }; if (false) { /** @type {?} */ NotifierComponent.prototype._id; /** @type {?} */ NotifierComponent.prototype._state; /** @type {?} */ NotifierComponent.prototype._close; /** @type {?} */ NotifierComponent.prototype._animationStateChanged; /** @type {?} */ NotifierComponent.prototype._style; /** @type {?} */ NotifierComponent.prototype.subject; /** @type {?} */ NotifierComponent.prototype.seconds; /** @type {?} */ NotifierComponent.prototype.configuration; /** @type {?} */ NotifierComponent.prototype.appDynamic; /** @type {?} */ NotifierComponent.prototype.data; /** * @type {?} * @private */ NotifierComponent.prototype.componentFactoryResolver; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifier.component.js","sourceRoot":"ng://@addapptables/notifier/","sources":["lib/notifier.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  EventEmitter,\n  AfterViewInit,\n  HostListener,\n  OnDestroy,\n  Inject,\n  ViewEncapsulation,\n  Injector,\n  TemplateRef,\n  ViewContainerRef,\n  ComponentFactoryResolver,\n  ViewChild,\n  OnInit\n} from '@angular/core';\nimport { notifierAnimation } from './animations/notifier.animation';\nimport { AnimationEvent } from '@angular/animations';\nimport { interval, Subject } from 'rxjs';\nimport { take, tap, takeUntil } from 'rxjs/operators';\nimport { ADDAPPTABLE_CONFIGURATION_NOTIFIER_DATA, ADDAPPTABLE_NOTIFIER_DATA } from './tokens';\nimport { NotifierConfiguration } from './models/notifier-configuration.model';\nimport { Notifier } from './models/notifier.model';\nimport { PortalInjector, ComponentType } from '@angular/cdk/portal';\nimport { DynamicDirective } from '@addapptables/core';\nimport { NotifierPositionType } from './models/notifier-position-enum.model';\n\n@Component({\n  selector: 'addapptable-notifier',\n  templateUrl: './notifier.component.html',\n  styleUrls: ['./notifier.component.scss'],\n  changeDetection: ChangeDetectionStrategy.Default,\n  animations: [notifierAnimation.notifierAnimator],\n  encapsulation: ViewEncapsulation.None\n})\nexport class NotifierComponent implements OnInit, AfterViewInit, OnDestroy {\n\n  _id: string;\n\n  _state: 'slideInUp' | 'exit' | 'slideInDown' = 'slideInUp';\n\n  _close = new EventEmitter();\n\n  _animationStateChanged = new EventEmitter<AnimationEvent>();\n\n  _style = {};\n\n  subject = new Subject<void>();\n\n  seconds = interval(5000);\n\n  configuration: NotifierConfiguration = {\n    position: NotifierPositionType.bottomRight,\n    timeout: 5000,\n    classIcon: 'material-icons',\n    iconValue: 'notifications'\n  };\n\n  @ViewChild(DynamicDirective, { static: true })\n  appDynamic: DynamicDirective;\n\n  constructor(\n    @Inject(ADDAPPTABLE_CONFIGURATION_NOTIFIER_DATA) configuration: NotifierConfiguration,\n    @Inject(ADDAPPTABLE_NOTIFIER_DATA) public data: Notifier,\n    private componentFactoryResolver: ComponentFactoryResolver\n  ) {\n    this.configuration = Object.assign({\n      position: NotifierPositionType.bottomRight,\n      timeout: 5000,\n      classIcon: 'material-icons',\n      iconValue: 'notifications'\n    }, configuration);\n    this.seconds = interval(this.configuration.timeout);\n  }\n\n  ngOnInit(): void {\n    if (this.data.templateOrComponent) {\n      this.resolveComponent(this.data.templateOrComponent, this.appDynamic.viewContainerRef);\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this._timeOut();\n  }\n\n  @HostListener('mouseover') onMouseOver() {\n    this.subject.next();\n    this.subject.complete();\n  }\n\n\n  @HostListener('mouseleave') onMouseLeave() {\n    this.subject = new Subject<void>();\n    this._timeOut();\n  }\n\n  private _timeOut() {\n    this.seconds.pipe(\n      takeUntil(this.subject),\n      take(1),\n      tap(() => this.close())\n    ).subscribe();\n  }\n\n  close() {\n    this._close.emit();\n  }\n\n  startExitAnimation(): void {\n    this._state = 'exit';\n  }\n\n  private resolveComponent(component: ComponentType<{}> | TemplateRef<{}>, viewContainerRef: ViewContainerRef) {\n    if (!component) { return; }\n    viewContainerRef.clear();\n    if (component instanceof TemplateRef) {\n      viewContainerRef.createEmbeddedView(component, { $implicit: this.data });\n    } else {\n      const componentFactory = component && this.componentFactoryResolver.resolveComponentFactory(component);\n      const injector = this.createInjector(viewContainerRef.injector);\n      viewContainerRef.createComponent(componentFactory, null, injector);\n    }\n  }\n\n  private createInjector(injector: Injector): PortalInjector {\n    const injectionTokens = new WeakMap<any, any>([\n      [ADDAPPTABLE_NOTIFIER_DATA, this.data]\n    ]);\n    return new PortalInjector(injector, injectionTokens);\n  }\n\n  ngOnDestroy(): void {\n    this.subject.next();\n    this.subject.complete();\n  }\n}\n"]}