toast.component.js 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. import * as tslib_1 from "tslib";
  2. import { animate, state, style, transition, trigger } from '@angular/animations';
  3. import { Component, HostBinding, HostListener, NgZone } from '@angular/core';
  4. import { ToastPackage } from './toastr-config';
  5. import { ToastrService } from './toastr.service';
  6. var Toast = /** @class */ (function () {
  7. function Toast(toastrService, toastPackage, ngZone) {
  8. var _this = this;
  9. this.toastrService = toastrService;
  10. this.toastPackage = toastPackage;
  11. this.ngZone = ngZone;
  12. /** width of progress bar */
  13. this.width = -1;
  14. /** a combination of toast type and options.toastClass */
  15. this.toastClasses = '';
  16. /** controls animation */
  17. this.state = {
  18. value: 'inactive',
  19. params: {
  20. easeTime: this.toastPackage.config.easeTime,
  21. easing: 'ease-in'
  22. }
  23. };
  24. this.message = toastPackage.message;
  25. this.title = toastPackage.title;
  26. this.options = toastPackage.config;
  27. this.originalTimeout = toastPackage.config.timeOut;
  28. this.toastClasses = toastPackage.toastType + " " + toastPackage.config.toastClass;
  29. this.sub = toastPackage.toastRef.afterActivate().subscribe(function () {
  30. _this.activateToast();
  31. });
  32. this.sub1 = toastPackage.toastRef.manualClosed().subscribe(function () {
  33. _this.remove();
  34. });
  35. this.sub2 = toastPackage.toastRef.timeoutReset().subscribe(function () {
  36. _this.resetTimeout();
  37. });
  38. this.sub3 = toastPackage.toastRef.countDuplicate().subscribe(function (count) {
  39. _this.duplicatesCount = count;
  40. });
  41. }
  42. Object.defineProperty(Toast.prototype, "displayStyle", {
  43. /** hides component when waiting to be displayed */
  44. get: function () {
  45. if (this.state.value === 'inactive') {
  46. return 'none';
  47. }
  48. },
  49. enumerable: true,
  50. configurable: true
  51. });
  52. Toast.prototype.ngOnDestroy = function () {
  53. this.sub.unsubscribe();
  54. this.sub1.unsubscribe();
  55. this.sub2.unsubscribe();
  56. this.sub3.unsubscribe();
  57. clearInterval(this.intervalId);
  58. clearTimeout(this.timeout);
  59. };
  60. /**
  61. * activates toast and sets timeout
  62. */
  63. Toast.prototype.activateToast = function () {
  64. var _this = this;
  65. this.state = tslib_1.__assign({}, this.state, { value: 'active' });
  66. if (!this.options.disableTimeOut && this.options.timeOut) {
  67. this.outsideTimeout(function () { return _this.remove(); }, this.options.timeOut);
  68. this.hideTime = new Date().getTime() + this.options.timeOut;
  69. if (this.options.progressBar) {
  70. this.outsideInterval(function () { return _this.updateProgress(); }, 10);
  71. }
  72. }
  73. };
  74. /**
  75. * updates progress bar width
  76. */
  77. Toast.prototype.updateProgress = function () {
  78. if (this.width === 0 || this.width === 100 || !this.options.timeOut) {
  79. return;
  80. }
  81. var now = new Date().getTime();
  82. var remaining = this.hideTime - now;
  83. this.width = (remaining / this.options.timeOut) * 100;
  84. if (this.options.progressAnimation === 'increasing') {
  85. this.width = 100 - this.width;
  86. }
  87. if (this.width <= 0) {
  88. this.width = 0;
  89. }
  90. if (this.width >= 100) {
  91. this.width = 100;
  92. }
  93. };
  94. Toast.prototype.resetTimeout = function () {
  95. var _this = this;
  96. clearTimeout(this.timeout);
  97. clearInterval(this.intervalId);
  98. this.state = tslib_1.__assign({}, this.state, { value: 'active' });
  99. this.outsideTimeout(function () { return _this.remove(); }, this.originalTimeout);
  100. this.options.timeOut = this.originalTimeout;
  101. this.hideTime = new Date().getTime() + (this.options.timeOut || 0);
  102. this.width = -1;
  103. if (this.options.progressBar) {
  104. this.outsideInterval(function () { return _this.updateProgress(); }, 10);
  105. }
  106. };
  107. /**
  108. * tells toastrService to remove this toast after animation time
  109. */
  110. Toast.prototype.remove = function () {
  111. var _this = this;
  112. if (this.state.value === 'removed') {
  113. return;
  114. }
  115. clearTimeout(this.timeout);
  116. this.state = tslib_1.__assign({}, this.state, { value: 'removed' });
  117. this.outsideTimeout(function () { return _this.toastrService.remove(_this.toastPackage.toastId); }, +this.toastPackage.config.easeTime);
  118. };
  119. Toast.prototype.tapToast = function () {
  120. if (this.state.value === 'removed') {
  121. return;
  122. }
  123. this.toastPackage.triggerTap();
  124. if (this.options.tapToDismiss) {
  125. this.remove();
  126. }
  127. };
  128. Toast.prototype.stickAround = function () {
  129. if (this.state.value === 'removed') {
  130. return;
  131. }
  132. clearTimeout(this.timeout);
  133. this.options.timeOut = 0;
  134. this.hideTime = 0;
  135. // disable progressBar
  136. clearInterval(this.intervalId);
  137. this.width = 0;
  138. };
  139. Toast.prototype.delayedHideToast = function () {
  140. var _this = this;
  141. if (this.options.disableTimeOut ||
  142. this.options.extendedTimeOut === 0 ||
  143. this.state.value === 'removed') {
  144. return;
  145. }
  146. this.outsideTimeout(function () { return _this.remove(); }, this.options.extendedTimeOut);
  147. this.options.timeOut = this.options.extendedTimeOut;
  148. this.hideTime = new Date().getTime() + (this.options.timeOut || 0);
  149. this.width = -1;
  150. if (this.options.progressBar) {
  151. this.outsideInterval(function () { return _this.updateProgress(); }, 10);
  152. }
  153. };
  154. Toast.prototype.outsideTimeout = function (func, timeout) {
  155. var _this = this;
  156. if (this.ngZone) {
  157. this.ngZone.runOutsideAngular(function () {
  158. return (_this.timeout = setTimeout(function () { return _this.runInsideAngular(func); }, timeout));
  159. });
  160. }
  161. else {
  162. this.timeout = setTimeout(function () { return func(); }, timeout);
  163. }
  164. };
  165. Toast.prototype.outsideInterval = function (func, timeout) {
  166. var _this = this;
  167. if (this.ngZone) {
  168. this.ngZone.runOutsideAngular(function () {
  169. return (_this.intervalId = setInterval(function () { return _this.runInsideAngular(func); }, timeout));
  170. });
  171. }
  172. else {
  173. this.intervalId = setInterval(function () { return func(); }, timeout);
  174. }
  175. };
  176. Toast.prototype.runInsideAngular = function (func) {
  177. if (this.ngZone) {
  178. this.ngZone.run(function () { return func(); });
  179. }
  180. else {
  181. func();
  182. }
  183. };
  184. tslib_1.__decorate([
  185. HostBinding('class'),
  186. tslib_1.__metadata("design:type", Object)
  187. ], Toast.prototype, "toastClasses", void 0);
  188. tslib_1.__decorate([
  189. HostBinding('@flyInOut'),
  190. tslib_1.__metadata("design:type", Object)
  191. ], Toast.prototype, "state", void 0);
  192. tslib_1.__decorate([
  193. HostBinding('style.display'),
  194. tslib_1.__metadata("design:type", Object),
  195. tslib_1.__metadata("design:paramtypes", [])
  196. ], Toast.prototype, "displayStyle", null);
  197. tslib_1.__decorate([
  198. HostListener('click'),
  199. tslib_1.__metadata("design:type", Function),
  200. tslib_1.__metadata("design:paramtypes", []),
  201. tslib_1.__metadata("design:returntype", void 0)
  202. ], Toast.prototype, "tapToast", null);
  203. tslib_1.__decorate([
  204. HostListener('mouseenter'),
  205. tslib_1.__metadata("design:type", Function),
  206. tslib_1.__metadata("design:paramtypes", []),
  207. tslib_1.__metadata("design:returntype", void 0)
  208. ], Toast.prototype, "stickAround", null);
  209. tslib_1.__decorate([
  210. HostListener('mouseleave'),
  211. tslib_1.__metadata("design:type", Function),
  212. tslib_1.__metadata("design:paramtypes", []),
  213. tslib_1.__metadata("design:returntype", void 0)
  214. ], Toast.prototype, "delayedHideToast", null);
  215. Toast = tslib_1.__decorate([
  216. Component({
  217. selector: '[toast-component]',
  218. template: "\n <button *ngIf=\"options.closeButton\" (click)=\"remove()\" class=\"toast-close-button\" aria-label=\"Close\">\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <div *ngIf=\"title\" [class]=\"options.titleClass\" [attr.aria-label]=\"title\">\n {{ title }} <ng-container *ngIf=\"duplicatesCount\">[{{ duplicatesCount + 1 }}]</ng-container>\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 *ngIf=\"options.progressBar\">\n <div class=\"toast-progress\" [style.width]=\"width + '%'\"></div>\n </div>\n ",
  219. animations: [
  220. trigger('flyInOut', [
  221. state('inactive', style({ opacity: 0 })),
  222. state('active', style({ opacity: 1 })),
  223. state('removed', style({ opacity: 0 })),
  224. transition('inactive => active', animate('{{ easeTime }}ms {{ easing }}')),
  225. transition('active => removed', animate('{{ easeTime }}ms {{ easing }}'))
  226. ])
  227. ],
  228. preserveWhitespaces: false
  229. }),
  230. tslib_1.__metadata("design:paramtypes", [ToastrService,
  231. ToastPackage,
  232. NgZone])
  233. ], Toast);
  234. return Toast;
  235. }());
  236. export { Toast };
  237. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"ng://ngx-toastr/","sources":["toastr/toast.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  state,\n  style,\n  transition,\n  trigger\n} from '@angular/animations';\nimport {\n  Component,\n  HostBinding,\n  HostListener,\n  NgZone,\n  OnDestroy\n} from '@angular/core';\nimport { SafeHtml } from '@angular/platform-browser';\nimport { Subscription } from 'rxjs';\nimport { IndividualConfig, ToastPackage } from './toastr-config';\nimport { ToastrService } from './toastr.service';\n\n@Component({\n  selector: '[toast-component]',\n  template: `\n  <button *ngIf=\"options.closeButton\" (click)=\"remove()\" class=\"toast-close-button\" aria-label=\"Close\">\n    <span aria-hidden=\"true\">&times;</span>\n  </button>\n  <div *ngIf=\"title\" [class]=\"options.titleClass\" [attr.aria-label]=\"title\">\n    {{ title }} <ng-container *ngIf=\"duplicatesCount\">[{{ duplicatesCount + 1 }}]</ng-container>\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 *ngIf=\"options.progressBar\">\n    <div class=\"toast-progress\" [style.width]=\"width + '%'\"></div>\n  </div>\n  `,\n  animations: [\n    trigger('flyInOut', [\n      state('inactive', style({ opacity: 0 })),\n      state('active', style({ opacity: 1 })),\n      state('removed', style({ opacity: 0 })),\n      transition(\n        'inactive => active',\n        animate('{{ easeTime }}ms {{ easing }}')\n      ),\n      transition(\n        'active => removed',\n        animate('{{ easeTime }}ms {{ easing }}')\n      )\n    ])\n  ],\n  preserveWhitespaces: false\n})\nexport class Toast implements OnDestroy {\n  message?: string | SafeHtml | null;\n  title?: string;\n  options: IndividualConfig;\n  duplicatesCount: number;\n  originalTimeout: number;\n  /** width of progress bar */\n  width = -1;\n  /** a combination of toast type and options.toastClass */\n  @HostBinding('class') toastClasses = '';\n  /** controls animation */\n  @HostBinding('@flyInOut')\n  state = {\n    value: 'inactive',\n    params: {\n      easeTime: this.toastPackage.config.easeTime,\n      easing: 'ease-in'\n    }\n  };\n\n  /** hides component when waiting to be displayed */\n  @HostBinding('style.display')\n  get displayStyle() {\n    if (this.state.value === 'inactive') {\n      return 'none';\n    }\n  }\n\n  private timeout: any;\n  private intervalId: any;\n  private hideTime: number;\n  private sub: Subscription;\n  private sub1: Subscription;\n  private sub2: Subscription;\n  private sub3: Subscription;\n\n  constructor(\n    protected toastrService: ToastrService,\n    public toastPackage: ToastPackage,\n    protected ngZone?: NgZone\n  ) {\n    this.message = toastPackage.message;\n    this.title = toastPackage.title;\n    this.options = toastPackage.config;\n    this.originalTimeout = toastPackage.config.timeOut;\n    this.toastClasses = `${toastPackage.toastType} ${\n      toastPackage.config.toastClass\n    }`;\n    this.sub = toastPackage.toastRef.afterActivate().subscribe(() => {\n      this.activateToast();\n    });\n    this.sub1 = toastPackage.toastRef.manualClosed().subscribe(() => {\n      this.remove();\n    });\n    this.sub2 = toastPackage.toastRef.timeoutReset().subscribe(() => {\n      this.resetTimeout();\n    });\n    this.sub3 = toastPackage.toastRef.countDuplicate().subscribe(count => {\n      this.duplicatesCount = count;\n    });\n  }\n  ngOnDestroy() {\n    this.sub.unsubscribe();\n    this.sub1.unsubscribe();\n    this.sub2.unsubscribe();\n    this.sub3.unsubscribe();\n    clearInterval(this.intervalId);\n    clearTimeout(this.timeout);\n  }\n  /**\n   * activates toast and sets timeout\n   */\n  activateToast() {\n    this.state = { ...this.state, value: 'active' };\n    if (!this.options.disableTimeOut && this.options.timeOut) {\n      this.outsideTimeout(() => this.remove(), this.options.timeOut);\n      this.hideTime = new Date().getTime() + this.options.timeOut;\n      if (this.options.progressBar) {\n        this.outsideInterval(() => this.updateProgress(), 10);\n      }\n    }\n  }\n  /**\n   * updates progress bar width\n   */\n  updateProgress() {\n    if (this.width === 0 || this.width === 100 || !this.options.timeOut) {\n      return;\n    }\n    const now = new Date().getTime();\n    const remaining = this.hideTime - now;\n    this.width = (remaining / this.options.timeOut) * 100;\n    if (this.options.progressAnimation === 'increasing') {\n      this.width = 100 - this.width;\n    }\n    if (this.width <= 0) {\n      this.width = 0;\n    }\n    if (this.width >= 100) {\n      this.width = 100;\n    }\n  }\n\n  resetTimeout() {\n    clearTimeout(this.timeout);\n    clearInterval(this.intervalId);\n    this.state = { ...this.state, value: 'active' };\n\n    this.outsideTimeout(() => this.remove(), this.originalTimeout);\n    this.options.timeOut = this.originalTimeout;\n    this.hideTime = new Date().getTime() + (this.options.timeOut || 0);\n    this.width = -1;\n    if (this.options.progressBar) {\n      this.outsideInterval(() => this.updateProgress(), 10);\n    }\n  }\n\n  /**\n   * tells toastrService to remove this toast after animation time\n   */\n  remove() {\n    if (this.state.value === 'removed') {\n      return;\n    }\n    clearTimeout(this.timeout);\n    this.state = { ...this.state, value: 'removed' };\n    this.outsideTimeout(\n      () => this.toastrService.remove(this.toastPackage.toastId),\n      +this.toastPackage.config.easeTime\n    );\n  }\n  @HostListener('click')\n  tapToast() {\n    if (this.state.value === 'removed') {\n      return;\n    }\n    this.toastPackage.triggerTap();\n    if (this.options.tapToDismiss) {\n      this.remove();\n    }\n  }\n  @HostListener('mouseenter')\n  stickAround() {\n    if (this.state.value === 'removed') {\n      return;\n    }\n    clearTimeout(this.timeout);\n    this.options.timeOut = 0;\n    this.hideTime = 0;\n\n    // disable progressBar\n    clearInterval(this.intervalId);\n    this.width = 0;\n  }\n  @HostListener('mouseleave')\n  delayedHideToast() {\n    if (\n      this.options.disableTimeOut ||\n      this.options.extendedTimeOut === 0 ||\n      this.state.value === 'removed'\n    ) {\n      return;\n    }\n    this.outsideTimeout(() => this.remove(), this.options.extendedTimeOut);\n    this.options.timeOut = this.options.extendedTimeOut;\n    this.hideTime = new Date().getTime() + (this.options.timeOut || 0);\n    this.width = -1;\n    if (this.options.progressBar) {\n      this.outsideInterval(() => this.updateProgress(), 10);\n    }\n  }\n\n  outsideTimeout(func: Function, timeout: number) {\n    if (this.ngZone) {\n      this.ngZone.runOutsideAngular(\n        () =>\n          (this.timeout = setTimeout(\n            () => this.runInsideAngular(func),\n            timeout\n          ))\n      );\n    } else {\n      this.timeout = setTimeout(() => func(), timeout);\n    }\n  }\n\n  outsideInterval(func: Function, timeout: number) {\n    if (this.ngZone) {\n      this.ngZone.runOutsideAngular(\n        () =>\n          (this.intervalId = setInterval(\n            () => this.runInsideAngular(func),\n            timeout\n          ))\n      );\n    } else {\n      this.intervalId = setInterval(() => func(), timeout);\n    }\n  }\n\n  private runInsideAngular(func: Function) {\n    if (this.ngZone) {\n      this.ngZone.run(() => func());\n    } else {\n      func();\n    }\n  }\n}\n"]}