@addapptables/notifier
Version:
Material notifier library for angular
218 lines • 19 kB
JavaScript
/**
* @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';
var NotifierComponent = /** @class */ (function () {
function NotifierComponent(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 {?}
*/
NotifierComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.data.templateOrComponent) {
this.resolveComponent(this.data.templateOrComponent, this.appDynamic.viewContainerRef);
}
};
/**
* @return {?}
*/
NotifierComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this._timeOut();
};
/**
* @return {?}
*/
NotifierComponent.prototype.onMouseOver = /**
* @return {?}
*/
function () {
this.subject.next();
this.subject.complete();
};
/**
* @return {?}
*/
NotifierComponent.prototype.onMouseLeave = /**
* @return {?}
*/
function () {
this.subject = new Subject();
this._timeOut();
};
/**
* @private
* @return {?}
*/
NotifierComponent.prototype._timeOut = /**
* @private
* @return {?}
*/
function () {
var _this = this;
this.seconds.pipe(takeUntil(this.subject), take(1), tap((/**
* @return {?}
*/
function () { return _this.close(); }))).subscribe();
};
/**
* @return {?}
*/
NotifierComponent.prototype.close = /**
* @return {?}
*/
function () {
this._close.emit();
};
/**
* @return {?}
*/
NotifierComponent.prototype.startExitAnimation = /**
* @return {?}
*/
function () {
this._state = 'exit';
};
/**
* @private
* @param {?} component
* @param {?} viewContainerRef
* @return {?}
*/
NotifierComponent.prototype.resolveComponent = /**
* @private
* @param {?} component
* @param {?} viewContainerRef
* @return {?}
*/
function (component, viewContainerRef) {
if (!component) {
return;
}
viewContainerRef.clear();
if (component instanceof TemplateRef) {
viewContainerRef.createEmbeddedView(component, { $implicit: this.data });
}
else {
/** @type {?} */
var componentFactory = component && this.componentFactoryResolver.resolveComponentFactory(component);
/** @type {?} */
var injector = this.createInjector(viewContainerRef.injector);
viewContainerRef.createComponent(componentFactory, null, injector);
}
};
/**
* @private
* @param {?} injector
* @return {?}
*/
NotifierComponent.prototype.createInjector = /**
* @private
* @param {?} injector
* @return {?}
*/
function (injector) {
/** @type {?} */
var injectionTokens = new WeakMap([
[ADDAPPTABLE_NOTIFIER_DATA, this.data]
]);
return new PortalInjector(injector, injectionTokens);
};
/**
* @return {?}
*/
NotifierComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
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 = function () { return [
{ 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',] }]
};
return NotifierComponent;
}());
export { NotifierComponent };
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":";;;;AAAA,OAAO,EACL,SAAS,EACT,uBAAuB,EACvB,YAAY,EAEZ,YAAY,EAEZ,MAAM,EACN,iBAAiB,EAEjB,WAAW,EAEX,wBAAwB,EACxB,SAAS,EAEV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AAEpE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,uCAAuC,EAAE,yBAAyB,EAAE,MAAM,UAAU,CAAC;AAC9F,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAiB,MAAM,qBAAqB,CAAC;AACpE,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAE7E;IAkCE,2BACmD,aAAoC,EAC3C,IAAc,EAChD,wBAAkD;QADhB,SAAI,GAAJ,IAAI,CAAU;QAChD,6BAAwB,GAAxB,wBAAwB,CAA0B;QAzB5D,WAAM,GAAyC,WAAW,CAAC;QAE3D,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAE5B,2BAAsB,GAAG,IAAI,YAAY,EAAkB,CAAC;QAE5D,WAAM,GAAG,EAAE,CAAC;QAEZ,YAAO,GAAG,IAAI,OAAO,EAAQ,CAAC;QAE9B,YAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;QAEzB,kBAAa,GAA0B;YACrC,QAAQ,EAAE,oBAAoB,CAAC,WAAW;YAC1C,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,gBAAgB;YAC3B,SAAS,EAAE,eAAe;SAC3B,CAAC;QAUA,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC;YACjC,QAAQ,EAAE,oBAAoB,CAAC,WAAW;YAC1C,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,gBAAgB;YAC3B,SAAS,EAAE,eAAe;SAC3B,EAAE,aAAa,CAAC,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;;;;IAED,oCAAQ;;;IAAR;QACE,IAAI,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE;YACjC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;SACxF;IACH,CAAC;;;;IAED,2CAAe;;;IAAf;QACE,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;IAE0B,uCAAW;;;IAAtC;QACE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACpB,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;;;;IAG2B,wCAAY;;;IAAxC;QACE,IAAI,CAAC,OAAO,GAAG,IAAI,OAAO,EAAQ,CAAC;QACnC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;;IAEO,oCAAQ;;;;IAAhB;QAAA,iBAMC;QALC,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,IAAI,CAAC,CAAC,CAAC,EACP,GAAG;;;QAAC,cAAM,OAAA,KAAI,CAAC,KAAK,EAAE,EAAZ,CAAY,EAAC,CACxB,CAAC,SAAS,EAAE,CAAC;IAChB,CAAC;;;;IAED,iCAAK;;;IAAL;QACE,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;;;;IAED,8CAAkB;;;IAAlB;QACE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;;;;;;;IAEO,4CAAgB;;;;;;IAAxB,UAAyB,SAA8C,EAAE,gBAAkC;QACzG,IAAI,CAAC,SAAS,EAAE;YAAE,OAAO;SAAE;QAC3B,gBAAgB,CAAC,KAAK,EAAE,CAAC;QACzB,IAAI,SAAS,YAAY,WAAW,EAAE;YACpC,gBAAgB,CAAC,kBAAkB,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;SAC1E;aAAM;;gBACC,gBAAgB,GAAG,SAAS,IAAI,IAAI,CAAC,wBAAwB,CAAC,uBAAuB,CAAC,SAAS,CAAC;;gBAChG,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,QAAQ,CAAC;YAC/D,gBAAgB,CAAC,eAAe,CAAC,gBAAgB,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAC;SACpE;IACH,CAAC;;;;;;IAEO,0CAAc;;;;;IAAtB,UAAuB,QAAkB;;YACjC,eAAe,GAAG,IAAI,OAAO,CAAW;YAC5C,CAAC,yBAAyB,EAAE,IAAI,CAAC,IAAI,CAAC;SACvC,CAAC;QACF,OAAO,IAAI,cAAc,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;IACvD,CAAC;;;;IAED,uCAAW;;;IAAX;QACE,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACpB,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IAC1B,CAAC;;gBA3GF,SAAS,SAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,2kBAAwC;oBAExC,eAAe,EAAE,uBAAuB,CAAC,OAAO;oBAChD,UAAU,EAAE,CAAC,iBAAiB,CAAC,gBAAgB,CAAC;oBAChD,aAAa,EAAE,iBAAiB,CAAC,IAAI;;iBACtC;;;;gBAbQ,qBAAqB,uBAyCzB,MAAM,SAAC,uCAAuC;gBAxC1C,QAAQ,uBAyCZ,MAAM,SAAC,yBAAyB;gBAnDnC,wBAAwB;;;6BA8CvB,SAAS,SAAC,gBAAgB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;8BA2B5C,YAAY,SAAC,WAAW;+BAMxB,YAAY,SAAC,YAAY;;IA4C5B,wBAAC;CAAA,AA5GD,IA4GC;SApGY,iBAAiB;;;IAE5B,gCAAY;;IAEZ,mCAA2D;;IAE3D,mCAA4B;;IAE5B,mDAA4D;;IAE5D,mCAAY;;IAEZ,oCAA8B;;IAE9B,oCAAyB;;IAEzB,0CAKE;;IAEF,uCAC6B;;IAI3B,iCAAwD;;;;;IACxD,qDAA0D","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"]}