@craftsjs/alert
Version:
Material alert library for angular
78 lines • 18.1 kB
JavaScript
import { Component, ChangeDetectionStrategy, Inject, ViewEncapsulation, Injector, InjectionToken, ViewChildren, TemplateRef } from '@angular/core';
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
import { alertComponents } from './components/components';
import { DynamicDirective } from '@craftsjs/core';
import { TranslateModule } from '@ngx-translate/core';
import { AlertOkButtonComponent } from './components/buttons/alert-ok-button/alert-ok-button.component';
import { AlertCancelButtonComponent } from './components/buttons/alert-cancel-button/alert-cancel-button.component';
import * as i0 from "@angular/core";
import * as i1 from "@angular/material/dialog";
import * as i2 from "@ngx-translate/core";
export const CRAFTSJS_ALERT_DATA = new InjectionToken('CraftsjsAlertData');
export class DialogAlertComponent {
constructor(dialogRef, data) {
this.dialogRef = dialogRef;
this.data = data;
}
ngOnInit() {
}
ngAfterViewInit() {
this.loadComponents();
}
loadComponents() {
const itemComponent = alertComponents.find(x => x.type === this.data.type);
const component = itemComponent && itemComponent.component;
this.resolveComponent(component, this.appDynamic.find(x => x.name === 'alert-icon').viewContainerRef);
this.resolveComponent(this.data.customBody, this.appDynamic.find(x => x.name === 'alert-body').viewContainerRef);
this.resolveComponent(this.data.customButtonComponent, this.appDynamic.find(x => x.name === 'alert-buttons').viewContainerRef);
}
resolveComponent(component, viewContainerRef) {
if (!component) {
return;
}
viewContainerRef.clear();
if (component instanceof TemplateRef) {
viewContainerRef.createEmbeddedView(component, { $implicit: this.data, dialogRef: this.dialogRef });
}
else {
const injector = this.createInjector(viewContainerRef.injector);
viewContainerRef.createComponent(component, {
injector
});
}
}
createInjector(injector) {
return Injector.create({
providers: [{
provide: CRAFTSJS_ALERT_DATA,
useValue: this.data
},
{
provide: MatDialogRef,
useValue: this.dialogRef
}],
parent: injector
});
}
buttonClick(result) {
this.dialogRef.close({ data: this.data, result });
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DialogAlertComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DialogAlertComponent, isStandalone: true, selector: "dialog-alert", viewQueries: [{ propertyName: "appDynamic", predicate: DynamicDirective, descendants: true }], ngImport: i0, template: "<ng-template craftsjsDynamic name=\"alert-icon\"></ng-template>\r\n@if (data?.title) {\r\n <div class=\"alert-title\">\r\n <span>\r\n {{data.title | translate}}\r\n </span>\r\n </div>\r\n}\r\n@if (data?.text) {\r\n <div class=\"alert-text\">\r\n <span>\r\n {{data.text | translate}}\r\n </span>\r\n </div>\r\n}\r\n<ng-template craftsjsDynamic name=\"alert-body\"></ng-template>\r\n@if (!data?.hiddenButtons) {\r\n <div class=\"alert-footer\">\r\n @if (!data?.customButtonComponent) {\r\n <alert-ok-button (click)=\"buttonClick('ok')\">\r\n </alert-ok-button>\r\n }\r\n @if (!data?.customButtonComponent && data?.showCancelButton) {\r\n <alert-cancel-button\r\n (click)=\"buttonClick('cancel')\">\r\n </alert-cancel-button>\r\n }\r\n </div>\r\n}\r\n<ng-template craftsjsDynamic name=\"alert-buttons\"></ng-template>", styles: [".alert-icon{width:80px;height:80px;border-width:4px;border-style:solid;border-radius:50%;padding:0;position:relative;box-sizing:content-box;margin:20px auto}.alert-icon-custom{width:auto;height:auto;max-width:100%;border:none;border-radius:0}.alert-icon img{max-width:100%;max-height:100%}.alert-title{color:#000000a6;font-weight:600;text-transform:none;position:relative;display:block;font-size:27px;line-height:normal;text-align:center;margin-bottom:0}.alert-title:first-child{margin-top:26px}.alert-title:not(:first-child){padding-bottom:0}.alert-title:not(:last-child){margin-bottom:13px}.alert-text{font-size:16px;position:relative;float:none;line-height:normal;vertical-align:top;text-align:center;display:inline-block;margin:0;padding:0 10px;font-weight:400;color:#000000a3;overflow-wrap:break-word;box-sizing:border-box;width:100%}.alert-text:first-child{margin-top:45px}.alert-text:last-child{margin-bottom:45px}.alert-footer{text-align:right;margin-top:13px;padding:13px 16px;border-radius:inherit;border-top-left-radius:0;border-top-right-radius:0}.alert-footer-button-container{margin:5px;display:inline-block;position:relative}.alert-footer>*{display:inline-block;margin-right:.5em}.alert-footer>:last-child{margin-right:inherit}\n"], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: DynamicDirective, selector: "[craftsjsDynamic]", inputs: ["name"] }, { kind: "component", type: AlertOkButtonComponent, selector: "alert-ok-button", outputs: ["click"] }, { kind: "component", type: AlertCancelButtonComponent, selector: "alert-cancel-button", outputs: ["click"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DialogAlertComponent, decorators: [{
type: Component,
args: [{ selector: 'dialog-alert', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [
TranslateModule,
DynamicDirective,
AlertOkButtonComponent,
AlertCancelButtonComponent
], template: "<ng-template craftsjsDynamic name=\"alert-icon\"></ng-template>\r\n@if (data?.title) {\r\n <div class=\"alert-title\">\r\n <span>\r\n {{data.title | translate}}\r\n </span>\r\n </div>\r\n}\r\n@if (data?.text) {\r\n <div class=\"alert-text\">\r\n <span>\r\n {{data.text | translate}}\r\n </span>\r\n </div>\r\n}\r\n<ng-template craftsjsDynamic name=\"alert-body\"></ng-template>\r\n@if (!data?.hiddenButtons) {\r\n <div class=\"alert-footer\">\r\n @if (!data?.customButtonComponent) {\r\n <alert-ok-button (click)=\"buttonClick('ok')\">\r\n </alert-ok-button>\r\n }\r\n @if (!data?.customButtonComponent && data?.showCancelButton) {\r\n <alert-cancel-button\r\n (click)=\"buttonClick('cancel')\">\r\n </alert-cancel-button>\r\n }\r\n </div>\r\n}\r\n<ng-template craftsjsDynamic name=\"alert-buttons\"></ng-template>", styles: [".alert-icon{width:80px;height:80px;border-width:4px;border-style:solid;border-radius:50%;padding:0;position:relative;box-sizing:content-box;margin:20px auto}.alert-icon-custom{width:auto;height:auto;max-width:100%;border:none;border-radius:0}.alert-icon img{max-width:100%;max-height:100%}.alert-title{color:#000000a6;font-weight:600;text-transform:none;position:relative;display:block;font-size:27px;line-height:normal;text-align:center;margin-bottom:0}.alert-title:first-child{margin-top:26px}.alert-title:not(:first-child){padding-bottom:0}.alert-title:not(:last-child){margin-bottom:13px}.alert-text{font-size:16px;position:relative;float:none;line-height:normal;vertical-align:top;text-align:center;display:inline-block;margin:0;padding:0 10px;font-weight:400;color:#000000a3;overflow-wrap:break-word;box-sizing:border-box;width:100%}.alert-text:first-child{margin-top:45px}.alert-text:last-child{margin-bottom:45px}.alert-footer{text-align:right;margin-top:13px;padding:13px 16px;border-radius:inherit;border-top-left-radius:0;border-top-right-radius:0}.alert-footer-button-container{margin:5px;display:inline-block;position:relative}.alert-footer>*{display:inline-block;margin-right:.5em}.alert-footer>:last-child{margin-right:inherit}\n"] }]
}], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
type: Inject,
args: [MAT_DIALOG_DATA]
}] }], propDecorators: { appDynamic: [{
type: ViewChildren,
args: [DynamicDirective]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-alert.component.js","sourceRoot":"","sources":["../../../../../../../projects/craftsjs/alert/src/lib/components/dialog-alert/dialog-alert.component.ts","../../../../../../../projects/craftsjs/alert/src/lib/components/dialog-alert/dialog-alert.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,uBAAuB,EACvB,MAAM,EACN,iBAAiB,EAEjB,QAAQ,EACR,cAAc,EAId,YAAY,EAEZ,WAAW,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAEzE,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,gEAAgE,CAAC;AACxG,OAAO,EAAE,0BAA0B,EAAE,MAAM,wEAAwE,CAAC;;;;AAEpH,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,cAAc,CAAM,mBAAmB,CAAC,CAAC;AAgBhF,MAAM,OAAO,oBAAoB;IAK/B,YACS,SAA6C,EACpB,IAAgB;QADzC,cAAS,GAAT,SAAS,CAAoC;QACpB,SAAI,GAAJ,IAAI,CAAY;IAElD,CAAC;IAED,QAAQ;IAER,CAAC;IAED,eAAe;QACb,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,cAAc;QACpB,MAAM,aAAa,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3E,MAAM,SAAS,GAAG,aAAa,IAAI,aAAa,CAAC,SAAS,CAAC;QAC3D,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC,gBAAgB,CAAC,CAAC;QACtG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC,gBAAgB,CAAC,CAAC;QACjH,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,eAAe,CAAC,CAAC,gBAAgB,CAAC,CAAC;IACjI,CAAC;IAEO,gBAAgB,CAAC,SAAuC,EAAE,gBAAkC;QAClG,IAAI,CAAC,SAAS,EAAE,CAAC;YAAC,OAAO;QAAC,CAAC;QAC3B,gBAAgB,CAAC,KAAK,EAAE,CAAC;QACzB,IAAI,SAAS,YAAY,WAAW,EAAE,CAAC;YACrC,gBAAgB,CAAC,kBAAkB,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACtG,CAAC;aAAM,CAAC;YACN,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;YAChE,gBAAgB,CAAC,eAAe,CAAC,SAAS,EAAE;gBAC1C,QAAQ;aACT,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,cAAc,CAAC,QAAkB;QACvC,OAAO,QAAQ,CAAC,MAAM,CAAC;YACrB,SAAS,EAAE,CAAC;oBACV,OAAO,EAAE,mBAAmB;oBAC5B,QAAQ,EAAE,IAAI,CAAC,IAAI;iBACpB;gBACD;oBACE,OAAO,EAAE,YAAY;oBACrB,QAAQ,EAAE,IAAI,CAAC,SAAS;iBACzB,CAAC;YACF,MAAM,EAAE,QAAQ;SACjB,CAAC,CAAA;IACJ,CAAC;IAED,WAAW,CAAC,MAAc;QACxB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;IACpD,CAAC;+GAxDU,oBAAoB,8CAOrB,eAAe;mGAPd,oBAAoB,uGAEjB,gBAAgB,gDC1ChC,m3BA6BgE,qxCDK5D,eAAe,4FACf,gBAAgB,gFAChB,sBAAsB,gFACtB,0BAA0B;;4FAGjB,oBAAoB;kBAdhC,SAAS;+BACE,cAAc,mBAGP,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,cACzB,IAAI,WACP;wBACP,eAAe;wBACf,gBAAgB;wBAChB,sBAAsB;wBACtB,0BAA0B;qBAC7B;;0BASI,MAAM;2BAAC,eAAe;yCAJzB,UAAU;sBADT,YAAY;uBAAC,gBAAgB","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  Inject,\r\n  ViewEncapsulation,\r\n  OnInit,\r\n  Injector,\r\n  InjectionToken,\r\n  Type,\r\n  ViewContainerRef,\r\n  QueryList,\r\n  ViewChildren,\r\n  AfterViewInit,\r\n  TemplateRef\r\n} from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { AlertModel } from '../../models/alert.model';\r\nimport { alertComponents } from './components/components';\r\nimport { DynamicDirective } from '@craftsjs/core';\r\n\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport { AlertOkButtonComponent } from './components/buttons/alert-ok-button/alert-ok-button.component';\r\nimport { AlertCancelButtonComponent } from './components/buttons/alert-cancel-button/alert-cancel-button.component';\r\n\r\nexport const CRAFTSJS_ALERT_DATA = new InjectionToken<any>('CraftsjsAlertData');\r\n\r\n@Component({\r\n  selector: 'dialog-alert',\r\n  templateUrl: './dialog-alert.component.html',\r\n  styleUrls: ['./dialog-alert.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  standalone: true,\r\n  imports: [\r\n    TranslateModule,\r\n    DynamicDirective,\r\n    AlertOkButtonComponent,\r\n    AlertCancelButtonComponent\r\n]\r\n})\r\nexport class DialogAlertComponent implements OnInit, AfterViewInit {\r\n\r\n  @ViewChildren(DynamicDirective)\r\n  appDynamic: QueryList<DynamicDirective>;\r\n\r\n  constructor(\r\n    public dialogRef: MatDialogRef<DialogAlertComponent>,\r\n    @Inject(MAT_DIALOG_DATA) public data: AlertModel,\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.loadComponents();\r\n  }\r\n\r\n  private loadComponents() {\r\n    const itemComponent = alertComponents.find(x => x.type === this.data.type);\r\n    const component = itemComponent && itemComponent.component;\r\n    this.resolveComponent(component, this.appDynamic.find(x => x.name === 'alert-icon').viewContainerRef);\r\n    this.resolveComponent(this.data.customBody, this.appDynamic.find(x => x.name === 'alert-body').viewContainerRef);\r\n    this.resolveComponent(this.data.customButtonComponent, this.appDynamic.find(x => x.name === 'alert-buttons').viewContainerRef);\r\n  }\r\n\r\n  private resolveComponent(component: Type<any> | TemplateRef<any>, viewContainerRef: ViewContainerRef) {\r\n    if (!component) { return; }\r\n    viewContainerRef.clear();\r\n    if (component instanceof TemplateRef) {\r\n      viewContainerRef.createEmbeddedView(component, { $implicit: this.data, dialogRef: this.dialogRef });\r\n    } else {\r\n      const injector = this.createInjector(viewContainerRef.injector);\r\n      viewContainerRef.createComponent(component, {\r\n        injector\r\n      });\r\n    }\r\n  }\r\n\r\n  private createInjector(injector: Injector) {\r\n    return Injector.create({\r\n      providers: [{\r\n        provide: CRAFTSJS_ALERT_DATA,\r\n        useValue: this.data\r\n      },\r\n      {\r\n        provide: MatDialogRef,\r\n        useValue: this.dialogRef\r\n      }],\r\n      parent: injector\r\n    })\r\n  }\r\n\r\n  buttonClick(result: string) {\r\n    this.dialogRef.close({ data: this.data, result });\r\n  }\r\n\r\n}\r\n","<ng-template craftsjsDynamic name=\"alert-icon\"></ng-template>\r\n@if (data?.title) {\r\n  <div class=\"alert-title\">\r\n    <span>\r\n      {{data.title | translate}}\r\n    </span>\r\n  </div>\r\n}\r\n@if (data?.text) {\r\n  <div class=\"alert-text\">\r\n    <span>\r\n      {{data.text | translate}}\r\n    </span>\r\n  </div>\r\n}\r\n<ng-template craftsjsDynamic name=\"alert-body\"></ng-template>\r\n@if (!data?.hiddenButtons) {\r\n  <div class=\"alert-footer\">\r\n    @if (!data?.customButtonComponent) {\r\n      <alert-ok-button (click)=\"buttonClick('ok')\">\r\n      </alert-ok-button>\r\n    }\r\n    @if (!data?.customButtonComponent && data?.showCancelButton) {\r\n      <alert-cancel-button\r\n        (click)=\"buttonClick('cancel')\">\r\n      </alert-cancel-button>\r\n    }\r\n  </div>\r\n}\r\n<ng-template craftsjsDynamic name=\"alert-buttons\"></ng-template>"]}