UNPKG

@coreui/angular

Version:

CoreUI for Angular UI components library

140 lines 21.4 kB
import { Component, ContentChildren, HostBinding, Input, VERSION, ViewChild, ViewContainerRef } from '@angular/core'; import { ToasterHostDirective } from './toaster-host.directive'; import { ToastComponent } from '../toast/toast.component'; import * as i0 from "@angular/core"; import * as i1 from "./toaster.service"; import * as i2 from "./toaster-host.directive"; 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 { constructor(componentFactoryResolver, hostElement, renderer, toasterService) { this.componentFactoryResolver = componentFactoryResolver; this.hostElement = hostElement; this.renderer = renderer; this.toasterService = toasterService; 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(true); } ngOnDestroy() { this.stateToasterSubscribe(false); } ngAfterContentChecked() { this.toasts = this.contentToasts; } addToast(toast, props, options) { let componentRef; if (parseInt(VERSION.major) < 13) { const factory = this.componentFactoryResolver.resolveComponentFactory(toast); componentRef = this.toasterHost.viewContainerRef.createComponent(factory, options?.index, options?.injector, options?.projectableNodes, options?.ngModuleRef); } else { // @ts-ignore 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.instance[key] = value; } componentRef.instance['placement'] = this.placement; componentRef.instance['dynamic'] = true; componentRef.instance['index'] = index; componentRef.instance['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.instance.visible = false; item.instance['visibleChange'].emit(false); setTimeout(() => { item.destroy(); }, 300); } }); this.toasts?.forEach(item => { if (item.element.nativeElement === state.toast?.hostElement.nativeElement) { if (!state.toast?.dynamic) { // @ts-ignore state.toast.visible = false; } } }); } stateToasterSubscribe(subscribe = true) { if (subscribe) { this.stateToasterSubscription = this.toasterService.toasterState$.subscribe((state) => { if (state.show === false) { this.removeToast(state); } if (state.show === true && state.toast?.dynamic === undefined) { } }); } else { this.stateToasterSubscription.unsubscribe(); } } } ToasterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ToasterComponent, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.ToasterService }], target: i0.ɵɵFactoryTarget.Component }); ToasterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ToasterComponent, selector: "c-toaster", inputs: { placement: "placement", position: "position" }, host: { properties: { "class": "this.hostClasses" } }, 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></ng-template>\n<ng-content cToasterHost></ng-content>\n", dependencies: [{ kind: "directive", type: i2.ToasterHostDirective, selector: "[cToasterHost]", exportAs: ["cToasterHost"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ToasterComponent, decorators: [{ type: Component, args: [{ selector: 'c-toaster', exportAs: 'cToaster', template: "<ng-template cToasterHost></ng-template>\n<ng-content cToasterHost></ng-content>\n" }] }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { 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":"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","sourcesContent":["import {\r\n  AfterContentChecked,\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ComponentRef,\r\n  ContentChildren,\r\n  ElementRef,\r\n  HostBinding,\r\n  Injector,\r\n  Input,\r\n  NgModuleRef,\r\n  OnDestroy,\r\n  OnInit,\r\n  QueryList,\r\n  Renderer2,\r\n  VERSION,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { IToasterAction, ToasterService } from './toaster.service';\r\nimport { ToasterHostDirective } from './toaster-host.directive';\r\nimport { ToastComponent } from '../toast/toast.component';\r\n\r\nexport enum ToasterPlacement {\r\n  Static = 'static',\r\n  TopStart = 'top-start',\r\n  TopCenter = 'top-center',\r\n  TopEnd = 'top-end',\r\n  MiddleStart = 'middle-start',\r\n  MiddleCenter = 'middle-center',\r\n  MiddleEnd = 'middle-end',\r\n  BottomStart = 'bottom-start',\r\n  BottomCenter = 'bottom-center',\r\n  BottomEnd = 'bottom-end',\r\n}\r\n\r\nexport type TToasterPlacement =\r\n  | ToasterPlacement.Static\r\n  | ToasterPlacement.TopStart\r\n  | ToasterPlacement.TopCenter\r\n  | ToasterPlacement.TopEnd\r\n  | ToasterPlacement.MiddleStart\r\n  | ToasterPlacement.MiddleCenter\r\n  | ToasterPlacement.MiddleEnd\r\n  | ToasterPlacement.BottomStart\r\n  | ToasterPlacement.BottomCenter\r\n  | ToasterPlacement.BottomEnd\r\n  | string;\r\n\r\n@Component({\r\n  selector: 'c-toaster',\r\n  templateUrl: './toaster.component.html',\r\n  exportAs: 'cToaster'\r\n})\r\nexport class ToasterComponent implements OnDestroy, OnInit, AfterContentChecked {\r\n\r\n  stateToasterSubscription!: Subscription;\r\n  placements = Object.values(ToasterPlacement);\r\n  toasts!: QueryList<ViewContainerRef>;\r\n  toastsDynamic: any[] = [];\r\n\r\n  /**\r\n   * Toaster placement\r\n   * @type TToasterPlacement\r\n   */\r\n  @Input() placement: TToasterPlacement = ToasterPlacement.TopEnd;\r\n\r\n  /**\r\n   * Toaster position\r\n   * @type (string | 'absolute' | 'fixed' | 'static')\r\n   */\r\n  @Input() position: (string | 'absolute' | 'fixed' | 'static') = 'absolute';\r\n\r\n  @ViewChild(ToasterHostDirective, {static: true}) toasterHost!: ToasterHostDirective;\r\n  @ContentChildren(ToastComponent, {read: ViewContainerRef}) contentToasts!: QueryList<ViewContainerRef>;\r\n\r\n  constructor(\r\n    private componentFactoryResolver: ComponentFactoryResolver,\r\n    private hostElement: ElementRef,\r\n    private renderer: Renderer2,\r\n    private toasterService: ToasterService\r\n  ) { }\r\n\r\n  @HostBinding('class')\r\n  get hostClasses(): any {\r\n    return {\r\n      toaster: true,\r\n      'toast-container': true,\r\n      [`position-${this.position}`]: !!this.position,\r\n      'top-0': this.placement.includes('top'),\r\n      'top-50': this.placement.includes('middle'),\r\n      'bottom-0': this.placement.includes('bottom'),\r\n      'start-0': this.placement.includes('start'),\r\n      'start-50': this.placement.includes('center'),\r\n      'end-0': this.placement.includes('end'),\r\n      'translate-middle-x': this.placement.includes('center') && !this.placement.includes('middle'),\r\n      'translate-middle-y': this.placement.includes('middle') && !this.placement.includes('center'),\r\n      'translate-middle': this.placement.includes('middle') && this.placement.includes('center'),\r\n    };\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.stateToasterSubscribe(true);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.stateToasterSubscribe(false);\r\n  }\r\n\r\n  ngAfterContentChecked(): void {\r\n    this.toasts = this.contentToasts;\r\n  }\r\n\r\n  addToast(toast: any, props: any, options?: { index?: number; injector?: Injector; ngModuleRef?: NgModuleRef<unknown>; projectableNodes?: Node[][]; }): ComponentRef<any> {\r\n    let componentRef: ComponentRef<any>;\r\n    if (parseInt(VERSION.major) < 13) {\r\n      const factory = this.componentFactoryResolver.resolveComponentFactory(toast);\r\n      componentRef = this.toasterHost.viewContainerRef.createComponent(factory, options?.index, options?.injector, options?.projectableNodes, options?.ngModuleRef);\r\n    } else {\r\n      // @ts-ignore\r\n      componentRef = this.toasterHost.viewContainerRef.createComponent(toast, options);\r\n    }\r\n    this.toastsDynamic.push(componentRef);\r\n    const index = this.toastsDynamic.indexOf(componentRef);\r\n    for (const [key, value] of Object.entries(props)) {\r\n      componentRef.instance[key] = value;\r\n    }\r\n    componentRef.instance['placement'] = this.placement;\r\n    componentRef.instance['dynamic'] = true;\r\n    componentRef.instance['index'] = index;\r\n    componentRef.instance['visible'] = true;\r\n    componentRef.instance['visibleChange'].emit(true);\r\n    componentRef.changeDetectorRef?.detectChanges();\r\n    return componentRef;\r\n  }\r\n\r\n  removeToast(state: IToasterAction): void {\r\n    this.toastsDynamic?.forEach(item => {\r\n      if (state.toast?.dynamic && (item.instance === state.toast)) {\r\n        item.instance.visible = false;\r\n        item.instance['visibleChange'].emit(false);\r\n        setTimeout(() => {\r\n          item.destroy();\r\n        }, 300);\r\n      }\r\n    });\r\n\r\n    this.toasts?.forEach(item => {\r\n      if (item.element.nativeElement === state.toast?.hostElement.nativeElement) {\r\n        if (!state.toast?.dynamic) {\r\n          // @ts-ignore\r\n          state.toast.visible = false;\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private stateToasterSubscribe(subscribe: boolean = true): void {\r\n    if (subscribe) {\r\n      this.stateToasterSubscription = this.toasterService.toasterState$.subscribe((state) => {\r\n        if (state.show === false) {\r\n          this.removeToast(state);\r\n        }\r\n        if (state.show === true && state.toast?.dynamic === undefined) {\r\n        }\r\n      });\r\n    } else {\r\n      this.stateToasterSubscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n","<ng-template cToasterHost></ng-template>\n<ng-content cToasterHost></ng-content>\n"]}