UNPKG

@dbg-riskit/angular-view

Version:

134 lines 17.4 kB
import { Injectable } from '@angular/core'; import { first } from 'rxjs/operators'; import { LoaderComponent } from './loader.component'; import { MessageDialogComponent } from './message.dialog.component'; import { ProgressLoaderComponent } from './progress.loader.component'; import * as i0 from "@angular/core"; import * as i1 from "@angular/material/dialog"; export class DialogService { constructor(dialog) { this.dialog = dialog; } showWarnDialog(message, note) { return this.showMessageDialog({ dialogType: 'warning', message, note }); } showWarnQuestionDialog(destroyCallback, destructiveButtonLabel, message, note) { return this.showMessageDialog({ dialogType: 'warning', message, note, buttons: [ { label: destructiveButtonLabel, value: true, primary: true }, { label: 'Cancel', value: false } ], answerCallback(result) { if (result) { destroyCallback(); } } }); } showErrorDialog(message, note) { return this.showMessageDialog({ dialogType: 'error', message, note }); } showInfoDialog(message, note) { return this.showMessageDialog({ dialogType: 'info', message, note }); } showSuccessDialog(message, note) { return this.showMessageDialog({ dialogType: 'success', message, note }); } showQuestionDialog(buttons, answerCallback, message, note) { return this.showMessageDialog({ dialogType: 'question', message, note, buttons, answerCallback }); } showMessageDialog(config) { return this.showDialog(MessageDialogComponent, { ...config.config, data: { dialogType: config.dialogType, buttons: config.buttons, title: config.title, message: config.message, note: config.note, icon: config.icon } }, config.answerCallback); } /* eslint-enable */ showLoaderDialog(data) { if (typeof data === 'string') { data = { title: data }; } return this.showDialog(LoaderComponent, { disableClose: true, hasBackdrop: true, data }); } /* eslint-enable */ showProgressLoaderDialog(data) { if (typeof data === 'string') { data = { title: data }; } return this.showDialog(ProgressLoaderComponent, { disableClose: true, hasBackdrop: true, data }); } /* eslint-enable */ showDialog(dialogClass, configOrCallback, callback) { let config; if (typeof configOrCallback === 'function') { callback = configOrCallback; } else { config = configOrCallback; } const dialogRef = this.dialog.open(dialogClass, config); dialogRef.afterClosed().pipe(first()).subscribe((result) => { if (callback) { callback(result); } }); return dialogRef.componentInstance; } } DialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: DialogService, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable }); DialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: DialogService }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.6", ngImport: i0, type: DialogService, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.MatDialog }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../pkg/dbg-riskit/angular-view/src/lib/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable, Type} from '@angular/core';\nimport {MatDialog} from '@angular/material/dialog';\nimport {first} from 'rxjs/operators';\nimport {DialogData as LoaderConfig, LoaderComponent} from './loader.component';\nimport {\n    DialogButton,\n    DialogConfig as MessageDialogConfig,\n    DialogType,\n    MessageDialogComponent\n} from './message.dialog.component';\nimport {DialogData as ProgressLoaderConfig, ProgressLoaderComponent} from './progress.loader.component';\n\nexport interface DialogConfig<T> {\n    /** Custom class for the overlay pane. */\n    readonly panelClass?: string;\n    /** Whether the dialog has a backdrop. */\n    readonly hasBackdrop?: boolean;\n    /** Custom class for the backdrop, */\n    readonly backdropClass?: string;\n    /** Whether the user can use escape or clicking outside to close a modal. */\n    readonly disableClose?: boolean;\n\n    readonly data?: T;\n}\n\nexport interface DialogComponent<T, R = unknown> {\n    readonly dialogData: T;\n}\n\n@Injectable()\nexport class DialogService {\n\n    public constructor(public readonly dialog: MatDialog) {\n    }\n\n    public showWarnDialog(message: string, note?: string) {\n        return this.showMessageDialog({\n            dialogType: 'warning',\n            message,\n            note\n        });\n    }\n\n    public showWarnQuestionDialog(destroyCallback: () => void,\n                                  destructiveButtonLabel: string,\n                                  message: string,\n                                  note?: string) {\n        return this.showMessageDialog({\n            dialogType: 'warning',\n            message,\n            note,\n            buttons   : [\n                {\n                    label  : destructiveButtonLabel,\n                    value  : true,\n                    primary: true\n                },\n                {\n                    label: 'Cancel',\n                    value: false\n                }\n            ],\n            answerCallback(result?: boolean) {\n                if (result) {\n                    destroyCallback();\n                }\n            }\n        });\n    }\n\n    public showErrorDialog(message: string, note?: string) {\n        return this.showMessageDialog({\n            dialogType: 'error',\n            message,\n            note\n        });\n    }\n\n    public showInfoDialog(message: string, note?: string) {\n        return this.showMessageDialog({\n            dialogType: 'info',\n            message,\n            note\n        });\n    }\n\n    public showSuccessDialog(message: string, note?: string) {\n        return this.showMessageDialog({\n            dialogType: 'success',\n            message,\n            note\n        });\n    }\n\n    public showQuestionDialog<R>(buttons: Array<DialogButton<R>>,\n                                 answerCallback: (value?: R) => void,\n                                 message: string,\n                                 note?: string) {\n        return this.showMessageDialog({\n            dialogType: 'question',\n            message,\n            note,\n            buttons,\n            answerCallback\n        });\n    }\n\n    public showMessageDialog<R>(config: {\n        dialogType: DialogType;\n        buttons?: Array<DialogButton<R>>;\n        answerCallback?: (value?: R) => void;\n        config?: DialogConfig<undefined>;\n        title?: string,\n        message: string;\n        note?: string;\n        icon?: string;\n    }) {\n        return this.showDialog(MessageDialogComponent, {\n                ...config.config,\n                data: {\n                    dialogType: config.dialogType,\n                    buttons   : config.buttons,\n                    title     : config.title,\n                    message   : config.message,\n                    note      : config.note,\n                    icon      : config.icon\n                } as MessageDialogConfig<R>\n            },\n            config.answerCallback);\n    }\n\n    /* eslint-disable @typescript-eslint/unified-signatures */\n    public showLoaderDialog(title: string): LoaderComponent;\n    public showLoaderDialog(data: LoaderConfig): LoaderComponent;\n    /* eslint-enable */\n    public showLoaderDialog(data: string | LoaderConfig): LoaderComponent {\n        if (typeof data === 'string') {\n            data = {\n                title: data\n            };\n        }\n        return this.showDialog(LoaderComponent, {\n            disableClose: true,\n            hasBackdrop : true,\n            data\n        });\n    }\n\n    /* eslint-disable @typescript-eslint/unified-signatures */\n    public showProgressLoaderDialog(title: string): ProgressLoaderComponent;\n    public showProgressLoaderDialog(data: ProgressLoaderConfig): ProgressLoaderComponent;\n    /* eslint-enable */\n    public showProgressLoaderDialog(data: string | ProgressLoaderConfig): ProgressLoaderComponent {\n        if (typeof data === 'string') {\n            data = {\n                title: data\n            };\n        }\n\n        return this.showDialog(ProgressLoaderComponent, {\n            disableClose: true,\n            hasBackdrop : true,\n            data\n        });\n    }\n\n    /* eslint-disable @typescript-eslint/unified-signatures */\n    public showDialog<T extends DialogComponent<D, R>, D, R>(dialogClass: Type<T>): T;\n    public showDialog<T extends DialogComponent<D, R>, D, R>(dialogClass: Type<T>,\n                                                             config?: DialogConfig<D>): T;\n    public showDialog<T extends DialogComponent<D, R>, D, R>(dialogClass: Type<T>,\n                                                             callback?: (result?: R) => void): T;\n    public showDialog<T extends DialogComponent<D, R>, D, R>(dialogClass: Type<T>,\n                                                             config?: DialogConfig<D>,\n                                                             callback?: (result?: R) => void): T;\n    /* eslint-enable */\n    public showDialog<T extends DialogComponent<D, R>, D, R>(dialogClass: Type<T>,\n                                                             configOrCallback?: DialogConfig<D>\n                                                                 | ((result?: R) => void),\n                                                             callback?: (result?: R) => void): T {\n        let config: DialogConfig<D> | undefined;\n        if (typeof configOrCallback === 'function') {\n            callback = configOrCallback;\n        } else {\n            config = configOrCallback;\n        }\n        const dialogRef = this.dialog.open(dialogClass, config);\n\n        dialogRef.afterClosed().pipe(\n            first()\n        ).subscribe((result?: R) => {\n            if (callback) {\n                callback(result);\n            }\n        });\n\n        return dialogRef.componentInstance;\n    }\n}\n"]}