UNPKG

@hxui/angular

Version:

* * *

342 lines 32.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { animate, state, style, transition, trigger } from '@angular/animations'; import { Component, HostBinding, HostListener, NgZone } from '@angular/core'; import { ToastPackage } from './toastr-config'; import { ToastrService } from './toastr.service'; var ToastrComponent = /** @class */ (function () { function ToastrComponent(toastrService, toastPackage, ngZone) { var _this = this; this.toastrService = toastrService; this.toastPackage = toastPackage; this.ngZone = ngZone; /** * width of progress bar */ this.width = -1; /** * a combination of toast type and options.toastClass */ this.toastClasses = ''; /** * controls animation */ this.state = { value: 'inactive', params: { easeTime: this.toastPackage.config.easeTime, easing: 'ease-in' } }; this.message = toastPackage.message; this.title = toastPackage.title; this.options = toastPackage.config; this.originalTimeout = toastPackage.config.timeOut; this.toastClasses = toastPackage.toastType + " " + toastPackage.config.toastClass; this.sub = toastPackage.toastRef.afterActivate().subscribe(function () { _this.activateToast(); }); this.sub1 = toastPackage.toastRef.manualClosed().subscribe(function () { _this.remove(); }); this.sub2 = toastPackage.toastRef.timeoutReset().subscribe(function () { _this.resetTimeout(); }); } /** * @return {?} */ ToastrComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.sub.unsubscribe(); this.sub1.unsubscribe(); this.sub2.unsubscribe(); clearInterval(this.intervalId); clearTimeout(this.timeout); }; /** * activates toast and sets timeout */ /** * activates toast and sets timeout * @return {?} */ ToastrComponent.prototype.activateToast = /** * activates toast and sets timeout * @return {?} */ function () { var _this = this; this.state = tslib_1.__assign({}, this.state, { value: 'active' }); if (!this.options.disableTimeOut && this.options.timeOut) { this.outsideTimeout(function () { return _this.remove(); }, this.options.timeOut); this.hideTime = new Date().getTime() + this.options.timeOut; if (this.options.progressBar) { this.outsideInterval(function () { return _this.updateProgress(); }, 10); } } }; /** * updates progress bar width */ /** * updates progress bar width * @return {?} */ ToastrComponent.prototype.updateProgress = /** * updates progress bar width * @return {?} */ function () { if (this.width === 0 || this.width === 100 || !this.options.timeOut) { return; } /** @type {?} */ var now = new Date().getTime(); /** @type {?} */ var remaining = this.hideTime - now; this.width = (remaining / this.options.timeOut) * 100; if (this.options.progressAnimation === 'increasing') { this.width = 100 - this.width; } if (this.width <= 0) { this.width = 0; } if (this.width >= 100) { this.width = 100; } }; /** * @return {?} */ ToastrComponent.prototype.resetTimeout = /** * @return {?} */ function () { var _this = this; clearTimeout(this.timeout); clearInterval(this.intervalId); this.state = tslib_1.__assign({}, this.state, { value: 'active' }); this.outsideTimeout(function () { return _this.remove(); }, this.originalTimeout); this.options.timeOut = this.originalTimeout; this.hideTime = new Date().getTime() + (this.options.timeOut || 0); this.width = -1; if (this.options.progressBar) { this.outsideInterval(function () { return _this.updateProgress(); }, 10); } }; /** * tells toastrService to remove this toast after animation time */ /** * tells toastrService to remove this toast after animation time * @return {?} */ ToastrComponent.prototype.remove = /** * tells toastrService to remove this toast after animation time * @return {?} */ function () { var _this = this; if (this.state.value === 'removed') { return; } clearTimeout(this.timeout); this.state = tslib_1.__assign({}, this.state, { value: 'removed' }); this.outsideTimeout(function () { return _this.toastrService.remove(_this.toastPackage.toastId); }, +this.toastPackage.config.easeTime); }; /** * @return {?} */ ToastrComponent.prototype.tapToast = /** * @return {?} */ function () { if (this.state.value === 'removed') { return; } this.toastPackage.triggerTap(); if (this.options.tapToDismiss) { this.remove(); } }; /** * @return {?} */ ToastrComponent.prototype.stickAround = /** * @return {?} */ function () { if (this.state.value === 'removed') { return; } clearTimeout(this.timeout); this.options.timeOut = 0; this.hideTime = 0; // disable progressBar clearInterval(this.intervalId); this.width = 0; }; /** * @return {?} */ ToastrComponent.prototype.delayedHideToast = /** * @return {?} */ function () { var _this = this; if (this.options.disableTimeOut || this.options.extendedTimeOut === 0 || this.state.value === 'removed') { return; } this.outsideTimeout(function () { return _this.remove(); }, this.options.extendedTimeOut); this.options.timeOut = this.options.extendedTimeOut; this.hideTime = new Date().getTime() + (this.options.timeOut || 0); this.width = -1; if (this.options.progressBar) { this.outsideInterval(function () { return _this.updateProgress(); }, 10); } }; /** * @param {?} func * @param {?} timeout * @return {?} */ ToastrComponent.prototype.outsideTimeout = /** * @param {?} func * @param {?} timeout * @return {?} */ function (func, timeout) { var _this = this; if (this.ngZone) { this.ngZone.runOutsideAngular(function () { return (_this.timeout = setTimeout(function () { return _this.runInsideAngular(func); }, timeout)); }); } else { this.timeout = setTimeout(function () { return func(); }, timeout); } }; /** * @param {?} func * @param {?} timeout * @return {?} */ ToastrComponent.prototype.outsideInterval = /** * @param {?} func * @param {?} timeout * @return {?} */ function (func, timeout) { var _this = this; if (this.ngZone) { this.ngZone.runOutsideAngular(function () { return (_this.intervalId = setInterval(function () { return _this.runInsideAngular(func); }, timeout)); }); } else { this.intervalId = setInterval(function () { return func(); }, timeout); } }; /** * @param {?} func * @return {?} */ ToastrComponent.prototype.runInsideAngular = /** * @param {?} func * @return {?} */ function (func) { if (this.ngZone) { this.ngZone.run(function () { return func(); }); } else { func(); } }; ToastrComponent.decorators = [ { type: Component, args: [{ selector: '[hxa-toastr-component]', template: "\n\n <span class=\"hx-icon-control mr-2\">\n <i class=\"hx-icon is-medium icon-information\" *ngIf=\"toastPackage.toastType === 'is-info' || toastPackage.toastType === ''\"></i>\n <i class=\"hx-icon is-medium icon-check\" *ngIf=\"toastPackage.toastType === 'is-success'\"></i>\n <i class=\"hx-icon is-medium icon-warning\" *ngIf=\"toastPackage.toastType === 'is-warning' || toastPackage.toastType === 'is-danger'\"></i>\n </span>\n <div class=\"hx-flex-1\">\n <div *ngIf=\"title\" [class]=\"options.titleClass\" [attr.aria-label]=\"title\">\n {{ title }}\n </div>\n <div *ngIf=\"message && options.enableHtml\" role=\"alertdialog\" aria-live=\"polite\"\n [class]=\"options.messageClass\" [innerHTML]=\"message\">\n </div>\n <div *ngIf=\"message && !options.enableHtml\" role=\"alertdialog\" aria-live=\"polite\"\n [class]=\"options.messageClass\" [attr.aria-label]=\"message\">\n {{ message }}\n </div>\n </div>\n <div *ngIf=\"options.progressBar\">\n <div class=\"toast-progress\" [style.width]=\"width + '%'\"></div>\n </div>\n <span *ngIf=\"options.closeButton\" class=\"hx-icon-control ml-8\">\n <button (click)=\"remove()\" aria-label=\"Close\" class=\"hx-delete\"> <span aria-hidden=\"true\">&times;</span></button>\n </span>\n ", animations: [ trigger('flyInOut', [ state('inactive', style({ display: 'none', opacity: 0 })), state('active', style({})), state('removed', style({ opacity: 0 })), transition('inactive => active', animate('{{ easeTime }}ms {{ easing }}')), transition('active => removed', animate('{{ easeTime }}ms {{ easing }}')) ]) ], preserveWhitespaces: false },] }, ]; /** @nocollapse */ ToastrComponent.ctorParameters = function () { return [ { type: ToastrService }, { type: ToastPackage }, { type: NgZone } ]; }; ToastrComponent.propDecorators = { toastClasses: [{ type: HostBinding, args: ['class',] }], state: [{ type: HostBinding, args: ['@flyInOut',] }], tapToast: [{ type: HostListener, args: ['click',] }], stickAround: [{ type: HostListener, args: ['mouseenter',] }], delayedHideToast: [{ type: HostListener, args: ['mouseleave',] }] }; return ToastrComponent; }()); export { ToastrComponent }; if (false) { /** @type {?} */ ToastrComponent.prototype.message; /** @type {?} */ ToastrComponent.prototype.title; /** @type {?} */ ToastrComponent.prototype.options; /** @type {?} */ ToastrComponent.prototype.originalTimeout; /** * width of progress bar * @type {?} */ ToastrComponent.prototype.width; /** * a combination of toast type and options.toastClass * @type {?} */ ToastrComponent.prototype.toastClasses; /** * controls animation * @type {?} */ ToastrComponent.prototype.state; /** @type {?} */ ToastrComponent.prototype.timeout; /** @type {?} */ ToastrComponent.prototype.intervalId; /** @type {?} */ ToastrComponent.prototype.hideTime; /** @type {?} */ ToastrComponent.prototype.sub; /** @type {?} */ ToastrComponent.prototype.sub1; /** @type {?} */ ToastrComponent.prototype.sub2; /** @type {?} */ ToastrComponent.prototype.toastrService; /** @type {?} */ ToastrComponent.prototype.toastPackage; /** @type {?} */ ToastrComponent.prototype.ngZone; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toastr.component.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/toastr/toastr.component.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EACL,OAAO,EACP,KAAK,EACL,KAAK,EACL,UAAU,EACV,OAAO,EACR,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,SAAS,EACT,WAAW,EACX,YAAY,EACZ,MAAM,EAEP,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAoB,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD;IAyEE,yBACY,aAA4B,EAC/B,YAA0B,EACvB,MAAe;QAH3B,iBAqBC;QApBW,kBAAa,GAAb,aAAa,CAAe;QAC/B,iBAAY,GAAZ,YAAY,CAAc;QACvB,WAAM,GAAN,MAAM,CAAS;;;;QAtB3B,UAAK,GAAG,CAAC,CAAC,CAAC;;;;QAEW,iBAAY,GAAG,EAAE,CAAC;;;;QAGxC,UAAK,GAAG;YACN,KAAK,EAAE,UAAU;YACjB,MAAM,EAAE;gBACN,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ;gBAC3C,MAAM,EAAE,SAAS;aAClB;SACF,CAAC;QAaA,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC;QACpC,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,MAAM,CAAC;QACnC,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC;QACnD,IAAI,CAAC,YAAY,GAAM,YAAY,CAAC,SAAS,SAC3C,YAAY,CAAC,MAAM,CAAC,UACpB,CAAC;QACH,IAAI,CAAC,GAAG,GAAG,YAAY,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC;YACzD,KAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC;YACzD,KAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC;YACzD,KAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;;;;IACD,qCAAW;;;IAAX;QACE,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACxB,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC/B,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IACD;;OAEG;;;;;IACH,uCAAa;;;;IAAb;QAAA,iBASC;QARC,IAAI,CAAC,KAAK,wBAAQ,IAAI,CAAC,KAAK,IAAE,KAAK,EAAE,QAAQ,GAAE,CAAC;QAChD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;YACxD,IAAI,CAAC,cAAc,CAAC,cAAM,OAAA,KAAI,CAAC,MAAM,EAAE,EAAb,CAAa,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAC/D,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;YAC5D,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;gBAC5B,IAAI,CAAC,eAAe,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB,EAAE,EAAE,CAAC,CAAC;aACvD;SACF;IACH,CAAC;IACD;;OAEG;;;;;IACH,wCAAc;;;;IAAd;QACE,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;YACnE,OAAO;SACR;;YACK,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE;;YAC1B,SAAS,GAAG,IAAI,CAAC,QAAQ,GAAG,GAAG;QACrC,IAAI,CAAC,KAAK,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,GAAG,CAAC;QACtD,IAAI,IAAI,CAAC,OAAO,CAAC,iBAAiB,KAAK,YAAY,EAAE;YACnD,IAAI,CAAC,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC;SAC/B;QACD,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,EAAE;YACnB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;SAChB;QACD,IAAI,IAAI,CAAC,KAAK,IAAI,GAAG,EAAE;YACrB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;SAClB;IACH,CAAC;;;;IAED,sCAAY;;;IAAZ;QAAA,iBAYC;QAXC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3B,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC/B,IAAI,CAAC,KAAK,wBAAQ,IAAI,CAAC,KAAK,IAAE,KAAK,EAAE,QAAQ,GAAE,CAAC;QAEhD,IAAI,CAAC,cAAc,CAAC,cAAM,OAAA,KAAI,CAAC,MAAM,EAAE,EAAb,CAAa,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAC/D,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC;QAC5C,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAChB,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YAC5B,IAAI,CAAC,eAAe,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB,EAAE,EAAE,CAAC,CAAC;SACvD;IACH,CAAC;IAED;;OAEG;;;;;IACH,gCAAM;;;;IAAN;QAAA,iBAUC;QATC,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE;YAClC,OAAO;SACR;QACD,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,KAAK,wBAAQ,IAAI,CAAC,KAAK,IAAE,KAAK,EAAE,SAAS,GAAE,CAAC;QACjD,IAAI,CAAC,cAAc,CACjB,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAApD,CAAoD,EAC1D,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,QAAQ,CACnC,CAAC;IACJ,CAAC;;;;IAED,kCAAQ;;;IADR;QAEE,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE;YAClC,OAAO;SACR;QACD,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;QAC/B,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE;YAC7B,IAAI,CAAC,MAAM,EAAE,CAAC;SACf;IACH,CAAC;;;;IAED,qCAAW;;;IADX;QAEE,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,SAAS,EAAE;YAClC,OAAO;SACR;QACD,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;QAElB,sBAAsB;QACtB,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC/B,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACjB,CAAC;;;;IAED,0CAAgB;;;IADhB;QAAA,iBAgBC;QAdC,IACE,IAAI,CAAC,OAAO,CAAC,cAAc;YAC3B,IAAI,CAAC,OAAO,CAAC,eAAe,KAAK,CAAC;YAClC,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,SAAS,EAC9B;YACA,OAAO;SACR;QACD,IAAI,CAAC,cAAc,CAAC,cAAM,OAAA,KAAI,CAAC,MAAM,EAAE,EAAb,CAAa,EAAE,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QACvE,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;QACpD,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QAChB,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YAC5B,IAAI,CAAC,eAAe,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB,EAAE,EAAE,CAAC,CAAC;SACvD;IACH,CAAC;;;;;;IAED,wCAAc;;;;;IAAd,UAAe,IAAc,EAAE,OAAe;QAA9C,iBAYC;QAXC,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAC3B;gBACE,OAAA,CAAC,KAAI,CAAC,OAAO,GAAG,UAAU,CACxB,cAAM,OAAA,KAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAA3B,CAA2B,EACjC,OAAO,CACR,CAAC;YAHF,CAGE,CACL,CAAC;SACH;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,cAAM,OAAA,IAAI,EAAE,EAAN,CAAM,EAAE,OAAO,CAAC,CAAC;SAClD;IACH,CAAC;;;;;;IAED,yCAAe;;;;;IAAf,UAAgB,IAAc,EAAE,OAAe;QAA/C,iBAYC;QAXC,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAC3B;gBACE,OAAA,CAAC,KAAI,CAAC,UAAU,GAAG,WAAW,CAC5B,cAAM,OAAA,KAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAA3B,CAA2B,EACjC,OAAO,CACR,CAAC;YAHF,CAGE,CACL,CAAC;SACH;aAAM;YACL,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,cAAM,OAAA,IAAI,EAAE,EAAN,CAAM,EAAE,OAAO,CAAC,CAAC;SACtD;IACH,CAAC;;;;;IAEO,0CAAgB;;;;IAAxB,UAAyB,IAAc;QACrC,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,cAAM,OAAA,IAAI,EAAE,EAAN,CAAM,CAAC,CAAC;SAC/B;aAAM;YACL,IAAI,EAAE,CAAC;SACR;IACH,CAAC;;gBA/OF,SAAS,SAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,QAAQ,EAAE,s1CAyBT;oBACD,UAAU,EAAE;wBACV,OAAO,CAAC,UAAU,EAAE;4BAClB,KAAK,CACH,UAAU,EACV,KAAK,CAAC;gCACJ,OAAO,EAAE,MAAM;gCACf,OAAO,EAAE,CAAC;6BACX,CAAC,CACH;4BACD,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,CAAC;4BAC1B,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;4BACvC,UAAU,CACR,oBAAoB,EACpB,OAAO,CAAC,+BAA+B,CAAC,CACzC;4BACD,UAAU,CAAC,mBAAmB,EAAE,OAAO,CAAC,+BAA+B,CAAC,CAAC;yBAC1E,CAAC;qBACH;oBACD,mBAAmB,EAAE,KAAK;iBAC3B;;;;gBAjDQ,aAAa;gBADK,YAAY;gBALrC,MAAM;;;+BAgEL,WAAW,SAAC,OAAO;wBAEnB,WAAW,SAAC,WAAW;2BA0GvB,YAAY,SAAC,OAAO;8BAUpB,YAAY,SAAC,YAAY;mCAazB,YAAY,SAAC,YAAY;;IAqD5B,sBAAC;CAAA,AAhPD,IAgPC;SAhMY,eAAe;;;IAC1B,kCAAmC;;IACnC,gCAAe;;IACf,kCAA0B;;IAC1B,0CAAwB;;;;;IAExB,gCAAW;;;;;IAEX,uCAAwC;;;;;IAExC,gCAOE;;IACF,kCAAqB;;IACrB,qCAAwB;;IACxB,mCAAyB;;IACzB,8BAA0B;;IAC1B,+BAA2B;;IAC3B,+BAA2B;;IAGzB,wCAAsC;;IACtC,uCAAiC;;IACjC,iCAAyB","sourcesContent":["import {\r\n  animate,\r\n  state,\r\n  style,\r\n  transition,\r\n  trigger\r\n} from '@angular/animations';\r\nimport {\r\n  Component,\r\n  HostBinding,\r\n  HostListener,\r\n  NgZone,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport { SafeHtml } from '@angular/platform-browser';\r\nimport { Subscription } from 'rxjs';\r\nimport { IndividualConfig, ToastPackage } from './toastr-config';\r\nimport { ToastrService } from './toastr.service';\r\n\r\n@Component({\r\n  selector: '[hxa-toastr-component]',\r\n  template: `\r\n\r\n    <span class=\"hx-icon-control mr-2\">\r\n        <i class=\"hx-icon is-medium icon-information\" *ngIf=\"toastPackage.toastType === 'is-info' || toastPackage.toastType === ''\"></i>\r\n        <i class=\"hx-icon is-medium icon-check\" *ngIf=\"toastPackage.toastType === 'is-success'\"></i>\r\n        <i class=\"hx-icon is-medium icon-warning\" *ngIf=\"toastPackage.toastType === 'is-warning' || toastPackage.toastType === 'is-danger'\"></i>\r\n      </span>\r\n    <div class=\"hx-flex-1\">\r\n        <div *ngIf=\"title\" [class]=\"options.titleClass\" [attr.aria-label]=\"title\">\r\n        {{ title }}\r\n      </div>\r\n      <div *ngIf=\"message && options.enableHtml\" role=\"alertdialog\" aria-live=\"polite\"\r\n           [class]=\"options.messageClass\" [innerHTML]=\"message\">\r\n      </div>\r\n      <div *ngIf=\"message && !options.enableHtml\" role=\"alertdialog\" aria-live=\"polite\"\r\n           [class]=\"options.messageClass\" [attr.aria-label]=\"message\">\r\n        {{ message }}\r\n      </div>\r\n    </div>\r\n    <div *ngIf=\"options.progressBar\">\r\n      <div class=\"toast-progress\" [style.width]=\"width + '%'\"></div>\r\n    </div>\r\n      <span *ngIf=\"options.closeButton\" class=\"hx-icon-control ml-8\">\r\n        <button (click)=\"remove()\" aria-label=\"Close\" class=\"hx-delete\"> <span aria-hidden=\"true\">&times;</span></button>\r\n      </span>\r\n  `,\r\n  animations: [\r\n    trigger('flyInOut', [\r\n      state(\r\n        'inactive',\r\n        style({\r\n          display: 'none',\r\n          opacity: 0\r\n        })\r\n      ),\r\n      state('active', style({})),\r\n      state('removed', style({ opacity: 0 })),\r\n      transition(\r\n        'inactive => active',\r\n        animate('{{ easeTime }}ms {{ easing }}')\r\n      ),\r\n      transition('active => removed', animate('{{ easeTime }}ms {{ easing }}'))\r\n    ])\r\n  ],\r\n  preserveWhitespaces: false\r\n})\r\nexport class ToastrComponent implements OnDestroy {\r\n  message?: string | SafeHtml | null;\r\n  title?: string;\r\n  options: IndividualConfig;\r\n  originalTimeout: number;\r\n  /** width of progress bar */\r\n  width = -1;\r\n  /** a combination of toast type and options.toastClass */\r\n  @HostBinding('class') toastClasses = '';\r\n  /** controls animation */\r\n  @HostBinding('@flyInOut')\r\n  state = {\r\n    value: 'inactive',\r\n    params: {\r\n      easeTime: this.toastPackage.config.easeTime,\r\n      easing: 'ease-in'\r\n    }\r\n  };\r\n  private timeout: any;\r\n  private intervalId: any;\r\n  private hideTime: number;\r\n  private sub: Subscription;\r\n  private sub1: Subscription;\r\n  private sub2: Subscription;\r\n\r\n  constructor(\r\n    protected toastrService: ToastrService,\r\n    public toastPackage: ToastPackage,\r\n    protected ngZone?: NgZone\r\n  ) {\r\n    this.message = toastPackage.message;\r\n    this.title = toastPackage.title;\r\n    this.options = toastPackage.config;\r\n    this.originalTimeout = toastPackage.config.timeOut;\r\n    this.toastClasses = `${toastPackage.toastType} ${\r\n      toastPackage.config.toastClass\r\n    }`;\r\n    this.sub = toastPackage.toastRef.afterActivate().subscribe(() => {\r\n      this.activateToast();\r\n    });\r\n    this.sub1 = toastPackage.toastRef.manualClosed().subscribe(() => {\r\n      this.remove();\r\n    });\r\n    this.sub2 = toastPackage.toastRef.timeoutReset().subscribe(() => {\r\n      this.resetTimeout();\r\n    });\r\n  }\r\n  ngOnDestroy() {\r\n    this.sub.unsubscribe();\r\n    this.sub1.unsubscribe();\r\n    this.sub2.unsubscribe();\r\n    clearInterval(this.intervalId);\r\n    clearTimeout(this.timeout);\r\n  }\r\n  /**\r\n   * activates toast and sets timeout\r\n   */\r\n  activateToast() {\r\n    this.state = { ...this.state, value: 'active' };\r\n    if (!this.options.disableTimeOut && this.options.timeOut) {\r\n      this.outsideTimeout(() => this.remove(), this.options.timeOut);\r\n      this.hideTime = new Date().getTime() + this.options.timeOut;\r\n      if (this.options.progressBar) {\r\n        this.outsideInterval(() => this.updateProgress(), 10);\r\n      }\r\n    }\r\n  }\r\n  /**\r\n   * updates progress bar width\r\n   */\r\n  updateProgress() {\r\n    if (this.width === 0 || this.width === 100 || !this.options.timeOut) {\r\n      return;\r\n    }\r\n    const now = new Date().getTime();\r\n    const remaining = this.hideTime - now;\r\n    this.width = (remaining / this.options.timeOut) * 100;\r\n    if (this.options.progressAnimation === 'increasing') {\r\n      this.width = 100 - this.width;\r\n    }\r\n    if (this.width <= 0) {\r\n      this.width = 0;\r\n    }\r\n    if (this.width >= 100) {\r\n      this.width = 100;\r\n    }\r\n  }\r\n\r\n  resetTimeout() {\r\n    clearTimeout(this.timeout);\r\n    clearInterval(this.intervalId);\r\n    this.state = { ...this.state, value: 'active' };\r\n\r\n    this.outsideTimeout(() => this.remove(), this.originalTimeout);\r\n    this.options.timeOut = this.originalTimeout;\r\n    this.hideTime = new Date().getTime() + (this.options.timeOut || 0);\r\n    this.width = -1;\r\n    if (this.options.progressBar) {\r\n      this.outsideInterval(() => this.updateProgress(), 10);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * tells toastrService to remove this toast after animation time\r\n   */\r\n  remove() {\r\n    if (this.state.value === 'removed') {\r\n      return;\r\n    }\r\n    clearTimeout(this.timeout);\r\n    this.state = { ...this.state, value: 'removed' };\r\n    this.outsideTimeout(\r\n      () => this.toastrService.remove(this.toastPackage.toastId),\r\n      +this.toastPackage.config.easeTime\r\n    );\r\n  }\r\n  @HostListener('click')\r\n  tapToast() {\r\n    if (this.state.value === 'removed') {\r\n      return;\r\n    }\r\n    this.toastPackage.triggerTap();\r\n    if (this.options.tapToDismiss) {\r\n      this.remove();\r\n    }\r\n  }\r\n  @HostListener('mouseenter')\r\n  stickAround() {\r\n    if (this.state.value === 'removed') {\r\n      return;\r\n    }\r\n    clearTimeout(this.timeout);\r\n    this.options.timeOut = 0;\r\n    this.hideTime = 0;\r\n\r\n    // disable progressBar\r\n    clearInterval(this.intervalId);\r\n    this.width = 0;\r\n  }\r\n  @HostListener('mouseleave')\r\n  delayedHideToast() {\r\n    if (\r\n      this.options.disableTimeOut ||\r\n      this.options.extendedTimeOut === 0 ||\r\n      this.state.value === 'removed'\r\n    ) {\r\n      return;\r\n    }\r\n    this.outsideTimeout(() => this.remove(), this.options.extendedTimeOut);\r\n    this.options.timeOut = this.options.extendedTimeOut;\r\n    this.hideTime = new Date().getTime() + (this.options.timeOut || 0);\r\n    this.width = -1;\r\n    if (this.options.progressBar) {\r\n      this.outsideInterval(() => this.updateProgress(), 10);\r\n    }\r\n  }\r\n\r\n  outsideTimeout(func: Function, timeout: number) {\r\n    if (this.ngZone) {\r\n      this.ngZone.runOutsideAngular(\r\n        () =>\r\n          (this.timeout = setTimeout(\r\n            () => this.runInsideAngular(func),\r\n            timeout\r\n          ))\r\n      );\r\n    } else {\r\n      this.timeout = setTimeout(() => func(), timeout);\r\n    }\r\n  }\r\n\r\n  outsideInterval(func: Function, timeout: number) {\r\n    if (this.ngZone) {\r\n      this.ngZone.runOutsideAngular(\r\n        () =>\r\n          (this.intervalId = setInterval(\r\n            () => this.runInsideAngular(func),\r\n            timeout\r\n          ))\r\n      );\r\n    } else {\r\n      this.intervalId = setInterval(() => func(), timeout);\r\n    }\r\n  }\r\n\r\n  private runInsideAngular(func: Function) {\r\n    if (this.ngZone) {\r\n      this.ngZone.run(() => func());\r\n    } else {\r\n      func();\r\n    }\r\n  }\r\n}\r\n"]}