d2aura 26.0.13 → 26.0.14

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 (116) hide show
  1. package/api/eda/edaManagerApi.d.ts +50 -15
  2. package/api/eda/edaManagerApi.js +80 -29
  3. package/api/eda/edaManagerApi.js.map +1 -1
  4. package/api/eda/generated/events.d.ts +109 -60
  5. package/api/eda/generated/events.js +182 -88
  6. package/api/eda/generated/events.js.map +1 -1
  7. package/api/eda/generated/structures.d.ts +78 -14
  8. package/api/eda/generated/structures.js.map +1 -1
  9. package/core/i18n/d2aura.sk.json +30 -2
  10. package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.d.ts +1 -1
  11. package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.js +2 -2
  12. package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.js.map +1 -1
  13. package/coreui/components/edaManagerComponent/components/edaChartViewer.d.ts +14 -0
  14. package/coreui/components/edaManagerComponent/components/edaChartViewer.js +370 -0
  15. package/coreui/components/edaManagerComponent/components/edaChartViewer.js.map +1 -0
  16. package/coreui/components/edaManagerComponent/components/edaDataBasePanel.d.ts +4 -8
  17. package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js +18 -75
  18. package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js.map +1 -1
  19. package/coreui/components/edaManagerComponent/components/edaDetailPanel.d.ts +5 -14
  20. package/coreui/components/edaManagerComponent/components/edaDetailPanel.js +80 -19
  21. package/coreui/components/edaManagerComponent/components/edaDetailPanel.js.map +1 -1
  22. package/coreui/components/edaManagerComponent/components/edaGraphPanel.d.ts +2 -7
  23. package/coreui/components/edaManagerComponent/components/edaGraphPanel.js +15 -380
  24. package/coreui/components/edaManagerComponent/components/edaGraphPanel.js.map +1 -1
  25. package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.d.ts +3 -14
  26. package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js +54 -67
  27. package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js.map +1 -1
  28. package/coreui/components/edaManagerComponent/components/edaLoadingOverlay.d.ts +7 -0
  29. package/coreui/components/edaManagerComponent/components/edaLoadingOverlay.js +35 -0
  30. package/coreui/components/edaManagerComponent/components/edaLoadingOverlay.js.map +1 -0
  31. package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.d.ts +2 -16
  32. package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js +47 -50
  33. package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js.map +1 -1
  34. package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.d.ts +3 -14
  35. package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js +67 -81
  36. package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js.map +1 -1
  37. package/coreui/components/edaManagerComponent/components/edaTableEditorDialog.d.ts +12 -0
  38. package/coreui/components/edaManagerComponent/components/edaTableEditorDialog.js +268 -0
  39. package/coreui/components/edaManagerComponent/components/edaTableEditorDialog.js.map +1 -0
  40. package/coreui/components/edaManagerComponent/components/edaTablePanel.d.ts +2 -6
  41. package/coreui/components/edaManagerComponent/components/edaTablePanel.js +119 -62
  42. package/coreui/components/edaManagerComponent/components/edaTablePanel.js.map +1 -1
  43. package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.d.ts +2 -13
  44. package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js +57 -88
  45. package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js.map +1 -1
  46. package/coreui/components/edaManagerComponent/components/edaTreeView.d.ts +4 -51
  47. package/coreui/components/edaManagerComponent/components/edaTreeView.js +299 -259
  48. package/coreui/components/edaManagerComponent/components/edaTreeView.js.map +1 -1
  49. package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.d.ts +3 -21
  50. package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js +160 -179
  51. package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js.map +1 -1
  52. package/coreui/components/edaManagerComponent/components/exportDialog.d.ts +18 -0
  53. package/coreui/components/edaManagerComponent/components/exportDialog.js +157 -0
  54. package/coreui/components/edaManagerComponent/components/exportDialog.js.map +1 -0
  55. package/coreui/components/edaManagerComponent/constants/edaTypes.d.ts +10 -11
  56. package/coreui/components/edaManagerComponent/constants/edaTypes.js.map +1 -1
  57. package/coreui/components/edaManagerComponent/context/edaConfigContext.d.ts +26 -0
  58. package/coreui/components/edaManagerComponent/context/edaConfigContext.js +20 -0
  59. package/coreui/components/edaManagerComponent/context/edaConfigContext.js.map +1 -0
  60. package/coreui/components/edaManagerComponent/context/edaVectorDataContext.d.ts +9 -16
  61. package/coreui/components/edaManagerComponent/context/edaVectorDataContext.js.map +1 -1
  62. package/coreui/components/edaManagerComponent/context/edaVectorDataProvider.d.ts +0 -1
  63. package/coreui/components/edaManagerComponent/context/edaVectorDataProvider.js +71 -66
  64. package/coreui/components/edaManagerComponent/context/edaVectorDataProvider.js.map +1 -1
  65. package/coreui/components/edaManagerComponent/context/loadingContext.d.ts +1 -1
  66. package/coreui/components/edaManagerComponent/context/loadingContext.js.map +1 -1
  67. package/coreui/components/edaManagerComponent/context/{sharedSampleRange.d.ts → sharedSampleRangeContext.d.ts} +6 -3
  68. package/coreui/components/edaManagerComponent/context/sharedSampleRangeContext.js +3 -0
  69. package/coreui/components/edaManagerComponent/context/sharedSampleRangeContext.js.map +1 -0
  70. package/coreui/components/edaManagerComponent/context/useEdaActions.d.ts +7 -0
  71. package/coreui/components/edaManagerComponent/context/useEdaActions.js +22 -0
  72. package/coreui/components/edaManagerComponent/context/useEdaActions.js.map +1 -0
  73. package/coreui/components/edaManagerComponent/edaDetail.d.ts +7 -26
  74. package/coreui/components/edaManagerComponent/edaDetail.js +124 -106
  75. package/coreui/components/edaManagerComponent/edaDetail.js.map +1 -1
  76. package/coreui/components/edaManagerComponent/edaManager.d.ts +4 -11
  77. package/coreui/components/edaManagerComponent/edaManager.js +29 -22
  78. package/coreui/components/edaManagerComponent/edaManager.js.map +1 -1
  79. package/coreui/components/edaManagerComponent/edaNavigator.d.ts +4 -12
  80. package/coreui/components/edaManagerComponent/edaNavigator.js +36 -41
  81. package/coreui/components/edaManagerComponent/edaNavigator.js.map +1 -1
  82. package/coreui/components/edaManagerComponent/edaSelect.d.ts +2 -3
  83. package/coreui/components/edaManagerComponent/edaSelect.js +22 -44
  84. package/coreui/components/edaManagerComponent/edaSelect.js.map +1 -1
  85. package/coreui/components/edaManagerComponent/utils/export.d.ts +9 -0
  86. package/coreui/components/edaManagerComponent/utils/export.js +573 -0
  87. package/coreui/components/edaManagerComponent/utils/export.js.map +1 -0
  88. package/coreui/components/edaManagerComponent/utils/utils.d.ts +6 -12
  89. package/coreui/components/edaManagerComponent/utils/utils.js +26 -15
  90. package/coreui/components/edaManagerComponent/utils/utils.js.map +1 -1
  91. package/d2configuration/edaManager/DB.EM_EDA_DescriptiveVector.xml +65 -0
  92. package/d2configuration/edaManager/DB.EM_EDA_FunctionPrescription.xml +65 -0
  93. package/d2configuration/edaManager/E.EM_DETAIL_IMPL.xml +67 -1
  94. package/d2configuration/edaManager/E.EM_DETAIL_SQL.xml +85 -0
  95. package/d2configuration/edaManager/E.EM_DETAIL_UNIT.xml +123 -2
  96. package/d2configuration/edaManager/E.EM_NAVIGATOR_IMPL.xml +1 -1
  97. package/d2configuration/edaManager/E.EM_NAVIGATOR_UNIT.xml +1 -1
  98. package/d2configuration/edaManager/E.EM_VECTOR_IMPL.xml +20 -6
  99. package/d2configuration/edaManager/E.EM_VECTOR_UNIT.xml +95 -17
  100. package/d2configuration/edaManager/SD.EM_EDA_DescriptiveVector.xml +179 -0
  101. package/d2configuration/edaManager/SD.EM_EDA_FunctionPrescription.xml +91 -0
  102. package/d2configuration/edaManager/SD.EM_EDA_InsertValuesToVector_V1.xml +227 -0
  103. package/d2configuration/edaManager/SD.EM_EDA_PairVector.xml +454 -0
  104. package/d2configuration/edaManager/SD.EM_EDA_ReadValuesFromVector_V1.xml +13 -3
  105. package/d2configuration/edaManager/SD.EM_EDA_VectorStats.xml +91 -0
  106. package/d2configuration/edaManager/SD.EM_Filter_Condition.xml +1 -1
  107. package/package.json +5 -3
  108. package/coreui/components/edaManagerComponent/components/edaBasePanel.d.ts +0 -16
  109. package/coreui/components/edaManagerComponent/components/edaBasePanel.js +0 -85
  110. package/coreui/components/edaManagerComponent/components/edaBasePanel.js.map +0 -1
  111. package/coreui/components/edaManagerComponent/context/sharedSampleRange.js +0 -13
  112. package/coreui/components/edaManagerComponent/context/sharedSampleRange.js.map +0 -1
  113. package/d2configuration/edaManager/EDA_CancelSession.xml +0 -54
  114. package/d2configuration/edaManager/EDA_GetSessionId.xml +0 -54
  115. package/d2configuration/edaManager/EDA_ReadValuesFromVektorRec.xml +0 -54
  116. package/d2configuration/edaManager/EDA_StatVectorRec.xml +0 -56
