@coreui/angular
Version:
CoreUI for Angular UI components library
140 lines • 21.4 kB
JavaScript
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"]}