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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
/*-
* ============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 4/20/2016.
*/
/// <reference path="../references"/>
module Sdc.Models {
'use strict';
//this is an object contains keys, when each key has matching array.
// for example: key = tosca.capabilities.network.Linkable and the match array is array of capabilities objects
export class CapabilitiesGroup {
constructor(capabilityGroupObj?:Models.CapabilitiesGroup) {
_.forEach(capabilityGroupObj, (capabilitiesArrayObj:Array<Models.Capability>, instance) => {
this[instance] = [];
_.forEach(capabilitiesArrayObj, (capability:Models.Capability):void => {
this[instance].push(new Models.Capability(capability));
});
});
}
public findValueByKey(keySubstring:string):Array<Models.Capability> {
let key:string = _.find(Object.keys(this), (key)=> {
return _.includes(key.toLowerCase(), keySubstring);
});
return this[key];
}
}
export class Capability {
//server data
name:string;
ownerId:string;
ownerName:string;
type:string;
uniqueId:string;
capabilitySources:Array<String>;
minOccurrences:string;
maxOccurrences:string;
properties:Array<Models.PropertyModel>;
description:string;
validSourceTypes:Array<string>;
//custom
selected:boolean;
filterTerm:string;
constructor(capability?:Capability) {
if (capability) {
//server data
this.name = capability.name;
this.ownerId = capability.ownerId;
this.ownerName = capability.ownerName;
this.type = capability.type;
this.uniqueId = capability.uniqueId;
this.capabilitySources = capability.capabilitySources;
this.minOccurrences = capability.minOccurrences;
this.maxOccurrences = capability.maxOccurrences;
this.properties = capability.properties;
this.description = capability.description;
this.validSourceTypes = capability.validSourceTypes;
this.selected = capability.selected;
this.initFilterTerm();
}
}
public getFullTitle():string {
let maxOccurrences:string = this.maxOccurrences === 'UNBOUNDED' ? '∞' : this.maxOccurrences;
return this.ownerName + ': ' + this.name + ': [' + this.minOccurrences + ', ' + maxOccurrences + ']';
}
public toJSON = ():any => {
this.selected = undefined;
this.filterTerm = undefined;
return this;
};
private initFilterTerm = ():void =>{
this.filterTerm = this.name + " " +
(this.type ? (this.type.substring("tosca.capabilities.".length) + " " ) : "") +
(this.description||"") + " " +
(this.ownerName||"") + " " +
(this.validSourceTypes ? (this.validSourceTypes.join(',') + " ") : "") +
this.minOccurrences+","+this.maxOccurrences;
if(this.properties && this.properties.length){
_.forEach(this.properties,(prop:Models.PropertyModel)=>{
this.filterTerm += " "+ prop.name +
" " + (prop.description||"") +
" " + prop.type +
(prop.schema && prop.schema.property?(" " + prop.schema.property.type):"");
});
}
}
}
}
|