@@ -1,37 +1,50 @@
1
- import React from "react";
2
- import { EdaSamplingType, StepType } from "./constants/edaTypes";
3
- import i18n from "d2core/i18n/i18n";
4
- import { Tabs } from "antd";
5
- import { EdaDetailPanel } from "./components/edaDetailPanel";
1
+ import React, { useCallback, useEffect, useMemo, useState } from "react";
6
2
  import { createStyles } from "antd-style";
7
- import WithCss from "d2coreui/components/style/withCss";
8
- import { SharedSampleRangeContext } from "./context/sharedSampleRange";
3
+ import { EdaSamplingType, StepType } from "./constants/edaTypes";
4
+ import { SharedSampleRangeContext } from "./context/sharedSampleRangeContext";
9
5
  import dayjs from "d2core/dayjs";
6
+ import { loadDetail, loadPreference, savePreference, stepToDayJsType } from "./utils/utils";
10
7
  import { getRange } from "./components/edaTimeWindowPickerPanel";
11
- import { loadDetail, loadPreference, savePreference } from "./utils/utils";
12
- import { EdaVectorDataProvider } from "./context/edaVectorDataProvider";
8
+ import i18n from "d2core/i18n/i18n";
9
+ import { EdaDetailPanel } from "./components/edaDetailPanel";
13
10
  import { EdaTablePanel } from "./components/edaTablePanel";
11
+ import { EdaVectorDataProvider } from "./context/edaVectorDataProvider";
12
+ import { Button, ConfigProvider, Space, Tabs } from "antd";
14
13
  import { EdaGraphPanel } from "./components/edaGraphPanel";
14
+ import { ExportOutlined, FullscreenExitOutlined, FullscreenOutlined } from "@ant-design/icons";
15
+ import { createPortal } from "react-dom";
16
+ import { ModalDialog } from "d2coreui/components/modal/modalDialog";
17
+ import { useEdaActions } from "./context/useEdaActions";
15
18
  const useStyles = createStyles(({ css }) => {
16
19
  return {
17
20
  baseLayout: css `
18
21
  height: 100%;
19
22
  overflow: hidden;
20
-
23
+
21
24
  .ant-tabs-content {
22
25
  height: 100%;
23
26
  }
27
+ `,
28
+ fullscreenLayout: css `
29
+ .ant-design-draggable-modal-title {
30
+ display: none;
31
+ }
24
32
  `
25
33
  };
26
34
  });
