d2aura 26.0.7 → 26.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/api/eda/edaManagerApi.d.ts +26 -0
- package/api/eda/edaManagerApi.js +51 -0
- package/api/eda/edaManagerApi.js.map +1 -0
- package/api/eda/generated/events.d.ts +132 -0
- package/api/eda/generated/events.js +295 -0
- package/api/eda/generated/events.js.map +1 -0
- package/api/eda/generated/structures.d.ts +109 -0
- package/api/eda/generated/structures.js +2 -0
- package/api/eda/generated/structures.js.map +1 -0
- package/core/i18n/d2aura.en.json +40 -1
- package/core/i18n/d2aura.sk.json +87 -1
- package/coreui/components/edaManagerComponent/components/edaBasePanel.d.ts +16 -0
- package/coreui/components/edaManagerComponent/components/edaBasePanel.js +85 -0
- package/coreui/components/edaManagerComponent/components/edaBasePanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaDataBasePanel.d.ts +43 -0
- package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js +217 -0
- package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaDetailPanel.d.ts +16 -0
- package/coreui/components/edaManagerComponent/components/edaDetailPanel.js +25 -0
- package/coreui/components/edaManagerComponent/components/edaDetailPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaGraphPanel.d.ts +7 -0
- package/coreui/components/edaManagerComponent/components/edaGraphPanel.js +393 -0
- package/coreui/components/edaManagerComponent/components/edaGraphPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.d.ts +18 -0
- package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js +72 -0
- package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.d.ts +29 -0
- package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js +94 -0
- package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.d.ts +18 -0
- package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js +86 -0
- package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaTablePanel.d.ts +4 -0
- package/coreui/components/edaManagerComponent/components/edaTablePanel.js +73 -0
- package/coreui/components/edaManagerComponent/components/edaTablePanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.d.ts +34 -0
- package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js +202 -0
- package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaTreeView.d.ts +61 -0
- package/coreui/components/edaManagerComponent/components/edaTreeView.js +399 -0
- package/coreui/components/edaManagerComponent/components/edaTreeView.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.d.ts +20 -0
- package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js +162 -0
- package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/constants/edaTypes.d.ts +78 -0
- package/coreui/components/edaManagerComponent/constants/edaTypes.js +71 -0
- package/coreui/components/edaManagerComponent/constants/edaTypes.js.map +1 -0
- package/coreui/components/edaManagerComponent/constants/storageTypes.d.ts +5 -0
- package/coreui/components/edaManagerComponent/constants/storageTypes.js +7 -0
- package/coreui/components/edaManagerComponent/constants/storageTypes.js.map +1 -0
- package/coreui/components/edaManagerComponent/context/sharedSampleRange.d.ts +17 -0
- package/coreui/components/edaManagerComponent/context/sharedSampleRange.js +3 -0
- package/coreui/components/edaManagerComponent/context/sharedSampleRange.js.map +1 -0
- package/coreui/components/edaManagerComponent/context/sharedSampleRangeWrapper.d.ts +6 -0
- package/coreui/components/edaManagerComponent/context/sharedSampleRangeWrapper.js +14 -0
- package/coreui/components/edaManagerComponent/context/sharedSampleRangeWrapper.js.map +1 -0
- package/coreui/components/edaManagerComponent/edaDetail.d.ts +45 -0
- package/coreui/components/edaManagerComponent/edaDetail.js +173 -0
- package/coreui/components/edaManagerComponent/edaDetail.js.map +1 -0
- package/coreui/components/edaManagerComponent/edaManager.d.ts +20 -0
- package/coreui/components/edaManagerComponent/edaManager.js +33 -0
- package/coreui/components/edaManagerComponent/edaManager.js.map +1 -0
- package/coreui/components/edaManagerComponent/edaNavigator.d.ts +19 -0
- package/coreui/components/edaManagerComponent/edaNavigator.js +64 -0
- package/coreui/components/edaManagerComponent/edaNavigator.js.map +1 -0
- package/coreui/components/edaManagerComponent/edaSelect.d.ts +10 -0
- package/coreui/components/edaManagerComponent/edaSelect.js +9 -0
- package/coreui/components/edaManagerComponent/edaSelect.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/letterCFilled.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/letterCFilled.js +6 -0
- package/coreui/components/edaManagerComponent/icons/letterCFilled.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/letterDFilled.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/letterDFilled.js +6 -0
- package/coreui/components/edaManagerComponent/icons/letterDFilled.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/letterHFilled.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/letterHFilled.js +6 -0
- package/coreui/components/edaManagerComponent/icons/letterHFilled.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/letterIFilled.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/letterIFilled.js +6 -0
- package/coreui/components/edaManagerComponent/icons/letterIFilled.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/letterMFilled.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/letterMFilled.js +6 -0
- package/coreui/components/edaManagerComponent/icons/letterMFilled.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/numberFifteenFilled.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/numberFifteenFilled.js +7 -0
- package/coreui/components/edaManagerComponent/icons/numberFifteenFilled.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/pairOutlined.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/pairOutlined.js +6 -0
- package/coreui/components/edaManagerComponent/icons/pairOutlined.js.map +1 -0
- package/coreui/components/edaManagerComponent/icons/periodicOutlined.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/periodicOutlined.js +6 -0
- package/coreui/components/edaManagerComponent/icons/periodicOutlined.js.map +1 -0
- package/coreui/components/edaManagerComponent/utils/utils.d.ts +2 -0
- package/coreui/components/edaManagerComponent/utils/utils.js +8 -0
- package/coreui/components/edaManagerComponent/utils/utils.js.map +1 -0
- package/d2configuration/edaManager/DB.EM_EDA_Function.xml +65 -0
- package/d2configuration/edaManager/DB.EM_EDA_GroupVector.xml +65 -0
- package/d2configuration/edaManager/DB.EM_EDA_Scenario.xml +65 -0
- package/d2configuration/edaManager/DB.EM_EDA_Vector.xml +65 -0
- package/d2configuration/edaManager/DB.EM_EDA_VectorEx.xml +65 -0
- package/d2configuration/edaManager/DBC_EM_EDA.xml +51 -0
- package/d2configuration/edaManager/E.EM_DETAIL_IMPL.xml +124 -0
- package/d2configuration/edaManager/E.EM_DETAIL_UNIT.xml +202 -0
- package/d2configuration/edaManager/E.EM_NAVIGATOR_IMPL.xml +160 -0
- package/d2configuration/edaManager/E.EM_NAVIGATOR_SQL.xml +272 -0
- package/d2configuration/edaManager/E.EM_NAVIGATOR_UNIT.xml +346 -0
- package/d2configuration/edaManager/E.EM_VECTOR_IMPL.xml +92 -0
- package/d2configuration/edaManager/E.EM_VECTOR_MANAGER.xml +116 -0
- package/d2configuration/edaManager/E.EM_VECTOR_UNIT.xml +124 -0
- package/d2configuration/edaManager/EDA_CancelSession.xml +54 -0
- package/d2configuration/edaManager/EDA_GetSessionId.xml +54 -0
- package/d2configuration/edaManager/EDA_ReadValuesFromVektorRec.xml +54 -0
- package/d2configuration/edaManager/SD.EM_EDA_Function.xml +135 -0
- package/d2configuration/edaManager/SD.EM_EDA_GroupVector.xml +190 -0
- package/d2configuration/edaManager/SD.EM_EDA_ReadValuesFromVector_V1.xml +168 -0
- package/d2configuration/edaManager/SD.EM_EDA_Scenario.xml +322 -0
- package/d2configuration/edaManager/SD.EM_EDA_Vector.xml +465 -0
- package/d2configuration/edaManager/SD.EM_EDA_VectorEx.xml +80 -0
- package/d2configuration/edaManager/SD.EM_EDA_VectorValues.xml +58 -0
- package/d2configuration/edaManager/SD.EM_Tree_Item.xml +113 -0
- package/package.json +8 -6
|
@@ -0,0 +1,399 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Tree, Typography } from "antd";
|
|
3
|
+
import { FolderOpenOutlined, FunctionOutlined, LoadingOutlined, QuestionOutlined } from "@ant-design/icons";
|
|
4
|
+
import WithCss from "d2coreui/components/style/withCss";
|
|
5
|
+
import { createStyles } from "antd-style";
|
|
6
|
+
import { EdaVectorType } from "../constants/edaTypes";
|
|
7
|
+
import { NumberFifteenFilled } from "../icons/numberFifteenFilled";
|
|
8
|
+
import { LetterHFilled } from "../icons/letterHFilled";
|
|
9
|
+
import { LetterDFilled } from "../icons/letterDFilled";
|
|
10
|
+
import { LetterCFilled } from "../icons/letterCFilled";
|
|
11
|
+
import { LetterIFilled } from "../icons/letterIFilled";
|
|
12
|
+
import { PairOutlined } from "../icons/pairOutlined";
|
|
13
|
+
import { PeriodicOutlined } from "../icons/periodicOutlined";
|
|
14
|
+
import i18n from "d2core/i18n/i18n";
|
|
15
|
+
const useStyles = createStyles(({ css }) => {
|
|
16
|
+
return {
|
|
17
|
+
baseLayout: css `
|
|
18
|
+
position: relative;
|
|
19
|
+
height: 100%;
|
|
20
|
+
width: 100%;
|
|
21
|
+
|
|
22
|
+
.ant-tree {
|
|
23
|
+
height: 100%;
|
|
24
|
+
background-color: transparent;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.ant-tree-node-content-wrapper {
|
|
28
|
+
user-select: none;
|
|
29
|
+
-webkit-user-select: none;
|
|
30
|
+
-moz-user-select: none;
|
|
31
|
+
-ms-user-select: none;
|
|
32
|
+
white-space: nowrap;
|
|
33
|
+
text-overflow: ellipsis;
|
|
34
|
+
overflow: hidden;
|
|
35
|
+
|
|
36
|
+
.ant-tree-title {
|
|
37
|
+
white-space: nowrap;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
`,
|
|
41
|
+
absoluteLayout: css `
|
|
42
|
+
overflow: auto;
|
|
43
|
+
position: absolute;
|
|
44
|
+
left: 0;
|
|
45
|
+
right: 0;
|
|
46
|
+
top: 0;
|
|
47
|
+
bottom: 0;
|
|
48
|
+
`
|
|
49
|
+
};
|
|
50
|
+
});
|
|
51
|
+
export var TreeViewType;
|
|
52
|
+
(function (TreeViewType) {
|
|
53
|
+
TreeViewType["GROUP"] = "group";
|
|
54
|
+
TreeViewType["SCENARIO"] = "scenario";
|
|
55
|
+
})(TreeViewType || (TreeViewType = {}));
|
|
56
|
+
export class EdaTreeView extends React.Component {
|
|
57
|
+
constructor(props) {
|
|
58
|
+
super(props);
|
|
59
|
+
this.childParentMap = new Map();
|
|
60
|
+
this.nodeMap = new Map();
|
|
61
|
+
this.divRef = React.createRef();
|
|
62
|
+
this.resizeObserver = null;
|
|
63
|
+
this.state = {
|
|
64
|
+
treeData: [],
|
|
65
|
+
expandedKeys: [],
|
|
66
|
+
selectedKeys: [],
|
|
67
|
+
height: 0,
|
|
68
|
+
};
|
|
69
|
+
this.onExpand = this.onExpand.bind(this);
|
|
70
|
+
this.onLoadData = this.onLoadData.bind(this);
|
|
71
|
+
this.onDoubleClick = this.onDoubleClick.bind(this);
|
|
72
|
+
this.titleRenderer = this.titleRenderer.bind(this);
|
|
73
|
+
}
|
|
74
|
+
async componentDidMount() {
|
|
75
|
+
await this.loadData(this.props.type);
|
|
76
|
+
if (this.divRef.current) {
|
|
77
|
+
this.resizeObserver = new ResizeObserver((entries) => {
|
|
78
|
+
const entry = entries[0];
|
|
79
|
+
if (entry) {
|
|
80
|
+
const { height } = entry.contentRect;
|
|
81
|
+
this.setState({ height });
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
this.resizeObserver.observe(this.divRef.current);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
async componentDidUpdate(prevProps) {
|
|
88
|
+
if (prevProps.type !== this.props.type) {
|
|
89
|
+
await this.loadData(this.props.type);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
componentWillUnmount() {
|
|
93
|
+
if (this.resizeObserver) {
|
|
94
|
+
this.resizeObserver.disconnect();
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
render() {
|
|
98
|
+
const { treeData, expandedKeys, selectedKeys } = this.state;
|
|
99
|
+
return (React.createElement(WithCss, { useStyles: useStyles }, (css) => React.createElement("div", { ref: this.divRef, className: css.styles.baseLayout },
|
|
100
|
+
React.createElement("div", { className: css.styles.absoluteLayout },
|
|
101
|
+
React.createElement(Tree, { blockNode: true, showLine: true, showIcon: true, height: this.state.height, loadData: this.onLoadData, onExpand: this.onExpand, onDoubleClick: this.onDoubleClick, expandedKeys: expandedKeys, selectedKeys: selectedKeys, titleRender: this.titleRenderer, treeData: treeData })))));
|
|
102
|
+
}
|
|
103
|
+
titleRenderer(node) {
|
|
104
|
+
if (node.key === this.state.loading) {
|
|
105
|
+
return React.createElement(Typography.Link, null,
|
|
106
|
+
React.createElement(LoadingOutlined, null),
|
|
107
|
+
" ",
|
|
108
|
+
i18n("Loading"),
|
|
109
|
+
"...");
|
|
110
|
+
}
|
|
111
|
+
return node.title;
|
|
112
|
+
}
|
|
113
|
+
renderTitle(key, data, amount, total) {
|
|
114
|
+
return (React.createElement(Typography.Link, { onClick: () => this.onLoadData(data, key) }, i18n("Show %{n} more (of %{o})", { n: String(amount), o: String(total) })));
|
|
115
|
+
}
|
|
116
|
+
onExpand(keys) {
|
|
117
|
+
this.setState({ expandedKeys: (keys) });
|
|
118
|
+
}
|
|
119
|
+
async loadData(type) {
|
|
120
|
+
this.setState({ loading: "" });
|
|
121
|
+
try {
|
|
122
|
+
let treeData;
|
|
123
|
+
switch (type) {
|
|
124
|
+
case TreeViewType.GROUP:
|
|
125
|
+
const rootGroups = await this.props.api.getGroupChildren(undefined);
|
|
126
|
+
treeData = this.convertGroups(rootGroups.items, undefined);
|
|
127
|
+
break;
|
|
128
|
+
case TreeViewType.SCENARIO:
|
|
129
|
+
const rootScenarios = await this.props.api.getScenarioChildren(undefined);
|
|
130
|
+
treeData = this.convertScenarios(rootScenarios.items, undefined);
|
|
131
|
+
break;
|
|
132
|
+
}
|
|
133
|
+
this.setState({ treeData: treeData });
|
|
134
|
+
}
|
|
135
|
+
catch (e) {
|
|
136
|
+
console.warn("failed to load tree data", e);
|
|
137
|
+
}
|
|
138
|
+
finally {
|
|
139
|
+
this.setState({ loading: undefined });
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
async loadGroups(data, id, nodes) {
|
|
143
|
+
const { api } = this.props;
|
|
144
|
+
if (!data.groupOffset?.done) {
|
|
145
|
+
const groups = await api.getGroupChildren(id, data.groupOffset?.offset);
|
|
146
|
+
const amount = groups.leftCount > api.pageSize ? api.pageSize : groups.leftCount;
|
|
147
|
+
nodes.push(...this.convertGroups(groups.items, id));
|
|
148
|
+
if (data.groupOffset === undefined) {
|
|
149
|
+
data.groupOffset = {
|
|
150
|
+
done: groups.leftCount === 0,
|
|
151
|
+
offset: groups.items.length,
|
|
152
|
+
total: groups.items.length + groups.leftCount,
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
else {
|
|
156
|
+
data.groupOffset.done = groups.leftCount === 0;
|
|
157
|
+
data.groupOffset.offset += groups.items.length;
|
|
158
|
+
}
|
|
159
|
+
if (!data.groupOffset.done) {
|
|
160
|
+
const key = `${id}_show_more`;
|
|
161
|
+
nodes.push({
|
|
162
|
+
key: key,
|
|
163
|
+
title: this.renderTitle(key, data, amount, data.groupOffset.total),
|
|
164
|
+
isLeaf: true,
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
if (data.groupOffset.done && !data.vectorOffset?.done) {
|
|
169
|
+
const vectors = await api.getGroupVectors(id, data.vectorOffset?.offset);
|
|
170
|
+
this.loadVectors(data, id, nodes, vectors);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
async loadScenarios(data, id, nodes) {
|
|
174
|
+
const { api } = this.props;
|
|
175
|
+
if (!data.scenarioOffset?.done) {
|
|
176
|
+
const groups = await api.getScenarioChildren(id, data.scenarioOffset?.offset);
|
|
177
|
+
const amount = groups.leftCount > api.pageSize ? api.pageSize : groups.leftCount;
|
|
178
|
+
nodes.push(...this.convertScenarios(groups.items, id));
|
|
179
|
+
if (data.scenarioOffset === undefined) {
|
|
180
|
+
data.scenarioOffset = {
|
|
181
|
+
done: groups.leftCount === 0,
|
|
182
|
+
offset: groups.items.length,
|
|
183
|
+
total: groups.items.length + groups.leftCount,
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
else {
|
|
187
|
+
data.scenarioOffset.done = groups.leftCount === 0;
|
|
188
|
+
data.scenarioOffset.offset += groups.items.length;
|
|
189
|
+
}
|
|
190
|
+
if (!data.scenarioOffset.done) {
|
|
191
|
+
const key = `${id}_show_more`;
|
|
192
|
+
nodes.push({
|
|
193
|
+
key: key,
|
|
194
|
+
title: this.renderTitle(key, data, amount, data.scenarioOffset.total),
|
|
195
|
+
isLeaf: true,
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
if (data.scenarioOffset.done && !data.vectorOffset?.done) {
|
|
200
|
+
const vectors = await api.getScenarioVectors(id, data.vectorOffset?.offset, undefined, true);
|
|
201
|
+
this.loadVectors(data, id, nodes, vectors);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
loadVectors(data, id, nodes, vectors) {
|
|
205
|
+
const { api } = this.props;
|
|
206
|
+
const amount = vectors.leftCount > api.pageSize ? api.pageSize : vectors.leftCount;
|
|
207
|
+
nodes.push(...this.convertVectors(vectors.items, id));
|
|
208
|
+
if (data.vectorOffset === undefined) {
|
|
209
|
+
data.vectorOffset = {
|
|
210
|
+
done: vectors.leftCount === 0,
|
|
211
|
+
offset: vectors.items.length,
|
|
212
|
+
total: vectors.items.length + vectors.leftCount,
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
else {
|
|
216
|
+
data.vectorOffset.done = vectors.leftCount === 0;
|
|
217
|
+
data.vectorOffset.offset += vectors.items.length;
|
|
218
|
+
}
|
|
219
|
+
if (!data.vectorOffset.done) {
|
|
220
|
+
const key = `${id}_show_more`;
|
|
221
|
+
nodes.push({
|
|
222
|
+
key: key,
|
|
223
|
+
title: this.renderTitle(key, data, amount, data.vectorOffset.total),
|
|
224
|
+
isLeaf: true,
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
async onLoadData(data, id) {
|
|
229
|
+
if (data.children) {
|
|
230
|
+
return Promise.resolve();
|
|
231
|
+
}
|
|
232
|
+
this.setState({ loading: id });
|
|
233
|
+
try {
|
|
234
|
+
const { type } = this.props;
|
|
235
|
+
let id;
|
|
236
|
+
const nodes = [];
|
|
237
|
+
switch (type) {
|
|
238
|
+
case TreeViewType.GROUP:
|
|
239
|
+
if (!data.group) {
|
|
240
|
+
console.warn("No group!");
|
|
241
|
+
this.setState({ loading: undefined });
|
|
242
|
+
return;
|
|
243
|
+
}
|
|
244
|
+
id = data.group.ID;
|
|
245
|
+
await this.loadGroups(data, id, nodes);
|
|
246
|
+
break;
|
|
247
|
+
case TreeViewType.SCENARIO:
|
|
248
|
+
if (!data.scenario) {
|
|
249
|
+
console.warn("No scenario!");
|
|
250
|
+
this.setState({ loading: undefined });
|
|
251
|
+
return;
|
|
252
|
+
}
|
|
253
|
+
id = data.scenario.ID;
|
|
254
|
+
await this.loadScenarios(data, id, nodes);
|
|
255
|
+
break;
|
|
256
|
+
default:
|
|
257
|
+
this.setState({ loading: undefined });
|
|
258
|
+
return;
|
|
259
|
+
}
|
|
260
|
+
const parentId = this.childParentMap.get(id);
|
|
261
|
+
await new Promise((resolve, reject) => {
|
|
262
|
+
if (parentId !== undefined) {
|
|
263
|
+
const parentNode = this.nodeMap.get(parentId);
|
|
264
|
+
if (parentNode?.children) {
|
|
265
|
+
this.updateTree(data, nodes, parentNode.children, id, resolve, reject);
|
|
266
|
+
}
|
|
267
|
+
else {
|
|
268
|
+
console.warn("No parent for node", id);
|
|
269
|
+
reject();
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
else {
|
|
273
|
+
this.updateTree(data, nodes, this.state.treeData, id, resolve, reject);
|
|
274
|
+
}
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
catch (e) {
|
|
278
|
+
console.warn("Failed to load tree data", e);
|
|
279
|
+
}
|
|
280
|
+
finally {
|
|
281
|
+
this.setState({ loading: undefined });
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
onDoubleClick(_e, node) {
|
|
285
|
+
if (node.vector !== undefined) {
|
|
286
|
+
this.props.onItemDoubleClick?.({ id: node.vector.ID, type: 0 });
|
|
287
|
+
}
|
|
288
|
+
else if (node.group !== undefined) {
|
|
289
|
+
this.props.onItemDoubleClick?.({ id: node.group.ID, type: 1 });
|
|
290
|
+
}
|
|
291
|
+
else if (node.scenario !== undefined) {
|
|
292
|
+
this.props.onItemDoubleClick?.({ id: node.scenario.ID, type: 2 });
|
|
293
|
+
}
|
|
294
|
+
this.setState({ selectedKeys: [node.key] });
|
|
295
|
+
}
|
|
296
|
+
updateTree(data, nodes, treeData, dataId, resolve, reject) {
|
|
297
|
+
const { type } = this.props;
|
|
298
|
+
const index = treeData.findIndex((t) => (type === TreeViewType.GROUP ? t.group?.ID : t.scenario?.ID) === dataId);
|
|
299
|
+
if (index < 0) {
|
|
300
|
+
console.warn("Failed to find index");
|
|
301
|
+
reject();
|
|
302
|
+
return;
|
|
303
|
+
}
|
|
304
|
+
treeData[index] = { ...data, children: treeData[index].children };
|
|
305
|
+
if (treeData[index].children) {
|
|
306
|
+
treeData[index].children.pop();
|
|
307
|
+
treeData[index].children.push(...nodes);
|
|
308
|
+
}
|
|
309
|
+
else {
|
|
310
|
+
treeData[index].children = nodes;
|
|
311
|
+
}
|
|
312
|
+
this.nodeMap.set(dataId, treeData[index]);
|
|
313
|
+
this.setState({ treeData: [...this.state.treeData] }, resolve);
|
|
314
|
+
}
|
|
315
|
+
convertGroups(groups, parentId) {
|
|
316
|
+
const data = [];
|
|
317
|
+
for (let group of groups) {
|
|
318
|
+
const node = {
|
|
319
|
+
key: group.ID,
|
|
320
|
+
title: group.DisplayName,
|
|
321
|
+
isLeaf: false,
|
|
322
|
+
icon: React.createElement(FolderOpenOutlined, null),
|
|
323
|
+
group: group,
|
|
324
|
+
};
|
|
325
|
+
data.push(node);
|
|
326
|
+
this.childParentMap.set(group.ID, parentId);
|
|
327
|
+
this.nodeMap.set(group.ID, node);
|
|
328
|
+
}
|
|
329
|
+
return data;
|
|
330
|
+
}
|
|
331
|
+
convertScenarios(scenarios, parentId) {
|
|
332
|
+
const data = [];
|
|
333
|
+
for (let scenario of scenarios) {
|
|
334
|
+
const node = {
|
|
335
|
+
key: scenario.ID,
|
|
336
|
+
title: scenario.DisplayName,
|
|
337
|
+
isLeaf: false,
|
|
338
|
+
icon: React.createElement(FolderOpenOutlined, null),
|
|
339
|
+
scenario: scenario,
|
|
340
|
+
};
|
|
341
|
+
data.push(node);
|
|
342
|
+
this.childParentMap.set(scenario.ID, parentId);
|
|
343
|
+
this.nodeMap.set(scenario.ID, node);
|
|
344
|
+
}
|
|
345
|
+
return data;
|
|
346
|
+
}
|
|
347
|
+
convertVectors(vectors, parentId) {
|
|
348
|
+
const data = [];
|
|
349
|
+
for (let vector of vectors) {
|
|
350
|
+
const id = `${parentId}_${vector.ID}`;
|
|
351
|
+
const node = {
|
|
352
|
+
key: id,
|
|
353
|
+
title: vector.DisplayName,
|
|
354
|
+
isLeaf: true,
|
|
355
|
+
icon: this.getVectorIcon(vector.Type),
|
|
356
|
+
vector: vector,
|
|
357
|
+
};
|
|
358
|
+
data.push(node);
|
|
359
|
+
this.childParentMap.set(id, parentId);
|
|
360
|
+
this.nodeMap.set(id, node);
|
|
361
|
+
}
|
|
362
|
+
return data;
|
|
363
|
+
}
|
|
364
|
+
getVectorIcon(type) {
|
|
365
|
+
switch (type) {
|
|
366
|
+
case EdaVectorType.FifteenMinutes:
|
|
367
|
+
return React.createElement(NumberFifteenFilled, null);
|
|
368
|
+
case EdaVectorType.Hour:
|
|
369
|
+
return React.createElement(LetterHFilled, null);
|
|
370
|
+
case EdaVectorType.Day:
|
|
371
|
+
return React.createElement(LetterDFilled, null);
|
|
372
|
+
case EdaVectorType.Descriptive:
|
|
373
|
+
return React.createElement(LetterCFilled, null);
|
|
374
|
+
case EdaVectorType.Interval:
|
|
375
|
+
return React.createElement(LetterIFilled, null);
|
|
376
|
+
case EdaVectorType.FifteenMinutesCalc:
|
|
377
|
+
return React.createElement(NumberFifteenFilled, { style: { color: "orange" } });
|
|
378
|
+
case EdaVectorType.HourCalc:
|
|
379
|
+
return React.createElement(LetterHFilled, { style: { color: "orange" } });
|
|
380
|
+
case EdaVectorType.DayCalc:
|
|
381
|
+
return React.createElement(LetterDFilled, { style: { color: "orange" } });
|
|
382
|
+
case EdaVectorType.Change:
|
|
383
|
+
return React.createElement(LetterCFilled, null);
|
|
384
|
+
case EdaVectorType.ChangeCalc:
|
|
385
|
+
return React.createElement(LetterCFilled, { style: { color: "orange" } });
|
|
386
|
+
case EdaVectorType.Pair:
|
|
387
|
+
return React.createElement(PairOutlined, null);
|
|
388
|
+
case EdaVectorType.Periodic:
|
|
389
|
+
return React.createElement(PeriodicOutlined, null);
|
|
390
|
+
case EdaVectorType.PeriodicCalc:
|
|
391
|
+
return React.createElement(PeriodicOutlined, { style: { color: "orange" } });
|
|
392
|
+
case EdaVectorType.Functional:
|
|
393
|
+
return React.createElement(FunctionOutlined, null);
|
|
394
|
+
default:
|
|
395
|
+
return React.createElement(QuestionOutlined, null);
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
//# sourceMappingURL=edaTreeView.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"edaTreeView.js","sourceRoot":"","sources":["../../../../../../coreui/components/edaManagerComponent/components/edaTreeView.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, {Key} from \"react\";\r\nimport {Tree, TreeDataNode, Typography} from \"antd\";\r\nimport EdaManagerApi from \"../../../../api/eda/edaManagerApi\";\r\nimport {FolderOpenOutlined, FunctionOutlined, LoadingOutlined, QuestionOutlined} from \"@ant-design/icons\";\r\nimport WithCss from \"d2coreui/components/style/withCss\";\r\nimport {createStyles} from \"antd-style\";\r\nimport {EdaVectorType, IdType, TypedIndex} from \"../constants/edaTypes\";\r\nimport {NumberFifteenFilled} from \"../icons/numberFifteenFilled\";\r\nimport {LetterHFilled} from \"../icons/letterHFilled\";\r\nimport {LetterDFilled} from \"../icons/letterDFilled\";\r\nimport {LetterCFilled} from \"../icons/letterCFilled\";\r\nimport {LetterIFilled} from \"../icons/letterIFilled\";\r\nimport {PairOutlined} from \"../icons/pairOutlined\";\r\nimport {PeriodicOutlined} from \"../icons/periodicOutlined\";\r\nimport i18n from \"d2core/i18n/i18n\";\r\nimport {SD_EM_Tree_Item} from \"../../../../api/eda/generated/structures\";\r\nimport {EM_NAVIGATOR_IMPLGetGroupVectorsResult, EM_NAVIGATOR_IMPLGetScenarioVectorsResult} from \"../../../../api/eda/generated/events\";\r\n\r\nconst useStyles = createStyles(({css}) => {\r\n return {\r\n baseLayout: css`\r\n position: relative;\r\n height: 100%;\r\n width: 100%;\r\n \r\n .ant-tree {\r\n height: 100%;\r\n background-color: transparent;\r\n }\r\n\r\n .ant-tree-node-content-wrapper {\r\n user-select: none;\r\n -webkit-user-select: none;\r\n -moz-user-select: none;\r\n -ms-user-select: none;\r\n white-space: nowrap;\r\n text-overflow: ellipsis;\r\n overflow: hidden;\r\n \r\n .ant-tree-title {\r\n white-space: nowrap;\r\n }\r\n }\r\n `,\r\n absoluteLayout: css`\r\n overflow: auto;\r\n position: absolute;\r\n left: 0;\r\n right: 0;\r\n top: 0;\r\n bottom: 0;\r\n `\r\n }\r\n});\r\n\r\nexport enum TreeViewType {\r\n GROUP = \"group\",\r\n SCENARIO = \"scenario\",\r\n}\r\n\r\ninterface PageData {\r\n total: number\r\n offset: number\r\n done: boolean\r\n}\r\n\r\ninterface DataNode extends TreeDataNode {\r\n group?: SD_EM_Tree_Item\r\n vector?: SD_EM_Tree_Item\r\n scenario?: SD_EM_Tree_Item\r\n\r\n vectorOffset?: PageData\r\n groupOffset?: PageData\r\n scenarioOffset?: PageData\r\n}\r\n\r\ninterface Props {\r\n api: EdaManagerApi\r\n type: TreeViewType\r\n\r\n onItemSelected?: () => void\r\n onItemDoubleClick?: (item: TypedIndex) => void\r\n}\r\n\r\ninterface State {\r\n treeData: DataNode[]\r\n expandedKeys: Key[]\r\n selectedKeys: Key[]\r\n height: number;\r\n loading?: string;\r\n}\r\n\r\nexport class EdaTreeView extends React.Component<Props, State> {\r\n private readonly childParentMap: Map<number | string, number | undefined> = new Map();\r\n private readonly nodeMap: Map<number | string, DataNode> = new Map();\r\n private readonly divRef = React.createRef<HTMLDivElement>();\r\n private resizeObserver: ResizeObserver | null = null;\r\n\r\n constructor(props: Readonly<Props>) {\r\n super(props);\r\n this.state = {\r\n treeData: [],\r\n expandedKeys: [],\r\n selectedKeys: [],\r\n height: 0,\r\n }\r\n\r\n this.onExpand = this.onExpand.bind(this);\r\n this.onLoadData = this.onLoadData.bind(this);\r\n this.onDoubleClick = this.onDoubleClick.bind(this);\r\n this.titleRenderer = this.titleRenderer.bind(this);\r\n }\r\n\r\n async componentDidMount() {\r\n await this.loadData(this.props.type);\r\n if (this.divRef.current) {\r\n this.resizeObserver = new ResizeObserver((entries) => {\r\n const entry = entries[0];\r\n\r\n if (entry) {\r\n const {height} = entry.contentRect;\r\n this.setState({height});\r\n }\r\n });\r\n\r\n this.resizeObserver.observe(this.divRef.current);\r\n }\r\n }\r\n\r\n async componentDidUpdate(prevProps: Props) {\r\n if (prevProps.type !== this.props.type) {\r\n await this.loadData(this.props.type);\r\n }\r\n }\r\n\r\n componentWillUnmount() {\r\n if (this.resizeObserver) {\r\n this.resizeObserver.disconnect();\r\n }\r\n }\r\n\r\n render(): React.ReactNode {\r\n const {treeData, expandedKeys, selectedKeys} = this.state;\r\n\r\n return (\r\n <WithCss useStyles={useStyles}>\r\n {(css) =>\r\n <div ref={this.divRef} className={css.styles.baseLayout}>\r\n <div className={css.styles.absoluteLayout}>\r\n <Tree<DataNode>\r\n blockNode\r\n showLine\r\n showIcon\r\n height={this.state.height}\r\n loadData={this.onLoadData}\r\n onExpand={this.onExpand}\r\n onDoubleClick={this.onDoubleClick}\r\n expandedKeys={expandedKeys}\r\n selectedKeys={selectedKeys}\r\n titleRender={this.titleRenderer}\r\n treeData={treeData}/>\r\n </div>\r\n </div>\r\n }\r\n </WithCss>\r\n )\r\n }\r\n\r\n private titleRenderer(node: DataNode): React.ReactNode {\r\n if (node.key === this.state.loading) {\r\n return <Typography.Link><LoadingOutlined /> {i18n(\"Loading\")}...</Typography.Link>;\r\n }\r\n\r\n return node.title as React.ReactNode;\r\n }\r\n\r\n private renderTitle(key: string, data: DataNode, amount: number, total: number): React.ReactNode {\r\n return (\r\n <Typography.Link onClick={() => this.onLoadData(data, key)}>\r\n {i18n(\"Show %{n} more (of %{o})\", {n: String(amount), o: String(total)})}\r\n </Typography.Link>\r\n );\r\n }\r\n\r\n private onExpand(keys: Key[]) {\r\n this.setState({expandedKeys: (keys)})\r\n }\r\n\r\n private async loadData(type: TreeViewType) {\r\n this.setState({loading: \"\"});\r\n\r\n try {\r\n let treeData: DataNode[];\r\n\r\n switch (type) {\r\n case TreeViewType.GROUP:\r\n const rootGroups = await this.props.api.getGroupChildren(undefined);\r\n treeData = this.convertGroups(rootGroups.items as SD_EM_Tree_Item[], undefined);\r\n break;\r\n case TreeViewType.SCENARIO:\r\n const rootScenarios = await this.props.api.getScenarioChildren(undefined);\r\n treeData = this.convertScenarios(rootScenarios.items as SD_EM_Tree_Item[], undefined);\r\n break;\r\n }\r\n\r\n this.setState({treeData: treeData});\r\n } catch (e) {\r\n console.warn(\"failed to load tree data\", e);\r\n } finally {\r\n this.setState({loading: undefined});\r\n }\r\n }\r\n\r\n private async loadGroups(data: DataNode, id: number, nodes: DataNode[]) {\r\n const {api} = this.props;\r\n\r\n if (!data.groupOffset?.done) {\r\n const groups = await api.getGroupChildren(id, data.groupOffset?.offset);\r\n const amount = groups.leftCount > api.pageSize ? api.pageSize : groups.leftCount;\r\n\r\n nodes.push(...this.convertGroups(groups.items as SD_EM_Tree_Item[], id));\r\n\r\n if (data.groupOffset === undefined) {\r\n data.groupOffset = {\r\n done: groups.leftCount === 0,\r\n offset: groups.items.length,\r\n total: groups.items.length + groups.leftCount,\r\n }\r\n } else {\r\n data.groupOffset.done = groups.leftCount === 0;\r\n data.groupOffset.offset += groups.items.length;\r\n }\r\n\r\n if (!data.groupOffset.done) {\r\n const key = `${id}_show_more`;\r\n\r\n nodes.push({\r\n key: key,\r\n title: this.renderTitle(key, data, amount, data.groupOffset.total),\r\n isLeaf: true,\r\n });\r\n }\r\n }\r\n\r\n if (data.groupOffset.done && !data.vectorOffset?.done) {\r\n const vectors = await api.getGroupVectors(id, data.vectorOffset?.offset);\r\n\r\n this.loadVectors(data, id, nodes, vectors);\r\n }\r\n }\r\n\r\n private async loadScenarios(data: DataNode, id: number, nodes: DataNode[]) {\r\n const {api} = this.props;\r\n\r\n if (!data.scenarioOffset?.done) {\r\n const groups = await api.getScenarioChildren(id, data.scenarioOffset?.offset);\r\n const amount = groups.leftCount > api.pageSize ? api.pageSize : groups.leftCount;\r\n\r\n nodes.push(...this.convertScenarios(groups.items as SD_EM_Tree_Item[], id));\r\n\r\n if (data.scenarioOffset === undefined) {\r\n data.scenarioOffset = {\r\n done: groups.leftCount === 0,\r\n offset: groups.items.length,\r\n total: groups.items.length + groups.leftCount,\r\n }\r\n } else {\r\n data.scenarioOffset.done = groups.leftCount === 0;\r\n data.scenarioOffset.offset += groups.items.length;\r\n }\r\n\r\n if (!data.scenarioOffset.done) {\r\n const key = `${id}_show_more`;\r\n\r\n nodes.push({\r\n key: key,\r\n title: this.renderTitle(key, data, amount, data.scenarioOffset.total),\r\n isLeaf: true,\r\n });\r\n }\r\n }\r\n\r\n if (data.scenarioOffset.done && !data.vectorOffset?.done) {\r\n const vectors = await api.getScenarioVectors(id, data.vectorOffset?.offset, undefined, true);\r\n\r\n this.loadVectors(data, id, nodes, vectors);\r\n }\r\n }\r\n\r\n private loadVectors(data: DataNode, id: number, nodes: DataNode[], vectors: Omit<EM_NAVIGATOR_IMPLGetGroupVectorsResult | EM_NAVIGATOR_IMPLGetScenarioVectorsResult, \"isOk\" | \"errorMsg\">) {\r\n const {api} = this.props;\r\n\r\n const amount = vectors.leftCount > api.pageSize ? api.pageSize : vectors.leftCount;\r\n\r\n nodes.push(...this.convertVectors(vectors.items as SD_EM_Tree_Item[], id));\r\n\r\n if (data.vectorOffset === undefined) {\r\n data.vectorOffset = {\r\n done: vectors.leftCount === 0,\r\n offset: vectors.items.length,\r\n total: vectors.items.length + vectors.leftCount,\r\n }\r\n } else {\r\n data.vectorOffset.done = vectors.leftCount === 0;\r\n data.vectorOffset.offset += vectors.items.length;\r\n }\r\n\r\n if (!data.vectorOffset.done) {\r\n const key = `${id}_show_more`;\r\n\r\n nodes.push({\r\n key: key,\r\n title: this.renderTitle(key, data, amount, data.vectorOffset.total),\r\n isLeaf: true,\r\n });\r\n }\r\n }\r\n\r\n private async onLoadData(data: DataNode, id?: string): Promise<void> {\r\n if (data.children) { // data already available\r\n return Promise.resolve();\r\n }\r\n\r\n this.setState({loading: id});\r\n\r\n try {\r\n const {type} = this.props;\r\n let id: number;\r\n const nodes: DataNode[] = [];\r\n\r\n switch (type) {\r\n case TreeViewType.GROUP:\r\n if (!data.group) {\r\n console.warn(\"No group!\");\r\n this.setState({loading: undefined});\r\n return;\r\n }\r\n\r\n id = data.group.ID;\r\n await this.loadGroups(data, id, nodes);\r\n break;\r\n case TreeViewType.SCENARIO:\r\n if (!data.scenario) {\r\n console.warn(\"No scenario!\");\r\n this.setState({loading: undefined});\r\n return;\r\n }\r\n\r\n id = data.scenario.ID;\r\n await this.loadScenarios(data, id, nodes);\r\n break;\r\n default:\r\n this.setState({loading: undefined});\r\n return;\r\n }\r\n\r\n const parentId = this.childParentMap.get(id);\r\n\r\n await new Promise<void>((resolve, reject) => {\r\n if (parentId !== undefined) {\r\n const parentNode = this.nodeMap.get(parentId);\r\n\r\n if (parentNode?.children) {\r\n this.updateTree(data, nodes, parentNode.children, id, resolve, reject);\r\n } else {\r\n console.warn(\"No parent for node\", id);\r\n reject();\r\n }\r\n } else {\r\n this.updateTree(data, nodes, this.state.treeData, id, resolve, reject);\r\n }\r\n });\r\n } catch (e) {\r\n console.warn(\"Failed to load tree data\", e);\r\n } finally {\r\n this.setState({loading: undefined});\r\n }\r\n }\r\n\r\n private onDoubleClick(_e: React.MouseEvent, node: DataNode) {\r\n if (node.vector !== undefined) {\r\n this.props.onItemDoubleClick?.({id: node.vector.ID, type: IdType.VECTOR});\r\n } else if (node.group !== undefined) {\r\n this.props.onItemDoubleClick?.({id: node.group.ID, type: IdType.GROUP});\r\n } else if (node.scenario !== undefined) {\r\n this.props.onItemDoubleClick?.({id: node.scenario.ID, type: IdType.SCENARIO});\r\n }\r\n\r\n this.setState({selectedKeys: [node.key]});\r\n }\r\n\r\n private updateTree(data: DataNode, nodes: DataNode[], treeData: DataNode[], dataId: number, resolve: () => void, reject: () => void) {\r\n const {type} = this.props;\r\n const index: number = treeData.findIndex((t: DataNode) => (type === TreeViewType.GROUP ? t.group?.ID : t.scenario?.ID) === dataId);\r\n\r\n if (index < 0) {\r\n console.warn(\"Failed to find index\");\r\n reject();\r\n return;\r\n }\r\n\r\n treeData[index] = {...data, children: treeData[index].children};\r\n\r\n if (treeData[index].children) {\r\n treeData[index].children.pop();\r\n treeData[index].children.push(...nodes);\r\n } else {\r\n treeData[index].children = nodes;\r\n }\r\n\r\n this.nodeMap.set(dataId, treeData[index]);\r\n\r\n this.setState({treeData: [...this.state.treeData]}, resolve);\r\n }\r\n\r\n private convertGroups(groups: SD_EM_Tree_Item[], parentId: number | undefined): DataNode[] {\r\n const data: DataNode[] = [];\r\n\r\n for (let group of groups) {\r\n const node: DataNode = {\r\n key: group.ID,\r\n title: group.DisplayName,\r\n isLeaf: false,\r\n icon: <FolderOpenOutlined/>,\r\n group: group,\r\n };\r\n\r\n data.push(node);\r\n this.childParentMap.set(group.ID, parentId);\r\n this.nodeMap.set(group.ID, node);\r\n }\r\n\r\n return data;\r\n }\r\n\r\n private convertScenarios(scenarios: SD_EM_Tree_Item[], parentId: number | undefined): DataNode[] {\r\n const data: DataNode[] = [];\r\n\r\n for (let scenario of scenarios) {\r\n const node: DataNode = {\r\n key: scenario.ID,\r\n title: scenario.DisplayName,\r\n isLeaf: false,\r\n icon: <FolderOpenOutlined/>,\r\n scenario: scenario,\r\n };\r\n\r\n data.push(node);\r\n this.childParentMap.set(scenario.ID, parentId);\r\n this.nodeMap.set(scenario.ID, node);\r\n }\r\n\r\n return data;\r\n }\r\n\r\n private convertVectors(vectors: SD_EM_Tree_Item[], parentId: number | undefined): DataNode[] {\r\n const data: DataNode[] = [];\r\n\r\n for (let vector of vectors) {\r\n const id = `${parentId}_${vector.ID}`;\r\n const node: DataNode = {\r\n key: id,\r\n title: vector.DisplayName,\r\n isLeaf: true,\r\n icon: this.getVectorIcon(vector.Type),\r\n vector: vector,\r\n };\r\n\r\n data.push(node);\r\n this.childParentMap.set(id, parentId);\r\n this.nodeMap.set(id, node);\r\n }\r\n\r\n return data;\r\n }\r\n\r\n private getVectorIcon(type: number) {\r\n switch (type) {\r\n case EdaVectorType.FifteenMinutes:\r\n return <NumberFifteenFilled/>;\r\n case EdaVectorType.Hour:\r\n return <LetterHFilled/>;\r\n case EdaVectorType.Day:\r\n return <LetterDFilled/>;\r\n case EdaVectorType.Descriptive:\r\n return <LetterCFilled/>;\r\n case EdaVectorType.Interval:\r\n return <LetterIFilled/>;\r\n case EdaVectorType.FifteenMinutesCalc:\r\n return <NumberFifteenFilled style={{color: \"orange\"}}/>;\r\n case EdaVectorType.HourCalc:\r\n return <LetterHFilled style={{color: \"orange\"}}/>;\r\n case EdaVectorType.DayCalc:\r\n return <LetterDFilled style={{color: \"orange\"}}/>;\r\n case EdaVectorType.Change:\r\n return <LetterCFilled/>;\r\n case EdaVectorType.ChangeCalc:\r\n return <LetterCFilled style={{color: \"orange\"}}/>;\r\n case EdaVectorType.Pair:\r\n return <PairOutlined/>\r\n case EdaVectorType.Periodic:\r\n return <PeriodicOutlined/>\r\n case EdaVectorType.PeriodicCalc:\r\n return <PeriodicOutlined style={{color: \"orange\"}}/>\r\n case EdaVectorType.Functional:\r\n return <FunctionOutlined/>\r\n default:\r\n return <QuestionOutlined/>;\r\n }\r\n }\r\n}"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { VectorData } from "../constants/edaTypes";
|
|
3
|
+
import { SizeType } from "antd/lib/config-provider/SizeContext";
|
|
4
|
+
import { Variant } from "antd/es/config-provider";
|
|
5
|
+
interface Props {
|
|
6
|
+
data: VectorData;
|
|
7
|
+
size?: SizeType;
|
|
8
|
+
variant?: Variant;
|
|
9
|
+
}
|
|
10
|
+
interface State {
|
|
11
|
+
}
|
|
12
|
+
export declare class EdaVectorDetailPanel extends React.Component<Props, State> {
|
|
13
|
+
private mask;
|
|
14
|
+
private readonly formRef;
|
|
15
|
+
componentDidMount(): void;
|
|
16
|
+
componentDidUpdate(prevProps: Readonly<Props>): void;
|
|
17
|
+
render(): React.JSX.Element;
|
|
18
|
+
private getCollapseItems;
|
|
19
|
+
}
|
|
20
|
+
export {};
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Checkbox, Col, Collapse, Form, Input, InputNumber, Row, Select, Typography } from "antd";
|
|
3
|
+
import WithCss from "d2coreui/components/style/withCss";
|
|
4
|
+
import i18n from "d2core/i18n/i18n";
|
|
5
|
+
import { createStyles } from "antd-style";
|
|
6
|
+
import dayjs from "d2core/dayjs";
|
|
7
|
+
import { EdaAccessType, EdaRoundingType, EdaValueClassType, EdaVectorType } from "../constants/edaTypes";
|
|
8
|
+
import EnumValuePicker from "d2coreui/components/picker/enumValuePicker";
|
|
9
|
+
import { EdaSelect } from "../edaSelect";
|
|
10
|
+
import { LocaleHolder } from "d2core/i18n/localeHolder";
|
|
11
|
+
const useStyles = createStyles(({ css }) => {
|
|
12
|
+
return {
|
|
13
|
+
baseLayout: css `
|
|
14
|
+
`
|
|
15
|
+
};
|
|
16
|
+
});
|
|
17
|
+
export class EdaVectorDetailPanel extends React.Component {
|
|
18
|
+
constructor() {
|
|
19
|
+
super(...arguments);
|
|
20
|
+
this.mask = LocaleHolder.getDateTimeFormat(true, false, false, true);
|
|
21
|
+
this.formRef = React.createRef();
|
|
22
|
+
}
|
|
23
|
+
componentDidMount() {
|
|
24
|
+
this.formRef.current?.setFieldsValue(this.props.data);
|
|
25
|
+
}
|
|
26
|
+
componentDidUpdate(prevProps) {
|
|
27
|
+
if (prevProps.data !== this.props.data) {
|
|
28
|
+
this.formRef.current?.setFieldsValue(this.props.data);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
render() {
|
|
32
|
+
const { data, size, variant } = this.props;
|
|
33
|
+
return (React.createElement(WithCss, { useStyles: useStyles }, (css) => React.createElement(Form, { ref: this.formRef, layout: "horizontal", style: { overflowX: "hidden" }, className: "record-config-form", size: size, variant: variant, labelCol: { sm: 24, md: 24, lg: 24, xl: 24, xxl: 24 } },
|
|
34
|
+
React.createElement(Row, { gutter: css.theme.padding, align: "bottom" },
|
|
35
|
+
React.createElement(Col, { flex: "auto" },
|
|
36
|
+
React.createElement(Form.Item, { label: i18n("Vector Type"), name: ["data", "TYP"], required: true },
|
|
37
|
+
React.createElement(EnumValuePicker, { open: false, style: { maxWidth: "250px" }, values: EdaVectorType, translateValue: true, translationPrefix: "EdaVectorType_" }))),
|
|
38
|
+
React.createElement(Col, null,
|
|
39
|
+
React.createElement("span", null,
|
|
40
|
+
"ID: ",
|
|
41
|
+
data.data.ID_VEKTOR))),
|
|
42
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
43
|
+
React.createElement(Col, { span: 24 },
|
|
44
|
+
React.createElement(Form.Item, { required: true, name: ["data", "ANO_PLATNY"], valuePropName: "checked", getValueProps: (v) => ({ checked: v === 1 }), getValueFromEvent: (e) => (e.target.checked ? 1 : 0) },
|
|
45
|
+
React.createElement(Checkbox, { disabled: true }, i18n("Record Validity Indication"))))),
|
|
46
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
47
|
+
React.createElement(Col, { span: 24 },
|
|
48
|
+
React.createElement(Form.Item, { required: true, name: ["data", "MENO"], label: i18n("Code") },
|
|
49
|
+
React.createElement(Input, { readOnly: true })))),
|
|
50
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
51
|
+
React.createElement(Col, { span: 24 },
|
|
52
|
+
React.createElement(Form.Item, { required: true, name: ["data", "ZOBRAZ_MENO"], label: i18n("Name[Title]") },
|
|
53
|
+
React.createElement(Input, { readOnly: true })))),
|
|
54
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
55
|
+
React.createElement(Col, { span: 12 },
|
|
56
|
+
React.createElement(Form.Item, { required: true, name: ["data", "INTEGRAL"], label: i18n("Value Class") },
|
|
57
|
+
React.createElement(EnumValuePicker, { open: false, values: EdaValueClassType, translateValue: true, translationPrefix: "EdaValueClassType_" }))),
|
|
58
|
+
React.createElement(Col, { span: 12 },
|
|
59
|
+
React.createElement(Form.Item, { name: ["data", "TECH_JEDNOTKY"], label: i18n("Units") },
|
|
60
|
+
React.createElement(Input, { readOnly: true, style: { width: '100%' } })))),
|
|
61
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
62
|
+
React.createElement(Col, { span: 24 },
|
|
63
|
+
React.createElement(Form.Item, { required: true, label: i18n("Filter"), name: ["data", "MENOEX"] },
|
|
64
|
+
React.createElement(Input, { readOnly: true })))),
|
|
65
|
+
React.createElement(Collapse, { size: size, items: this.getCollapseItems(css), style: { marginTop: css.theme.paddingXS + "px" }, bordered: false }))));
|
|
66
|
+
}
|
|
67
|
+
getCollapseItems(css) {
|
|
68
|
+
return [
|
|
69
|
+
{
|
|
70
|
+
key: "rounding",
|
|
71
|
+
label: i18n("Rounding"),
|
|
72
|
+
children: (React.createElement(React.Fragment, null,
|
|
73
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
74
|
+
React.createElement(Col, { span: 16 },
|
|
75
|
+
React.createElement(Form.Item, { required: true, label: i18n("View"), name: ["data", "VIEW_ROUND"] },
|
|
76
|
+
React.createElement(EnumValuePicker, { open: false, values: EdaRoundingType, translateValue: true, translationPrefix: "EdaRoundingType_" }))),
|
|
77
|
+
React.createElement(Col, { span: 8 },
|
|
78
|
+
React.createElement(Form.Item, { required: true, label: i18n("Decimal Places"), name: ["data", "VIEW_DEC_PL"] },
|
|
79
|
+
React.createElement(InputNumber, { readOnly: true, style: { width: "100%" } })))),
|
|
80
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
81
|
+
React.createElement(Col, { span: 16 },
|
|
82
|
+
React.createElement(Form.Item, { required: true, label: i18n("Calculation"), name: ["data", "EXEC_ROUND"] },
|
|
83
|
+
React.createElement(EnumValuePicker, { open: false, values: EdaRoundingType, translateValue: true, translationPrefix: "EdaRoundingType_" }))),
|
|
84
|
+
React.createElement(Col, { span: 8 },
|
|
85
|
+
React.createElement(Form.Item, { required: true, label: i18n("Decimal Places"), name: ["data", "EXEC_DEC_PL"] },
|
|
86
|
+
React.createElement(InputNumber, { readOnly: true, style: { width: "100%" } })))))),
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
key: "time_values",
|
|
90
|
+
label: i18n("Time Values"),
|
|
91
|
+
children: (React.createElement(React.Fragment, null,
|
|
92
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
93
|
+
React.createElement(Col, { span: 12 },
|
|
94
|
+
React.createElement(Form.Item, { label: i18n("Creation Date"), name: ["extData", "DATE_IN"], getValueProps: (v) => ({ value: v ? dayjs(v).format(this.mask) : undefined }) },
|
|
95
|
+
React.createElement(Input, { readOnly: true, variant: "borderless", style: { fontWeight: "bold", width: "100%" } }))),
|
|
96
|
+
React.createElement(Col, { span: 12 },
|
|
97
|
+
React.createElement(Form.Item, { label: i18n("Last Modified Date"), name: ["extData", "DATE_CH"], getValueProps: (v) => ({ value: v ? dayjs(v).format(this.mask) : undefined }) },
|
|
98
|
+
React.createElement(Input, { readOnly: true, variant: "borderless", style: { fontWeight: "bold", width: "100%" } })))),
|
|
99
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
100
|
+
React.createElement(Col, { span: 12 },
|
|
101
|
+
React.createElement(Form.Item, { label: i18n("Validity From"), name: ["data", "DATA_OD"], getValueProps: (v) => ({ value: v ? dayjs(v).format(this.mask) : undefined }) },
|
|
102
|
+
React.createElement(Input, { readOnly: true, variant: "borderless", style: { fontWeight: "bold", width: "100%" } }))),
|
|
103
|
+
React.createElement(Col, { span: 12 },
|
|
104
|
+
React.createElement(Form.Item, { label: i18n("Validity To"), name: ["data", "DATA_DO"], getValueProps: (v) => ({ value: v ? dayjs(v).format(this.mask) : undefined }) },
|
|
105
|
+
React.createElement(Input, { readOnly: true, variant: "borderless", style: { fontWeight: "bold", width: "100%" } })))),
|
|
106
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
107
|
+
React.createElement(Col, { span: 12 },
|
|
108
|
+
React.createElement(Form.Item, { label: i18n("Pre-calc From"), name: ["dataFunction", "PREDV_OD"], getValueProps: (v) => ({ value: v ? dayjs(v).format(this.mask) : undefined }) },
|
|
109
|
+
React.createElement(Input, { readOnly: true, variant: "borderless", style: { fontWeight: "bold", width: "100%" } }))),
|
|
110
|
+
React.createElement(Col, { span: 12 },
|
|
111
|
+
React.createElement(Form.Item, { label: i18n("Pre-calc To"), name: ["dataFunction", "PREDV_DO"], getValueProps: (v) => ({ value: v ? dayjs(v).format(this.mask) : undefined }) },
|
|
112
|
+
React.createElement(Input, { readOnly: true, variant: "borderless", style: { fontWeight: "bold", width: "100%" } })))))),
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
key: "other_info",
|
|
116
|
+
label: i18n("Other Info"),
|
|
117
|
+
children: (React.createElement(React.Fragment, null,
|
|
118
|
+
React.createElement(Row, null,
|
|
119
|
+
React.createElement(Col, { span: 24 },
|
|
120
|
+
React.createElement(Form.Item, { label: i18n("Tablespace"), name: ["data", "ID_TABLESPACE"] },
|
|
121
|
+
React.createElement(Select, { open: false })))),
|
|
122
|
+
React.createElement(Row, null,
|
|
123
|
+
React.createElement(Col, { span: 24 },
|
|
124
|
+
React.createElement(Form.Item, { label: i18n("Validation"), name: ["data", "ID_VALIDATOR"] },
|
|
125
|
+
React.createElement(EdaSelect, { open: false })))),
|
|
126
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
127
|
+
React.createElement(Col, { flex: "auto" },
|
|
128
|
+
React.createElement(Form.Item, { label: i18n("Time Zone"), name: ["data", "TIME_ZONE"] },
|
|
129
|
+
React.createElement(Input, { readOnly: true }))),
|
|
130
|
+
React.createElement(Col, { flex: "none" },
|
|
131
|
+
React.createElement(Form.Item, { required: true, label: i18n("Data Offset"), name: ["data", "DATA_OFFSET"] },
|
|
132
|
+
React.createElement(Input, { readOnly: true })))),
|
|
133
|
+
React.createElement(Row, { gutter: css.theme.padding },
|
|
134
|
+
React.createElement(Col, { flex: "auto" },
|
|
135
|
+
React.createElement(Form.Item, { required: true, label: i18n("Access Type"), name: ["data", "PRIVATE"] },
|
|
136
|
+
React.createElement(EnumValuePicker, { open: false, values: EdaAccessType, translateValue: true, translationPrefix: "EdaAccessType_" }))),
|
|
137
|
+
React.createElement(Col, { flex: "none" },
|
|
138
|
+
React.createElement(Form.Item, { label: i18n("Owner"), name: ["data", "AUTOR"] },
|
|
139
|
+
React.createElement(Input, { readOnly: true })))))),
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
key: "note",
|
|
143
|
+
label: i18n("Note"),
|
|
144
|
+
children: (React.createElement(Form.Item, { name: ["data", "POPIS"] },
|
|
145
|
+
React.createElement(Input.TextArea, { rows: 4, readOnly: true })))
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
key: "parameters",
|
|
149
|
+
label: i18n("Parameters"),
|
|
150
|
+
children: (React.createElement(React.Fragment, null,
|
|
151
|
+
React.createElement(Typography.Title, null, "TODO")))
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
key: "versioning",
|
|
155
|
+
label: i18n("Versioning"),
|
|
156
|
+
children: (React.createElement(React.Fragment, null,
|
|
157
|
+
React.createElement(Typography.Title, null, "TODO")))
|
|
158
|
+
},
|
|
159
|
+
];
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
//# sourceMappingURL=edaVectorDetailPanel.js.map
|