All files / modal/services modal.service.ts

100% Statements 13/13
100% Branches 12/12
100% Functions 4/4
100% Lines 11/11

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 622x   2x 2x       2x 13x           8x         8x             5x         5x     2x                 13x                                    
import { ModalContainerComponent } from '../components/modal-container.component';
import { LazyComponentLoader, ModalConfig, ModalRef } from '../models/modal.types';
import { Injectable, inject } from '@angular/core';
import { MatDialog, MatDialogConfig } from '@angular/material/dialog';
import { Observable } from 'rxjs';
 
@Injectable({ providedIn: 'root' })
export class ModalService {
    private readonly dialog = inject(MatDialog);
 
    open<TData = unknown, TResult = unknown>(
        loader: LazyComponentLoader<unknown>,
        config: ModalConfig<TData> = {}
    ): Observable<TResult | undefined> {
        const dialogRef = this.dialog.open<ModalContainerComponent<TData, TResult>, unknown, TResult>(
            ModalContainerComponent,
            this.buildDialogConfig(loader, config)
        );
 
        return dialogRef.afterClosed();
    }
 
    openWithRef<TData = unknown, TResult = unknown>(
        loader: LazyComponentLoader<unknown>,
        config: ModalConfig<TData> = {}
    ): { closed: Observable<TResult | undefined>; ref: ModalRef<TResult> } {
        const dialogRef = this.dialog.open<ModalContainerComponent<TData, TResult>, unknown, TResult>(
            ModalContainerComponent,
            this.buildDialogConfig(loader, config)
        );
 
        return {
            closed: dialogRef.afterClosed(),
            ref: {
                close: (result?: TResult) => dialogRef.close(result),
            },
        };
    }
 
    private buildDialogConfig<TData>(
        loader: LazyComponentLoader<unknown>,
        config: ModalConfig<TData>
    ): MatDialogConfig {
        return {
            data: {
                loader,
                data: config.data,
            },
            width: config.width ?? '500px',
            minWidth: config.minWidth,
            maxWidth: config.maxWidth ?? '90vw',
            height: config.height,
            maxHeight: '90vh',
            disableClose: config.disableClose ?? false,
            panelClass: (config.border ?? true) ? ['ui-modal-panel'] : ['ui-modal-panel', 'ui-modal-no-border'],
            backdropClass: ['cdk-overlay-dark-backdrop', 'ui-modal-backdrop'],
            autoFocus: 'first-tabbable',
            restoreFocus: true,
        };
    }
}