toast-noanimation.component.js 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. import * as tslib_1 from "tslib";
  2. import { CommonModule } from '@angular/common';
  3. import { ApplicationRef, Component, HostBinding, HostListener, NgModule, } from '@angular/core';
  4. import { DefaultNoComponentGlobalConfig, ToastPackage, TOAST_CONFIG, } from './toastr-config';
  5. import { ToastrService } from './toastr.service';
  6. var ToastNoAnimation = /** @class */ (function () {
  7. function ToastNoAnimation(toastrService, toastPackage, appRef) {
  8. var _this = this;
  9. this.toastrService = toastrService;
  10. this.toastPackage = toastPackage;
  11. this.appRef = appRef;
  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 = 'inactive';
  18. this.message = toastPackage.message;
  19. this.title = toastPackage.title;
  20. this.options = toastPackage.config;
  21. this.originalTimeout = toastPackage.config.timeOut;
  22. this.toastClasses = toastPackage.toastType + " " + toastPackage.config.toastClass;
  23. this.sub = toastPackage.toastRef.afterActivate().subscribe(function () {
  24. _this.activateToast();
  25. });
  26. this.sub1 = toastPackage.toastRef.manualClosed().subscribe(function () {
  27. _this.remove();
  28. });
  29. this.sub2 = toastPackage.toastRef.timeoutReset().subscribe(function () {
  30. _this.resetTimeout();
  31. });
  32. this.sub3 = toastPackage.toastRef.countDuplicate().subscribe(function (count) {
  33. _this.duplicatesCount = count;
  34. });
  35. }
  36. Object.defineProperty(ToastNoAnimation.prototype, "displayStyle", {
  37. /** hides component when waiting to be displayed */
  38. get: function () {
  39. if (this.state === 'inactive') {
  40. return 'none';
  41. }
  42. },
  43. enumerable: true,
  44. configurable: true
  45. });
  46. ToastNoAnimation.prototype.ngOnDestroy = function () {
  47. this.sub.unsubscribe();
  48. this.sub1.unsubscribe();
  49. this.sub2.unsubscribe();
  50. this.sub3.unsubscribe();
  51. clearInterval(this.intervalId);
  52. clearTimeout(this.timeout);
  53. };
  54. /**
  55. * activates toast and sets timeout
  56. */
  57. ToastNoAnimation.prototype.activateToast = function () {
  58. var _this = this;
  59. this.state = 'active';
  60. if (!this.options.disableTimeOut && this.options.timeOut) {
  61. this.timeout = setTimeout(function () {
  62. _this.remove();
  63. }, this.options.timeOut);
  64. this.hideTime = new Date().getTime() + this.options.timeOut;
  65. if (this.options.progressBar) {
  66. this.intervalId = setInterval(function () { return _this.updateProgress(); }, 10);
  67. }
  68. }
  69. if (this.options.onActivateTick) {
  70. this.appRef.tick();
  71. }
  72. };
  73. /**
  74. * updates progress bar width
  75. */
  76. ToastNoAnimation.prototype.updateProgress = function () {
  77. if (this.width === 0 || this.width === 100 || !this.options.timeOut) {
  78. return;
  79. }
  80. var now = new Date().getTime();
  81. var remaining = this.hideTime - now;
  82. this.width = (remaining / this.options.timeOut) * 100;
  83. if (this.options.progressAnimation === 'increasing') {
  84. this.width = 100 - this.width;
  85. }
  86. if (this.width <= 0) {
  87. this.width = 0;
  88. }
  89. if (this.width >= 100) {
  90. this.width = 100;
  91. }
  92. };
  93. ToastNoAnimation.prototype.resetTimeout = function () {
  94. var _this = this;
  95. clearTimeout(this.timeout);
  96. clearInterval(this.intervalId);
  97. this.state = 'active';
  98. this.options.timeOut = this.originalTimeout;
  99. this.timeout = setTimeout(function () { return _this.remove(); }, this.originalTimeout);
  100. this.hideTime = new Date().getTime() + (this.originalTimeout || 0);
  101. this.width = -1;
  102. if (this.options.progressBar) {
  103. this.intervalId = setInterval(function () { return _this.updateProgress(); }, 10);
  104. }
  105. };
  106. /**
  107. * tells toastrService to remove this toast after animation time
  108. */
  109. ToastNoAnimation.prototype.remove = function () {
  110. var _this = this;
  111. if (this.state === 'removed') {
  112. return;
  113. }
  114. clearTimeout(this.timeout);
  115. this.state = 'removed';
  116. this.timeout = setTimeout(function () {
  117. return _this.toastrService.remove(_this.toastPackage.toastId);
  118. });
  119. };
  120. ToastNoAnimation.prototype.tapToast = function () {
  121. if (this.state === 'removed') {
  122. return;
  123. }
  124. this.toastPackage.triggerTap();
  125. if (this.options.tapToDismiss) {
  126. this.remove();
  127. }
  128. };
  129. ToastNoAnimation.prototype.stickAround = function () {
  130. if (this.state === 'removed') {
  131. return;
  132. }
  133. clearTimeout(this.timeout);
  134. this.options.timeOut = 0;
  135. this.hideTime = 0;
  136. // disable progressBar
  137. clearInterval(this.intervalId);
  138. this.width = 0;
  139. };
  140. ToastNoAnimation.prototype.delayedHideToast = function () {
  141. var _this = this;
  142. if (this.options.disableTimeOut ||
  143. this.options.extendedTimeOut === 0 ||
  144. this.state === 'removed') {
  145. return;
  146. }
  147. this.timeout = setTimeout(function () { return _this.remove(); }, this.options.extendedTimeOut);
  148. this.options.timeOut = this.options.extendedTimeOut;
  149. this.hideTime = new Date().getTime() + (this.options.timeOut || 0);
  150. this.width = -1;
  151. if (this.options.progressBar) {
  152. this.intervalId = setInterval(function () { return _this.updateProgress(); }, 10);
  153. }
  154. };
  155. tslib_1.__decorate([
  156. HostBinding('class'),
  157. tslib_1.__metadata("design:type", Object)
  158. ], ToastNoAnimation.prototype, "toastClasses", void 0);
  159. tslib_1.__decorate([
  160. HostBinding('style.display'),
  161. tslib_1.__metadata("design:type", Object),
  162. tslib_1.__metadata("design:paramtypes", [])
  163. ], ToastNoAnimation.prototype, "displayStyle", null);
  164. tslib_1.__decorate([
  165. HostListener('click'),
  166. tslib_1.__metadata("design:type", Function),
  167. tslib_1.__metadata("design:paramtypes", []),
  168. tslib_1.__metadata("design:returntype", void 0)
  169. ], ToastNoAnimation.prototype, "tapToast", null);
  170. tslib_1.__decorate([
  171. HostListener('mouseenter'),
  172. tslib_1.__metadata("design:type", Function),
  173. tslib_1.__metadata("design:paramtypes", []),
  174. tslib_1.__metadata("design:returntype", void 0)
  175. ], ToastNoAnimation.prototype, "stickAround", null);
  176. tslib_1.__decorate([
  177. HostListener('mouseleave'),
  178. tslib_1.__metadata("design:type", Function),
  179. tslib_1.__metadata("design:paramtypes", []),
  180. tslib_1.__metadata("design:returntype", void 0)
  181. ], ToastNoAnimation.prototype, "delayedHideToast", null);
  182. ToastNoAnimation = tslib_1.__decorate([
  183. Component({
  184. selector: '[toast-component]',
  185. 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=\"alert\" aria-live=\"polite\"\n [class]=\"options.messageClass\" [innerHTML]=\"message\">\n </div>\n <div *ngIf=\"message && !options.enableHtml\" role=\"alert\" 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 "
  186. }),
  187. tslib_1.__metadata("design:paramtypes", [ToastrService,
  188. ToastPackage,
  189. ApplicationRef])
  190. ], ToastNoAnimation);
  191. return ToastNoAnimation;
  192. }());
  193. export { ToastNoAnimation };
  194. export var DefaultNoAnimationsGlobalConfig = tslib_1.__assign({}, DefaultNoComponentGlobalConfig, { toastComponent: ToastNoAnimation });
  195. var ToastNoAnimationModule = /** @class */ (function () {
  196. function ToastNoAnimationModule() {
  197. }
  198. ToastNoAnimationModule_1 = ToastNoAnimationModule;
  199. ToastNoAnimationModule.forRoot = function (config) {
  200. if (config === void 0) { config = {}; }
  201. return {
  202. ngModule: ToastNoAnimationModule_1,
  203. providers: [
  204. {
  205. provide: TOAST_CONFIG,
  206. useValue: {
  207. default: DefaultNoAnimationsGlobalConfig,
  208. config: config,
  209. },
  210. },
  211. ],
  212. };
  213. };
  214. var ToastNoAnimationModule_1;
  215. ToastNoAnimationModule = ToastNoAnimationModule_1 = tslib_1.__decorate([
  216. NgModule({
  217. imports: [CommonModule],
  218. declarations: [ToastNoAnimation],
  219. exports: [ToastNoAnimation],
  220. entryComponents: [ToastNoAnimation],
  221. })
  222. ], ToastNoAnimationModule);
  223. return ToastNoAnimationModule;
  224. }());
  225. export { ToastNoAnimationModule };
  226. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast-noanimation.component.js","sourceRoot":"ng://ngx-toastr/","sources":["toastr/toast-noanimation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ModuleWithProviders } from '@angular/compiler/src/core';\nimport {\n  ApplicationRef,\n  Component,\n  HostBinding,\n  HostListener,\n  NgModule,\n  OnDestroy,\n} from '@angular/core';\nimport { SafeHtml } from '@angular/platform-browser';\n\nimport { Subscription } from 'rxjs';\n\nimport {\n  DefaultNoComponentGlobalConfig,\n  GlobalConfig,\n  IndividualConfig,\n  ToastPackage,\n  TOAST_CONFIG,\n} 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=\"alert\" aria-live=\"polite\"\n    [class]=\"options.messageClass\" [innerHTML]=\"message\">\n  </div>\n  <div *ngIf=\"message && !options.enableHtml\" role=\"alert\" 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})\nexport class ToastNoAnimation 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\n  /** hides component when waiting to be displayed */\n  @HostBinding('style.display')\n  get displayStyle() {\n    if (this.state === 'inactive') {\n      return 'none';\n    }\n  }\n\n  /** controls animation */\n  state = 'inactive';\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 appRef: ApplicationRef,\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 = 'active';\n    if (!this.options.disableTimeOut && this.options.timeOut) {\n      this.timeout = setTimeout(() => {\n        this.remove();\n      }, this.options.timeOut);\n      this.hideTime = new Date().getTime() + this.options.timeOut;\n      if (this.options.progressBar) {\n        this.intervalId = setInterval(() => this.updateProgress(), 10);\n      }\n    }\n    if (this.options.onActivateTick) {\n      this.appRef.tick();\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 = 'active';\n\n    this.options.timeOut = this.originalTimeout;\n    this.timeout = setTimeout(() => this.remove(), this.originalTimeout);\n    this.hideTime = new Date().getTime() + (this.originalTimeout || 0);\n    this.width = -1;\n    if (this.options.progressBar) {\n      this.intervalId = setInterval(() => this.updateProgress(), 10);\n    }\n  }\n\n  /**\n   * tells toastrService to remove this toast after animation time\n   */\n  remove() {\n    if (this.state === 'removed') {\n      return;\n    }\n    clearTimeout(this.timeout);\n    this.state = 'removed';\n    this.timeout = setTimeout(() =>\n      this.toastrService.remove(this.toastPackage.toastId),\n    );\n  }\n  @HostListener('click')\n  tapToast() {\n    if (this.state === '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 === '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 === 'removed'\n    ) {\n      return;\n    }\n    this.timeout = setTimeout(\n      () => this.remove(),\n      this.options.extendedTimeOut,\n    );\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.intervalId = setInterval(() => this.updateProgress(), 10);\n    }\n  }\n}\n\nexport const DefaultNoAnimationsGlobalConfig: GlobalConfig = {\n  ...DefaultNoComponentGlobalConfig,\n  toastComponent: ToastNoAnimation,\n};\n\n@NgModule({\n  imports: [CommonModule],\n  declarations: [ToastNoAnimation],\n  exports: [ToastNoAnimation],\n  entryComponents: [ToastNoAnimation],\n})\nexport class ToastNoAnimationModule {\n  static forRoot(config: Partial<GlobalConfig> = {}): ModuleWithProviders {\n    return {\n      ngModule: ToastNoAnimationModule,\n      providers: [\n        {\n          provide: TOAST_CONFIG,\n          useValue: {\n            default: DefaultNoAnimationsGlobalConfig,\n            config,\n          },\n        },\n      ],\n    };\n  }\n}\n"]}