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
117
118
119
|
'use strict';
import {SchemaAttributeGroupModel, SchemaAttribute} from "./schema-attribute";
import {SchemaPropertyGroupModel, SchemaProperty} from "./aschema-property";
export class AttributesGroup {
constructor(attributesObj?:AttributesGroup) {
_.forEach(attributesObj, (attributes:Array<AttributeModel>, instance) => {
this[instance] = [];
_.forEach(attributes, (attribute:AttributeModel):void => {
attribute.resourceInstanceUniqueId = instance;
attribute.readonly = true;
this[instance].push(new AttributeModel(attribute));
});
});
}
}
export interface IAttributeModel {
//server data
uniqueId:string;
name:string;
defaultValue:string;
description:string;
type:string;
schema:SchemaAttributeGroupModel;
status:string;
value:string;
hidden:boolean;
parentUniqueId:string;
//custom data
resourceInstanceUniqueId:string;
readonly:boolean;
valueUniqueUid:string;
}
export class AttributeModel implements IAttributeModel {
//server data
uniqueId:string;
name:string;
defaultValue:string;
description:string;
type:string;
schema:SchemaAttributeGroupModel;
status:string;
value:string;
hidden:boolean;
parentUniqueId:string;
//custom data
resourceInstanceUniqueId:string;
readonly:boolean;
valueUniqueUid:string;
constructor(attribute?:AttributeModel) {
if (attribute) {
this.uniqueId = attribute.uniqueId;
this.name = attribute.name;
this.defaultValue = attribute.defaultValue;
this.description = attribute.description;
this.type = attribute.type;
this.status = attribute.status;
this.schema = attribute.schema;
this.value = attribute.value;
this.hidden = attribute.hidden;
this.parentUniqueId = attribute.parentUniqueId;
this.resourceInstanceUniqueId = attribute.resourceInstanceUniqueId;
this.readonly = attribute.readonly;
this.valueUniqueUid = attribute.valueUniqueUid;
}
if (!this.schema || !this.schema.property) {
this.schema = new SchemaPropertyGroupModel(new SchemaProperty());
} else {
//forcing creating new object, so editing different one than the object in the table
this.schema = new SchemaAttributeGroupModel(new SchemaAttribute(this.schema.property));
}
this.convertValueToView();
}
public convertToServerObject:Function = ():string => {
if (this.defaultValue && this.type === 'map') {
this.defaultValue = '{' + this.defaultValue + '}';
}
if (this.defaultValue && this.type === 'list') {
this.defaultValue = '[' + this.defaultValue + ']';
}
this.defaultValue = this.defaultValue != "" && this.defaultValue != "[]" && this.defaultValue != "{}" ? this.defaultValue : null;
return JSON.stringify(this);
};
public convertValueToView() {
//unwrapping value {} or [] if type is complex
if (this.defaultValue && (this.type === 'map' || this.type === 'list') &&
['[', '{'].indexOf(this.defaultValue.charAt(0)) > -1 &&
[']', '}'].indexOf(this.defaultValue.slice(-1)) > -1) {
this.defaultValue = this.defaultValue.slice(1, -1);
}
//also for value - for the modal in canvas
if (this.value && (this.type === 'map' || this.type === 'list') &&
['[', '{'].indexOf(this.value.charAt(0)) > -1 &&
[']', '}'].indexOf(this.value.slice(-1)) > -1) {
this.value = this.value.slice(1, -1);
}
}
public toJSON = ():any => {
if (!this.resourceInstanceUniqueId) {
this.value = undefined;
}
this.readonly = undefined;
this.resourceInstanceUniqueId = undefined;
return this;
};
}
|