27
- export class EdaDetail extends React.Component {
28
- constructor(props) {
29
- super(props);
35
+ export const EdaDetail = ({ api, item, className, style, size, variant }) => {
36
+ const { styles } = useStyles();
37
+ const { triggerExport, renderActionDialogs } = useEdaActions(api);
38
+ const [activeTabKey, setActiveTabKey] = useState("detail");
39
+ const [detailData, setDetailData] = useState();
40
+ const [isFullscreen, setIsFullscreen] = useState(false);
41
+ const [portalTarget, setPortalTarget] = useState(null);
42
+ const [sampleRange, setSampleRange] = useState(() => {
30
43
  const btTotal = dayjs(loadPreference("EDA_DETAIL_BT", dayjs().startOf('day').toISOString()));
31
44
  const etTotal = dayjs(loadPreference("EDA_DETAIL_ET", dayjs().endOf('day').toISOString()));
32
45
  const step = loadPreference("EDA_DETAIL_STEP", StepType.Daily);
33
46
  const { bt, et } = getRange(btTotal, etTotal, step);
34
- const context = {
47
+ return {
35
48
  btTotal,
36
49
  etTotal,
37
50
  btWindow: bt,
@@ -39,100 +52,105 @@ export class EdaDetail extends React.Component {
39
52
  sampling: EdaSamplingType.Default,
40
53
  step,
41
54
  vectorPage: 1,
42
- updateValues: (bt, et, step, vectorPage) => this.updateSampleRange(bt, et, step, vectorPage),
43
- updateTimeWindow: (bt, et, step) => this.updateTimeWindow(bt, et, step),
55
+ totalCount: 0,
44
56
  };
45
- this.state = {
46
- tabs: [],
47
- activeTabKey: "detail",
48
- context: context,
49
- };
50
- this.updateSampleRange = this.updateSampleRange.bind(this);
51
- this.updateTimeWindow = this.updateTimeWindow.bind(this);
52
- this.setContextState = this.setContextState.bind(this);
53
- }
54
- async componentDidMount() {
55
- const { api, item } = this.props;
56
- const { data, type } = this.state;
57
- if (item && !Array.isArray(item)) {
58
- const result = await loadDetail(api, item);
59
- this.setState({
60
- type: item.type,
61
- data: result,
62
- tabs: this.getTabs(result, item.type),
63
- });
64
- }
65
- else {
66
- this.setState({ tabs: this.getTabs(data, type) });
67
- }
68
- }
69
- async componentDidUpdate(prevProps, prevState) {
70
- const { data, type, activeTabKey, context } = this.state;
71
- const { api, item, size, variant, showTimeWindow, showChartLegend } = this.props;
72
- if (prevProps.item !== item) {
73
- if (item && !Array.isArray(item)) {
74
- const result = await loadDetail(api, item);
75
- this.setState({
76
- type: item.type,
77
- data: result,
78
- tabs: this.getTabs(result, item.type),
79
- });
57
+ });
58
+ const updateSampleRange = useCallback((bt, et, sampling, vectorPage) => {
59
+ setSampleRange((s) => {
60
+ let { btWindow, etWindow } = s;
61
+ const unit = stepToDayJsType(s.step);
62
+ if (unit) {
63
+ if (s.btWindow.isBefore(bt)) {
64
+ btWindow = bt;
65
+ etWindow = bt.endOf(unit);
66
+ }
67
+ if (s.etWindow.isAfter(et)) {
68
+ btWindow = et.startOf(unit);
69
+ etWindow = et;
70
+ }
80
71
  }
72
+ else {
73
+ btWindow = bt;
74
+ etWindow = et;
75
+ }
76
+ return { ...s, btTotal: bt, etTotal: et, btWindow, etWindow, sampling, vectorPage };
77
+ });
78
+ }, []);
79
+ const updateTimeWindow = useCallback((bt, et, step) => {
80
+ setSampleRange((s) => ({ ...s, btWindow: bt, etWindow: et, step }));
81
+ }, []);
82
+ const updateTotalCount = useCallback((totalCount) => {
83
+ setSampleRange((s) => ({ ...s, totalCount }));
84
+ }, []);
85
+ const contextValue = useMemo(() => ({
86
+ ...sampleRange,
87
+ updateValues: updateSampleRange,
88
+ updateTimeWindow,
89
+ updateTotalCount,
90
+ }), [sampleRange, updateSampleRange, updateTimeWindow, updateTotalCount]);
91
+ const handleToggleFullscreen = useCallback(() => {
92
+ setIsFullscreen(!isFullscreen);
93
+ if (isFullscreen) {
94
+ setPortalTarget(null);
81
95
  }
82
- else if (prevProps.size !== size ||
83
- prevProps.variant !== variant ||
84
- prevState.activeTabKey !== activeTabKey ||
85
- prevProps.showTimeWindow !== showTimeWindow ||
86
- prevProps.showChartLegend !== showChartLegend) {
87
- this.setState({ tabs: this.getTabs(data, type) });
88
- }
89
- if (!prevState.context.btTotal.isSame(context.btTotal)) {
90
- savePreference("EDA_DETAIL_BT", context.btTotal);
91
- }
92
- if (!prevState.context.etTotal.isSame(context.etTotal)) {
93
- savePreference("EDA_DETAIL_ET", context.etTotal);
94
- }
95
- if (prevState.context.step !== context.step) {
96
- savePreference("EDA_DETAIL_STEP", context.step);
96
+ }, [isFullscreen]);
97
+ const tabItems = useMemo(() => [
98
+ {
99
+ key: "detail",
100
+ label: i18n("Detail"),
101
+ children: (React.createElement(EdaDetailPanel, { api: api, data: detailData })),
102
+ },
103
+ {
104
+ key: "table",
105
+ label: i18n("Table"),
106
+ children: (React.createElement(EdaTablePanel, { api: api, data: detailData, isActive: activeTabKey === "table" })),
107
+ },
108
+ {
109
+ key: "graph",
110
+ label: i18n("Graph"),
111
+ children: (React.createElement(EdaGraphPanel, { api: api, data: detailData, isActive: activeTabKey === "graph" })),
112
+ },
113
+ ], [api, detailData, activeTabKey]);
114
+ const renderTabs = (React.createElement("div", { style: { position: 'relative', height: '100%', width: '100%', display: 'flex', flexDirection: 'column' } },
115
+ React.createElement(Tabs, { type: "card", className: styles.baseLayout, onChange: setActiveTabKey, activeKey: activeTabKey, destroyOnHidden: false, items: tabItems, tabBarExtraContent: {
116
+ right: (React.createElement(Space.Compact, null,
117
+ detailData !== undefined && (React.createElement(Button, { icon: React.createElement(ExportOutlined, null), onClick: () => triggerExport(detailData), title: i18n("Export") })),
118
+ React.createElement(Button, { disabled: item === undefined, icon: isFullscreen ? React.createElement(FullscreenExitOutlined, null) : React.createElement(FullscreenOutlined, null), onClick: handleToggleFullscreen, title: i18n(isFullscreen ? "Restore" : "Fullscreen") }))),
119
+ } })));
120
+ useEffect(() => {
121
+ let isMounted = true;
122
+ if (item && !Array.isArray(item)) {
123
+ loadDetail(api, item).then((result) => {
124
+ if (isMounted && result) {
125
+ setDetailData(result);
126
+ }
127
+ });
97
128
  }
98
- }
99
- render() {
100
- const { api, className, style, size, showTimeWindow } = this.props;
101
- const { context, activeTabKey } = this.state;
102
- return (React.createElement("div", { className: className, style: style },
103
- React.createElement(WithCss, { useStyles: useStyles }, (css) => React.createElement(SharedSampleRangeContext.Provider, { value: context },
104
- React.createElement(EdaVectorDataProvider, { api: api, showTimeWindow: showTimeWindow },
105
- React.createElement(Tabs, { size: size, type: "card", className: css.styles.baseLayout, onChange: (key) => this.setState({ activeTabKey: key }), activeKey: activeTabKey, items: this.state.tabs }))))));
106
- }
107
- updateSampleRange(bt, et, step, vectorPage) {
108
- this.setContextState({ btTotal: bt, etTotal: et, sampling: step, vectorPage: vectorPage });
109
- }
110
- updateTimeWindow(bt, et, step) {
111
- this.setContextState({ btWindow: bt, etWindow: et, step: step });
112
- }
113
- getTabs(data, type) {
114
- const { size, variant, api, showTimeWindow, showChartLegend } = this.props;
115
- const { activeTabKey } = this.state;
116
- return [
117
- {
118
- key: "detail",
119
- label: i18n("Detail"),
120
- children: (React.createElement(EdaDetailPanel, { api: api, data: data, type: type, size: size, variant: variant })),
121
- },
122
- {
123
- key: "table",
124
- label: i18n("Table"),
125
- children: (React.createElement(EdaTablePanel, { api: api, data: data, type: type, size: size, isActive: activeTabKey === "table", showTimeWindow: showTimeWindow })),
126
- },
127
- {
128
- key: "graph",
129
- label: i18n("Graph"),
130
- children: (React.createElement(EdaGraphPanel, { api: api, data: data, type: type, size: size, isActive: activeTabKey === "graph", showTimeWindow: showTimeWindow, showChartLegend: showChartLegend })),
131
- },
132
- ];
133
- }
134
- setContextState(partialContext) {
135
- this.setState({ context: { ...this.state.context, ...partialContext } });
136
- }
137
- }
129
+ return () => {
130
+ isMounted = false;
131
+ };
132
+ }, [api, item]);
133
+ useEffect(() => {
134
+ savePreference("EDA_DETAIL_BT", sampleRange.btTotal.toISOString());
135
+ savePreference("EDA_DETAIL_ET", sampleRange.etTotal.toISOString());
136
+ savePreference("EDA_DETAIL_STEP", sampleRange.step);
137
+ }, [sampleRange.btTotal, sampleRange.etTotal, sampleRange.step]);
138
+ return (React.createElement(ConfigProvider, { componentSize: size, variant: variant },
139
+ React.createElement("div", { className: className, style: style },
140
+ React.createElement(SharedSampleRangeContext.Provider, { value: contextValue },
141
+ React.createElement(EdaVectorDataProvider, { api: api },
142
+ isFullscreen && portalTarget ? createPortal(renderTabs, portalTarget) : renderTabs,
143
+ React.createElement(ModalDialog, { classNames: { header: styles.fullscreenLayout }, open: isFullscreen, onCancel: handleToggleFullscreen, footer: null, closable: false, initialWidth: window.innerWidth * 0.9, initialHeight: window.innerHeight * 0.9, destroyOnHidden: false, mode: "NO_BUTTONS", styles: {
144
+ header: {
145
+ padding: 0,
146
+ margin: 0
147
+ },
148
+ } },
149
+ React.createElement("div", { style: { width: '100%', height: '100%' }, ref: (el) => {
150
+ if (el && !portalTarget) {
151
+ setPortalTarget(el);
152
+ }
153
+ } })),
154
+ renderActionDialogs())))));
155
+ };
138
156
  //# sourceMappingURL=edaDetail.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"edaDetail.js","sourceRoot":"","sources":["../../../../../coreui/components/edaManagerComponent/edaDetail.tsx"],"names":[],"mappings":"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","sourcesContent":["import EdaManagerApi from \"../../../api/eda/edaManagerApi\";\r\nimport React from \"react\";\r\nimport {SD_EM_Tree_Item} from \"../../../api/eda/generated/structures\";\r\nimport {EdaSamplingType, GroupData, IdType, ScenarioData, StepType, TypedIndex, VectorData} from \"./constants/edaTypes\";\r\nimport i18n from \"d2core/i18n/i18n\";\r\nimport {Tabs} from \"antd\";\r\nimport {Tab} from \"rc-tabs/lib/interface\"\r\nimport {EdaDetailPanel} from \"./components/edaDetailPanel\";\r\nimport {createStyles} from \"antd-style\";\r\nimport WithCss from \"d2coreui/components/style/withCss\";\r\nimport {SizeType} from \"antd/lib/config-provider/SizeContext\";\r\nimport {SharedSampleRange, SharedSampleRangeContext} from \"./context/sharedSampleRange\";\r\nimport dayjs from \"d2core/dayjs\";\r\nimport {getRange} from \"./components/edaTimeWindowPickerPanel\";\r\nimport {loadDetail, loadPreference, savePreference} from \"./utils/utils\";\r\nimport {StorageTypes} from \"./constants/storageTypes\";\r\nimport {Variant} from \"antd/es/config-provider\";\r\nimport {EdaVectorDataProvider} from \"./context/edaVectorDataProvider\";\r\nimport {EdaTablePanel} from \"./components/edaTablePanel\";\r\nimport {EdaGraphPanel} from \"./components/edaGraphPanel\";\r\n\r\nconst useStyles = createStyles(({css},) => {\r\n return {\r\n baseLayout: css`\r\n height: 100%;\r\n overflow: hidden;\r\n \r\n .ant-tabs-content {\r\n height: 100%;\r\n }\r\n `\r\n }\r\n});\r\n\r\nexport type ItemType = SD_EM_Tree_Item[] | TypedIndex\r\n\r\ninterface Props {\r\n api: EdaManagerApi\r\n item?: ItemType\r\n className?: string\r\n style?: React.CSSProperties\r\n\r\n size?: SizeType\r\n variant?: Variant\r\n\r\n showTimeWindow?: boolean\r\n showChartLegend?: boolean\r\n}\r\n\r\ninterface State {\r\n type?: IdType\r\n data?: VectorData | GroupData | ScenarioData\r\n tabs: Tab[]\r\n activeTabKey: string\r\n context: SharedSampleRange\r\n}\r\n\r\nexport class EdaDetail extends React.Component<Props, State> {\r\n constructor(props: Readonly<Props>) {\r\n super(props);\r\n const btTotal = dayjs(loadPreference(StorageTypes.EDA_DETAIL_BT, dayjs().startOf('day').toISOString()));\r\n const etTotal = dayjs(loadPreference(StorageTypes.EDA_DETAIL_ET, dayjs().endOf('day').toISOString()));\r\n const step = loadPreference(StorageTypes.EDA_DETAIL_STEP, StepType.Daily);\r\n const {bt, et} = getRange(btTotal, etTotal, step);\r\n const context: SharedSampleRange = {\r\n btTotal,\r\n etTotal,\r\n btWindow: bt,\r\n etWindow: et,\r\n sampling: EdaSamplingType.Default,\r\n step,\r\n vectorPage: 1,\r\n updateValues: (bt, et, step, vectorPage) => this.updateSampleRange(bt, et, step, vectorPage),\r\n updateTimeWindow: (bt, et, step) => this.updateTimeWindow(bt, et, step),\r\n }\r\n\r\n this.state = {\r\n tabs: [],\r\n activeTabKey: \"detail\",\r\n context: context,\r\n }\r\n\r\n this.updateSampleRange = this.updateSampleRange.bind(this);\r\n this.updateTimeWindow = this.updateTimeWindow.bind(this);\r\n this.setContextState = this.setContextState.bind(this);\r\n }\r\n\r\n async componentDidMount() {\r\n const {api, item} = this.props;\r\n const {data, type} = this.state;\r\n\r\n if (item && !Array.isArray(item)) {\r\n const result = await loadDetail(api, item);\r\n\r\n this.setState({\r\n type: item.type,\r\n data: result,\r\n tabs: this.getTabs(result, item.type),\r\n });\r\n } else {\r\n this.setState({tabs: this.getTabs(data, type)});\r\n }\r\n }\r\n\r\n async componentDidUpdate(prevProps: Readonly<Props>, prevState: Readonly<State>) {\r\n const {data, type, activeTabKey, context} = this.state;\r\n const {api, item, size, variant, showTimeWindow, showChartLegend} = this.props;\r\n\r\n if (prevProps.item !== item) {\r\n if (item && !Array.isArray(item)) {\r\n const result = await loadDetail(api, item);\r\n\r\n this.setState({\r\n type: item.type,\r\n data: result,\r\n tabs: this.getTabs(result, item.type),\r\n });\r\n }\r\n } else if (\r\n prevProps.size !== size ||\r\n prevProps.variant !== variant ||\r\n prevState.activeTabKey !== activeTabKey ||\r\n prevProps.showTimeWindow !== showTimeWindow ||\r\n prevProps.showChartLegend !== showChartLegend\r\n ) {\r\n this.setState({tabs: this.getTabs(data, type)});\r\n }\r\n\r\n if (!prevState.context.btTotal.isSame(context.btTotal)) {\r\n savePreference(StorageTypes.EDA_DETAIL_BT, context.btTotal);\r\n }\r\n if (!prevState.context.etTotal.isSame(context.etTotal)) {\r\n savePreference(StorageTypes.EDA_DETAIL_ET, context.etTotal);\r\n }\r\n if (prevState.context.step !== context.step) {\r\n savePreference(StorageTypes.EDA_DETAIL_STEP, context.step);\r\n }\r\n }\r\n\r\n render() {\r\n const {api, className, style, size, showTimeWindow} = this.props;\r\n const {context, activeTabKey} = this.state;\r\n\r\n return (\r\n <div className={className} style={style}>\r\n <WithCss useStyles={useStyles}>\r\n {(css) =>\r\n <SharedSampleRangeContext.Provider value={context}>\r\n <EdaVectorDataProvider\r\n api={api}\r\n showTimeWindow={showTimeWindow}\r\n >\r\n <Tabs\r\n size={size}\r\n type={\"card\"}\r\n className={css.styles.baseLayout}\r\n onChange={(key) => this.setState({activeTabKey: key})}\r\n activeKey={activeTabKey}\r\n items={this.state.tabs}/>\r\n </EdaVectorDataProvider>\r\n </SharedSampleRangeContext.Provider>\r\n }\r\n </WithCss>\r\n </div>\r\n )\r\n }\r\n\r\n private updateSampleRange(bt: dayjs.Dayjs, et: dayjs.Dayjs, step: EdaSamplingType, vectorPage: number) {\r\n this.setContextState({btTotal: bt, etTotal: et, sampling: step, vectorPage: vectorPage});\r\n }\r\n\r\n private updateTimeWindow(bt: dayjs.Dayjs, et: dayjs.Dayjs, step: StepType) {\r\n this.setContextState({btWindow: bt, etWindow: et, step: step});\r\n }\r\n\r\n private getTabs(data?: VectorData | GroupData | ScenarioData, type?: IdType): Tab[] {\r\n const {size, variant, api, showTimeWindow, showChartLegend} = this.props;\r\n const {activeTabKey} = this.state;\r\n\r\n return [\r\n {\r\n key: \"detail\",\r\n label: i18n(\"Detail\"),\r\n children: (\r\n <EdaDetailPanel\r\n api={api}\r\n data={data}\r\n type={type}\r\n size={size}\r\n variant={variant}\r\n />\r\n ),\r\n },\r\n {\r\n key: \"table\",\r\n label: i18n(\"Table\"),\r\n children: (\r\n <EdaTablePanel\r\n api={api}\r\n data={data}\r\n type={type}\r\n size={size}\r\n isActive={activeTabKey === \"table\"}\r\n showTimeWindow={showTimeWindow}\r\n />\r\n ),\r\n },\r\n {\r\n key: \"graph\",\r\n label: i18n(\"Graph\"),\r\n children: (\r\n <EdaGraphPanel\r\n api={api}\r\n data={data}\r\n type={type}\r\n size={size}\r\n isActive={activeTabKey === \"graph\"}\r\n showTimeWindow={showTimeWindow}\r\n showChartLegend={showChartLegend}\r\n />\r\n ),\r\n },\r\n ]\r\n }\r\n\r\n private setContextState(partialContext: Partial<SharedSampleRange>) {\r\n this.setState({context: {...this.state.context, ...partialContext}});\r\n }\r\n}"]}
1
+ {"version":3,"file":"edaDetail.js","sourceRoot":"","sources":["../../../../../coreui/components/edaManagerComponent/edaDetail.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, {FC, useCallback, useEffect, useMemo, useState} from \"react\";\r\nimport {createStyles} from \"antd-style\";\r\nimport {EdaSamplingType, StepType, TypedData, TypedIndex} from \"./constants/edaTypes\";\r\nimport EdaManagerApi, {TreeItem} from \"../../../api/eda/edaManagerApi\";\r\nimport {SizeType} from \"antd/lib/config-provider/SizeContext\";\r\nimport {Variant} from \"antd/es/config-provider\";\r\nimport {SharedSampleRangeContext, SharedSampleRangeState} from \"./context/sharedSampleRangeContext\";\r\nimport dayjs from \"d2core/dayjs\";\r\nimport {loadDetail, loadPreference, savePreference, stepToDayJsType} from \"./utils/utils\";\r\nimport {StorageTypes} from \"./constants/storageTypes\";\r\nimport {getRange} from \"./components/edaTimeWindowPickerPanel\";\r\nimport i18n from \"d2core/i18n/i18n\";\r\nimport {EdaDetailPanel} from \"./components/edaDetailPanel\";\r\nimport {EdaTablePanel} from \"./components/edaTablePanel\";\r\nimport {EdaVectorDataProvider} from \"./context/edaVectorDataProvider\";\r\nimport {Button, ConfigProvider, Space, Tabs} from \"antd\";\r\nimport {EdaConfiguration} from \"./context/edaConfigContext\";\r\nimport {EdaGraphPanel} from \"./components/edaGraphPanel\";\r\nimport {ExportOutlined, FullscreenExitOutlined, FullscreenOutlined} from \"@ant-design/icons\";\r\nimport {createPortal} from \"react-dom\";\r\nimport {ModalDialog, ModalDialogMode} from \"d2coreui/components/modal/modalDialog\";\r\nimport {useEdaActions} from \"./context/useEdaActions\";\r\n\r\nconst useStyles = createStyles(({css},) => {\r\n return {\r\n baseLayout: css`\r\n height: 100%;\r\n overflow: hidden;\r\n\r\n .ant-tabs-content {\r\n height: 100%;\r\n }\r\n `,\r\n fullscreenLayout: css`\r\n .ant-design-draggable-modal-title {\r\n display: none;\r\n }\r\n `\r\n }\r\n});\r\n\r\nexport type ItemType = TreeItem[] | TypedIndex\r\n\r\ninterface Props {\r\n api: EdaManagerApi\r\n item?: ItemType\r\n className?: string\r\n style?: React.CSSProperties\r\n\r\n size?: SizeType\r\n variant?: Variant\r\n\r\n // Eda detail configuration\r\n configuration?: EdaConfiguration\r\n}\r\n\r\nexport const EdaDetail: FC<Props> = ({api, item, className, style, size, variant}) => {\r\n const {styles} = useStyles();\r\n const {triggerExport, renderActionDialogs} = useEdaActions(api);\r\n\r\n const [activeTabKey, setActiveTabKey] = useState<string>(\"detail\");\r\n const [detailData, setDetailData] = useState<TypedData>();\r\n\r\n const [isFullscreen, setIsFullscreen] = useState<boolean>(false);\r\n const [portalTarget, setPortalTarget] = useState<HTMLDivElement | null>(null);\r\n\r\n const [sampleRange, setSampleRange] = useState<SharedSampleRangeState>(() => {\r\n const btTotal = dayjs(loadPreference(StorageTypes.EDA_DETAIL_BT, dayjs().startOf('day').toISOString()));\r\n const etTotal = dayjs(loadPreference(StorageTypes.EDA_DETAIL_ET, dayjs().endOf('day').toISOString()));\r\n const step = loadPreference(StorageTypes.EDA_DETAIL_STEP, StepType.Daily);\r\n const {bt, et} = getRange(btTotal, etTotal, step);\r\n\r\n return {\r\n btTotal,\r\n etTotal,\r\n btWindow: bt,\r\n etWindow: et,\r\n sampling: EdaSamplingType.Default,\r\n step,\r\n vectorPage: 1,\r\n totalCount: 0,\r\n }\r\n });\r\n\r\n const updateSampleRange = useCallback((bt: dayjs.Dayjs, et: dayjs.Dayjs, sampling: EdaSamplingType, vectorPage: number) => {\r\n setSampleRange((s) => {\r\n let {btWindow, etWindow} = s;\r\n const unit = stepToDayJsType(s.step);\r\n\r\n if (unit) {\r\n if (s.btWindow.isBefore(bt)) {\r\n btWindow = bt;\r\n etWindow = bt.endOf(unit);\r\n }\r\n\r\n if (s.etWindow.isAfter(et)) {\r\n btWindow = et.startOf(unit);\r\n etWindow = et;\r\n }\r\n } else {\r\n btWindow = bt;\r\n etWindow = et;\r\n }\r\n\r\n return {...s, btTotal: bt, etTotal: et, btWindow, etWindow, sampling, vectorPage}\r\n });\r\n }, []);\r\n const updateTimeWindow = useCallback((bt: dayjs.Dayjs, et: dayjs.Dayjs, step: StepType) => {\r\n setSampleRange((s) => ({...s, btWindow: bt, etWindow: et, step}));\r\n }, []);\r\n const updateTotalCount = useCallback((totalCount: number) => {\r\n setSampleRange((s) => ({...s, totalCount}));\r\n }, []);\r\n const contextValue: SharedSampleRangeContext = useMemo(() => ({\r\n ...sampleRange,\r\n updateValues: updateSampleRange,\r\n updateTimeWindow,\r\n updateTotalCount,\r\n }), [sampleRange, updateSampleRange, updateTimeWindow, updateTotalCount]);\r\n\r\n const handleToggleFullscreen = useCallback(() => {\r\n setIsFullscreen(!isFullscreen);\r\n\r\n if (isFullscreen) {\r\n setPortalTarget(null);\r\n }\r\n }, [isFullscreen]);\r\n\r\n const tabItems = useMemo(() => [\r\n {\r\n key: \"detail\",\r\n label: i18n(\"Detail\"),\r\n children: (\r\n <EdaDetailPanel\r\n api={api}\r\n data={detailData}\r\n />\r\n ),\r\n },\r\n {\r\n key: \"table\",\r\n label: i18n(\"Table\"),\r\n children: (\r\n <EdaTablePanel\r\n api={api}\r\n data={detailData}\r\n isActive={activeTabKey === \"table\"}\r\n />\r\n ),\r\n },\r\n {\r\n key: \"graph\",\r\n label: i18n(\"Graph\"),\r\n children: (\r\n <EdaGraphPanel\r\n api={api}\r\n data={detailData}\r\n isActive={activeTabKey === \"graph\"}\r\n />\r\n ),\r\n },\r\n ], [api, detailData, activeTabKey]);\r\n\r\n const renderTabs = (\r\n <div style={{position: 'relative', height: '100%', width: '100%', display: 'flex', flexDirection: 'column'}}>\r\n <Tabs\r\n type={\"card\"}\r\n className={styles.baseLayout}\r\n onChange={setActiveTabKey}\r\n activeKey={activeTabKey}\r\n destroyOnHidden={false}\r\n items={tabItems}\r\n tabBarExtraContent={{\r\n right: (\r\n <Space.Compact>\r\n {detailData !== undefined && (\r\n <Button\r\n icon={<ExportOutlined />}\r\n onClick={() => triggerExport(detailData)}\r\n title={i18n(\"Export\")}\r\n />\r\n )}\r\n <Button\r\n disabled={item === undefined}\r\n icon={isFullscreen ? <FullscreenExitOutlined/> : <FullscreenOutlined/>}\r\n onClick={handleToggleFullscreen}\r\n title={i18n(isFullscreen ? \"Restore\" : \"Fullscreen\")}\r\n />\r\n </Space.Compact>\r\n ),\r\n }}\r\n />\r\n </div>\r\n );\r\n\r\n useEffect(() => {\r\n let isMounted = true;\r\n\r\n if (item && !Array.isArray(item)) {\r\n loadDetail(api, item).then((result) => {\r\n if (isMounted && result) {\r\n setDetailData(result);\r\n }\r\n });\r\n }\r\n\r\n return () => {\r\n isMounted = false;\r\n }\r\n }, [api, item]);\r\n\r\n useEffect(() => {\r\n savePreference(StorageTypes.EDA_DETAIL_BT, sampleRange.btTotal.toISOString());\r\n savePreference(StorageTypes.EDA_DETAIL_ET, sampleRange.etTotal.toISOString());\r\n savePreference(StorageTypes.EDA_DETAIL_STEP, sampleRange.step);\r\n }, [sampleRange.btTotal, sampleRange.etTotal, sampleRange.step]);\r\n\r\n return (\r\n <ConfigProvider componentSize={size} variant={variant}>\r\n <div className={className} style={style}>\r\n <SharedSampleRangeContext.Provider value={contextValue}>\r\n <EdaVectorDataProvider api={api}>\r\n {isFullscreen && portalTarget ? createPortal(renderTabs, portalTarget) : renderTabs}\r\n <ModalDialog\r\n classNames={{header: styles.fullscreenLayout}}\r\n open={isFullscreen}\r\n onCancel={handleToggleFullscreen}\r\n footer={null}\r\n closable={false}\r\n initialWidth={window.innerWidth * 0.9}\r\n initialHeight={window.innerHeight * 0.9}\r\n destroyOnHidden={false}\r\n mode={ModalDialogMode.NO_BUTTONS}\r\n styles={{\r\n header: {\r\n padding: 0,\r\n margin: 0\r\n },\r\n }}\r\n >\r\n <div\r\n style={{width: '100%', height: '100%'}}\r\n ref={(el) => {\r\n if (el && !portalTarget) {\r\n setPortalTarget(el);\r\n }\r\n }}\r\n />\r\n </ModalDialog>\r\n {renderActionDialogs()}\r\n </EdaVectorDataProvider>\r\n </SharedSampleRangeContext.Provider>\r\n </div>\r\n </ConfigProvider>\r\n );\r\n}"]}
@@ -1,20 +1,13 @@
1
- import React from "react";
2
- import { ItemType } from "./edaDetail";
1
+ import { FC } from "react";
3
2
  import EdaManagerApi from "../../../api/eda/edaManagerApi";
4
3
  import { SizeType } from "antd/lib/config-provider/SizeContext";
5
4
  import { Variant } from "antd/es/config-provider";
5
+ import { EdaConfiguration } from "./context/edaConfigContext";
6
6
  interface Props {
7
7
  api: EdaManagerApi;
8
8
  size?: SizeType;
9
9
  variant?: Variant;
10
- showTimeWindow?: boolean;
11
- showChartLegend?: boolean;
12
- }
13
- interface State {
14
- selectedItem?: ItemType;
15
- }
16
- export declare class EdaManager extends React.Component<Props, State> {
17
- constructor(props: Readonly<Props>);
18
- render(): React.JSX.Element;
10
+ configuration?: EdaConfiguration;
19
11
  }
12
+ export declare const EdaManager: FC<Props>;
20
13
  export {};
@@ -1,33 +1,40 @@
1
- import React from "react";
2
- import { Splitter } from "antd";
1
+ import React, { useCallback, useState } from "react";
2
+ import { ConfigProvider, Splitter } from "antd";
3
3
  import { EdaNavigator } from "./edaNavigator";
4
- import { EdaDetail } from "./edaDetail";
5
- import WithCss from "d2coreui/components/style/withCss";
6
4
  import { createStyles } from "antd-style";
5
+ import { EdaDetail } from "./edaDetail";
6
+ import { EdaConfigProvider } from "./context/edaConfigContext";
7
7
  const useStyles = createStyles(({ css, token }) => {
8
8
  return {
9
9
  baseLayout: css `
10
10
  width: 100%;
11
11
  height: 100%;
12
12
  padding: ${token.paddingXXS}px;
13
- `
13
+ `,
14
+ navPanel: css `
15
+ height: 100%;
16
+ padding-inline-end: ${token?.paddingXXS}px;
17
+ `,
18
+ detailPanel: css `
19
+ height: 100%;
20
+ padding-inline-start: ${token?.paddingXXS}px;
21
+ `,
14
22
  };
15
23
  });
16
- export class EdaManager extends React.Component {
17
- constructor(props) {
18
- super(props);
19
- this.state = {};
20
- }
21
- render() {
22
- const { selectedItem } = this.state;
23
- const { size, variant, showTimeWindow } = this.props;
24
- return (React.createElement(WithCss, { useStyles: useStyles }, (css) => React.createElement(Splitter, { className: css.styles.baseLayout },
25
- React.createElement(Splitter.Panel, { defaultSize: "25%" },
26
- React.createElement(EdaNavigator, { api: this.props.api, size: size, style: { paddingRight: css.theme.paddingXXS }, onDoubleClick: (item) => {
27
- this.setState({ selectedItem: item });
28
- } })),
29
- React.createElement(Splitter.Panel, null,
30
- React.createElement(EdaDetail, { api: this.props.api, item: selectedItem, size: size, variant: variant, showTimeWindow: showTimeWindow, showChartLegend: showTimeWindow, style: { width: '100%', height: '100%', paddingLeft: css.theme.paddingXXS } })))));
31
- }
32
- }
24
+ export const EdaManager = ({ api, size, variant, configuration }) => {
25
+ const { styles } = useStyles();
26
+ const [selectedItem, setSelectedItem] = useState();
27
+ const handleDoubleClick = useCallback((item) => {
28
+ setSelectedItem(item);
29
+ }, []);
30
+ return (React.createElement(EdaConfigProvider, { config: configuration },
31
+ React.createElement(ConfigProvider, { componentSize: size, variant: variant },
32
+ React.createElement(Splitter, { className: styles.baseLayout },
33
+ React.createElement(Splitter.Panel, { defaultSize: "25%" },
34
+ React.createElement("div", { className: styles.navPanel },
35
+ React.createElement(EdaNavigator, { api: api, onDoubleClick: handleDoubleClick }))),
36
+ React.createElement(Splitter.Panel, null,
37
+ React.createElement("div", { className: styles.detailPanel },
38
+ React.createElement(EdaDetail, { api: api, item: selectedItem, style: { width: '100%', height: '100%' } })))))));
39
+ };
33
40
  //# sourceMappingURL=edaManager.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"edaManager.js","sourceRoot":"","sources":["../../../../../coreui/components/edaManagerComponent/edaManager.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAC,QAAQ,EAAC,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAC,SAAS,EAAW,MAAM,aAAa,CAAC;AAGhD,OAAO,OAAO,MAAM,mCAAmC,CAAC;AACxD,OAAO,EAAC,YAAY,EAAC,MAAM,YAAY,CAAC;AAGxC,MAAM,SAAS,GAAG,YAAY,CAAC,CAAC,EAAC,GAAG,EAAE,KAAK,EAAC,EAAG,EAAE;IAC7C,OAAO;QACH,UAAU,EAAE,GAAG,CAAA;;;uBAGA,KAAK,CAAC,UAAU;SAC9B;KACJ,CAAA;AACL,CAAC,CAAC,CAAC;AAkBH,MAAM,OAAO,UAAW,SAAQ,KAAK,CAAC,SAAuB;IACzD,YAAY,KAAsB;QAC9B,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,IAAI,CAAC,KAAK,GAAG,EAAE,CAAA;IACnB,CAAC;IAED,MAAM;QACF,MAAM,EAAC,YAAY,EAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QAClC,MAAM,EAAC,IAAI,EAAE,OAAO,EAAE,cAAc,EAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QAEnD,OAAO,CACH,oBAAC,OAAO,IAAC,SAAS,EAAE,SAAS,IACxB,CAAC,GAAG,EAAE,EAAE,CACL,oBAAC,QAAQ,IAAC,SAAS,EAAE,GAAG,CAAC,MAAM,CAAC,UAAU;YACtC,oBAAC,QAAQ,CAAC,KAAK,IAAC,WAAW,EAAE,KAAK;gBAC9B,oBAAC,YAAY,IAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,EACnB,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,EAAC,YAAY,EAAE,GAAG,CAAC,KAAK,CAAC,UAAU,EAAC,EAC3C,aAAa,EAAE,CAAC,IAAI,EAAE,EAAE;wBACpB,IAAI,CAAC,QAAQ,CAAC,EAAC,YAAY,EAAE,IAAI,EAAC,CAAC,CAAC;oBACxC,CAAC,GACb,CACW;YACjB,oBAAC,QAAQ,CAAC,KAAK;gBACX,oBAAC,SAAS,IAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,EACnB,IAAI,EAAE,YAAY,EAClB,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,cAAc,EAAE,cAAc,EAC9B,eAAe,EAAE,cAAc,EAC/B,KAAK,EAAE,EAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,CAAC,KAAK,CAAC,UAAU,EAAC,GAClF,CACW,CACV,CAET,CACb,CAAC;IACN,CAAC;CACJ","sourcesContent":["import React from \"react\";\r\nimport {Splitter} from \"antd\";\r\nimport {EdaNavigator} from \"./edaNavigator\";\r\nimport {EdaDetail, ItemType} from \"./edaDetail\";\r\nimport EdaManagerApi from \"../../../api/eda/edaManagerApi\";\r\nimport {SizeType} from \"antd/lib/config-provider/SizeContext\";\r\nimport WithCss from \"d2coreui/components/style/withCss\";\r\nimport {createStyles} from \"antd-style\";\r\nimport {Variant} from \"antd/es/config-provider\";\r\n\r\nconst useStyles = createStyles(({css, token},) => {\r\n return {\r\n baseLayout: css`\r\n width: 100%;\r\n height: 100%;\r\n padding: ${token.paddingXXS}px;\r\n `\r\n }\r\n});\r\n\r\ninterface Props {\r\n api: EdaManagerApi\r\n\r\n // Size of AntD components\r\n size?: SizeType\r\n variant?: Variant\r\n // Displaying of time window selector in Table and Graph panel\r\n showTimeWindow?: boolean\r\n // Default displayed chart legend\r\n showChartLegend?: boolean\r\n}\r\n\r\ninterface State {\r\n selectedItem?: ItemType\r\n}\r\n\r\nexport class EdaManager extends React.Component<Props, State> {\r\n constructor(props: Readonly<Props>) {\r\n super(props);\r\n this.state = {}\r\n }\r\n\r\n render() {\r\n const {selectedItem} = this.state;\r\n const {size, variant, showTimeWindow} = this.props;\r\n\r\n return (\r\n <WithCss useStyles={useStyles}>\r\n {(css) =>\r\n <Splitter className={css.styles.baseLayout}>\r\n <Splitter.Panel defaultSize={\"25%\"}>\r\n <EdaNavigator api={this.props.api}\r\n size={size}\r\n style={{paddingRight: css.theme.paddingXXS}}\r\n onDoubleClick={(item) => {\r\n this.setState({selectedItem: item});\r\n }}\r\n />\r\n </Splitter.Panel>\r\n <Splitter.Panel>\r\n <EdaDetail api={this.props.api}\r\n item={selectedItem}\r\n size={size}\r\n variant={variant}\r\n showTimeWindow={showTimeWindow}\r\n showChartLegend={showTimeWindow}\r\n style={{width: '100%', height: '100%', paddingLeft: css.theme.paddingXXS}}\r\n />\r\n </Splitter.Panel>\r\n </Splitter>\r\n }\r\n </WithCss>\r\n );\r\n }\r\n}"]}
1
+ {"version":3,"file":"edaManager.js","sourceRoot":"","sources":["../../../../../coreui/components/edaManagerComponent/edaManager.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAK,WAAW,EAAE,QAAQ,EAAC,MAAM,OAAO,CAAC;AACvD,OAAO,EAAC,cAAc,EAAE,QAAQ,EAAC,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAG5C,OAAO,EAAC,YAAY,EAAC,MAAM,YAAY,CAAC;AAGxC,OAAO,EAAC,SAAS,EAAC,MAAM,aAAa,CAAC;AACtC,OAAO,EAAC,iBAAiB,EAAmB,MAAM,4BAA4B,CAAC;AAE/E,MAAM,SAAS,GAAG,YAAY,CAAC,CAAC,EAAC,GAAG,EAAE,KAAK,EAAC,EAAG,EAAE;IAC7C,OAAO;QACH,UAAU,EAAE,GAAG,CAAA;;;uBAGA,KAAK,CAAC,UAAU;SAC9B;QACD,QAAQ,EAAE,GAAG,CAAA;;kCAEa,KAAK,EAAE,UAAU;SAC1C;QACD,WAAW,EAAE,GAAG,CAAA;;oCAEY,KAAK,EAAE,UAAU;SAC5C;KACJ,CAAA;AACL,CAAC,CAAC,CAAC;AAYH,MAAM,CAAC,MAAM,UAAU,GAAc,CAAC,EAAC,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,aAAa,EAAC,EAAE,EAAE;IACzE,MAAM,EAAC,MAAM,EAAC,GAAG,SAAS,EAAE,CAAC;IAE7B,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,EAAc,CAAC;IAE/D,MAAM,iBAAiB,GAAG,WAAW,CAAC,CAAC,IAAgB,EAAE,EAAE;QACvD,eAAe,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACH,oBAAC,iBAAiB,IAAC,MAAM,EAAE,aAAa;QACpC,oBAAC,cAAc,IAAC,aAAa,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO;YACjD,oBAAC,QAAQ,IAAC,SAAS,EAAE,MAAM,CAAC,UAAU;gBAClC,oBAAC,QAAQ,CAAC,KAAK,IAAC,WAAW,EAAE,KAAK;oBAC9B,6BAAK,SAAS,EAAE,MAAM,CAAC,QAAQ;wBAC3B,oBAAC,YAAY,IACT,GAAG,EAAE,GAAG,EACR,aAAa,EAAE,iBAAiB,GAClC,CACA,CACO;gBACjB,oBAAC,QAAQ,CAAC,KAAK;oBACX,6BAAK,SAAS,EAAE,MAAM,CAAC,WAAW;wBAC9B,oBAAC,SAAS,IACN,GAAG,EAAE,GAAG,EACR,IAAI,EAAE,YAAY,EAClB,KAAK,EAAE,EAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAC,GACxC,CACA,CACO,CACV,CACE,CACD,CACvB,CAAC;AACN,CAAC,CAAC","sourcesContent":["import React, {FC, useCallback, useState} from \"react\";\r\nimport {ConfigProvider, Splitter} from \"antd\";\r\nimport {EdaNavigator} from \"./edaNavigator\";\r\nimport EdaManagerApi from \"../../../api/eda/edaManagerApi\";\r\nimport {SizeType} from \"antd/lib/config-provider/SizeContext\";\r\nimport {createStyles} from \"antd-style\";\r\nimport {Variant} from \"antd/es/config-provider\";\r\nimport {TypedIndex} from \"./constants/edaTypes\";\r\nimport {EdaDetail} from \"./edaDetail\";\r\nimport {EdaConfigProvider, EdaConfiguration} from \"./context/edaConfigContext\";\r\n\r\nconst useStyles = createStyles(({css, token},) => {\r\n return {\r\n baseLayout: css`\r\n width: 100%;\r\n height: 100%;\r\n padding: ${token.paddingXXS}px;\r\n `,\r\n navPanel: css`\r\n height: 100%;\r\n padding-inline-end: ${token?.paddingXXS}px;\r\n `,\r\n detailPanel: css`\r\n height: 100%;\r\n padding-inline-start: ${token?.paddingXXS}px;\r\n `,\r\n }\r\n});\r\n\r\ninterface Props {\r\n api: EdaManagerApi\r\n // Size of AntD components\r\n size?: SizeType\r\n // Variant of AntD components\r\n variant?: Variant\r\n // Eda manager configuration\r\n configuration?: EdaConfiguration\r\n}\r\n\r\nexport const EdaManager: FC<Props> = ({api, size, variant, configuration}) => {\r\n const {styles} = useStyles();\r\n\r\n const [selectedItem, setSelectedItem] = useState<TypedIndex>();\r\n\r\n const handleDoubleClick = useCallback((item: TypedIndex) => {\r\n setSelectedItem(item);\r\n }, []);\r\n\r\n return (\r\n <EdaConfigProvider config={configuration}>\r\n <ConfigProvider componentSize={size} variant={variant}>\r\n <Splitter className={styles.baseLayout}>\r\n <Splitter.Panel defaultSize={\"25%\"}>\r\n <div className={styles.navPanel}>\r\n <EdaNavigator\r\n api={api}\r\n onDoubleClick={handleDoubleClick}\r\n />\r\n </div>\r\n </Splitter.Panel>\r\n <Splitter.Panel>\r\n <div className={styles.detailPanel}>\r\n <EdaDetail\r\n api={api}\r\n item={selectedItem}\r\n style={{width: '100%', height: '100%'}}\r\n />\r\n </div>\r\n </Splitter.Panel>\r\n </Splitter>\r\n </ConfigProvider>\r\n </EdaConfigProvider>\r\n );\r\n};"]}
@@ -1,20 +1,12 @@
1
- import React from "react";
2
- import EdaManagerApi from "../../../api/eda/edaManagerApi";
1
+ import React, { FC } from "react";
2
+ import EdaManagerApi, { TreeItem } from "../../../api/eda/edaManagerApi";
3
3
  import { TypedIndex } from "./constants/edaTypes";
4
4
  import { SizeType } from "antd/lib/config-provider/SizeContext";
5
- import { SD_EM_Tree_Item } from "../../../api/eda/generated/structures";
6
5
  interface Props {
7
6
  api: EdaManagerApi;
8
7
  style?: React.CSSProperties;
9
8
  size?: SizeType;
10
- onDoubleClick?: (id: TypedIndex, item: SD_EM_Tree_Item) => void;
11
- }
12
- interface State {
13
- }
14
- export declare class EdaNavigator extends React.Component<Props, State> {
15
- constructor(props: Readonly<Props>);
16
- renderGroups(): React.ReactNode;
17
- renderScenarios(): React.ReactNode;
18
- render(): React.ReactNode;
9
+ onDoubleClick?: (id: TypedIndex, item: TreeItem) => void;
19
10
  }
11
+ export declare const EdaNavigator: FC<Props>;
20
12
  export {};
@@ -1,8 +1,7 @@
1
- import React from "react";
1
+ import React, { memo, useMemo } from "react";
2
2
  import { EdaTreeView, TreeViewType } from "./components/edaTreeView";
3
- import { Button, Space, Tabs } from "antd";
3
+ import { Button, ConfigProvider, Space, Tabs } from "antd";
4
4
  import { createStyles } from "antd-style";
5
- import WithCss from "d2coreui/components/style/withCss";
6
5
  import { SearchOutlined } from "@ant-design/icons";
7
6
  import i18n from "d2core/i18n/i18n";
8
7
  const useStyles = createStyles(({ css, token }) => {
@@ -20,45 +19,41 @@ const useStyles = createStyles(({ css, token }) => {
20
19
  .control-buttons {
21
20
  padding: ${token.paddingXXS}px;
22
21
  }
22
+
23
+ .tree {
24
+ flex: 1 1 auto;
25
+ }
26
+ `,
27
+ groupsLayout: css `
28
+ height: 100%;
29
+ display: flex;
30
+ flex-direction: column;
23
31
  `
24
32
  };
25
33
  });
26
- export class EdaNavigator extends React.Component {
27
- constructor(props) {
28
- super(props);
29
- this.state = {};
30
- }
31
- renderGroups() {
32
- const { size, api, onDoubleClick } = this.props;
33
- return (React.createElement("div", { style: { height: "100%", display: "flex", flexDirection: "column" } },
34
- React.createElement("div", { className: "control-buttons" },
35
- React.createElement(Space.Compact, { size: size },
36
- React.createElement(Button, { icon: React.createElement(SearchOutlined, null) }))),
37
- React.createElement("div", { style: { flex: "1 1 auto" } },
38
- React.createElement(EdaTreeView, { api: api, type: TreeViewType.GROUP, onItemDoubleClick: onDoubleClick }))));
39
- }
40
- renderScenarios() {
41
- const { api, onDoubleClick } = this.props;
42
- return (React.createElement(React.Fragment, null,
43
- React.createElement(EdaTreeView, { api: api, type: TreeViewType.SCENARIO, onItemDoubleClick: onDoubleClick })));
44
- }
45
- render() {
46
- const { style, size } = this.props;
47
- return (React.createElement(WithCss, { useStyles: useStyles }, (css) => React.createElement("div", { className: css.styles.baseLayout, style: style },
48
- React.createElement(Tabs, { type: "editable-card", size: size, style: { height: "100%" }, items: [
49
- {
50
- key: "groups",
51
- label: i18n("Groups"),
52
- closable: false,
53
- children: this.renderGroups(),
54
- },
55
- {
56
- key: "scenarios",
57
- label: i18n("Scenarios"),
58
- closable: false,
59
- children: this.renderScenarios(),
60
- },
61
- ] }))));
62
- }
63
- }
34
+ export const EdaNavigator = memo(({ api, style, size, onDoubleClick }) => {
35
+ const { styles } = useStyles();
36
+ const tabs = useMemo(() => [
37
+ {
38
+ key: "groups",
39
+ label: i18n("Groups"),
40
+ closable: false,
41
+ children: (React.createElement("div", { className: styles.groupsLayout },
42
+ React.createElement("div", { className: "control-buttons" },
43
+ React.createElement(Space.Compact, null,
44
+ React.createElement(Button, { icon: React.createElement(SearchOutlined, null) }))),
45
+ React.createElement("div", { className: "tree" },
46
+ React.createElement(EdaTreeView, { api: api, type: TreeViewType.GROUP, onItemDoubleClick: onDoubleClick })))),
47
+ },
48
+ {
49
+ key: "scenarios",
50
+ label: i18n("Scenarios"),
51
+ closable: false,
52
+ children: (React.createElement(EdaTreeView, { api: api, type: TreeViewType.SCENARIO, onItemDoubleClick: onDoubleClick })),
53
+ },
54
+ ], [api, styles, onDoubleClick]);
55
+ return (React.createElement(ConfigProvider, { componentSize: size },
56
+ React.createElement("div", { className: styles.baseLayout, style: style },
57
+ React.createElement(Tabs, { type: "editable-card", style: { height: "100%" }, destroyOnHidden: false, items: tabs }))));
58
+ });
64
59
  //# sourceMappingURL=edaNavigator.js.map