UNPKG

@coreui/angular

Version:

CoreUI Components Library for Angular

123 lines 19 kB
import { Component, ContentChildren, DestroyRef, HostBinding, inject, Input, ViewChild, ViewContainerRef } from '@angular/core'; import { takeUntilDestroyed } from '@angular/core/rxjs-interop'; import { ToasterHostDirective } from './toaster-host.directive'; import { ToastComponent } from '../toast/toast.component'; import * as i0 from "@angular/core"; import * as i1 from "./toaster.service"; export var ToasterPlacement; (function (ToasterPlacement) { ToasterPlacement["Static"] = "static"; ToasterPlacement["TopStart"] = "top-start"; ToasterPlacement["TopCenter"] = "top-center"; ToasterPlacement["TopEnd"] = "top-end"; ToasterPlacement["MiddleStart"] = "middle-start"; ToasterPlacement["MiddleCenter"] = "middle-center"; ToasterPlacement["MiddleEnd"] = "middle-end"; ToasterPlacement["BottomStart"] = "bottom-start"; ToasterPlacement["BottomCenter"] = "bottom-center"; ToasterPlacement["BottomEnd"] = "bottom-end"; })(ToasterPlacement || (ToasterPlacement = {})); export class ToasterComponent { #destroyRef; constructor(hostElement, renderer, toasterService) { this.hostElement = hostElement; this.renderer = renderer; this.toasterService = toasterService; this.#destroyRef = inject(DestroyRef); this.placements = Object.values(ToasterPlacement); this.toastsDynamic = []; /** * Toaster placement * @type TToasterPlacement */ this.placement = ToasterPlacement.TopEnd; /** * Toaster position * @type (string | 'absolute' | 'fixed' | 'static') */ this.position = 'absolute'; } get hostClasses() { return { toaster: true, 'toast-container': true, [`position-${this.position}`]: !!this.position, 'top-0': this.placement.includes('top'), 'top-50': this.placement.includes('middle'), 'bottom-0': this.placement.includes('bottom'), 'start-0': this.placement.includes('start'), 'start-50': this.placement.includes('center'), 'end-0': this.placement.includes('end'), 'translate-middle-x': this.placement.includes('center') && !this.placement.includes('middle'), 'translate-middle-y': this.placement.includes('middle') && !this.placement.includes('center'), 'translate-middle': this.placement.includes('middle') && this.placement.includes('center') }; } ngOnInit() { this.stateToasterSubscribe(); } ngAfterContentChecked() { this.toasts = this.contentToasts; } addToast(toast, props, options) { const componentRef = this.toasterHost.viewContainerRef.createComponent(toast, options); this.toastsDynamic.push(componentRef); const index = this.toastsDynamic.indexOf(componentRef); for (const [key, value] of Object.entries(props)) { componentRef.setInput(key, value); } componentRef.setInput('placement', this.placement); componentRef.setInput('dynamic', true); componentRef.setInput('index', index); componentRef.setInput('visible', true); componentRef.instance['visibleChange'].emit(true); componentRef.changeDetectorRef?.detectChanges(); return componentRef; } removeToast(state) { this.toastsDynamic?.forEach((item) => { if (state.toast?.dynamic() && item.instance === state.toast) { item.setInput('visible', false); item.instance['visibleChange'].emit(false); item.destroy(); } }); this.toasts?.forEach((item) => { if (state.toast && item.element.nativeElement === state.toast.hostElement.nativeElement) { if (!state.toast.dynamic()) { state.toast['visible'] = false; } } }); } stateToasterSubscribe() { this.toasterService.toasterState$.pipe(takeUntilDestroyed(this.#destroyRef)).subscribe((state) => { if (state.show === false) { this.removeToast(state); } // if (state.show === true && state.toast?.dynamic() === undefined) { // /* empty */ // } }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ToasterComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.ToasterService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: ToasterComponent, isStandalone: true, selector: "c-toaster", inputs: { placement: "placement", position: "position" }, host: { properties: { "class": "this.hostClasses" }, classAttribute: "toaster toast-container" }, queries: [{ propertyName: "contentToasts", predicate: ToastComponent, read: ViewContainerRef }], viewQueries: [{ propertyName: "toasterHost", first: true, predicate: ToasterHostDirective, descendants: true, static: true }], exportAs: ["cToaster"], ngImport: i0, template: "<ng-template cToasterHost />\n<ng-content cToasterHost />\n", dependencies: [{ kind: "directive", type: ToasterHostDirective, selector: "[cToasterHost]", exportAs: ["cToasterHost"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: ToasterComponent, decorators: [{ type: Component, args: [{ selector: 'c-toaster', exportAs: 'cToaster', standalone: true, imports: [ToasterHostDirective], host: { class: 'toaster toast-container' }, template: "<ng-template cToasterHost />\n<ng-content cToasterHost />\n" }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.ToasterService }], propDecorators: { placement: [{ type: Input }], position: [{ type: Input }], toasterHost: [{ type: ViewChild, args: [ToasterHostDirective, { static: true }] }], contentToasts: [{ type: ContentChildren, args: [ToastComponent, { read: ViewContainerRef }] }], hostClasses: [{ type: HostBinding, args: ['class'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toaster.component.js","sourceRoot":"","sources":["../../../../../../projects/coreui-angular/src/lib/toast/toaster/toaster.component.ts","../../../../../../projects/coreui-angular/src/lib/toast/toaster/toaster.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,eAAe,EACf,UAAU,EAEV,WAAW,EACX,MAAM,EAEN,KAAK,EAKL,SAAS,EACT,gBAAgB,EACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAGhE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;;;AAE1D,MAAM,CAAN,IAAY,gBAWX;AAXD,WAAY,gBAAgB;IAC1B,qCAAiB,CAAA;IACjB,0CAAsB,CAAA;IACtB,4CAAwB,CAAA;IACxB,sCAAkB,CAAA;IAClB,gDAA4B,CAAA;IAC5B,kDAA8B,CAAA;IAC9B,4CAAwB,CAAA;IACxB,gDAA4B,CAAA;IAC5B,kDAA8B,CAAA;IAC9B,4CAAwB,CAAA;AAC1B,CAAC,EAXW,gBAAgB,KAAhB,gBAAgB,QAW3B;AAuBD,MAAM,OAAO,gBAAgB;IAClB,WAAW,CAAsB;IAE1C,YACU,WAAuB,EACvB,QAAmB,EACnB,cAA8B;QAF9B,gBAAW,GAAX,WAAW,CAAY;QACvB,aAAQ,GAAR,QAAQ,CAAW;QACnB,mBAAc,GAAd,cAAc,CAAgB;QAL/B,gBAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAQ1C,eAAU,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAE7C,kBAAa,GAAU,EAAE,CAAC;QAE1B;;;WAGG;QACM,cAAS,GAAsB,gBAAgB,CAAC,MAAM,CAAC;QAEhE;;;WAGG;QACM,aAAQ,GAA6C,UAAU,CAAC;IAhBtE,CAAC;IAqBJ,IACI,WAAW;QACb,OAAO;YACL,OAAO,EAAE,IAAI;YACb,iBAAiB,EAAE,IAAI;YACvB,CAAC,YAAY,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ;YAC9C,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC;YACvC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC;YAC3C,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC;YAC7C,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC;YAC3C,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC;YAC7C,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC;YACvC,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC;YAC7F,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC;YAC7F,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC;SAC3F,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC;IACnC,CAAC;IAEM,QAAQ,CACb,KAAU,EACV,KAAU,EACV,OAKC;QAED,MAAM,YAAY,GAAsB,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,eAAe,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAC1G,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACvD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACjD,YAAY,CAAC,QAAQ,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QACpC,CAAC;QACD,YAAY,CAAC,QAAQ,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACnD,YAAY,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QACvC,YAAY,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACtC,YAAY,CAAC,QAAQ,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QACvC,YAAY,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClD,YAAY,CAAC,iBAAiB,EAAE,aAAa,EAAE,CAAC;QAChD,OAAO,YAAY,CAAC;IACtB,CAAC;IAEM,WAAW,CAAC,KAAqB;QACtC,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACnC,IAAI,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC,KAAK,EAAE,CAAC;gBAC5D,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;gBAChC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC3C,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC5B,IAAI,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,KAAK,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC;gBACxF,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;oBAC3B,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC;gBACjC,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC/F,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;gBACzB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC;YACD,qEAAqE;YACrE,gBAAgB;YAChB,IAAI;QACN,CAAC,CAAC,CAAC;IACL,CAAC;+GA1GU,gBAAgB;mGAAhB,gBAAgB,+PA0BV,cAAc,QAAU,gBAAgB,0EAD9C,oBAAoB,sFCnFjC,6DAEA,4CDqDY,oBAAoB;;4FAGnB,gBAAgB;kBAR5B,SAAS;+BACE,WAAW,YAEX,UAAU,cACR,IAAI,WACP,CAAC,oBAAoB,CAAC,QACzB,EAAE,KAAK,EAAE,yBAAyB,EAAE;oIAmBjC,SAAS;sBAAjB,KAAK;gBAMG,QAAQ;sBAAhB,KAAK;gBAE6C,WAAW;sBAA7D,SAAS;uBAAC,oBAAoB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACY,aAAa;sBAAzE,eAAe;uBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;gBAGvD,WAAW;sBADd,WAAW;uBAAC,OAAO","sourcesContent":["import {\n  AfterContentChecked,\n  Component,\n  ComponentRef,\n  ContentChildren,\n  DestroyRef,\n  ElementRef,\n  HostBinding,\n  inject,\n  Injector,\n  Input,\n  NgModuleRef,\n  OnInit,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\nimport { IToasterAction, ToasterService } from './toaster.service';\nimport { ToasterHostDirective } from './toaster-host.directive';\nimport { ToastComponent } from '../toast/toast.component';\n\nexport enum ToasterPlacement {\n  Static = 'static',\n  TopStart = 'top-start',\n  TopCenter = 'top-center',\n  TopEnd = 'top-end',\n  MiddleStart = 'middle-start',\n  MiddleCenter = 'middle-center',\n  MiddleEnd = 'middle-end',\n  BottomStart = 'bottom-start',\n  BottomCenter = 'bottom-center',\n  BottomEnd = 'bottom-end'\n}\n\nexport type TToasterPlacement =\n  | ToasterPlacement.Static\n  | ToasterPlacement.TopStart\n  | ToasterPlacement.TopCenter\n  | ToasterPlacement.TopEnd\n  | ToasterPlacement.MiddleStart\n  | ToasterPlacement.MiddleCenter\n  | ToasterPlacement.MiddleEnd\n  | ToasterPlacement.BottomStart\n  | ToasterPlacement.BottomCenter\n  | ToasterPlacement.BottomEnd\n  | string;\n\n@Component({\n  selector: 'c-toaster',\n  templateUrl: './toaster.component.html',\n  exportAs: 'cToaster',\n  standalone: true,\n  imports: [ToasterHostDirective],\n  host: { class: 'toaster toast-container' }\n})\nexport class ToasterComponent implements OnInit, AfterContentChecked {\n  readonly #destroyRef = inject(DestroyRef);\n\n  constructor(\n    private hostElement: ElementRef,\n    private renderer: Renderer2,\n    private toasterService: ToasterService\n  ) {}\n\n  placements = Object.values(ToasterPlacement);\n  toasts!: QueryList<ViewContainerRef>;\n  toastsDynamic: any[] = [];\n\n  /**\n   * Toaster placement\n   * @type TToasterPlacement\n   */\n  @Input() placement: TToasterPlacement = ToasterPlacement.TopEnd;\n\n  /**\n   * Toaster position\n   * @type (string | 'absolute' | 'fixed' | 'static')\n   */\n  @Input() position: string | 'absolute' | 'fixed' | 'static' = 'absolute';\n\n  @ViewChild(ToasterHostDirective, { static: true }) toasterHost!: ToasterHostDirective;\n  @ContentChildren(ToastComponent, { read: ViewContainerRef }) contentToasts!: QueryList<ViewContainerRef>;\n\n  @HostBinding('class')\n  get hostClasses(): any {\n    return {\n      toaster: true,\n      'toast-container': true,\n      [`position-${this.position}`]: !!this.position,\n      'top-0': this.placement.includes('top'),\n      'top-50': this.placement.includes('middle'),\n      'bottom-0': this.placement.includes('bottom'),\n      'start-0': this.placement.includes('start'),\n      'start-50': this.placement.includes('center'),\n      'end-0': this.placement.includes('end'),\n      'translate-middle-x': this.placement.includes('center') && !this.placement.includes('middle'),\n      'translate-middle-y': this.placement.includes('middle') && !this.placement.includes('center'),\n      'translate-middle': this.placement.includes('middle') && this.placement.includes('center')\n    };\n  }\n\n  ngOnInit(): void {\n    this.stateToasterSubscribe();\n  }\n\n  ngAfterContentChecked(): void {\n    this.toasts = this.contentToasts;\n  }\n\n  public addToast(\n    toast: any,\n    props: any,\n    options?: {\n      index?: number;\n      injector?: Injector;\n      ngModuleRef?: NgModuleRef<unknown>;\n      projectableNodes?: Node[][];\n    }\n  ): ComponentRef<any> {\n    const componentRef: ComponentRef<any> = this.toasterHost.viewContainerRef.createComponent(toast, options);\n    this.toastsDynamic.push(componentRef);\n    const index = this.toastsDynamic.indexOf(componentRef);\n    for (const [key, value] of Object.entries(props)) {\n      componentRef.setInput(key, value);\n    }\n    componentRef.setInput('placement', this.placement);\n    componentRef.setInput('dynamic', true);\n    componentRef.setInput('index', index);\n    componentRef.setInput('visible', true);\n    componentRef.instance['visibleChange'].emit(true);\n    componentRef.changeDetectorRef?.detectChanges();\n    return componentRef;\n  }\n\n  public removeToast(state: IToasterAction): void {\n    this.toastsDynamic?.forEach((item) => {\n      if (state.toast?.dynamic() && item.instance === state.toast) {\n        item.setInput('visible', false);\n        item.instance['visibleChange'].emit(false);\n        item.destroy();\n      }\n    });\n\n    this.toasts?.forEach((item) => {\n      if (state.toast && item.element.nativeElement === state.toast.hostElement.nativeElement) {\n        if (!state.toast.dynamic()) {\n          state.toast['visible'] = false;\n        }\n      }\n    });\n  }\n\n  private stateToasterSubscribe(): void {\n    this.toasterService.toasterState$.pipe(takeUntilDestroyed(this.#destroyRef)).subscribe((state) => {\n      if (state.show === false) {\n        this.removeToast(state);\n      }\n      // if (state.show === true && state.toast?.dynamic() === undefined) {\n      //   /* empty */\n      // }\n    });\n  }\n}\n","<ng-template cToasterHost />\n<ng-content cToasterHost />\n"]}