blob: a9f24312fa60bed900f818300b138e3e4d0890cd (
plain)
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
|
import { Injectable } from '@angular/core';
import { observable, computed, action, toJS, reaction } from 'mobx';
import { findIndex } from 'lodash';
@Injectable()
export class Store {
@observable sdcParmas;
@observable isOwner;
@observable mcUuid;
@observable cdump;
@observable tabsProperties;
@observable tabIndex = 0;
@observable isEditMode = false;
@observable loader = false;
@observable cdumpIsDirty = false;
@observable expandAdvancedSetting = [];
@observable generalflow;
@observable vfiName;
// error dialog
@observable displayErrorDialog = false;
@observable ErrorContent = [];
// rule-engine
@observable tabParmasForRule;
@observable ruleList = new Array();
@observable ruleEditorInitializedState;
@observable isLeftVisible;
@observable inprogress;
@action
updateRuleInList(rule) {
console.log('current list:', toJS(this.ruleList));
console.log('new rule', rule);
const ruleIndex = findIndex(this.ruleList, function(ruleFromList) {
console.log(
`find match rule: list - ${ruleFromList.uid}, rule - ${rule.uid}`
);
return ruleFromList.uid === rule.uid;
});
if (ruleIndex > -1) {
console.log('update rule');
this.ruleList[ruleIndex] = rule;
} else {
console.log('new rule');
this.ruleList.push(rule);
}
}
@action
updateRuleList(listOfRules) {
this.ruleList = listOfRules;
console.log(toJS(this.ruleList));
}
@action
removeRuleFromList(uid) {
this.ruleList = this.ruleList.filter(item => item.uid !== uid);
}
@action
resetRuleList() {
this.ruleList = new Array();
}
@action
changeStateForEditor(data) {
this.ruleEditorInitializedState = data;
}
@action
setTabIndex(value) {
this.tabIndex = value;
}
@action
setTabsProperties(nodes) {
this.tabsProperties = nodes.map(tabItem => {
return tabItem.properties.map(x => {
if (!x.assignment) {
x.assignment = {};
x.assignment.value = '';
} else if (typeof x.assignment.value === 'object') {
x.assignment.value = JSON.stringify(x.assignment.value);
}
return x;
});
});
nodes.map(() => {
this.expandAdvancedSetting.push(false);
});
console.log('tabsProperties: %o', this.tabsProperties.toJS());
}
@computed
get configurationForm() {
return this.tabIndex >= 0 ? this.tabsProperties[this.tabIndex] : null;
}
}
|