Merge from ecomp 718fd196 - Modern UI
[vid.git] / vid-webpack-master / src / app / drawingBoard / service-planning / drawing-board-header / drawing-board-header.service.ts
1 import {Injectable} from "@angular/core";
2 import {ActivatedRoute} from "@angular/router";
3 import {addServiceAction} from "../../../shared/storeUtil/utils/service/service.actions";
4 import {ServiceInstanceActions} from "../../../shared/models/serviceInstanceActions";
5 import {AppState} from "../../../shared/store/reducers";
6 import {DrawingBoardTreeComponent} from "../drawing-board-tree/drawing-board-tree.component";
7 import {AuditInfoModalComponent} from "../../../shared/components/auditInfoModal/auditInfoModal.component";
8 import {ServiceModel} from "../../../shared/models/serviceModel";
9 import {NgRedux} from "@angular-redux/store";
10 import * as _ from 'lodash';
11 import {ErrorMsgService} from "../../../shared/components/error-msg/error-msg.service";
12 import {DrawingBoardModes} from "../drawing-board.modes";
13 import {ServiceInstance} from "../../../shared/models/serviceInstance";
14 import {FeatureFlagsService, Features} from "../../../shared/services/featureFlag/feature-flags.service";
15
16 @Injectable()
17 export class DrawingBoardHeaderService{
18
19   constructor(private route: ActivatedRoute, private store: NgRedux<AppState>, private errorMsgService: ErrorMsgService){}
20   generateOldViewEditPath(): string{
21     let query: string =
22       `subscriberId=${this.route.snapshot.queryParams['subscriberId']}&` +
23       `subscriberName=${this.route.snapshot.queryParams['subscriberName']}&` +
24       `serviceType=${this.route.snapshot.queryParams['serviceType']}&` +
25       `serviceInstanceId=${this.route.snapshot.queryParams['serviceInstanceId']}`;
26     return '../../serviceModels.htm#/instantiate?' + query;
27   }
28
29   deleteService(serviceModelId: string, isDeleted: boolean ) {
30     if(isDeleted){
31       this.store.dispatch(addServiceAction(serviceModelId, ServiceInstanceActions.Delete));
32       DrawingBoardTreeComponent.triggerDeleteActionService.next(serviceModelId);
33     } else{
34       this.store.dispatch(addServiceAction(serviceModelId, ServiceInstanceActions.None));
35       DrawingBoardTreeComponent.triggerUndoDeleteActionService.next(serviceModelId);
36     }
37   }
38
39   showAuditInfo(serviceModelId) : void {
40     let instance: ServiceInstance = this.store.getState().service.serviceInstance[serviceModelId];
41     let model =  new ServiceModel(this.store.getState().service.serviceHierarchy[serviceModelId]);
42     AuditInfoModalComponent.openInstanceAuditInfoModal.next({instanceId : serviceModelId , type : 'SERVICE', model : model , instance : instance});
43   }
44
45   toggleResumeService(serviceModelId, isResume: boolean) : void {
46     const action: ServiceInstanceActions = isResume ? ServiceInstanceActions.Resume : ServiceInstanceActions.None;
47     this.store.dispatch(addServiceAction(serviceModelId, action));
48
49   }
50
51
52   /*************************************************
53     should return true if deploy should be disabled
54    *************************************************/
55   deployShouldBeDisabled(serviceInstanceId: string, mode : string) : boolean {
56     const serviceInstance = this.store.getState().service.serviceInstance[serviceInstanceId];
57     if(!_.isNil(serviceInstance)){
58       const validationCounter = serviceInstance.validationCounter;
59       if (!_.isNil(this.errorMsgService.errorMsgObject) && mode !== DrawingBoardModes.RETRY_EDIT) return true;
60       if(validationCounter > 0) return true;
61       if(serviceInstance.action !== ServiceInstanceActions.None) return false;
62       if(mode === DrawingBoardModes.RETRY_EDIT) return false;
63       return !serviceInstance.isDirty;
64     }
65     return true;
66   }
67
68   getModeButton(mode : string) : string {
69     switch (mode) {
70       case DrawingBoardModes.EDIT:
71         return 'UPDATE';
72       case DrawingBoardModes.RETRY_EDIT:
73         return 'REDEPLOY';
74       default: return 'DEPLOY';
75     }
76   }
77   getButtonText(mode : DrawingBoardModes) : string {
78     switch (mode) {
79       case DrawingBoardModes.EDIT:
80       case DrawingBoardModes.VIEW:
81         return 'EDIT';
82       case DrawingBoardModes.RETRY_EDIT:
83       case DrawingBoardModes.RETRY:
84         return 'REDEPLOY';
85     }
86   }
87
88   showEditService(mode: DrawingBoardModes, serviceModelId: string): boolean{
89     const serviceInstance = this.store.getState().service.serviceInstance;
90     return mode === DrawingBoardModes.CREATE || ((mode === DrawingBoardModes.RETRY_EDIT || mode === DrawingBoardModes.EDIT)&&
91       !_.isNil(serviceInstance) && !_.isNil(serviceInstance[serviceModelId])&& serviceInstance[serviceModelId].action === ServiceInstanceActions.Create);
92   }
93
94   showResumeService(serviceModelId: string): boolean {
95     const serviceInstance: ServiceInstance = !_.isNil(this.store.getState().service.serviceInstance)? this.store.getState().service.serviceInstance[serviceModelId] : null;
96     if (serviceInstance)
97     {
98       return FeatureFlagsService.getFlagState(Features.FLAG_1908_RESUME_MACRO_SERVICE, this.store) &&
99         serviceInstance.vidNotions.instantiationType.toLowerCase() === "macro" &&
100         serviceInstance.subscriptionServiceType.toLowerCase() !== "transport" &&
101         serviceInstance.orchStatus &&
102         (serviceInstance.orchStatus.toLowerCase() === "assigned" ||
103           serviceInstance.orchStatus.toLowerCase() === "inventoried");
104     }
105     return false;
106   }
107 }