aboutsummaryrefslogtreecommitdiffstats
path: root/catalog-ui/app/scripts/services/components
diff options
context:
space:
mode:
Diffstat (limited to 'catalog-ui/app/scripts/services/components')
-rw-r--r--catalog-ui/app/scripts/services/components/component-service.ts698
-rw-r--r--catalog-ui/app/scripts/services/components/product-service.ts61
-rw-r--r--catalog-ui/app/scripts/services/components/resource-service.ts61
-rw-r--r--catalog-ui/app/scripts/services/components/service-service.ts97
-rw-r--r--catalog-ui/app/scripts/services/components/utils/composition-left-palette-service.ts248
5 files changed, 0 insertions, 1165 deletions
diff --git a/catalog-ui/app/scripts/services/components/component-service.ts b/catalog-ui/app/scripts/services/components/component-service.ts
deleted file mode 100644
index 393ea71c03..0000000000
--- a/catalog-ui/app/scripts/services/components/component-service.ts
+++ /dev/null
@@ -1,698 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * SDC
- * ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
- */
-/// <reference path="../../references"/>
-module Sdc.Services.Components {
-
- 'use strict';
-
- declare let CryptoJS:any;
-
- export interface IComponentService {
-
- getComponent(id:string);
- updateComponent(component:Models.Components.Component):ng.IPromise<Models.Components.Component>;
- changeLifecycleState(component:Models.Components.Component, state:string, userRemarks:any):ng.IPromise<Models.Components.Component> ;
- validateName(newName:string, subtype?:string):ng.IPromise<Models.IValidate>;
- createComponent(component:Models.Components.Component):ng.IPromise<Models.Components.Component>;
- addOrUpdateArtifact(componentId:string, artifact:Models.ArtifactModel):ng.IPromise<Models.ArtifactModel>;
- deleteArtifact(componentId:string, artifact:string, artifactLabel):ng.IPromise<Models.ArtifactModel>;
- addProperty(componentId:string, property:Models.PropertyModel):ng.IPromise<Models.PropertyModel>;
- updateProperty(componentId:string, property:Models.PropertyModel):ng.IPromise<Models.PropertyModel>;
- addAttribute(componentId:string, attribute:Models.AttributeModel):ng.IPromise<Models.AttributeModel>;
- updateAttribute(componentId:string, attribute:Models.AttributeModel):ng.IPromise<Models.AttributeModel>;
- deleteProperty(componentId:string, propertyId:string):ng.IPromise<Models.PropertyModel>;
- deleteAttribute(componentId:string, attributeId:string):ng.IPromise<Models.AttributeModel>;
- changeResourceInstanceVersion(componentId:string, componentInstanceId:string, componentUid:string):ng.IPromise<Models.ComponentsInstances.ComponentInstance>;
- updateInstanceArtifact(componentId:string, instanceId:string, artifact:Models.ArtifactModel):ng.IPromise<Models.ArtifactModel>;
- addInstanceArtifact(componentId: string, instanceId: string, artifact:Models.ArtifactModel):ng.IPromise<Models.ArtifactModel>;
- deleteInstanceArtifact(componentId: string, instanceId: string, artifact:string, artifactLabel):ng.IPromise<Models.ArtifactModel>;
- createComponentInstance(componentId:string, componentInstance:Models.ComponentsInstances.ComponentInstance):ng.IPromise<Models.ComponentsInstances.ComponentInstance>;
- updateComponentInstance(componentId:string, componentInstance:Models.ComponentsInstances.ComponentInstance):ng.IPromise<Models.ComponentsInstances.ComponentInstance>;
- updateMultipleComponentInstances(componentId:string, instances:Array<Models.ComponentsInstances.ComponentInstance>):ng.IPromise< Array<Models.ComponentsInstances.ComponentInstance>>;
- downloadArtifact(componentId:string, artifactId:string):ng.IPromise<Models.IFileDownload>;
- uploadInstanceEnvFile(componentId:string, instanceId:string, artifact:Models.ArtifactModel):ng.IPromise<Models.ArtifactModel>;
- downloadInstanceArtifact(componentId:string, instanceId:string, artifactId:string):ng.IPromise<Models.IFileDownload>;
- deleteComponentInstance(componentId:string, componentInstanceId:string):ng.IPromise<Models.ComponentsInstances.ComponentInstance>;
- createRelation(componentId:string, link:Models.RelationshipModel):ng.IPromise<Models.RelationshipModel>;
- deleteRelation(componentId:string, link:Models.RelationshipModel):ng.IPromise<Models.RelationshipModel>;
- getRequirementsCapabilities(componentId:string):ng.IPromise<any>;
- updateInstanceProperty(componentId:string, property:Models.PropertyModel):ng.IPromise<Models.PropertyModel>;
- updateInstanceAttribute(componentId:string, attribute:Models.AttributeModel):ng.IPromise<Models.AttributeModel>;
- getComponentInstancesFilteredByInputsAndProperties(componentId:string, searchText:string):ng.IPromise<Array<Models.ComponentsInstances.ComponentInstance>>
- getComponentInstanceInputs(componentId:string, instanceId:string, originComponentUid):ng.IPromise<Array<Models.InputModel>>;
- getComponentInputs(componentId:string):ng.IPromise<Array<Models.InputModel>>;
- getComponentInstanceInputProperties(componentId:string, instanceId:string, inputId:string):ng.IPromise<Array<Models.PropertyModel>>;
- getModuleForDisplay(componentId:string, moduleId:string):ng.IPromise<Models.DisplayModule>;
- updateGroupMetadata(componentId:string, group:Models.Module):ng.IPromise<Models.Module>;
- getComponentInputInputs(serviceId:string, input:string): ng.IPromise<Array<Models.InputModel>>;
- createInputsFromInstancesInputs(serviceId:string, instancesInputsMap:Models.InstancesInputsMap): ng.IPromise<Array<Models.InputModel>>;
- createInputsFromInstancesInputsProperties(resourceId:string, instanceInputsPropertiesMap:Models.InstanceInputsPropertiesMap): ng.IPromise<Array<Models.PropertyModel>>;
- deleteComponentInput(serviceId:string, inputId:string):ng.IPromise<Models.InputModel>;
- }
-
- export class ComponentService implements IComponentService {
-
- static '$inject' = [
- '$log',
- 'Restangular',
- 'sdcConfig',
- 'Sdc.Services.SharingService',
- '$q',
- '$interval',
- '$base64',
- 'ComponentInstanceFactory'
- ];
-
- constructor(protected $log: ng.ILogService,
- protected restangular:restangular.IElement,
- protected sdcConfig:Models.IAppConfigurtaion,
- protected sharingService:Sdc.Services.SharingService,
- protected $q:ng.IQService,
- protected $interval:any,
- protected $base64:any,
- protected ComponentInstanceFactory:Utils.ComponentInstanceFactory) {
-
- this.restangular.setBaseUrl(sdcConfig.api.root + sdcConfig.api.component_api_root);
- this.restangular.setRequestInterceptor(function (elem, operation) {
- if (operation === "remove") {
- return null;
- }
- return elem;
- });
- // this.restangular.setDefaultHeaders({'Content-Type': 'application/json; charset=UTF-8'});
- }
-
- //this function is override by each service, we need to change this method to abstract when updtaing typescript version
- protected createComponentObject = (component:Models.Components.Component):Models.Components.Component => {
- return component;
- };
-
- public getComponent = (id:string):ng.IPromise<Models.Components.Component> => {
- let deferred = this.$q.defer();
- this.restangular.one(id).get().then((response:Models.Components.Component) => {
- let component:Models.Components.Component = this.createComponentObject(response);
- //this.$log.debug("Component Loaded successfully : ", component);
- deferred.resolve(component);
- }, (err)=> {
- this.$log.debug("Failed to load component with ID: " + id);
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateComponent = (component:Models.Components.Component):ng.IPromise<Models.Components.Component> => {
- // If this is resource
- if (component instanceof Sdc.Models.Components.Resource) {
- let resource:Sdc.Models.Components.Resource = <Sdc.Models.Components.Resource>component;
- if (resource.importedFile) {
- // Update resource with payload data.
- return this.updateResourceWithPayload(resource);
- } else {
- if (component.csarUUID) {
- // Update resource without payload data.
- return this.updateResource(component);
- } else {
- // Update resource without payload data (metadata).
- return this.updateResourceMetadata(component);
- }
- }
- } else {
- return this.updateService(component);
- }
- };
-
- private updateService = (component:Models.Components.Component):ng.IPromise<Models.Components.Component> => {
- let deferred = this.$q.defer();
- this.restangular.one(component.uniqueId).one("metadata").customPUT(JSON.stringify(component)).then((response:Models.Components.Component) => {
- let component:Models.Components.Component = this.createComponentObject(response);
- deferred.resolve(component);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- private updateResource = (component:Models.Components.Component):ng.IPromise<Models.Components.Component> => {
- let deferred = this.$q.defer();
- this.restangular.one(component.uniqueId).customPUT(JSON.stringify(component)).then((response:Models.Components.Component) => {
- let component:Models.Components.Component = this.createComponentObject(response);
- deferred.resolve(component);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- private updateResourceMetadata = (component:Models.Components.Component):ng.IPromise<Models.Components.Component> => {
- let deferred = this.$q.defer();
- this.restangular.one(component.uniqueId).one('metadata').customPUT(JSON.stringify(component)).then((response:Models.Components.Component) => {
- let component:Models.Components.Component = this.createComponentObject(response);
- deferred.resolve(component);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- /**
- * Only resource can be updated with payload data
- * @param component
- * @returns {IPromise<T>}
- */
- private updateResourceWithPayload = (resource:Sdc.Models.Components.Resource):ng.IPromise<Models.Components.Component> => {
- let deferred = this.$q.defer();
-
- resource.payloadData = resource.importedFile.base64;
- resource.payloadName = resource.importedFile.filename;
- let headerObj = this.getHeaderMd5(resource);
-
- this.restangular.one(resource.uniqueId).customPUT(JSON.stringify(resource), '', {}, headerObj).then((response:Models.Components.Component) => {
- let componentResult:Models.Components.Component = this.createComponentObject(response);
- deferred.resolve(componentResult);
- }, (err)=> {
- deferred.reject(err);
- });
-
- return deferred.promise;
- };
-
- public createComponent = (component:Models.Components.Component):ng.IPromise<Models.Components.Component> => {
- let deferred = this.$q.defer();
- let headerObj = this.getHeaderMd5(component);
- this.restangular.customPOST(JSON.stringify(component), '', {}, headerObj).then((response:Models.Components.Component) => {
- let component:Models.Components.Component = this.createComponentObject(response);
- deferred.resolve(component);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public validateName = (newName:string, subtype?:string):ng.IPromise<Models.IValidate> => {
- let deferred = this.$q.defer();
- this.restangular.one("validate-name").one(newName).get({'subtype': subtype}).then((response:any) => {
- deferred.resolve(response.plain());
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public changeLifecycleState = (component:Models.Components.Component, state:string, userRemarks:any):ng.IPromise<Models.Components.Component> => {
- let deferred = this.$q.defer();
- this.restangular.one(component.uniqueId).one(state).customPOST(userRemarks).then((response:Models.Components.Component) => {
- this.sharingService.addUuidValue(response.uniqueId, response.uuid);
- let component:Models.Components.Component = this.createComponentObject(response);
- deferred.resolve(component);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- // ------------------------------------------------ Artifacts API --------------------------------------------------//
- public addOrUpdateArtifact = (componentId:string, artifact:Models.ArtifactModel):ng.IPromise<Models.ArtifactModel> => {
- let deferred = this.$q.defer();
- let headerObj = {};
- if (artifact.payloadData) {
- headerObj = this.getHeaderMd5(artifact);
- }
- this.restangular.one(componentId).one("artifacts").customPOST(JSON.stringify(artifact), artifact.uniqueId, {}, headerObj).then((response:any) => {
- deferred.resolve(response.plain());
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public downloadArtifact = (componentId:string, artifactId:string):ng.IPromise<Models.IFileDownload> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("artifacts").one(artifactId).get().then((response:any) => {
- deferred.resolve(response.plain());
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public deleteArtifact = (componentId:string, artifactId:string, artifactLabel:string):ng.IPromise<Models.ArtifactModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("artifacts").one(artifactId).remove({'operation': artifactLabel}).then((response:Models.ArtifactModel) => {
- deferred.resolve(response);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
-
- // ------------------------------------------------ Properties API --------------------------------------------------//
- public addProperty = (componentId:string, property:Models.PropertyModel):ng.IPromise<Models.PropertyModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("properties").customPOST(property.convertToServerObject()).then((response:any) => {
- let property:Models.PropertyModel = new Models.PropertyModel(response[Object.keys(response)[0]]);
- deferred.resolve(property);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateProperty = (componentId:string, property:Models.PropertyModel):ng.IPromise<Models.PropertyModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("properties").one(property.uniqueId).customPUT(property.convertToServerObject()).then((response:any) => {
- let property:Models.PropertyModel = new Models.PropertyModel(response[Object.keys(response)[0]]);
- deferred.resolve(property);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public deleteProperty = (componentId:string, propertyId:string):ng.IPromise<Models.PropertyModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("properties").one(propertyId).remove().then((response:any) => {
- deferred.resolve(response);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- // ------------------------------------------------ Attributes API --------------------------------------------------//
- public addAttribute = (componentId:string, attribute:Models.AttributeModel):ng.IPromise<Models.AttributeModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("attributes").customPOST(attribute.convertToServerObject()).then((response:any) => {
- let attribute:Models.AttributeModel = new Models.AttributeModel(response);
- deferred.resolve(attribute);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateAttribute = (componentId:string, attribute:Models.AttributeModel):ng.IPromise<Models.AttributeModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("attributes").one(attribute.uniqueId).customPUT(attribute.convertToServerObject()).then((response:any) => {
- let attribute:Models.AttributeModel = new Models.AttributeModel(response);
- deferred.resolve(attribute);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public deleteAttribute = (componentId:string, attributeId:string):ng.IPromise<Models.AttributeModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("attributes").one(attributeId).remove().then((response:any) => {
- deferred.resolve(response);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- // ------------------------------------------------ Component Instances API --------------------------------------------------//
-
- public createComponentInstance = (componentId:string, componentInstance:Models.ComponentsInstances.ComponentInstance):ng.IPromise<Models.ComponentsInstances.ComponentInstance> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance").customPOST(JSON.stringify(componentInstance)).then((response:any) => {
- let componentInstance:Models.ComponentsInstances.ComponentInstance = Utils.ComponentInstanceFactory.createComponentInstance(response);
- this.$log.debug("Component Instance created", componentInstance);
- deferred.resolve(componentInstance);
- }, (err)=> {
- this.$log.debug("Failed to create componentInstance. With Name: " + componentInstance.name);
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateComponentInstance = (componentId:string, componentInstance:Models.ComponentsInstances.ComponentInstance):ng.IPromise<Models.ComponentsInstances.ComponentInstance> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance").one(componentInstance.uniqueId).customPOST(JSON.stringify(componentInstance)).then((response:any) => {
- let componentInstance:Models.ComponentsInstances.ComponentInstance = Utils.ComponentInstanceFactory.createComponentInstance(response);
- this.$log.debug("Component Instance was updated", componentInstance);
- deferred.resolve(componentInstance);
- }, (err)=> {
- this.$log.debug("Failed to update componentInstance. With ID: " + componentInstance.uniqueId + "Name: " + componentInstance.name);
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateMultipleComponentInstances = (componentId:string, instances:Array<Models.ComponentsInstances.ComponentInstance>):ng.IPromise<Array<Models.ComponentsInstances.ComponentInstance>> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance/multipleComponentInstance").customPOST(JSON.stringify(instances)).then((response:any) => {
- this.$log.debug("Multiple Component Instances was updated", response);
- let updateInstances:Array<Models.ComponentsInstances.ComponentInstance> = new Array<Models.ComponentsInstances.ComponentInstance>();
- _.forEach(response, (componentInstance:Models.ComponentsInstances.ComponentInstance) => {
- let updatedComponentInstance:Models.ComponentsInstances.ComponentInstance = Utils.ComponentInstanceFactory.createComponentInstance(componentInstance);
- updateInstances.push(updatedComponentInstance);
- });
- deferred.resolve(updateInstances);
- }, (err)=> {
- this.$log.debug("Failed to update Multiple componentInstance.");
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public deleteComponentInstance = (componentId:string, componentInstanceId:string):ng.IPromise<Models.ComponentsInstances.ComponentInstance> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance").one(componentInstanceId).remove().then(() => {
- this.$log.debug("Component Instance was deleted");
- deferred.resolve();
- }, (err)=> {
- this.$log.debug("Failed to delete componentInstance. With ID: " + componentInstanceId);
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public changeResourceInstanceVersion = (componentId:string, componentInstanceId:string, componentUid:string):ng.IPromise<Models.ComponentsInstances.ComponentInstance> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance").one(componentInstanceId).one("changeVersion").customPOST({'componentUid': componentUid}).then((response:any) => {
- let componentInstance:Models.ComponentsInstances.ComponentInstance = Utils.ComponentInstanceFactory.createComponentInstance(response);
- deferred.resolve(componentInstance);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public downloadInstanceArtifact = (componentId:string, instanceId:string, artifactId:string):ng.IPromise<Models.IFileDownload> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstances").one(instanceId).one("artifacts").one(artifactId).get().then((response:any) => {
- deferred.resolve(response.plain());
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateInstanceArtifact = (componentId:string, instanceId:string, artifact:Models.ArtifactModel):ng.IPromise<Models.ArtifactModel> => {
- let deferred = this.$q.defer();
- let headerObj = {};
- if(artifact.payloadData){
- headerObj = this.getHeaderMd5(artifact);
- }
- this.restangular.one(componentId).one("resourceInstance").one(instanceId).one("artifacts").customPOST(JSON.stringify(artifact), artifact.uniqueId , {}, headerObj).then((response: any) => {
- let newArtifact = new Models.ArtifactModel(response);
- deferred.resolve(newArtifact);
- }, (err)=>{
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public addInstanceArtifact = (componentId: string, instanceId: string, artifact:Models.ArtifactModel): ng.IPromise<Models.ArtifactModel> => {
- let deferred = this.$q.defer();
- let headerObj = {};
- if(artifact.payloadData){
- headerObj = this.getHeaderMd5(artifact);
- }
- this.restangular.one(componentId).one("resourceInstance").one(instanceId).one("artifacts").customPOST(JSON.stringify(artifact), artifact.uniqueId , {}, headerObj).then((response: any) => {
- let artifact:Models.ArtifactModel = new Models.ArtifactModel(response.plain());
- deferred.resolve(artifact);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public deleteInstanceArtifact = (componentId: string , instanceId: string, artifactId:string, artifactLabel: string): ng.IPromise<Models.ArtifactModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance").one(instanceId).one("artifacts").one(artifactId).remove({'operation': artifactLabel}).then((response: Models.ArtifactModel) => {
- deferred.resolve(response);
- }, (err)=>{
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public uploadInstanceEnvFile = (componentId:string, instanceId:string, artifact:Models.ArtifactModel):ng.IPromise<Models.ArtifactModel> => {
- let deferred = this.$q.defer();
- let headerObj = {};
- if (artifact.payloadData) {
- headerObj = this.getHeaderMd5(artifact);
- }
- this.restangular.one(componentId).one("resourceInstance").one(instanceId).one("artifacts").customPOST(JSON.stringify(artifact), artifact.uniqueId, {}, headerObj).then((response:any) => {
- let newArtifact = new Models.ArtifactModel(response);
- deferred.resolve(newArtifact);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateInstanceProperty = (componentId:string, property:Models.PropertyModel):ng.IPromise<Models.PropertyModel> => {
- let deferred = this.$q.defer();
- let instanceId = property.resourceInstanceUniqueId;
- this.restangular.one(componentId).one("resourceInstance").one(instanceId).one("property").customPOST(JSON.stringify(property)).then((response:any) => {
- let newProperty = new Models.PropertyModel(response);
- newProperty.readonly = true;
- newProperty.resourceInstanceUniqueId = instanceId;
- deferred.resolve(newProperty);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public updateInstanceAttribute = (componentId:string, attribute:Models.AttributeModel):ng.IPromise<Models.AttributeModel> => {
- let deferred = this.$q.defer();
- let instanceId = attribute.resourceInstanceUniqueId;
- this.restangular.one(componentId).one("resourceInstance").one(instanceId).one("attribute").customPOST(JSON.stringify(attribute)).then((response:any) => {
- let newAttribute = new Models.AttributeModel(response);
- newAttribute.readonly = true;
- newAttribute.resourceInstanceUniqueId = instanceId;
- deferred.resolve(newAttribute);
- }, (err)=> {
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public createRelation = (componentId:string, link:Models.RelationshipModel):ng.IPromise<Models.RelationshipModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance").one("associate").customPOST(JSON.stringify(link)).then((response:any) => {
- let relation:Models.RelationshipModel = new Models.RelationshipModel(response.plain());
- this.$log.debug("Link created successfully ", relation);
- deferred.resolve(relation);
- }, (err)=> {
- this.$log.debug("Failed to create Link From: " + link.fromNode + "To: " + link.toNode);
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public deleteRelation = (componentId:string, link:Models.RelationshipModel):ng.IPromise<Models.RelationshipModel> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("resourceInstance").one("dissociate").customPUT(JSON.stringify(link)).then((response:any) => {
- let relation:Models.RelationshipModel = new Models.RelationshipModel(response);
- this.$log.debug("Link deleted successfully ", relation);
- deferred.resolve(relation);
- }, (err)=> {
- this.$log.debug("Failed to delete Link From: " + link.fromNode + "To: " + link.toNode);
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public getRequirementsCapabilities = (componentId:string):ng.IPromise<any> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("requirmentsCapabilities").get().then((response:any) => {
- this.$log.debug("Component requirement capabilities recived: ", response);
- deferred.resolve(response);
- }, (err)=> {
- this.$log.debug("Failed to get requirements & capabilities");
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public getModuleForDisplay = (componentId:string, moduleId:string):ng.IPromise<Models.DisplayModule> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("groups").one(moduleId).get().then((response:any) => {
- this.$log.debug("module loaded successfully: ", response);
- let module:Models.DisplayModule = new Models.DisplayModule(response);
- deferred.resolve(module);
- }, (err)=> {
- this.$log.debug("Failed to get module with id: ", moduleId);
- deferred.reject(err);
- });
- return deferred.promise;
- };
-
- public getComponentInstancesFilteredByInputsAndProperties = (componentId:string, searchText?:string):ng.IPromise<Array<Models.ComponentsInstances.ComponentInstance>> => {
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("componentInstances").get({'searchText': searchText}).then((response:any) => {
- this.$log.debug("component instances return successfully: ", response);
- let componentInstances:Array<Models.ComponentsInstances.ComponentInstance> = Utils.CommonUtils.initComponentInstances(response);
- deferred.resolve(componentInstances);
- }, (err) => {
- this.$log.debug("Failed to get component instances of component with id: " + componentId);
- deferred.reject(err);
- });
-
- return deferred.promise;
- };
-
- public getComponentInstanceInputs = (componentId:string, instanceId:string, originComponentUid):ng.IPromise<Array<Models.InputModel>> => {
-
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("componentInstances").one(instanceId).one(originComponentUid).one("inputs").get().then((response:any) => {
- this.$log.debug("component instance input return successfully: ", response);
- let inputsArray:Array<Models.InputModel> = new Array<Models.InputModel>();
- _.forEach(response, (inputObj:Models.InputModel) => {
- inputsArray.push(new Models.InputModel(inputObj));
- });
- deferred.resolve(inputsArray);
- }, (err) => {
- this.$log.debug("Failed to get component instance input with id: " + instanceId);
- deferred.reject(err);
- });
-
- return deferred.promise;
- };
-
- public getComponentInputs = (componentId:string):ng.IPromise<Array<Models.InputModel>> => {
-
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("inputs").get().then((response:any) => {
- this.$log.debug("component inputs return successfully: ", response);
- let inputsArray:Array<Models.InputModel> = new Array<Models.InputModel>();
- _.forEach(response, (inputObj:Models.InputModel) => {
- inputsArray.push(new Models.InputModel(inputObj));
- });
- deferred.resolve(inputsArray);
- }, (err) => {
- this.$log.debug("Failed to get component inputs for component with id: " + componentId);
- deferred.reject(err);
- });
-
- return deferred.promise;
- };
-
- public getComponentInstanceInputProperties = (componentId:string, instanceId:string, inputId:string):ng.IPromise<Array<Models.PropertyModel>> => {
-
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("componentInstances").one(instanceId).one(inputId).one("properties").get().then((response:any) => {
- this.$log.debug("component instance input properties return successfully: ", response);
- let propertiesArray:Array<Models.PropertyModel> = new Array<Models.PropertyModel>();
- _.forEach(response, (propertyObj:Models.PropertyModel) => {
- propertiesArray.push(new Models.PropertyModel(propertyObj));
- });
- deferred.resolve(propertiesArray);
- }, (err) => {
- this.$log.debug("Failed to get component instance input properties with instanceId: " + instanceId + "and input id: " + inputId);
- deferred.reject(err);
- });
-
- return deferred.promise;
- };
-
- public updateGroupMetadata = (componentId:string, group:Models.Module):ng.IPromise<Models.Module> => {
-
- let deferred = this.$q.defer();
- this.restangular.one(componentId).one("groups").one(group.uniqueId).one("metadata").customPUT(JSON.stringify(group)).then((response:Models.Module) => {
- this.$log.debug("group metadata updated successfully: ", response);
- let updatedGroup:Models.Module = new Models.Module(response);
-
- deferred.resolve(updatedGroup);
- }, (err) => {
- this.$log.debug("Failed to update group metadata for component: " + componentId + " for group with id: " + group.uniqueId);
- deferred.reject(err);
- });
-
- return deferred.promise;
- };
-
- public getComponentInputInputs = (serviceId:string, inputId:string): ng.IPromise<Array<Models.InputModel>> => {
- let defer = this.$q.defer<any>();
- this.restangular.one(serviceId).one("inputs").one(inputId).one("inputs").get().then((response: any) => {
- let inputsArray:Array<Models.InputModel> = new Array<Models.InputModel>();
- _.forEach(response, (inputObj:Models.InputModel) => {
- inputsArray.push(new Models.InputModel(inputObj));
- });
- defer.resolve(inputsArray);
- }, (err)=>{
- this.$log.debug("failed to get inputs of input : ", err);
- defer.reject(err);
- });
- return defer.promise;
- };
-
- createInputsFromInstancesInputsProperties = (resourceId:string, instancePropertyMap:Models.InstanceInputsPropertiesMap): ng.IPromise<Array<Models.PropertyModel>> => {
- let defer = this.$q.defer<any>();
- this.restangular.one(resourceId).one("create/properties").customPOST(instancePropertyMap).then((response: any) => {
- let inputsArray:Array<Models.PropertyModel> = new Array<Models.PropertyModel>();
- _.forEach(response, (inputObj:Models.PropertyModel) => {
- inputsArray.push(new Models.PropertyModel(inputObj));
- });
- defer.resolve(inputsArray);
- }, (err)=>{
- this.$log.debug("failed to create service inputs from VF instances inputs : ", err);
- defer.reject(err);
- });
- return defer.promise;
- };
-
- createInputsFromInstancesInputs = (serviceId:string, instancesMap:Models.InstancesInputsMap): ng.IPromise<Array<Models.InputModel>> => {
- let defer = this.$q.defer<any>();
- this.restangular.one(serviceId).one("create/inputs").customPOST(instancesMap).then((response: any) => {
- let inputsArray:Array<Models.InputModel> = new Array<Models.InputModel>();
- _.forEach(response, (inputObj:Models.InputModel) => {
- inputsArray.push(new Models.InputModel(inputObj));
- });
- defer.resolve(inputsArray);
- }, (err)=>{
- this.$log.debug("failed to create service inputs from VF instances inputs : ", err);
- defer.reject(err);
- });
- return defer.promise;
- };
-
- deleteComponentInput = (serviceId:string, inputId:string) : ng.IPromise<Models.InputModel> => {
- var defer = this.$q.defer();
- this.restangular.one(serviceId).one("delete").one(inputId).one("input").remove().then((response: any) => {
- var inputToDelete = new Models.InputModel(response);
-
- defer.resolve(inputToDelete);
- }, (err)=> {
- console.log("failed to delete input from service: ", err);
- defer.reject(err);
- });
- return defer.promise;
- };
-
- private getHeaderMd5 = (object:any):any => {
- let headerObj={};
- // This is ugly workaround!!!
- // The md5 result is not correct if we do not add the line JSON.stringify(resource); twice.
- JSON.stringify(object);
- let componentString:string = JSON.stringify(object);
- let md5Result = md5(componentString).toLowerCase();
- headerObj = {'Content-MD5': this.$base64.encode(md5Result)};
- return headerObj;
- };
-
- }
-}
diff --git a/catalog-ui/app/scripts/services/components/product-service.ts b/catalog-ui/app/scripts/services/components/product-service.ts
deleted file mode 100644
index 69171fbbfa..0000000000
--- a/catalog-ui/app/scripts/services/components/product-service.ts
+++ /dev/null
@@ -1,61 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * SDC
- * ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
- */
-/**
- * Created by obarda on 2/8/2016.
- */
-/// <reference path="../../references"/>
-module Sdc.Services.Components {
- 'use strict';
-
- export interface IProductService extends IComponentService {
-
- }
-
- export class ProductService extends ComponentService implements IProductService {
-
- static '$inject' = [
- '$log',
- 'Restangular',
- 'sdcConfig',
- 'Sdc.Services.SharingService',
- '$q',
- '$interval',
- '$base64',
- 'ComponentInstanceFactory'
- ];
-
- constructor(protected $log: ng.ILogService,
- protected restangular: restangular.IElement,
- protected sdcConfig: Models.IAppConfigurtaion,
- protected sharingService: Sdc.Services.SharingService,
- protected $q: ng.IQService,
- protected $interval: any,
- protected $base64: any,
- protected ComponentInstanceFactory: Utils.ComponentInstanceFactory) {
- super($log, restangular, sdcConfig, sharingService, $q, $interval, $base64, ComponentInstanceFactory);
-
- this.restangular = restangular.one("products");
- }
-
- createComponentObject = (component: Models.Components.Component): Models.Components.Component => {
- return new Models.Components.Product(this, this.$q, <Models.Components.Product>component);
- };
- }
-}
diff --git a/catalog-ui/app/scripts/services/components/resource-service.ts b/catalog-ui/app/scripts/services/components/resource-service.ts
deleted file mode 100644
index 48781da48e..0000000000
--- a/catalog-ui/app/scripts/services/components/resource-service.ts
+++ /dev/null
@@ -1,61 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * SDC
- * ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
- */
-/**
- * Created by obarda on 2/4/2016.
- */
-/// <reference path="../../references"/>
-module Sdc.Services.Components {
- 'use strict';
-
- export interface IResourceService extends IComponentService {
-
- }
-
- export class ResourceService extends ComponentService implements IResourceService {
-
- static '$inject' = [
- '$log',
- 'Restangular',
- 'sdcConfig',
- 'Sdc.Services.SharingService',
- '$q',
- '$interval',
- '$base64',
- 'ComponentInstanceFactory'
- ];
-
- constructor(protected $log: ng.ILogService,
- protected restangular: restangular.IElement,
- protected sdcConfig: Models.IAppConfigurtaion,
- protected sharingService: Sdc.Services.SharingService,
- protected $q: ng.IQService,
- protected $interval: any,
- protected $base64: any,
- protected ComponentInstanceFactory: Utils.ComponentInstanceFactory) {
- super($log, restangular, sdcConfig, sharingService, $q, $interval, $base64, ComponentInstanceFactory);
-
- this.restangular = restangular.one("resources");
- }
-
- createComponentObject = (component: Models.Components.Component): Models.Components.Component => {
- return new Models.Components.Resource(this, this.$q, <Models.Components.Resource>component);
- };
- }
-}
diff --git a/catalog-ui/app/scripts/services/components/service-service.ts b/catalog-ui/app/scripts/services/components/service-service.ts
deleted file mode 100644
index fef0b47512..0000000000
--- a/catalog-ui/app/scripts/services/components/service-service.ts
+++ /dev/null
@@ -1,97 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * SDC
- * ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
- */
-/**
- * Created by obarda on 2/4/2016.
- */
-/// <reference path="../../references"/>
-module Sdc.Services.Components {
- 'use strict';
-
-
- export interface IServiceService extends IComponentService {
- getDistributionsList(uuid: string): ng.IPromise<Array<Models.Distribution>>;
- getDistributionComponents(distributionId: string): ng.IPromise<Array<Models.DistributionComponent>>;
- markAsDeployed(serviceId: string, distributionId: string): ng.IPromise<any>;
- }
-
- export class ServiceService extends ComponentService implements IServiceService {
-
- static '$inject' = [
- '$log',
- 'Restangular',
- 'sdcConfig',
- 'Sdc.Services.SharingService',
- '$q',
- '$interval',
- '$base64',
- 'ComponentInstanceFactory'
- ];
-
- public distribution: string = "distribution";
-
- constructor(protected $log: ng.ILogService,
- protected restangular: restangular.IElement,
- protected sdcConfig: Models.IAppConfigurtaion,
- protected sharingService: Sdc.Services.SharingService,
- protected $q: ng.IQService,
- protected $interval: any,
- protected $base64: any,
- protected ComponentInstanceFactory: Utils.ComponentInstanceFactory) {
- super($log, restangular, sdcConfig, sharingService, $q, $interval, $base64, ComponentInstanceFactory);
-
- this.restangular = restangular.one("services");
- }
-
- getDistributionsList = (uuid: string): ng.IPromise<Array<Models.Distribution>> => {
- let defer = this.$q.defer<Array<Models.Distribution>>();
- this.restangular.one(uuid).one("distribution").get().then((distributions: any) => {
- defer.resolve(<Array<Models.Distribution>> distributions.distributionStatusOfServiceList);
- }, (err)=> {
- defer.reject(err);
- });
- return defer.promise;
- };
-
- getDistributionComponents = (distributionId: string): ng.IPromise<Array<Models.DistributionComponent>> => {
- let defer = this.$q.defer<Array<Models.DistributionComponent>>();
- this.restangular.one("distribution").one(distributionId).get().then((distributions: any) => {
- defer.resolve(<Array<Models.DistributionComponent>> distributions.distributionStatusList);
- }, (err)=> {
- defer.reject(err);
- });
- return defer.promise;
- };
-
- markAsDeployed = (serviceId: string, distributionId: string): ng.IPromise<any> => {
- let defer = this.$q.defer<any>();
- this.restangular.one(serviceId).one("distribution").one(distributionId).one("markDeployed").customPOST().then((result: any) => {
- defer.resolve(result);
- }, (err)=> {
-
- defer.reject(err);
- });
- return defer.promise;
- };
-
- createComponentObject = (component: Models.Components.Component): Models.Components.Component => {
- return new Models.Components.Service(this, this.$q, <Models.Components.Service>component);
- };
- }
-}
diff --git a/catalog-ui/app/scripts/services/components/utils/composition-left-palette-service.ts b/catalog-ui/app/scripts/services/components/utils/composition-left-palette-service.ts
deleted file mode 100644
index 25ac1cdf17..0000000000
--- a/catalog-ui/app/scripts/services/components/utils/composition-left-palette-service.ts
+++ /dev/null
@@ -1,248 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * SDC
- * ================================================================================
- * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- * ============LICENSE_END=========================================================
- */
-/**
- * Created by obarda on 3/13/2016.
- */
-/// <reference path="../../../references"/>
-module Sdc.Services.Components {
-
- 'use strict';
-
- export class LeftPanelLatestVersion {
- uid: string;
- version: string;
- }
-
- export class LeftPaletteDataObject {
- currentUpdatingIdsList: Array<string>;
- latestVersionAndIdsList: Array<LeftPanelLatestVersion>;
- fullDataLeftPaletteComponents: Array<Models.Components.Component>;
- displayLeftPanelComponents: Array<Models.DisplayComponent>;
- onFinishLoadingEvent: string;
-
- constructor(onFinishEventListener: string) {
-
- this.fullDataLeftPaletteComponents = new Array<Models.Components.Component>();
- this.displayLeftPanelComponents = new Array<Models.DisplayComponent>();
- this.currentUpdatingIdsList = new Array<string>();
- this.latestVersionAndIdsList = new Array<LeftPanelLatestVersion>();
- this.onFinishLoadingEvent = onFinishEventListener;
- }
- }
-
- export class LeftPaletteLoaderService {
-
- static '$inject' = [
- 'Restangular',
- 'sdcConfig',
- '$q',
- '$base64',
- 'ComponentFactory',
- 'EventListenerService'
-
- ];
-
- constructor(protected restangular: restangular.IElement,
- protected sdcConfig: Models.IAppConfigurtaion,
- protected $q: ng.IQService,
- protected $base64: any,
- protected ComponentFactory: Utils.ComponentFactory,
- protected EventListenerService: Services.EventListenerService) {
-
- this.restangular.setBaseUrl(sdcConfig.api.root + sdcConfig.api.component_api_root);
- }
-
- private serviceLeftPaletteData: LeftPaletteDataObject;
- private resourceLeftPaletteData: LeftPaletteDataObject;
- private productLeftPaletteData: LeftPaletteDataObject;
- private vlData: LeftPaletteDataObject;
-
- public loadLeftPanel = (): void => {
-
- this.serviceLeftPaletteData = new LeftPaletteDataObject(Utils.Constants.EVENTS.SERVICE_LEFT_PALETTE_UPDATE_EVENT);
- this.resourceLeftPaletteData = new LeftPaletteDataObject(Utils.Constants.EVENTS.RESOURCE_LEFT_PALETTE_UPDATE_EVENT);
- this.productLeftPaletteData = new LeftPaletteDataObject(Utils.Constants.EVENTS.PRODUCT_LEFT_PALETTE_UPDATE_EVENT);
- this.vlData = new LeftPaletteDataObject(Utils.Constants.EVENTS.VL_LEFT_PALETTE_UPDATE_EVENT);
-
- //initiating service palette
- this.updateComponentLeftPalette(Utils.Constants.ComponentType.SERVICE);
-
- //initiating resource palette
- this.updateComponentLeftPalette(Utils.Constants.ComponentType.RESOURCE);
-
- //initiating product palette
- this.updateComponentLeftPalette(Utils.Constants.ComponentType.PRODUCT);
-
- //initiating vl
- this.updateComponentLeftPalette(Utils.Constants.ResourceType.VL);
- };
-
- private updateData = (latestVersionComponents: Array<Models.Components.Component>, leftPaletteDataObj: LeftPaletteDataObject) => {
-
- let fullDataComponentsArray: Array<Models.Components.Component> = new Array<Models.Components.Component>();
- let displayComponentsArray: Array<Models.DisplayComponent> = new Array<Models.DisplayComponent>();
-
- _.forEach(latestVersionComponents, (componentObj: any) => {
- let component: Models.Components.Component = this.ComponentFactory.createComponent(componentObj);
- fullDataComponentsArray.push(component);
- displayComponentsArray.push(new Models.DisplayComponent(component));
- });
-
- leftPaletteDataObj.fullDataLeftPaletteComponents = leftPaletteDataObj.fullDataLeftPaletteComponents.concat(fullDataComponentsArray);
- leftPaletteDataObj.displayLeftPanelComponents = leftPaletteDataObj.displayLeftPanelComponents.concat(displayComponentsArray);
- };
-
- private getTypeUrl = (componentType: string): string => {
- return Utils.Constants.ComponentType.PRODUCT === componentType ? "services" : "resources";
- };
-
- private onFinishLoading = (componentType: string, leftPaletteData: LeftPaletteDataObject): void => {
- leftPaletteData.currentUpdatingIdsList = [];
- this.EventListenerService.notifyObservers(leftPaletteData.onFinishLoadingEvent);
- };
-
- private getPartialLastVersionFullComponents = (componentType: string, componentInternalType: string, leftPaletteData: LeftPaletteDataObject): void => {
- this.restangular.one(this.getTypeUrl(componentType)).one('/latestversion/notabstract').customPOST(leftPaletteData.currentUpdatingIdsList, '', {'internalComponentType': componentInternalType}).then((componentsArray: any) => {
- this.updateData(componentsArray, leftPaletteData);
- this.onFinishLoading(componentType, leftPaletteData); //when finish loading update view
- });
- };
-
- private removeNotUpdatedComponents = (leftPaletteObject: LeftPaletteDataObject) => {
-
- leftPaletteObject.fullDataLeftPaletteComponents = _.filter(leftPaletteObject.fullDataLeftPaletteComponents, (component)=> {
- return leftPaletteObject.currentUpdatingIdsList.indexOf(component.uniqueId) != -1;
- });
- leftPaletteObject.displayLeftPanelComponents = _.filter(leftPaletteObject.displayLeftPanelComponents, (component)=> {
- return leftPaletteObject.currentUpdatingIdsList.indexOf(component.uniqueId) != -1;
- });
- };
-
- private findIdsToUpdate = (leftPaletteObj: LeftPaletteDataObject): Array<string> => {
- let idsToUpdate = <string[]>_.difference(leftPaletteObj.currentUpdatingIdsList, _.map(leftPaletteObj.fullDataLeftPaletteComponents, 'uniqueId'));
- let neededUpdate = _.filter(leftPaletteObj.fullDataLeftPaletteComponents, (component) => {
- let updated = _.find(leftPaletteObj.latestVersionAndIdsList, (versionAndId: LeftPanelLatestVersion) => {
- return versionAndId.uid === component.uniqueId && versionAndId.version != component.version
- });
- return updated != undefined;
- });
- if (neededUpdate && neededUpdate.length > 0) {
- let neededUpdateIds = <string[]>_.map(neededUpdate, 'uid');
- idsToUpdate.concat(neededUpdateIds);
- }
- return idsToUpdate;
- };
-
- private updateCurrentIdsList = (componentType: string, leftPaletteObj: LeftPaletteDataObject): void=> {
- this.removeNotUpdatedComponents(leftPaletteObj);
- leftPaletteObj.currentUpdatingIdsList = this.findIdsToUpdate(leftPaletteObj);
- //remove all components that needed update from current lists
- if (leftPaletteObj.currentUpdatingIdsList.length > 0) {
- leftPaletteObj.displayLeftPanelComponents = _.filter(leftPaletteObj.displayLeftPanelComponents, (component)=> {
- return leftPaletteObj.currentUpdatingIdsList.indexOf(component.uniqueId) === -1;
- });
- leftPaletteObj.fullDataLeftPaletteComponents = _.filter(leftPaletteObj.fullDataLeftPaletteComponents, (component)=> {
- return leftPaletteObj.currentUpdatingIdsList.indexOf(component.uniqueId) === -1;
- });
- }
- };
-
- private updateLeftPalette = (componentType, componentInternalType: string, leftPaletteData: LeftPaletteDataObject): void => {
- if (leftPaletteData.currentUpdatingIdsList.length > 0) return; //this means the service is still performing update
- this.restangular.one(this.getTypeUrl(componentType)).one('/latestversion/notabstract/uidonly').get({'internalComponentType': componentInternalType}).then((latestVersionUniqueIds: Array<LeftPanelLatestVersion>) => {
- leftPaletteData.latestVersionAndIdsList = latestVersionUniqueIds;
- leftPaletteData.currentUpdatingIdsList = <string[]>_.map(latestVersionUniqueIds, 'uid')
-
- if (leftPaletteData.fullDataLeftPaletteComponents.length === 0) { //this is when first loading product or resource left palette
- this.getPartialLastVersionFullComponents(componentType, componentInternalType, leftPaletteData);
- } else {
- this.updateCurrentIdsList(componentType, leftPaletteData);
- if (leftPaletteData.currentUpdatingIdsList.length === 0) {
- this.onFinishLoading(componentType, leftPaletteData); //when finish loading update view
- return;
- }
- this.getPartialLastVersionFullComponents(componentType, componentInternalType, leftPaletteData);
- }
- });
- };
-
- public getLeftPanelComponentsForDisplay = (componentType: string): Array<Models.DisplayComponent> => {
- switch (componentType) {
- case Utils.Constants.ComponentType.SERVICE:
- return this.serviceLeftPaletteData.displayLeftPanelComponents;
- case Utils.Constants.ComponentType.PRODUCT:
- return this.productLeftPaletteData.displayLeftPanelComponents;
- default:
- return this.resourceLeftPaletteData.displayLeftPanelComponents;
- }
- };
-
- public getFullDataComponentList = (componentType: string): Array<Models.Components.Component> => {
- switch (componentType) {
- case Utils.Constants.ResourceType.VL:
- return this.vlData.fullDataLeftPaletteComponents;
- case Utils.Constants.ComponentType.SERVICE:
- return this.serviceLeftPaletteData.fullDataLeftPaletteComponents;
- case Utils.Constants.ComponentType.PRODUCT:
- return this.productLeftPaletteData.fullDataLeftPaletteComponents;
- default :
- return this.resourceLeftPaletteData.fullDataLeftPaletteComponents;
- }
- };
-
- public getFullDataComponentListWithVls = (componentType: string): Array<Models.Components.Component> => {
- let listPart1: Array<Models.Components.Component>;
- let listPart2: Array<Models.Components.Component>;
- if (componentType === Utils.Constants.ResourceType.VL) {
- listPart1 = [];
- listPart2 = this.getFullDataComponentList(Utils.Constants.ResourceType.VL);
- } else {
- listPart1 = this.getFullDataComponentList(componentType);
- listPart2 = this.getFullDataComponentList(Utils.Constants.ResourceType.VL);
- }
- return listPart1.concat(listPart2);
- };
-
- public updateSpecificComponentLeftPalette = (component: Models.Components.Component, componentType: string): void => {
- let listComponents: Array<Models.Components.Component> = this.getFullDataComponentList(componentType);
- for (let i in listComponents) {
- if (listComponents[i].uniqueId === component.uniqueId) {
- listComponents[i] = component;
- }
- }
- };
-
- public updateComponentLeftPalette = (componentType): void => {
- switch (componentType) {
- case Utils.Constants.ResourceType.VL:
- this.updateLeftPalette(Utils.Constants.ComponentType.RESOURCE, Utils.Constants.ResourceType.VL, this.vlData);
- break;
- case Utils.Constants.ComponentType.SERVICE:
- this.updateLeftPalette(Utils.Constants.ComponentType.SERVICE, Utils.Constants.ComponentType.SERVICE, this.serviceLeftPaletteData);
- break;
- case Utils.Constants.ComponentType.PRODUCT:
- this.updateLeftPalette(Utils.Constants.ComponentType.PRODUCT, Utils.Constants.ComponentType.SERVICE, this.productLeftPaletteData);
- break;
- default:
- this.updateLeftPalette(Utils.Constants.ComponentType.RESOURCE, Utils.Constants.ResourceType.VF, this.resourceLeftPaletteData);
- }
- };
- }
-}