MC App metrics display
[portal/ric-dashboard.git] / webapp-frontend / src / app / ran-control / ran-control.component.ts
index f5ef36c..172a84e 100644 (file)
  * limitations under the License.
  * ========================LICENSE_END===================================
  */
+import { HttpErrorResponse } from '@angular/common/http';
 import { Component, OnInit } from '@angular/core';
-import { HttpResponse, HttpErrorResponse } from '@angular/common/http';
 import { MatDialog } from '@angular/material/dialog';
-import { RanControlConnectDialogComponent } from './ran-connection-dialog.component';
+import { finalize } from 'rxjs/operators';
 import { E2ManagerService } from '../services/e2-mgr/e2-mgr.service';
-import { ErrorDialogService } from '../services/ui/error-dialog.service';
 import { ConfirmDialogService } from '../services/ui/confirm-dialog.service';
+import { ErrorDialogService } from '../services/ui/error-dialog.service';
+import { LoadingDialogService } from '../services/ui/loading-dialog.service';
 import { NotificationService } from '../services/ui/notification.service';
+import { RanControlConnectDialogComponent } from './ran-connection-dialog.component';
 import { RANControlDataSource } from './ran-control.datasource';
 
 @Component({
@@ -40,6 +42,7 @@ export class RanControlComponent implements OnInit {
     private errorDialogService: ErrorDialogService,
     private confirmDialogService: ConfirmDialogService,
     private notificationService: NotificationService,
+    private loadingDialogService: LoadingDialogService,
     public dialog: MatDialog) { }
 
   ngOnInit() {
@@ -63,21 +66,24 @@ export class RanControlComponent implements OnInit {
     this.confirmDialogService.openConfirmDialog('Are you sure you want to disconnect all RAN connections?')
       .afterClosed().subscribe( (res: boolean) => {
         if (res) {
-          this.e2MgrSvc.nodebDelete().subscribe(
-            ( response: HttpResponse<Object>) => {
-              if (response.status === 200) {
-                this.notificationService.success('Disconnect succeeded!');
-                this.dataSource.loadTable();
-              }
+          this.loadingDialogService.startLoading("Disconnecting");
+          this.e2MgrSvc.nodebPut()
+            .pipe(
+              finalize(() => this.loadingDialogService.stopLoading())
+            )
+            .subscribe(
+            ( body: any ) => {
+              this.notificationService.success('Disconnect succeeded!');
+              this.dataSource.loadTable();
             },
-            ( (her: HttpErrorResponse) => {
+            (her: HttpErrorResponse) => {
               // the error field should have an ErrorTransport object
               let msg = her.message;
               if (her.error && her.error.message) {
                 msg = her.error.message;
               }
               this.errorDialogService.displayError('Disconnect failed: ' + msg);
-            })
+            }
           );
         }
       });