@universis/common
Version:
Universis - common directives and services
158 lines (157 loc) • 18.3 kB
JavaScript
import { ApplicationRef, ComponentFactoryResolver, Injectable, Injector } from '@angular/core';
import { DialogComponent, DIALOG_BUTTONS } from '../components/modal/dialog.component';
import { BsModalService } 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, icon) {
return this.showDialog(null, `<div class="text-center">
<div class="icon-circle icon-circle-warning">
<i class="${icon || '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, icon) {
return this.showDialog(null, `<div class="text-center">
<div class="icon-circle icon-circle-success">
<i class="${icon || '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, icon) {
return this.showDialog(null, `<div class="text-center">
<div class="icon-circle icon-circle-danger">
<i class="${icon || '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'
});
}
showDangerDialog(title, message, buttons = DIALOG_BUTTONS.Ok, icon) {
return this.showDialog(null, `<div class="text-center">
<div class="icon-circle icon-circle-danger">
<i class="${icon || '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-danger'
});
}
showInfoDialog(title, message, buttons = DIALOG_BUTTONS.Ok, icon) {
return this.showDialog(null, `<div class="text-center">
<div class="icon-circle icon-circle-info">
<i class="${icon || '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.decorators = [
{ type: Injectable }
];
/** @nocollapse */
ModalService.ctorParameters = () => [
{ type: ComponentFactoryResolver },
{ type: ApplicationRef },
{ type: Injector },
{ type: BsModalService }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"ng://@universis/common/","sources":["shared/services/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {ApplicationRef, ComponentFactoryResolver, EmbeddedViewRef, Injectable, Injector, EventEmitter} from '@angular/core';\nimport {DialogComponent, DIALOG_BUTTONS} from '../components/modal/dialog.component';\nimport { ToastService } from './toast.service';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { BsModalRef } from 'ngx-bootstrap/modal/bs-modal-ref.service';\nimport {TranslateService} from '@ngx-translate/core';\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, icon?: string) {\n      return this.showDialog(\n        null,\n        `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-warning\">\n                    <i class=\"${ icon || '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, icon?: string) {\n    return this.showDialog(\n        null,\n        `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-success\">\n                    <i class=\"${ icon || '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, icon?: string) {\n    return this.showDialog(\n        null,\n        `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-danger\">\n                    <i class=\"${ icon || '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  showDangerDialog(title: string, message: string, buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.Ok, icon?: string) {\n    return this.showDialog(\n        null,\n        `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-danger\">\n                    <i class=\"${ icon || '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-danger'\n        });\n  }\n\n    showInfoDialog(title: string, message: string, buttons: DIALOG_BUTTONS = DIALOG_BUTTONS.Ok, icon?: string) {\n        return this.showDialog(\n            null,\n            `<div class=\"text-center\">\n                <div class=\"icon-circle icon-circle-info\">\n                    <i class=\"${ icon || '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"]}