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
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { Store } from '../../store/store';
import { RuleEngineApiService } from '../api/rule-engine-api.service';
@Component({
selector: 'app-version-type-select',
templateUrl: './version-type-select.component.html',
styleUrls: ['./version-type-select.component.scss']
})
export class VersionTypeSelectComponent {
mappingTarget: string;
selectedEvent: String;
selectedVersion: String;
events: Array<String>;
loader: boolean;
editMode = false;
readOnly = false;
@Input() versions;
@Input() metaData;
@Output() nodesUpdated = new EventEmitter();
@Output() refrashRuleList = new EventEmitter();
advancedSetting: Array<any>;
notifyIdCheckbox = false;
constructor(private _ruleApi: RuleEngineApiService, public store: Store) {
this.selectedVersion = null;
this.selectedEvent = null;
// set ddl with the first option value.
this._ruleApi.tabIndex.subscribe(index => {
console.log('rule index:', index);
const tabName = this.store.cdump.nodes[index].name;
console.log('tab name:', tabName);
if (tabName.toLowerCase().includes('map')) {
this.mappingTarget = this.store.tabsProperties[index][0].name;
this.advancedSetting = this.store.tabsProperties[index].filter(item => {
if (
!(
item.hasOwnProperty('constraints') &&
!item.value.includes('get_input')
)
) {
return item;
}
});
this._ruleApi
.generateMappingRulesFileName(
this.store.ruleListExistParams.nodeName,
this.store.ruleListExistParams.nodeId,
this.store.ruleListExistParams.vfcmtUuid
)
.subscribe(response => {
console.log('generateMappingRulesFileName response: ', response);
this.advancedSetting.forEach(element => {
if (response.includes(element.name)) {
element.isExist = true;
} else {
element.isExist = false;
}
});
});
}
});
}
changeNotifyId() {
if (!this.notifyIdCheckbox) {
this.store.notifyIdValue = '';
}
return (this.notifyIdCheckbox = !this.notifyIdCheckbox);
}
onChangeMapping(configurationKey) {
console.log('changing propertiy key:', configurationKey);
this._ruleApi.setFieldName(configurationKey);
this.refrashRuleList.next();
}
updateData(version, eventType, isList) {
this.selectedVersion = version;
this.selectedEvent = eventType;
this.readOnly = true;
}
updateVersionTypeFlag(flag) {
this.readOnly = flag;
if (flag === false) {
this.selectedVersion = null;
this.selectedEvent = null;
}
}
onSelectVersion(version, eventType) {
if (typeof eventType === 'undefined') {
this.selectedEvent = '';
this.events = this.metaData
.filter(x => x.version === version)
.map(x => x.eventTypes)[0];
if (eventType) {
this.editMode = true;
this.selectedEvent = eventType + 'Fields';
}
}
}
onSelectEventType(eventType) {
this.loader = true;
this._ruleApi
.getSchema(this.selectedVersion, this.selectedEvent)
.subscribe(tree => {
console.log('tree: ', tree);
this.loader = false;
this.nodesUpdated.emit({ nodes: tree });
});
}
}
|