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.
Files changed (121) hide show
  1. package/api/eda/edaManagerApi.d.ts +26 -0
  2. package/api/eda/edaManagerApi.js +51 -0
  3. package/api/eda/edaManagerApi.js.map +1 -0
  4. package/api/eda/generated/events.d.ts +132 -0
  5. package/api/eda/generated/events.js +295 -0
  6. package/api/eda/generated/events.js.map +1 -0
  7. package/api/eda/generated/structures.d.ts +109 -0
  8. package/api/eda/generated/structures.js +2 -0
  9. package/api/eda/generated/structures.js.map +1 -0
  10. package/core/i18n/d2aura.en.json +40 -1
  11. package/core/i18n/d2aura.sk.json +87 -1
  12. package/coreui/components/edaManagerComponent/components/edaBasePanel.d.ts +16 -0
  13. package/coreui/components/edaManagerComponent/components/edaBasePanel.js +85 -0
  14. package/coreui/components/edaManagerComponent/components/edaBasePanel.js.map +1 -0
  15. package/coreui/components/edaManagerComponent/components/edaDataBasePanel.d.ts +43 -0
  16. package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js +217 -0
  17. package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js.map +1 -0
  18. package/coreui/components/edaManagerComponent/components/edaDetailPanel.d.ts +16 -0
  19. package/coreui/components/edaManagerComponent/components/edaDetailPanel.js +25 -0
  20. package/coreui/components/edaManagerComponent/components/edaDetailPanel.js.map +1 -0
  21. package/coreui/components/edaManagerComponent/components/edaGraphPanel.d.ts +7 -0
  22. package/coreui/components/edaManagerComponent/components/edaGraphPanel.js +393 -0
  23. package/coreui/components/edaManagerComponent/components/edaGraphPanel.js.map +1 -0
  24. package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.d.ts +18 -0
  25. package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js +72 -0
  26. package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js.map +1 -0
  27. package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.d.ts +29 -0
  28. package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js +94 -0
  29. package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js.map +1 -0
  30. package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.d.ts +18 -0
  31. package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js +86 -0
  32. package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js.map +1 -0
  33. package/coreui/components/edaManagerComponent/components/edaTablePanel.d.ts +4 -0
  34. package/coreui/components/edaManagerComponent/components/edaTablePanel.js +73 -0
  35. package/coreui/components/edaManagerComponent/components/edaTablePanel.js.map +1 -0
  36. package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.d.ts +34 -0
  37. package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js +202 -0
  38. package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js.map +1 -0
  39. package/coreui/components/edaManagerComponent/components/edaTreeView.d.ts +61 -0
  40. package/coreui/components/edaManagerComponent/components/edaTreeView.js +399 -0
  41. package/coreui/components/edaManagerComponent/components/edaTreeView.js.map +1 -0
  42. package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.d.ts +20 -0
  43. package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js +162 -0
  44. package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js.map +1 -0
  45. package/coreui/components/edaManagerComponent/constants/edaTypes.d.ts +78 -0
  46. package/coreui/components/edaManagerComponent/constants/edaTypes.js +71 -0
  47. package/coreui/components/edaManagerComponent/constants/edaTypes.js.map +1 -0
  48. package/coreui/components/edaManagerComponent/constants/storageTypes.d.ts +5 -0
  49. package/coreui/components/edaManagerComponent/constants/storageTypes.js +7 -0
  50. package/coreui/components/edaManagerComponent/constants/storageTypes.js.map +1 -0
  51. package/coreui/components/edaManagerComponent/context/sharedSampleRange.d.ts +17 -0
  52. package/coreui/components/edaManagerComponent/context/sharedSampleRange.js +3 -0
  53. package/coreui/components/edaManagerComponent/context/sharedSampleRange.js.map +1 -0
  54. package/coreui/components/edaManagerComponent/context/sharedSampleRangeWrapper.d.ts +6 -0
  55. package/coreui/components/edaManagerComponent/context/sharedSampleRangeWrapper.js +14 -0
  56. package/coreui/components/edaManagerComponent/context/sharedSampleRangeWrapper.js.map +1 -0
  57. package/coreui/components/edaManagerComponent/edaDetail.d.ts +45 -0
  58. package/coreui/components/edaManagerComponent/edaDetail.js +173 -0
  59. package/coreui/components/edaManagerComponent/edaDetail.js.map +1 -0
  60. package/coreui/components/edaManagerComponent/edaManager.d.ts +20 -0
  61. package/coreui/components/edaManagerComponent/edaManager.js +33 -0
  62. package/coreui/components/edaManagerComponent/edaManager.js.map +1 -0
  63. package/coreui/components/edaManagerComponent/edaNavigator.d.ts +19 -0
  64. package/coreui/components/edaManagerComponent/edaNavigator.js +64 -0
  65. package/coreui/components/edaManagerComponent/edaNavigator.js.map +1 -0
  66. package/coreui/components/edaManagerComponent/edaSelect.d.ts +10 -0
  67. package/coreui/components/edaManagerComponent/edaSelect.js +9 -0
  68. package/coreui/components/edaManagerComponent/edaSelect.js.map +1 -0
  69. package/coreui/components/edaManagerComponent/icons/letterCFilled.d.ts +6 -0
  70. package/coreui/components/edaManagerComponent/icons/letterCFilled.js +6 -0
  71. package/coreui/components/edaManagerComponent/icons/letterCFilled.js.map +1 -0
  72. package/coreui/components/edaManagerComponent/icons/letterDFilled.d.ts +6 -0
  73. package/coreui/components/edaManagerComponent/icons/letterDFilled.js +6 -0
  74. package/coreui/components/edaManagerComponent/icons/letterDFilled.js.map +1 -0
  75. package/coreui/components/edaManagerComponent/icons/letterHFilled.d.ts +6 -0
  76. package/coreui/components/edaManagerComponent/icons/letterHFilled.js +6 -0
  77. package/coreui/components/edaManagerComponent/icons/letterHFilled.js.map +1 -0
  78. package/coreui/components/edaManagerComponent/icons/letterIFilled.d.ts +6 -0
  79. package/coreui/components/edaManagerComponent/icons/letterIFilled.js +6 -0
  80. package/coreui/components/edaManagerComponent/icons/letterIFilled.js.map +1 -0
  81. package/coreui/components/edaManagerComponent/icons/letterMFilled.d.ts +6 -0
  82. package/coreui/components/edaManagerComponent/icons/letterMFilled.js +6 -0
  83. package/coreui/components/edaManagerComponent/icons/letterMFilled.js.map +1 -0
  84. package/coreui/components/edaManagerComponent/icons/numberFifteenFilled.d.ts +6 -0
  85. package/coreui/components/edaManagerComponent/icons/numberFifteenFilled.js +7 -0
  86. package/coreui/components/edaManagerComponent/icons/numberFifteenFilled.js.map +1 -0
  87. package/coreui/components/edaManagerComponent/icons/pairOutlined.d.ts +6 -0
  88. package/coreui/components/edaManagerComponent/icons/pairOutlined.js +6 -0
  89. package/coreui/components/edaManagerComponent/icons/pairOutlined.js.map +1 -0
  90. package/coreui/components/edaManagerComponent/icons/periodicOutlined.d.ts +6 -0
  91. package/coreui/components/edaManagerComponent/icons/periodicOutlined.js +6 -0
  92. package/coreui/components/edaManagerComponent/icons/periodicOutlined.js.map +1 -0
  93. package/coreui/components/edaManagerComponent/utils/utils.d.ts +2 -0
  94. package/coreui/components/edaManagerComponent/utils/utils.js +8 -0
  95. package/coreui/components/edaManagerComponent/utils/utils.js.map +1 -0
  96. package/d2configuration/edaManager/DB.EM_EDA_Function.xml +65 -0
  97. package/d2configuration/edaManager/DB.EM_EDA_GroupVector.xml +65 -0
  98. package/d2configuration/edaManager/DB.EM_EDA_Scenario.xml +65 -0
  99. package/d2configuration/edaManager/DB.EM_EDA_Vector.xml +65 -0
  100. package/d2configuration/edaManager/DB.EM_EDA_VectorEx.xml +65 -0
  101. package/d2configuration/edaManager/DBC_EM_EDA.xml +51 -0
  102. package/d2configuration/edaManager/E.EM_DETAIL_IMPL.xml +124 -0
  103. package/d2configuration/edaManager/E.EM_DETAIL_UNIT.xml +202 -0
  104. package/d2configuration/edaManager/E.EM_NAVIGATOR_IMPL.xml +160 -0
  105. package/d2configuration/edaManager/E.EM_NAVIGATOR_SQL.xml +272 -0
  106. package/d2configuration/edaManager/E.EM_NAVIGATOR_UNIT.xml +346 -0
  107. package/d2configuration/edaManager/E.EM_VECTOR_IMPL.xml +92 -0
  108. package/d2configuration/edaManager/E.EM_VECTOR_MANAGER.xml +116 -0
  109. package/d2configuration/edaManager/E.EM_VECTOR_UNIT.xml +124 -0
  110. package/d2configuration/edaManager/EDA_CancelSession.xml +54 -0
  111. package/d2configuration/edaManager/EDA_GetSessionId.xml +54 -0
  112. package/d2configuration/edaManager/EDA_ReadValuesFromVektorRec.xml +54 -0
  113. package/d2configuration/edaManager/SD.EM_EDA_Function.xml +135 -0
  114. package/d2configuration/edaManager/SD.EM_EDA_GroupVector.xml +190 -0
  115. package/d2configuration/edaManager/SD.EM_EDA_ReadValuesFromVector_V1.xml +168 -0
  116. package/d2configuration/edaManager/SD.EM_EDA_Scenario.xml +322 -0
  117. package/d2configuration/edaManager/SD.EM_EDA_Vector.xml +465 -0
  118. package/d2configuration/edaManager/SD.EM_EDA_VectorEx.xml +80 -0
  119. package/d2configuration/edaManager/SD.EM_EDA_VectorValues.xml +58 -0
  120. package/d2configuration/edaManager/SD.EM_Tree_Item.xml +113 -0
  121. 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