@hxui/angular
Version:
* * *
342 lines • 32.7 kB
JavaScript
/**
* @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\">×</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"]}