Simplify and add tests of confirm dialog
[portal/nonrtric-controlpanel.git] / webapp-frontend / src / app / services / ui / confirm-dialog.service.ts
1 /*-
2  * ========================LICENSE_START=================================
3  * O-RAN-SC
4  * %%
5  * Copyright (C) 2019 AT&T Intellectual Property
6  * %%
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ========================LICENSE_END===================================
19  */
20
21 import { Injectable } from "@angular/core";
22 import { MatDialog, MatDialogRef } from "@angular/material/dialog";
23 import { ConfirmDialogComponent } from "@ui/confirm-dialog/confirm-dialog.component";
24 import { UiService } from "./ui.service";
25
26 @Injectable({
27   providedIn: "root",
28 })
29 export class ConfirmDialogService {
30   constructor(private dialog: MatDialog, private ui: UiService) {}
31
32   openConfirmDialog(heading: string, msg: string): MatDialogRef<any> {
33     let panelClass = "";
34     let darkMode: boolean;
35     this.ui.darkModeState.subscribe((isDark) => {
36       darkMode = isDark;
37     });
38     if (darkMode) {
39       panelClass = "dark-theme";
40     }
41     return this.dialog.open(ConfirmDialogComponent, {
42       panelClass: panelClass,
43       width: "480px",
44       position: { top: "100px" },
45       data: {
46         heading: heading,
47         message: msg,
48       },
49     });
50   }
51 }