1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
/*
* ============LICENSE_START=======================================================
* Copyright (C) 2021 Nordix Foundation
* ================================================================================
* 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.
*
* SPDX-License-Identifier: Apache-2.0
* ============LICENSE_END=========================================================
*/
import {Component} from '@angular/core';
import {
ComponentMetadata, DataTypeModel, PropertyBEModel
} from 'app/models';
import {TopologyTemplateService} from "../../../services/component-services/topology-template.service";
import {WorkspaceService} from "../../workspace/workspace.service";
import {PropertiesService} from "../../../services/properties.service";
import {PROPERTY_DATA} from "../../../../utils/constants";
import {DataTypeService} from "../../../services/data-type.service";
@Component({
selector: 'input-list',
templateUrl: './input-list.component.html',
styleUrls: ['./input-list.component.less'],
})
export class InputListComponent {
selectInputValue;
isLoading: boolean;
propertyType: string;
inputs: Array<PropertyBEModel> = [];
private dataTypeProperties: Array<PropertyBEModel> = [];
private componentMetadata: ComponentMetadata;
constructor(private topologyTemplateService: TopologyTemplateService,
private workspaceService: WorkspaceService,
private propertiesService: PropertiesService,
private dataTypeService: DataTypeService) {
}
ngOnInit() {
this.componentMetadata = this.workspaceService.metadata;
this.propertyType = this.propertiesService.getCheckedPropertyType();
this.loadInputValues(this.propertyType);
}
private loadInputValues(propertyType: string): void {
this.isLoading = true;
this.topologyTemplateService.getComponentInputsValues(this.componentMetadata.componentType, this.componentMetadata.uniqueId)
.subscribe((response) => {
response.inputs.forEach((inputProperty: any) => {
if (propertyType === inputProperty.type) {
this.inputs.push(inputProperty);
} else if (PROPERTY_DATA.SIMPLE_TYPES.indexOf(inputProperty.type) === -1 && inputProperty.type !== propertyType) {
this.buildInputDataForComplexType(inputProperty, propertyType);
}
});
}, () => {
//error ignored
}, () => {
this.isLoading = false;
});
}
private buildInputDataForComplexType(inputProperty: PropertyBEModel, propertyType: string) {
let dataTypeFound: DataTypeModel = this.dataTypeService.getDataTypeByModelAndTypeName(this.componentMetadata.model, inputProperty.type);
if (dataTypeFound && dataTypeFound.properties) {
dataTypeFound.properties.forEach(dataTypeProperty => {
let inputData = inputProperty.name + "->" + dataTypeProperty.name;
dataTypeProperty.name = inputData;
if (this.dataTypeProperties.indexOf(dataTypeProperty) === -1 && dataTypeProperty.type === propertyType) {
this.inputs.push(dataTypeProperty);
}
});
}
}
}
|