UNPKG

@engie-group/fluid-design-system-angular

Version:

Fluid Design System Angular

105 lines 15 kB
import { CommonModule } from '@angular/common'; import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core'; import { IconButtonComponent } from '../icon-button/icon-button.component'; import { IconComponent } from '../icon/icon.component'; import * as i0 from "@angular/core"; import * as i1 from "@angular/platform-browser"; import * as i2 from "@angular/common"; export class ToastComponent { constructor(sanitize, el, cdr) { this.sanitize = sanitize; this.el = el; this.cdr = cdr; /** * Whether toast has a close icon or not */ this.hasCloseIcon = true; /** * Time in ms to dismiss after */ this.dismissAfter = 5000; /** * Gauge accessible hidden label. * @example "The toast will be automatically closed in 10s" */ this.gaugeLabel = 'Time left until toast is closed'; /** * Outputs event when toast is closed */ this.closed = new EventEmitter(); /** * Outputs event when toast is dismissed */ this.dismissed = new EventEmitter(); } ngOnInit() { if (this.shouldDismiss) { // @ts-ignore this._dismissTimeoutId = setTimeout(() => { this.removeToast(); this.dismissed.emit(); }, this.dismissAfter); } } ngOnDestroy() { this.clearDismissTimeout(); } /** * @ignore */ getGaugeAnimationStyles() { if (!this.dismissAfter) { return null; } return this.sanitize.bypassSecurityTrustStyle(` animation-duration: ${this.dismissAfter}ms `); } /** * Close toast */ close(event) { event?.preventDefault(); event?.stopImmediatePropagation(); this.removeToast(); this.closed.emit(event); this.cdr.markForCheck(); } /** * @ignore */ clearDismissTimeout() { if (this._dismissTimeoutId) { clearTimeout(this._dismissTimeoutId); } } removeToast() { this.el?.nativeElement?.remove(); this.clearDismissTimeout(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ToastComponent, deps: [{ token: i1.DomSanitizer }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ToastComponent, isStandalone: true, selector: "nj-toast", inputs: { toastId: "toastId", isInverse: "isInverse", hasCloseIcon: "hasCloseIcon", iconName: "iconName", dismissAfter: "dismissAfter", gaugeLabel: "gaugeLabel", shouldDismiss: "shouldDismiss" }, outputs: { closed: "closed", dismissed: "dismissed" }, ngImport: i0, template: "<div class=\"nj-toast\" [ngClass]=\"{'nj-toast--inverse': isInverse}\">\n <div class=\"nj-toast__body\">\n <nj-icon *ngIf=\"iconName\" [name]=\"iconName\" class=\"nj-toast__icon\" variant=\"inherit\"></nj-icon>\n <div class=\"nj-toast__content\">\n <p class=\"nj-toast__title\" [attr.id]=\"toastId\">\n <ng-content></ng-content>\n </p>\n <p class=\"nj-toast__text\">\n <ng-content select=\"[njToastBody]\"></ng-content>\n </p>\n </div>\n </div>\n <div class=\"nj-toast__action\" *ngIf=\"hasCloseIcon\">\n <nj-icon-button\n icon=\"close\"\n label=\"Close notification\"\n size=\"sm\"\n [variant]=\"isInverse ? 'primary' : 'inverse'\"\n [ariaDescribedby]=\"toastId\"\n (buttonClick)=\"close($event)\"\n >\n </nj-icon-button>\n </div>\n <div class=\"nj-toast__gauge\" *ngIf=\"shouldDismiss\">\n <div class=\"nj-toast__gauge-bar\" [style]=\"getGaugeAnimationStyles()\">\n <p class=\"nj-sr-only\">{{ gaugeLabel }}</p>\n </div>\n </div>\n</div>\n", styles: [".nj-toast__text:empty{display:none}\n"], dependencies: [{ kind: "component", type: IconComponent, selector: "nj-icon", inputs: ["size", "variant"] }, { kind: "component", type: IconButtonComponent, selector: "nj-icon-button", inputs: ["type", "ariaPressed", "ariaDescribedby", "isDisabled", "tabIndex", "variant", "size", "hasCustomIcon", "icon", "label", "additionalClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ToastComponent, decorators: [{ type: Component, args: [{ selector: 'nj-toast', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [IconComponent, IconButtonComponent, CommonModule], template: "<div class=\"nj-toast\" [ngClass]=\"{'nj-toast--inverse': isInverse}\">\n <div class=\"nj-toast__body\">\n <nj-icon *ngIf=\"iconName\" [name]=\"iconName\" class=\"nj-toast__icon\" variant=\"inherit\"></nj-icon>\n <div class=\"nj-toast__content\">\n <p class=\"nj-toast__title\" [attr.id]=\"toastId\">\n <ng-content></ng-content>\n </p>\n <p class=\"nj-toast__text\">\n <ng-content select=\"[njToastBody]\"></ng-content>\n </p>\n </div>\n </div>\n <div class=\"nj-toast__action\" *ngIf=\"hasCloseIcon\">\n <nj-icon-button\n icon=\"close\"\n label=\"Close notification\"\n size=\"sm\"\n [variant]=\"isInverse ? 'primary' : 'inverse'\"\n [ariaDescribedby]=\"toastId\"\n (buttonClick)=\"close($event)\"\n >\n </nj-icon-button>\n </div>\n <div class=\"nj-toast__gauge\" *ngIf=\"shouldDismiss\">\n <div class=\"nj-toast__gauge-bar\" [style]=\"getGaugeAnimationStyles()\">\n <p class=\"nj-sr-only\">{{ gaugeLabel }}</p>\n </div>\n </div>\n</div>\n", styles: [".nj-toast__text:empty{display:none}\n"] }] }], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { toastId: [{ type: Input }], isInverse: [{ type: Input }], hasCloseIcon: [{ type: Input }], iconName: [{ type: Input }], dismissAfter: [{ type: Input }], gaugeLabel: [{ type: Input }], shouldDismiss: [{ type: Input }], closed: [{ type: Output }], dismissed: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.component.js","sourceRoot":"","sources":["../../../../src/components/toast/toast.component.ts","../../../../src/components/toast/toast.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,uBAAuB,EAEvB,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,mBAAmB,EAAC,MAAM,sCAAsC,CAAC;AACzE,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;;;;AAUrD,MAAM,OAAO,cAAc;IAiDzB,YAAoB,QAAsB,EAAU,EAAc,EAAU,GAAsB;QAA9E,aAAQ,GAAR,QAAQ,CAAc;QAAU,OAAE,GAAF,EAAE,CAAY;QAAU,QAAG,GAAH,GAAG,CAAmB;QArClG;;WAEG;QACM,iBAAY,GAAG,IAAI,CAAC;QAQ7B;;WAEG;QACM,iBAAY,GAAI,IAAI,CAAC;QAE9B;;;WAGG;QACM,eAAU,GAAG,iCAAiC,CAAC;QAOxD;;WAEG;QACO,WAAM,GAAG,IAAI,YAAY,EAAS,CAAC;QAE7C;;WAEG;QACO,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;IAG/C,CAAC;IAED,QAAQ;QACN,IAAG,IAAI,CAAC,aAAa,EAAE;YACrB,aAAa;YACb,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC,GAAG,EAAE;gBACvC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YACxB,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SACvB;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,uBAAuB;QACrB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,OAAO,IAAI,CAAC;SACb;QACD,OAAO,IAAI,CAAC,QAAQ,CAAC,wBAAwB,CAAC;6BACrB,IAAI,CAAC,YAAY;KACzC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAkB;QACtB,KAAK,EAAE,cAAc,EAAE,CAAC;QACxB,KAAK,EAAE,wBAAwB,EAAE,CAAC;QAClC,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,mBAAmB;QACjB,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;SACtC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,EAAE,EAAE,aAAa,EAAE,MAAM,EAAE,CAAC;QACjC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;+GArGU,cAAc;mGAAd,cAAc,+TCxB3B,khCA6BA,+FDPY,aAAa,iFAAE,mBAAmB,0OAAE,YAAY;;4FAE/C,cAAc;kBAR1B,SAAS;+BACE,UAAU,mBAGH,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,aAAa,EAAE,mBAAmB,EAAE,YAAY,CAAC;4JAQlD,OAAO;sBAAf,KAAK;gBAIG,SAAS;sBAAjB,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAMG,QAAQ;sBAAhB,KAAK;gBAKG,YAAY;sBAApB,KAAK;gBAMG,UAAU;sBAAlB,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAKI,MAAM;sBAAf,MAAM;gBAKG,SAAS;sBAAlB,MAAM","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output\n} from '@angular/core';\nimport {DomSanitizer, SafeStyle} from '@angular/platform-browser';\nimport {IconButtonComponent} from '../icon-button/icon-button.component';\nimport {IconComponent} from '../icon/icon.component';\n\n@Component({\n  selector: 'nj-toast',\n  templateUrl: './toast.component.html',\n  styleUrls: ['./toast.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [IconComponent, IconButtonComponent, CommonModule]\n})\nexport class ToastComponent implements OnInit, OnDestroy {\n\n  private _dismissTimeoutId: number;\n  /**\n   * Toast unique id used to link description to close button\n   */\n  @Input() toastId: string;\n  /**\n   * Whether toast is inverse or not\n   */\n  @Input() isInverse: boolean;\n\n  /**\n   * Whether toast has a close icon or not\n   */\n  @Input() hasCloseIcon = true;\n\n  /**\n   * Icon :<br>\n   * <a href=\"https://material.io/resources/icons/\" target=\"_blank\">Material icons</a>\n   */\n  @Input() iconName?: string;\n\n  /**\n   * Time in ms to dismiss after\n   */\n  @Input() dismissAfter? = 5000;\n\n  /**\n   * Gauge accessible hidden label.\n   * @example \"The toast will be automatically closed in 10s\"\n   */\n  @Input() gaugeLabel = 'Time left until toast is closed';\n\n  /**\n   * Whether toast should dismiss after some time elapsed\n   */\n  @Input() shouldDismiss?: boolean;\n\n  /**\n   * Outputs event when toast is closed\n   */\n  @Output() closed = new EventEmitter<Event>();\n\n  /**\n   * Outputs event when toast is dismissed\n   */\n  @Output() dismissed = new EventEmitter<void>();\n\n  constructor(private sanitize: DomSanitizer, private el: ElementRef, private cdr: ChangeDetectorRef) {\n  }\n\n  ngOnInit() {\n    if(this.shouldDismiss) {\n      // @ts-ignore\n      this._dismissTimeoutId = setTimeout(() => {\n        this.removeToast();\n        this.dismissed.emit();\n      }, this.dismissAfter);\n    }\n  }\n\n  ngOnDestroy() {\n    this.clearDismissTimeout();\n  }\n\n  /**\n   * @ignore\n   */\n  getGaugeAnimationStyles(): SafeStyle {\n    if (!this.dismissAfter) {\n      return null;\n    }\n    return this.sanitize.bypassSecurityTrustStyle(`\n       animation-duration: ${this.dismissAfter}ms\n    `);\n  }\n\n  /**\n   * Close toast\n   */\n  close(event?: MouseEvent) {\n    event?.preventDefault();\n    event?.stopImmediatePropagation();\n    this.removeToast();\n    this.closed.emit(event);\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * @ignore\n   */\n  clearDismissTimeout() {\n    if (this._dismissTimeoutId) {\n      clearTimeout(this._dismissTimeoutId);\n    }\n  }\n\n  removeToast() {\n    this.el?.nativeElement?.remove();\n    this.clearDismissTimeout();\n  }\n}\n","<div class=\"nj-toast\" [ngClass]=\"{'nj-toast--inverse': isInverse}\">\n  <div class=\"nj-toast__body\">\n    <nj-icon *ngIf=\"iconName\" [name]=\"iconName\" class=\"nj-toast__icon\" variant=\"inherit\"></nj-icon>\n    <div class=\"nj-toast__content\">\n      <p class=\"nj-toast__title\" [attr.id]=\"toastId\">\n        <ng-content></ng-content>\n      </p>\n      <p class=\"nj-toast__text\">\n        <ng-content select=\"[njToastBody]\"></ng-content>\n      </p>\n    </div>\n  </div>\n  <div class=\"nj-toast__action\" *ngIf=\"hasCloseIcon\">\n    <nj-icon-button\n      icon=\"close\"\n      label=\"Close notification\"\n      size=\"sm\"\n      [variant]=\"isInverse ?  'primary' : 'inverse'\"\n      [ariaDescribedby]=\"toastId\"\n      (buttonClick)=\"close($event)\"\n    >\n    </nj-icon-button>\n  </div>\n  <div class=\"nj-toast__gauge\" *ngIf=\"shouldDismiss\">\n    <div class=\"nj-toast__gauge-bar\" [style]=\"getGaugeAnimationStyles()\">\n      <p class=\"nj-sr-only\">{{ gaugeLabel }}</p>\n    </div>\n  </div>\n</div>\n"]}