Sync Integ to Master
[sdc.git] / catalog-ui / src / app / services / components / utils / composition-left-palette-service.ts
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
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  * Created by obarda on 3/13/2016.
22  */
23 'use strict';
24 import * as _ from "lodash";
25 import {LeftPaletteComponent, LeftPaletteMetadataTypes} from "app/models/components/displayComponent";
26 import {Component} from "app/models/components/component";
27 import {EventListenerService} from "../../event-listener-service";
28 import {ComponentFactory} from "../../../utils/component-factory";
29 import {IAppConfigurtaion} from "app/models/app-config";
30 import {ResourceType, ComponentType, EVENTS} from "../../../utils/constants";
31 import {ComponentMetadata} from "app/models/component-metadata";
32 import {GroupMetadata, GroupTpes} from "app/models/group-metadata";
33 import {PolicyMetadata, PolicyTpes} from "app/models/policy-metadata";
34 import {Resource} from "app/models/components/resource";
35
36 // export class LeftPaletteDataObject {
37 //     displayLeftPanelComponents:Array<LeftPaletteComponent>;
38 //     onFinishLoadingEvent:string;
39
40 //     constructor(onFinishEventListener:string) {
41
42 //         this.displayLeftPanelComponents = new Array<LeftPaletteComponent>();
43 //         this.onFinishLoadingEvent = onFinishEventListener;
44 //     }
45 // }
46
47 export class LeftPaletteLoaderService {
48
49     static '$inject' = [
50         'Restangular',
51         'sdcConfig',
52         '$q',
53         'ComponentFactory',
54         'EventListenerService'
55
56     ];
57
58     constructor(protected restangular:restangular.IElement,
59                 protected sdcConfig:IAppConfigurtaion,
60                 protected $q:ng.IQService,
61                 protected ComponentFactory:ComponentFactory,
62                 protected EventListenerService:EventListenerService) {
63
64         this.restangular.setBaseUrl(sdcConfig.api.root + sdcConfig.api.component_api_root);
65
66     }
67
68     // private serviceLeftPaletteData:LeftPaletteDataObject;
69     // private resourceLeftPaletteData:LeftPaletteDataObject;
70     // private resourcePNFLeftPaletteData:LeftPaletteDataObject;
71     // private vlData:LeftPaletteDataObject;
72     leftPanelComponents:Array<LeftPaletteComponent>;
73
74     public loadLeftPanel = (component:Component):void => {
75         // this.serviceLeftPaletteData = new LeftPaletteDataObject(EVENTS.SERVICE_LEFT_PALETTE_UPDATE_EVENT);
76         // this.resourceLeftPaletteData = new LeftPaletteDataObject(EVENTS.RESOURCE_LEFT_PALETTE_UPDATE_EVENT);
77         // this.resourcePNFLeftPaletteData = new LeftPaletteDataObject(EVENTS.RESOURCE_PNF_LEFT_PALETTE_UPDATE_EVENT);
78         this.leftPanelComponents = [];
79         this.updateLeftPaletteForTopologyTemplate(component);
80     }
81
82     // private getResourceLeftPaletteDataByResourceType = (resourceType:string):LeftPaletteDataObject => {
83     //     if(resourceType == ResourceType.PNF) {
84     //         return this.resourcePNFLeftPaletteData;
85     //     }
86     //     return this.resourceLeftPaletteData;
87     // }
88
89     private updateLeftPalette = (componentInternalType:string):void => {
90
91         /* add components */
92         this.restangular.one("resources").one('/latestversion/notabstract/metadata').get({'internalComponentType': componentInternalType}).then((leftPaletteComponentMetadata:Array<ComponentMetadata>) => {
93             _.forEach(leftPaletteComponentMetadata, (componentMetadata:ComponentMetadata) => {
94                 this.leftPanelComponents.push(new LeftPaletteComponent(LeftPaletteMetadataTypes.Component, componentMetadata));
95             });
96             this.EventListenerService.notifyObservers(EVENTS.LEFT_PALETTE_UPDATE_EVENT);
97         });
98
99         /* add groups */
100         //TODO: In backend implement like this:
101         //this.restangular.one("groups").one('/latestversion/notabstract/metadata').get({'internalComponentType': componentInternalType}).then((leftPaletteComponentMetadata:Array<ComponentMetadata>) => {
102         this.restangular.one('/groupTypes').get().then((leftPaletteGroupTypes:GroupTpes) => {
103             _.forEach(leftPaletteGroupTypes.groupTypes, (groupMetadata: GroupMetadata) => {
104                 this.leftPanelComponents.push(new LeftPaletteComponent(LeftPaletteMetadataTypes.Group, groupMetadata));
105             });
106             this.EventListenerService.notifyObservers(EVENTS.LEFT_PALETTE_UPDATE_EVENT);
107         });
108
109         /* add policies */
110         //TODO: In backend implement like this:
111         //this.restangular.one("policies").one('/latestversion/notabstract/metadata').get({'internalComponentType': componentInternalType}).then((leftPaletteComponentMetadata:Array<ComponentMetadata>) => {
112          this.restangular.one('/policyTypes').get().then((leftPalettePolicyTypes:PolicyTpes) => {
113             _.forEach(leftPalettePolicyTypes.policyTypes, (policyMetadata: PolicyMetadata) => {
114                 this.leftPanelComponents.push(new LeftPaletteComponent(LeftPaletteMetadataTypes.Policy, policyMetadata));
115             });
116             this.EventListenerService.notifyObservers(EVENTS.LEFT_PALETTE_UPDATE_EVENT);
117         });
118     }
119
120     public getLeftPanelComponentsForDisplay = (component:Component):Array<LeftPaletteComponent> => {
121         return this.leftPanelComponents;
122     };
123
124     /**
125      * Update left palete items according to current topology templates we are in.
126      */
127     public updateLeftPaletteForTopologyTemplate = (component:Component):void => {
128         switch (component.componentType) {
129             case ComponentType.SERVICE:
130                 this.updateLeftPalette(ComponentType.SERVICE);
131                 break;
132             case ComponentType.RESOURCE:
133                 this.updateLeftPalette((<Resource>component).resourceType);
134                 break;
135             default:
136                 console.log('ERROR: Component type '+ component.componentType + ' is not exists');
137         }
138     };
139 }