merge from ecomp a88f0072 - Modern UI
[vid.git] / vid-webpack-master / src / app / drawingBoard / service-planning / drawing-board-tree / drawing-board-tree.service.ts
1 import {Injectable} from "@angular/core";
2 import {ITreeNode} from "angular-tree-component/dist/defs/api";
3 import * as _ from 'lodash';
4 import {NgRedux} from "@angular-redux/store";
5 import {AppState} from "../../../shared/store/reducers";
6 import {FeatureFlagsService, Features} from "../../../shared/services/featureFlag/feature-flags.service";
7 import {ServiceInstanceActions} from "../../../shared/models/serviceInstanceActions";
8
9 @Injectable()
10 export class  DrawingBoardTreeService {
11   constructor(private store: NgRedux<AppState>){}
12   isVFModuleMissingData(node: ITreeNode, serviceModelId : string): boolean {
13     if(node.data.type === 'VFmodule' &&!_.isNil(this.store.getState().service.serviceInstance[serviceModelId].vnfs) &&  !_.isNil(this.store.getState().service.serviceInstance[serviceModelId].vnfs[node.parent.data.vnfStoreKey])){
14       if(!_.isNil(this.store.getState().service.serviceInstance[serviceModelId].vnfs[node.parent.data.vnfStoreKey].vfModules)
15         && !_.isNil(this.store.getState().service.serviceInstance[serviceModelId].vnfs[node.parent.data.vnfStoreKey].vfModules[node.data.modelName])
16         && !_.isNil(this.store.getState().service.serviceInstance[serviceModelId].vnfs[node.parent.data.vnfStoreKey].vfModules[node.data.modelName][node.data.dynamicModelName])){
17
18         return this.store.getState().service.serviceInstance[serviceModelId].vnfs[node.parent.data.vnfStoreKey].vfModules[node.data.modelName][node.data.dynamicModelName].isMissingData;
19       }
20     }
21     return false;
22   }
23
24   isVNFMissingData(node : ITreeNode, serviceModelId : string) : boolean {
25     if(node.data.type == 'VF'  && !_.isNil(this.store.getState().service.serviceInstance[serviceModelId].vnfs[node.data.vnfStoreKey])){
26       return  this.store.getState().service.serviceInstance[serviceModelId].vnfs[node.data.vnfStoreKey].isMissingData;
27     }
28   }
29
30   isViewEditFlagTrue():boolean{
31     return FeatureFlagsService.getFlagState(Features.FLAG_1902_NEW_VIEW_EDIT, this.store);
32   }
33
34   /**********************************************
35    return all drawing board context menu options
36    ***********************************************/
37   generateContextMenuOptions() : TreeNodeContextMenuModel[]{
38     return [
39       new TreeNodeContextMenuModel('edit', 'context-menu-edit', 'Edit', 'edit-file-o'),
40       new TreeNodeContextMenuModel('duplicate', 'context-menu-duplicate', 'Duplicate', 'copy-o'),
41       new TreeNodeContextMenuModel('showAuditInfo', 'context-menu-showAuditInfo', 'Show audit info', 'eye-o'),
42       new TreeNodeContextMenuModel('addGroupMember', 'context-menu-addGroupMember', 'Add group members', 'plus'),
43       new TreeNodeContextMenuModel('delete', 'context-menu-delete', 'Delete', 'trash-o'),
44       new TreeNodeContextMenuModel('remove', 'context-menu-remove', 'Remove', 'trash-o'),
45       new TreeNodeContextMenuModel('undoDelete', 'context-menu-undoDelete', 'Undo Delete', 'undo-delete')
46     ];
47   }
48
49
50   /*******************************************************************
51     delete or remove all service child's on delete existing service
52    *******************************************************************/
53   deleteActionService(nodes : ITreeNode[], serviceModelId : string){
54     if(!_.isNil(nodes)){
55       for(let node of nodes){
56         node.data = node;
57         if(!_.isNil(node.children)){
58           node.children.map((child)=>{
59             child.data = child;
60             child.parent = node;
61           });
62         }
63
64         let menuActionsName : string = node.data.action === ServiceInstanceActions.Create ? 'remove' : 'delete';
65         if(!_.isNil(node.data.menuActions) && !_.isNil(node.data.menuActions[menuActionsName])){
66           node.data.menuActions[menuActionsName]['method'](node, serviceModelId)
67         }
68
69       }
70     }
71   }
72   /*******************************************************************
73    undo delete all service child's on undo delete existing service
74    *******************************************************************/
75   undoDeleteActionService(nodes : ITreeNode[], serviceModelId : string){
76     if(!_.isNil(nodes)){
77       for(let node of nodes){
78         node.data = node;
79         if(!_.isNil(node.children)){
80           node.children.map((child)=>{
81             child.data = child;
82             child.parent = node;
83           });
84         }
85
86         if(!_.isNil(node.data.menuActions) && !_.isNil(node.data.menuActions['undoDelete'])){
87           node.data.menuActions['undoDelete']['method'](node, serviceModelId)
88         }
89       }
90     }
91   }
92
93   /***********************************************************
94    return true if should add line hover the instance name
95    ***********************************************************/
96   isTextDecoration(node) : boolean{
97     return !_.isNil(node.data) && !_.isNil(node.data.action) && node.data.action.split('_').pop() === 'Delete';
98   }
99
100
101   /******************************************
102    should create object of instances action
103    ******************************************/
104   generateServiceActionObject(nodes){
105     let obj = {};
106     let index = 0;
107     for(let node of nodes){
108       obj[index] = {};
109       index++;
110     }
111   }
112 }
113
114 export class TreeNodeContextMenuModel {
115   methodName: string;
116   dataTestId: string;
117   label: string;
118   iconClass: string;
119
120   constructor(methodName: string,
121               dataTestId: string,
122               label: string,
123               iconClass: string) {
124     this.methodName = methodName;
125     this.dataTestId = dataTestId;
126     this.label = label;
127     this.iconClass = iconClass;
128   }
129 }