@coreui/angular
Version:
CoreUI Components Library for Angular
123 lines • 19 kB
JavaScript
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":"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","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"]}