1 import { HttpClient, HttpParams } from '@angular/common/http';
2 import { Inject, Injectable } from '@angular/core';
3 import { LeftPaletteComponent, LeftPaletteMetadataTypes } from 'app/models/components/displayComponent';
4 import { GroupMetadata } from 'app/models/group-metadata';
5 import { PolicyMetadata } from 'app/models/policy-metadata';
6 import { IComponentMetadata } from 'app/models/component-metadata';
7 import { SdcConfigToken } from 'app/ng2/config/sdc-config.config';
8 import { ISdcConfig } from 'app/ng2/config/sdc-config.config.factory';
9 import { WorkspaceService } from 'app/ng2/pages/workspace/workspace.service';
10 import 'rxjs/add/observable/forkJoin';
11 import { Observable } from 'rxjs/Rx';
12 import Dictionary = _.Dictionary;
17 export class CompositionPaletteService {
19 protected baseUrl = '';
21 private leftPaletteComponents: Dictionary<Dictionary<LeftPaletteComponent[]>>;
22 private facadeUrl: string;
23 constructor(protected http: HttpClient, @Inject(SdcConfigToken) sdcConfig: ISdcConfig, private workspaceService: WorkspaceService) {
24 this.baseUrl = sdcConfig.api.root + sdcConfig.api.component_api_root;
25 this.facadeUrl = sdcConfig.api.uicache_root + sdcConfig.api.GET_uicache_left_palette;
29 public subscribeToLeftPaletteElements(next, error) {
31 let params = new HttpParams();
32 params = params.append('internalComponentType', this.workspaceService.getMetadataType());
34 const loadInstances = this.http.get(this.facadeUrl, {params});
35 const loadGroups = this.http.get(this.baseUrl + 'groupTypes', {params});
36 const loadPolicies = this.http.get(this.baseUrl + 'policyTypes', {params});
39 loadInstances, loadGroups, loadPolicies
40 ).subscribe( ([resInstances, resGrouops, resPolicies]) => {
41 const combinedDictionary = this.combineResoponses(resInstances, resGrouops, resPolicies);
42 this.leftPaletteComponents = combinedDictionary;
43 next(this.leftPaletteComponents);
47 public getLeftPaletteElements = (): Dictionary<Dictionary<LeftPaletteComponent[]>> => {
48 return this.leftPaletteComponents;
52 public convertPoliciesOrGroups = (paletteListResult, type: string ) => {
53 const components: LeftPaletteComponent[] = [];
55 if (type === 'Policies') {
56 _.forEach(paletteListResult, (policyMetadata: PolicyMetadata) => {
57 components.push(new LeftPaletteComponent(LeftPaletteMetadataTypes.Policy, policyMetadata));
64 if (type === 'Groups') {
65 _.forEach(paletteListResult, (groupMetadata: GroupMetadata) => {
66 const item = new LeftPaletteComponent(LeftPaletteMetadataTypes.Group, groupMetadata);
67 components.push(item);
77 private combineResoponses(resInstances: object, resGrouops: object, resPolicies: object) {
78 const retValObject = {};
80 if (resInstances['Generic']) {
81 if (this.isSubstitutionForNestedServices()) {
82 const serviceGroup = this.createServiceGroup(resInstances);
84 retValObject['Service'] = serviceGroup;
88 // Generic will be the 1st category in the left Pallete
89 retValObject['Generic'] = resInstances['Generic'];
93 // Add all other categories
94 for (const category in resInstances) {
95 if (category === 'Generic') {
98 retValObject[category] = resInstances[category];
102 retValObject["Groups"] = this.convertPoliciesOrGroups(resGrouops, 'Groups');
105 retValObject["Policies"] = this.convertPoliciesOrGroups(resPolicies, 'Policies');
110 private isSubstitutionForNestedServices(): boolean {
111 return this.workspaceService.metadata.categories[0].useServiceSubstitutionForNestedServices;
114 private createServiceGroup(resInstances: object): object {
115 const servicesList = resInstances['Generic']['Generic'];
116 if (Array.isArray(servicesList) && servicesList.length > 0) {
117 delete resInstances['Generic']['Generic'];
118 return servicesList.reduce(function (map, component) {
119 if (map[component.categories[0].name]) {
120 map[component.categories[0].name].push(component);
122 map[component.categories[0].name] = [component];