UNPKG

@universis/common

Version:

Universis - common directives and services

138 lines 16.5 kB
import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector } from '@angular/core'; import { DialogComponent, DIALOG_BUTTONS } from '../components/modal/dialog.component'; import { BsModalService } from 'ngx-bootstrap/modal'; import * as i0 from "@angular/core"; import * as i1 from "ngx-bootstrap/modal"; /** * * Displays a Modal window or a type of Notification (based on choice the color changes) * @export * @class ModalService */ export class ModalService { constructor(componentFactoryResolver, appRef, injector, modalService) { this.componentFactoryResolver = componentFactoryResolver; this.appRef = appRef; this.injector = injector; this.modalService = modalService; this.config = { ignoreBackdropClick: true, keyboard: false, initialState: null, class: 'modal-content-base' }; } showDialog(title, message, buttons = DIALOG_BUTTONS.Ok, extras) { const componentRef = this.componentFactoryResolver .resolveComponentFactory(DialogComponent) .create(this.injector); componentRef.instance.title = title; componentRef.instance.message = message; componentRef.instance.buttons = buttons; if (extras) { componentRef.instance.theme = extras.theme; } // attach component to the appRef so that it's inside the ng component tree this.appRef.attachView(componentRef.hostView); // get DOM element from component const modalElement = componentRef.hostView .rootNodes[0]; // append DOM element to the body document.body.appendChild(modalElement); return componentRef.instance.ngOnInit().then(() => { // show dialog return componentRef.instance.show().then(result => { // detach view this.appRef.detachView(componentRef.hostView); // destroy component ref componentRef.destroy(); // return Promise.resolve(result); }); }); } showWarningDialog(title, message, buttons = DIALOG_BUTTONS.OkCancel) { return this.showDialog('', `<div class="text-center"> <div class="icon-circle icon-circle-warning"> <i class="fa fa-exclamation"></i> </div> <div class="font-2xl font-weight-bold mt-2"> ${title} </div> <p class="mt-2"> ${message} </p> </div> `, buttons, { theme: 'modal-dialog-warning' }); } showSuccessDialog(title, message, buttons = DIALOG_BUTTONS.Ok) { return this.showDialog('', `<div class="text-center"> <div class="icon-circle icon-circle-success"> <i class="fa fa-check"></i> </div> <div class="font-2xl font-weight-bold mt-2"> ${title} </div> <p class="mt-2"> ${message} </p> </div> `, buttons, { theme: 'modal-dialog-success' }); } showErrorDialog(title, message, buttons = DIALOG_BUTTONS.Ok) { return this.showDialog('', `<div class="text-center"> <div class="icon-circle icon-circle-danger"> <i class="fa fa-times"></i> </div> <div class="font-2xl font-weight-bold mt-2"> ${title} </div> <p class="mt-2"> ${message} </p> </div> `, buttons, { theme: 'modal-dialog-danger' }); } showInfoDialog(title, message, buttons = DIALOG_BUTTONS.Ok) { return this.showDialog('', `<div class="text-center"> <div class="icon-circle icon-circle-info"> <i class="fa fa-info"></i> </div> <div class="font-2xl font-weight-bold mt-2"> ${title} </div> <p class="mt-2"> ${message} </p> </div> `, buttons, { theme: 'modal-dialog-info' }); } openModal(template, customClass) { let config; if (customClass) { config = JSON.parse(JSON.stringify(this.config)); config.class = customClass; } else { config = this.config; } return this.modalRef = this.modalService.show(template, config); } openModalComponent(template, options) { return this.modalRef = this.modalService.show(template, options); } } ModalService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ModalService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ApplicationRef }, { token: i0.Injector }, { token: i1.BsModalService }], target: i0.ɵɵFactoryTarget.Injectable }); ModalService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ModalService }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ModalService, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ApplicationRef }, { type: i0.Injector }, { type: i1.BsModalService }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"","sources":["../../../../src/shared/services/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {ApplicationRef, ComponentFactoryResolver, EmbeddedViewRef, Injectable, Injector} from '@angular/core';\nimport {DialogComponent, DIALOG_BUTTONS} from '../components/modal/dialog.component';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { BsModalRef } from 'ngx-bootstrap/modal/bs-modal-ref.service';\n\nexport interface DialogComponentExtras {\n  theme?: string;\n}\n\n/**\n *\n * Displays a Modal window or a type of Notification (based on choice the color changes)\n * @export\n * @class ModalService\n */\n@Injectable()\nexport class ModalService {\n  modalRef: any;\n  config = {\n    ignoreBackdropClick: true,\n    keyboard: false,\n    initialState: null,\n    class: 'modal-content-base'\n  };\n\n  constructor(private componentFactoryResolver: ComponentFactoryResolver,\n              private appRef: ApplicationRef,\n              private injector: Injector,\n              private modalService: BsModalService) { }\n\n  showDialog(title: string, message: string, buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.Ok, extras?: DialogComponentExtras) {\n    const componentRef = this.componentFactoryResolver\n        .resolveComponentFactory(DialogComponent)\n        .create(this.injector);\n    componentRef.instance.title = title;\n    componentRef.instance.message = message;\n    componentRef.instance.buttons = buttons;\n    if (extras) {\n      componentRef.instance.theme = extras.theme;\n    }\n    // attach component to the appRef so that it's inside the ng component tree\n    this.appRef.attachView(componentRef.hostView);\n    // get DOM element from component\n    const modalElement = (componentRef.hostView as EmbeddedViewRef<any>)\n        .rootNodes[0] as HTMLElement;\n    // append DOM element to the body\n    document.body.appendChild(modalElement);\n    return componentRef.instance.ngOnInit().then(() => {\n      // show dialog\n      return componentRef.instance.show().then( result => {\n        // detach view\n        this.appRef.detachView(componentRef.hostView);\n        // destroy component ref\n        componentRef.destroy();\n        //\n        return Promise.resolve(result);\n      });\n    });\n  }\n\n  showWarningDialog(title: string, message: string, buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.OkCancel) {\n      return this.showDialog(\n        '',\n        `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-warning\">\n                    <i class=\"fa fa-exclamation\"></i>\n                </div>\n                <div class=\"font-2xl font-weight-bold mt-2\">\n                ${title}\n                </div>\n                <p class=\"mt-2\">\n                ${message}\n                </p>\n            </div>\n            `,\n        buttons, {\n          theme: 'modal-dialog-warning'\n        });\n  }\n\n  showSuccessDialog(title: string, message: string, buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.Ok) {\n    return this.showDialog(\n        '',\n        `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-success\">\n                    <i class=\"fa fa-check\"></i>\n                </div>\n                <div class=\"font-2xl font-weight-bold mt-2\">\n                ${title}\n                </div>\n                <p class=\"mt-2\">\n                ${message}\n                </p>\n            </div>\n            `,\n        buttons, {\n          theme: 'modal-dialog-success'\n        });\n  }\n\n  showErrorDialog(title: string, message: string, buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.Ok) {\n    return this.showDialog(\n        '',\n        `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-danger\">\n                    <i class=\"fa fa-times\"></i>\n                </div>\n                <div class=\"font-2xl font-weight-bold mt-2\">\n                ${title}\n                </div>\n                <p class=\"mt-2\">\n                ${message}\n                </p>\n            </div>\n            `,\n        buttons, {\n          theme: 'modal-dialog-danger'\n        });\n  }\n\n    showInfoDialog(title: string, message: string, buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.Ok) {\n        return this.showDialog(\n            '',\n            `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-info\">\n                    <i class=\"fa fa-info\"></i>\n                </div>\n                <div class=\"font-2xl font-weight-bold mt-2\">\n                ${title}\n                </div>\n                <p class=\"mt-2\">\n                ${message}\n                </p>\n            </div>\n            `,\n            buttons, {\n                theme: 'modal-dialog-info'\n            });\n    }\n\n  openModal(template: any, customClass?: string): BsModalRef {\n    let config;\n    if (customClass) {\n      config = JSON.parse(JSON.stringify(this.config));\n      config.class = customClass;\n    } else {\n      config = this.config;\n    }\n    return this.modalRef = this.modalService.show(template, config);\n  }\n\n  openModalComponent(template: any, options?: any): BsModalRef {\n        return this.modalRef = this.modalService.show(template, options);\n    }\n}\n"]}