d2aura 26.0.13 → 26.0.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/api/eda/edaManagerApi.d.ts +54 -15
- package/api/eda/edaManagerApi.js +106 -29
- package/api/eda/edaManagerApi.js.map +1 -1
- package/api/eda/generated/events.d.ts +115 -35
- package/api/eda/generated/events.js +193 -41
- package/api/eda/generated/events.js.map +1 -1
- package/api/eda/generated/structures.d.ts +110 -33
- package/api/eda/generated/structures.js.map +1 -1
- package/core/i18n/d2aura.en.json +14 -0
- package/core/i18n/d2aura.sk.json +92 -2
- package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.d.ts +1 -1
- package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.js +2 -2
- package/coreui/components/edaManager/components/detail/components/edaVectorMassChangeButton.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaChartViewer.d.ts +14 -0
- package/coreui/components/edaManagerComponent/components/edaChartViewer.js +374 -0
- package/coreui/components/edaManagerComponent/components/edaChartViewer.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaDataBasePanel.d.ts +4 -8
- package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js +18 -75
- package/coreui/components/edaManagerComponent/components/edaDataBasePanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaDetailPanel.d.ts +5 -14
- package/coreui/components/edaManagerComponent/components/edaDetailPanel.js +80 -19
- package/coreui/components/edaManagerComponent/components/edaDetailPanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaGraphPanel.d.ts +2 -7
- package/coreui/components/edaManagerComponent/components/edaGraphPanel.js +22 -390
- package/coreui/components/edaManagerComponent/components/edaGraphPanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.d.ts +3 -14
- package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js +54 -67
- package/coreui/components/edaManagerComponent/components/edaGroupDetailPanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaLoadingOverlay.d.ts +7 -0
- package/coreui/components/edaManagerComponent/components/edaLoadingOverlay.js +35 -0
- package/coreui/components/edaManagerComponent/components/edaLoadingOverlay.js.map +1 -0
- package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.d.ts +12 -18
- package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js +55 -51
- package/coreui/components/edaManagerComponent/components/edaSampleRangePickerPanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.d.ts +3 -14
- package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js +67 -81
- package/coreui/components/edaManagerComponent/components/edaScenarioDetailPanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaTablePanel.d.ts +2 -6
- package/coreui/components/edaManagerComponent/components/edaTablePanel.js +188 -110
- package/coreui/components/edaManagerComponent/components/edaTablePanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.d.ts +2 -13
- package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js +57 -88
- package/coreui/components/edaManagerComponent/components/edaTimeWindowPickerPanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaTreeView.d.ts +9 -51
- package/coreui/components/edaManagerComponent/components/edaTreeView.js +431 -262
- package/coreui/components/edaManagerComponent/components/edaTreeView.js.map +1 -1
- package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.d.ts +3 -21
- package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js +160 -179
- package/coreui/components/edaManagerComponent/components/edaVectorDetailPanel.js.map +1 -1
- package/coreui/components/edaManagerComponent/constants/actionTypes.d.ts +5 -0
- package/coreui/components/edaManagerComponent/constants/actionTypes.js +7 -0
- package/coreui/components/edaManagerComponent/constants/actionTypes.js.map +1 -0
- package/coreui/components/edaManagerComponent/constants/edaTypes.d.ts +23 -11
- package/coreui/components/edaManagerComponent/constants/edaTypes.js +15 -0
- package/coreui/components/edaManagerComponent/constants/edaTypes.js.map +1 -1
- package/coreui/components/edaManagerComponent/context/edaConfigContext.d.ts +26 -0
- package/coreui/components/edaManagerComponent/context/edaConfigContext.js +20 -0
- package/coreui/components/edaManagerComponent/context/edaConfigContext.js.map +1 -0
- package/coreui/components/edaManagerComponent/context/edaVectorDataContext.d.ts +10 -16
- package/coreui/components/edaManagerComponent/context/edaVectorDataContext.js +8 -1
- package/coreui/components/edaManagerComponent/context/edaVectorDataContext.js.map +1 -1
- package/coreui/components/edaManagerComponent/context/edaVectorDataProvider.d.ts +0 -1
- package/coreui/components/edaManagerComponent/context/edaVectorDataProvider.js +90 -92
- package/coreui/components/edaManagerComponent/context/edaVectorDataProvider.js.map +1 -1
- package/coreui/components/edaManagerComponent/context/loadingContext.d.ts +1 -1
- package/coreui/components/edaManagerComponent/context/loadingContext.js.map +1 -1
- package/coreui/components/edaManagerComponent/context/{sharedSampleRange.d.ts → sharedSampleRangeContext.d.ts} +12 -4
- package/coreui/components/edaManagerComponent/context/sharedSampleRangeContext.js +10 -0
- package/coreui/components/edaManagerComponent/context/sharedSampleRangeContext.js.map +1 -0
- package/coreui/components/edaManagerComponent/context/useEdaActions.d.ts +9 -0
- package/coreui/components/edaManagerComponent/context/useEdaActions.js +36 -0
- package/coreui/components/edaManagerComponent/context/useEdaActions.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/controlButtons.d.ts +13 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/controlButtons.js +19 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/controlButtons.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/descriptiveVectorDetailPanel.d.ts +8 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/descriptiveVectorDetailPanel.js +171 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/descriptiveVectorDetailPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/graphPanel.d.ts +22 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/graphPanel.js +75 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/graphPanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/intervalInput.d.ts +12 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/intervalInput.js +52 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/intervalInput.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/tablePanel.d.ts +22 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/tablePanel.js +130 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/tablePanel.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/types.d.ts +58 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/types.js +51 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/types.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/useSharedData.d.ts +18 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/useSharedData.js +74 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/useSharedData.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/utils.d.ts +38 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/utils.js +299 -0
- package/coreui/components/edaManagerComponent/dialogs/descriptiveVectorDialog/utils.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/edaDescriptiveVectorEditorDialog.d.ts +10 -0
- package/coreui/components/edaManagerComponent/dialogs/edaDescriptiveVectorEditorDialog.js +343 -0
- package/coreui/components/edaManagerComponent/dialogs/edaDescriptiveVectorEditorDialog.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/edaTableEditorDialog.d.ts +12 -0
- package/coreui/components/edaManagerComponent/dialogs/edaTableEditorDialog.js +268 -0
- package/coreui/components/edaManagerComponent/dialogs/edaTableEditorDialog.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/exportDialog.d.ts +18 -0
- package/coreui/components/edaManagerComponent/dialogs/exportDialog.js +156 -0
- package/coreui/components/edaManagerComponent/dialogs/exportDialog.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/groupVectorSelection.d.ts +12 -0
- package/coreui/components/edaManagerComponent/dialogs/groupVectorSelection.js +74 -0
- package/coreui/components/edaManagerComponent/dialogs/groupVectorSelection.js.map +1 -0
- package/coreui/components/edaManagerComponent/dialogs/insertVectorDialog.d.ts +16 -0
- package/coreui/components/edaManagerComponent/dialogs/insertVectorDialog.js +32 -0
- package/coreui/components/edaManagerComponent/dialogs/insertVectorDialog.js.map +1 -0
- package/coreui/components/edaManagerComponent/edaDetail.d.ts +7 -26
- package/coreui/components/edaManagerComponent/edaDetail.js +138 -106
- package/coreui/components/edaManagerComponent/edaDetail.js.map +1 -1
- package/coreui/components/edaManagerComponent/edaManager.d.ts +4 -11
- package/coreui/components/edaManagerComponent/edaManager.js +29 -22
- package/coreui/components/edaManagerComponent/edaManager.js.map +1 -1
- package/coreui/components/edaManagerComponent/edaNavigator.d.ts +6 -12
- package/coreui/components/edaManagerComponent/edaNavigator.js +36 -41
- package/coreui/components/edaManagerComponent/edaNavigator.js.map +1 -1
- package/coreui/components/edaManagerComponent/edaSelect.d.ts +4 -3
- package/coreui/components/edaManagerComponent/edaSelect.js +32 -54
- package/coreui/components/edaManagerComponent/edaSelect.js.map +1 -1
- package/coreui/components/edaManagerComponent/icons/folderRemoveOutlined.d.ts +6 -0
- package/coreui/components/edaManagerComponent/icons/folderRemoveOutlined.js +7 -0
- package/coreui/components/edaManagerComponent/icons/folderRemoveOutlined.js.map +1 -0
- package/coreui/components/edaManagerComponent/utils/export.d.ts +9 -0
- package/coreui/components/edaManagerComponent/utils/export.js +570 -0
- package/coreui/components/edaManagerComponent/utils/export.js.map +1 -0
- package/coreui/components/edaManagerComponent/utils/utils.d.ts +6 -12
- package/coreui/components/edaManagerComponent/utils/utils.js +26 -15
- package/coreui/components/edaManagerComponent/utils/utils.js.map +1 -1
- package/d2configuration/edaManager/DB.EM_EDA_FunctionPrescription.xml +65 -0
- package/d2configuration/edaManager/DB.EM_EDA_VectorScenario.xml +65 -0
- package/d2configuration/edaManager/E.EM_DETAIL_IMPL.xml +67 -1
- package/d2configuration/edaManager/E.EM_DETAIL_SQL.xml +85 -0
- package/d2configuration/edaManager/E.EM_DETAIL_UNIT.xml +143 -2
- package/d2configuration/edaManager/E.EM_NAVIGATOR_IMPL.xml +14 -6
- package/d2configuration/edaManager/E.EM_NAVIGATOR_SQL.xml +12 -1
- package/d2configuration/edaManager/E.EM_NAVIGATOR_UNIT.xml +114 -6
- package/d2configuration/edaManager/E.EM_VECTOR_IMPL.xml +30 -6
- package/d2configuration/edaManager/E.EM_VECTOR_UNIT.xml +119 -17
- package/d2configuration/edaManager/SD.EM_EDA_FunctionPrescription.xml +91 -0
- package/d2configuration/edaManager/SD.EM_EDA_PairVector.xml +454 -0
- package/d2configuration/edaManager/{SD.EM_EDA_StatVectorRec_V1.xml → SD.EM_EDA_VectorScenario.xml} +13 -36
- package/d2configuration/edaManager/{SD.EM_EDA_VectorValues.xml → SD.EM_EDA_VectorStats.xml} +39 -6
- package/d2configuration/edaManager/SD.EM_Filter_Condition.xml +1 -1
- package/package.json +5 -3
- package/coreui/components/edaManagerComponent/components/edaBasePanel.d.ts +0 -16
- package/coreui/components/edaManagerComponent/components/edaBasePanel.js +0 -85
- package/coreui/components/edaManagerComponent/components/edaBasePanel.js.map +0 -1
- package/coreui/components/edaManagerComponent/context/sharedSampleRange.js +0 -13
- package/coreui/components/edaManagerComponent/context/sharedSampleRange.js.map +0 -1
- package/d2configuration/edaManager/EDA_CancelSession.xml +0 -54
- package/d2configuration/edaManager/EDA_GetSessionId.xml +0 -54
- package/d2configuration/edaManager/EDA_ReadValuesFromVektorRec.xml +0 -54
- package/d2configuration/edaManager/EDA_StatVectorRec.xml +0 -56
- package/d2configuration/edaManager/SD.EM_EDA_ReadValuesFromVector_V1.xml +0 -168
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"groupVectorSelection.js","sourceRoot":"","sources":["../../../../../../coreui/components/edaManagerComponent/dialogs/groupVectorSelection.tsx"],"names":[],"mappings":"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","sourcesContent":["import React, {FC, Key, useCallback, useEffect, useRef, useState} from \"react\";\r\nimport EdaManagerApi, {TreeItem, TreeItemsResult} from \"../../../../api/eda/edaManagerApi\";\r\nimport i18n from \"d2core/i18n/i18n\";\r\nimport {IdType, TypedData} from \"../constants/edaTypes\";\r\nimport {ModalDialog, ModalDialogMode, ModalDialogProps} from \"d2coreui/components/modal/modalDialog\";\r\nimport {Alert, Transfer} from \"antd\";\r\n\r\ninterface Props extends Omit<ModalDialogProps, \"mode\" | \"onOk\"> {\r\n api: EdaManagerApi\r\n data?: TypedData\r\n displayedVectors: TreeItem[]\r\n onSelected: (vectors: TreeItem[]) => void\r\n}\r\n\r\nexport const GroupVectorSelection: FC<Props> = ({api, data, displayedVectors, onSelected, open, ...props}) => {\r\n const [visibleVectors, setVisibleVectors] = useState<Key[]>([]);\r\n const [availableVectors, setAvailableVectors] = useState<TreeItem[]>(displayedVectors);\r\n const [isLoading, setIsLoading] = useState(false);\r\n\r\n const lastLoaded = useRef<TypedData | undefined>(undefined);\r\n\r\n const handleChange = useCallback((targetKeys: Key[]) => setVisibleVectors(targetKeys), []);\r\n\r\n const handleOk = useCallback(() => {\r\n const availableMap = new Map(availableVectors.map(v => [v.ID, v]));\r\n const selected = visibleVectors\r\n .map((id) => availableMap.get(id as number))\r\n .filter((v): v is TreeItem => !!v);\r\n onSelected(selected);\r\n }, [availableVectors, visibleVectors, onSelected]);\r\n\r\n useEffect(() => {\r\n let isCurrent = true;\r\n\r\n if (open && data && data.type !== IdType.VECTOR && data !== lastLoaded.current) {\r\n const fetchAllVectors = async () => {\r\n setIsLoading(true);\r\n setVisibleVectors(displayedVectors.map((v) => v.ID));\r\n setAvailableVectors([]);\r\n lastLoaded.current = data;\r\n\r\n const result: TreeItem[] = [];\r\n const id = data.type === IdType.GROUP ? data.data.data.ID_SKVEKTOR : data.data.data.ID_SCENAR;\r\n\r\n try {\r\n let vectors: TreeItemsResult;\r\n let page = 0;\r\n\r\n do {\r\n const offset = page * api.pageSize;\r\n\r\n if (data.type === IdType.GROUP) {\r\n vectors = await api.getGroupVectors(id, offset);\r\n } else {\r\n vectors = await api.getScenarioVectors(id, offset, undefined, true);\r\n }\r\n\r\n if (!isCurrent) {\r\n return;\r\n }\r\n\r\n result.push(...vectors.items);\r\n page++;\r\n } while (vectors.leftCount > 0);\r\n\r\n if (isCurrent) {\r\n setAvailableVectors(result);\r\n }\r\n } catch (e) {\r\n console.error(\"Failed to load vectors\", e);\r\n } finally {\r\n if (isCurrent) {\r\n setIsLoading(false);\r\n }\r\n }\r\n };\r\n\r\n fetchAllVectors();\r\n }\r\n\r\n return () => {\r\n isCurrent = false;\r\n }\r\n }, [api, data, open, displayedVectors]);\r\n\r\n return (\r\n <ModalDialog\r\n {...props}\r\n mode={ModalDialogMode.OK_CANCEL}\r\n open={open}\r\n styles={{body: {paddingTop: 0}}}\r\n title={i18n(\"User Selection\")}\r\n initialWidth={window.innerWidth * 0.8}\r\n initialHeight={window.innerHeight * 0.8}\r\n okButtonProps={{disabled: visibleVectors.length > api.pageSize || isLoading}}\r\n onOk={handleOk}\r\n >\r\n <Transfer<TreeItem>\r\n style={{width: \"100%\", height: \"100%\"}}\r\n listStyle={{flex: \"1 1 auto\", height: \"100%\"}}\r\n dataSource={availableVectors}\r\n rowKey={(vector) => vector.ID}\r\n titles={[i18n(\"Hidden vectors\"), i18n(\"Displayed vectors\")]}\r\n targetKeys={visibleVectors}\r\n onChange={handleChange}\r\n status={visibleVectors.length > api.pageSize ? \"error\": undefined}\r\n render={(vector) => vector.DisplayName}\r\n footer={(_, info) => {\r\n if (visibleVectors.length > api.pageSize && info?.direction === \"right\") {\r\n return (<Alert type={\"error\"} message={i18n(\"Maximum number of displayed vectors: %{n}\", {n: String(api.pageSize)})} />);\r\n } else {\r\n return undefined;\r\n }\r\n }}\r\n />\r\n </ModalDialog>\r\n );\r\n}"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ModalProps } from "antd";
|
|
2
|
+
import { TypedIndex } from "../constants/edaTypes";
|
|
3
|
+
import EdaManagerApi from "../../../../api/eda/edaManagerApi";
|
|
4
|
+
import { FC } from "react";
|
|
5
|
+
export declare enum InsertTo {
|
|
6
|
+
SCENARIO = 0,
|
|
7
|
+
GROUP = 1
|
|
8
|
+
}
|
|
9
|
+
interface Props extends Omit<ModalProps, "title"> {
|
|
10
|
+
api: EdaManagerApi;
|
|
11
|
+
data: TypedIndex;
|
|
12
|
+
insertTo: InsertTo;
|
|
13
|
+
onOk?: () => void;
|
|
14
|
+
}
|
|
15
|
+
export declare const InsertVectorDialog: FC<Props>;
|
|
16
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import i18n from "d2core/i18n/i18n";
|
|
2
|
+
import { EdaTreeView, TreeViewType } from "../components/edaTreeView";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { ModalDialog } from "d2coreui/components/modal/modalDialog";
|
|
5
|
+
export var InsertTo;
|
|
6
|
+
(function (InsertTo) {
|
|
7
|
+
InsertTo[InsertTo["SCENARIO"] = 0] = "SCENARIO";
|
|
8
|
+
InsertTo[InsertTo["GROUP"] = 1] = "GROUP";
|
|
9
|
+
})(InsertTo || (InsertTo = {}));
|
|
10
|
+
export const InsertVectorDialog = ({ api, data, insertTo, onOk, ...otherProps }) => {
|
|
11
|
+
return (React.createElement(ModalDialog, { ...otherProps, initialWidth: 400, initialHeight: 600, mode: "NO_BUTTONS", title: i18n(insertTo == InsertTo.GROUP ? "Include vector to group" : "Include vector to scenario") },
|
|
12
|
+
React.createElement(EdaTreeView, { api: api, type: data.type === 0 && insertTo === InsertTo.SCENARIO ? TreeViewType.SCENARIO : TreeViewType.GROUP, showOmitted: true, hideContextMenu: true, hideVectors: data.type === 0, disableVectorSelection: data.type === 0, disableBranchSelection: data.type !== 0, onItemDoubleClick: async (id) => {
|
|
13
|
+
if (data.type === 2 && insertTo === InsertTo.SCENARIO) {
|
|
14
|
+
await api.includeVectorToScenario(data.id, id.id);
|
|
15
|
+
onOk?.();
|
|
16
|
+
}
|
|
17
|
+
else if (data.type === 1 && insertTo === InsertTo.GROUP) {
|
|
18
|
+
await api.includeVectorToGroup(data.id, id.id);
|
|
19
|
+
onOk?.();
|
|
20
|
+
}
|
|
21
|
+
else if (data.type === 0) {
|
|
22
|
+
if (insertTo === InsertTo.SCENARIO) {
|
|
23
|
+
await api.includeVectorToScenario(id.id, data.id);
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
await api.includeVectorToGroup(id.id, data.id);
|
|
27
|
+
}
|
|
28
|
+
onOk?.();
|
|
29
|
+
}
|
|
30
|
+
} })));
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=insertVectorDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"insertVectorDialog.js","sourceRoot":"","sources":["../../../../../../coreui/components/edaManagerComponent/dialogs/insertVectorDialog.tsx"],"names":[],"mappings":"AACA,OAAO,IAAI,MAAM,kBAAkB,CAAC;AAEpC,OAAO,EAAC,WAAW,EAAE,YAAY,EAAC,MAAM,2BAA2B,CAAC;AAEpE,OAAO,KAAW,MAAM,OAAO,CAAC;AAChC,OAAO,EAAC,WAAW,EAAkB,MAAM,uCAAuC,CAAC;AAEnF,MAAM,CAAN,IAAY,QAGX;AAHD,WAAY,QAAQ;IAChB,+CAAQ,CAAA;IACR,yCAAK,CAAA;AACT,CAAC,EAHW,QAAQ,KAAR,QAAQ,QAGnB;AAUD,MAAM,CAAC,MAAM,kBAAkB,GAAc,CAAC,EAAC,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,UAAU,EAAC,EAAE,EAAE;IACxF,OAAO,CACH,oBAAC,WAAW,OACJ,UAAU,EACd,YAAY,EAAE,GAAG,EACjB,aAAa,EAAE,GAAG,EAClB,IAAI,gBACJ,KAAK,EAAE,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC,4BAA4B,CAAC;QAElG,oBAAC,WAAW,IACR,GAAG,EAAE,GAAG,EACR,IAAI,EAAE,IAAI,CAAC,IAAI,MAAkB,IAAI,QAAQ,KAAK,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,EAChH,WAAW,QACX,eAAe,QACf,WAAW,EAAE,IAAI,CAAC,IAAI,MAAkB,EACxC,sBAAsB,EAAE,IAAI,CAAC,IAAI,MAAkB,EACnD,sBAAsB,EAAE,IAAI,CAAC,IAAI,MAAkB,EACnD,iBAAiB,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE;gBAC5B,IAAI,IAAI,CAAC,IAAI,MAAoB,IAAI,QAAQ,KAAK,QAAQ,CAAC,QAAQ,EAAE,CAAC;oBAClE,MAAM,GAAG,CAAC,uBAAuB,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;oBAClD,IAAI,EAAE,EAAE,CAAC;gBACb,CAAC;qBAAM,IAAI,IAAI,CAAC,IAAI,MAAiB,IAAI,QAAQ,KAAK,QAAQ,CAAC,KAAK,EAAE,CAAC;oBACnE,MAAM,GAAG,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;oBAC/C,IAAI,EAAE,EAAE,CAAC;gBACb,CAAC;qBAAM,IAAI,IAAI,CAAC,IAAI,MAAkB,EAAE,CAAC;oBACrC,IAAI,QAAQ,KAAK,QAAQ,CAAC,QAAQ,EAAE,CAAC;wBACjC,MAAM,GAAG,CAAC,uBAAuB,CAAC,EAAE,CAAC,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;oBACtD,CAAC;yBAAM,CAAC;wBACJ,MAAM,GAAG,CAAC,oBAAoB,CAAC,EAAE,CAAC,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;oBACnD,CAAC;oBAED,IAAI,EAAE,EAAE,CAAC;gBACb,CAAC;YACL,CAAC,GACH,CACQ,CACjB,CAAA;AACL,CAAC,CAAA","sourcesContent":["import {ModalProps} from \"antd\";\r\nimport i18n from \"d2core/i18n/i18n\";\r\nimport {IdType, TypedIndex} from \"../constants/edaTypes\";\r\nimport {EdaTreeView, TreeViewType} from \"../components/edaTreeView\";\r\nimport EdaManagerApi from \"../../../../api/eda/edaManagerApi\";\r\nimport React, {FC} from \"react\";\r\nimport {ModalDialog, ModalDialogMode} from \"d2coreui/components/modal/modalDialog\";\r\n\r\nexport enum InsertTo {\r\n SCENARIO,\r\n GROUP,\r\n}\r\n\r\ninterface Props extends Omit<ModalProps, \"title\"> {\r\n api: EdaManagerApi\r\n data: TypedIndex\r\n insertTo: InsertTo\r\n\r\n onOk?: () => void\r\n}\r\n\r\nexport const InsertVectorDialog: FC<Props> = ({api, data, insertTo, onOk, ...otherProps}) => {\r\n return (\r\n <ModalDialog\r\n {...otherProps}\r\n initialWidth={400}\r\n initialHeight={600}\r\n mode={ModalDialogMode.NO_BUTTONS}\r\n title={i18n(insertTo == InsertTo.GROUP ? \"Include vector to group\" : \"Include vector to scenario\")}\r\n >\r\n <EdaTreeView\r\n api={api}\r\n type={data.type === IdType.VECTOR && insertTo === InsertTo.SCENARIO ? TreeViewType.SCENARIO : TreeViewType.GROUP}\r\n showOmitted\r\n hideContextMenu\r\n hideVectors={data.type === IdType.VECTOR}\r\n disableVectorSelection={data.type === IdType.VECTOR}\r\n disableBranchSelection={data.type !== IdType.VECTOR}\r\n onItemDoubleClick={async (id) => {\r\n if (data.type === IdType.SCENARIO && insertTo === InsertTo.SCENARIO) {\r\n await api.includeVectorToScenario(data.id, id.id);\r\n onOk?.();\r\n } else if (data.type === IdType.GROUP && insertTo === InsertTo.GROUP) {\r\n await api.includeVectorToGroup(data.id, id.id);\r\n onOk?.();\r\n } else if (data.type === IdType.VECTOR) {\r\n if (insertTo === InsertTo.SCENARIO) {\r\n await api.includeVectorToScenario(id.id, data.id);\r\n } else {\r\n await api.includeVectorToGroup(id.id, data.id);\r\n }\r\n\r\n onOk?.();\r\n }\r\n }}\r\n />\r\n </ModalDialog>\r\n )\r\n}"]}
|
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import { GroupData, IdType, ScenarioData, TypedIndex, VectorData } from "./constants/edaTypes";
|
|
5
|
-
import { Tab } from "rc-tabs/lib/interface";
|
|
1
|
+
import React, { FC } from "react";
|
|
2
|
+
import { TypedIndex } from "./constants/edaTypes";
|
|
3
|
+
import EdaManagerApi, { TreeItem } from "../../../api/eda/edaManagerApi";
|
|
6
4
|
import { SizeType } from "antd/lib/config-provider/SizeContext";
|
|
7
|
-
import { SharedSampleRange } from "./context/sharedSampleRange";
|
|
8
5
|
import { Variant } from "antd/es/config-provider";
|
|
9
|
-
|
|
6
|
+
import { EdaConfiguration } from "./context/edaConfigContext";
|
|
7
|
+
export type ItemType = TreeItem[] | TypedIndex;
|
|
10
8
|
interface Props {
|
|
11
9
|
api: EdaManagerApi;
|
|
12
10
|
item?: ItemType;
|
|
@@ -14,24 +12,7 @@ interface Props {
|
|
|
14
12
|
style?: React.CSSProperties;
|
|
15
13
|
size?: SizeType;
|
|
16
14
|
variant?: Variant;
|
|
17
|
-
|
|
18
|
-
showChartLegend?: boolean;
|
|
19
|
-
}
|
|
20
|
-
interface State {
|
|
21
|
-
type?: IdType;
|
|
22
|
-
data?: VectorData | GroupData | ScenarioData;
|
|
23
|
-
tabs: Tab[];
|
|
24
|
-
activeTabKey: string;
|
|
25
|
-
context: SharedSampleRange;
|
|
26
|
-
}
|
|
27
|
-
export declare class EdaDetail extends React.Component<Props, State> {
|
|
28
|
-
constructor(props: Readonly<Props>);
|
|
29
|
-
componentDidMount(): Promise<void>;
|
|
30
|
-
componentDidUpdate(prevProps: Readonly<Props>, prevState: Readonly<State>): Promise<void>;
|
|
31
|
-
render(): React.JSX.Element;
|
|
32
|
-
private updateSampleRange;
|
|
33
|
-
private updateTimeWindow;
|
|
34
|
-
private getTabs;
|
|
35
|
-
private setContextState;
|
|
15
|
+
configuration?: EdaConfiguration;
|
|
36
16
|
}
|
|
17
|
+
export declare const EdaDetail: FC<Props>;
|
|
37
18
|
export {};
|
|
@@ -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
|
|
8
|
-
import { SharedSampleRangeContext } from "./context/
|
|
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
|
|
12
|
-
import {
|
|
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 { AppstoreAddOutlined, ExportOutlined, FileAddOutlined, FolderAddOutlined, 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
|
|
28
|
-
|
|
29
|
-
|
|
35
|
+
export const EdaDetail = ({ api, item, className, style, size, variant }) => {
|
|
36
|
+
const { styles } = useStyles();
|
|
37
|
+
const { triggerExportToXML, triggerIncludeToScenario, triggerIncludeToGroup, 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
|
-
|
|
47
|
+
return {
|
|
35
48
|
btTotal,
|
|
36
49
|
etTotal,
|
|
37
50
|
btWindow: bt,
|
|
@@ -39,100 +52,119 @@ export class EdaDetail extends React.Component {
|
|
|
39
52
|
sampling: EdaSamplingType.Default,
|
|
40
53
|
step,
|
|
41
54
|
vectorPage: 1,
|
|
42
|
-
|
|
43
|
-
updateTimeWindow: (bt, et, step) => this.updateTimeWindow(bt, et, step),
|
|
55
|
+
totalCount: 0,
|
|
44
56
|
};
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
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 updateValues = useCallback((bt, et, sampling) => {
|
|
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 };
|
|
77
|
+
});
|
|
78
|
+
}, []);
|
|
79
|
+
const updatePage = useCallback((page) => {
|
|
80
|
+
setSampleRange((s) => ({ ...s, vectorPage: page, vectors: undefined }));
|
|
81
|
+
}, []);
|
|
82
|
+
const updateVectors = useCallback((vectors) => {
|
|
83
|
+
setSampleRange((s) => ({ ...s, vectorPage: 1, vectors: vectors }));
|
|
84
|
+
}, []);
|
|
85
|
+
const updateTimeWindow = useCallback((bt, et, step) => {
|
|
86
|
+
setSampleRange((s) => ({ ...s, btWindow: bt, etWindow: et, step }));
|
|
87
|
+
}, []);
|
|
88
|
+
const updateTotalCount = useCallback((totalCount) => {
|
|
89
|
+
setSampleRange((s) => ({ ...s, totalCount }));
|
|
90
|
+
}, []);
|
|
91
|
+
const contextValue = useMemo(() => ({
|
|
92
|
+
...sampleRange,
|
|
93
|
+
updateValues,
|
|
94
|
+
updatePage,
|
|
95
|
+
updateVectors,
|
|
96
|
+
updateTimeWindow,
|
|
97
|
+
updateTotalCount,
|
|
98
|
+
}), [sampleRange, updateValues, updatePage, updateTimeWindow, updateTotalCount]);
|
|
99
|
+
const handleToggleFullscreen = useCallback(() => {
|
|
100
|
+
setIsFullscreen(!isFullscreen);
|
|
101
|
+
if (isFullscreen) {
|
|
102
|
+
setPortalTarget(null);
|
|
81
103
|
}
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
104
|
+
}, [isFullscreen]);
|
|
105
|
+
const tabItems = useMemo(() => [
|
|
106
|
+
{
|
|
107
|
+
key: "detail",
|
|
108
|
+
label: i18n("Detail"),
|
|
109
|
+
children: (React.createElement(EdaDetailPanel, { api: api, data: detailData })),
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
key: "table",
|
|
113
|
+
label: i18n("Table"),
|
|
114
|
+
children: (React.createElement(EdaTablePanel, { api: api, data: detailData, isActive: activeTabKey === "table" })),
|
|
115
|
+
},
|
|
116
|
+
{
|
|
117
|
+
key: "graph",
|
|
118
|
+
label: i18n("Graph"),
|
|
119
|
+
children: (React.createElement(EdaGraphPanel, { api: api, data: detailData, isActive: activeTabKey === "graph" })),
|
|
120
|
+
},
|
|
121
|
+
], [api, detailData, activeTabKey]);
|
|
122
|
+
const renderTabs = (React.createElement("div", { style: { position: 'relative', height: '100%', width: '100%', display: 'flex', flexDirection: 'column' } },
|
|
123
|
+
React.createElement(Tabs, { type: "card", className: styles.baseLayout, onChange: setActiveTabKey, activeKey: activeTabKey, destroyOnHidden: false, items: tabItems, tabBarExtraContent: {
|
|
124
|
+
right: (React.createElement(Space.Compact, null,
|
|
125
|
+
detailData !== undefined && (React.createElement(React.Fragment, null,
|
|
126
|
+
React.createElement(Button, { icon: React.createElement(ExportOutlined, null), onClick: () => triggerExportToXML(detailData), title: i18n("Export") }),
|
|
127
|
+
!Array.isArray(item) && item && item.type === 0 && (React.createElement(React.Fragment, null,
|
|
128
|
+
React.createElement(Button, { icon: React.createElement(AppstoreAddOutlined, null), onClick: () => triggerIncludeToGroup(item), title: i18n("Include vector to group") }),
|
|
129
|
+
React.createElement(Button, { icon: React.createElement(FolderAddOutlined, null), onClick: () => triggerIncludeToScenario(item), title: i18n("Include vector to scenario") }))),
|
|
130
|
+
!Array.isArray(item) && item && item.type === 1 && (React.createElement(Button, { icon: React.createElement(FileAddOutlined, null), onClick: () => triggerIncludeToGroup(item), title: i18n("Include vector to group") })),
|
|
131
|
+
!Array.isArray(item) && item && item.type === 2 && (React.createElement(Button, { icon: React.createElement(FileAddOutlined, null), onClick: () => triggerIncludeToScenario(item), title: i18n("Include vector to scenario") })))),
|
|
132
|
+
React.createElement(Button, { disabled: item === undefined, icon: isFullscreen ? React.createElement(FullscreenExitOutlined, null) : React.createElement(FullscreenOutlined, null), onClick: handleToggleFullscreen, title: i18n(isFullscreen ? "Restore" : "Fullscreen") }))),
|
|
133
|
+
} })));
|
|
134
|
+
useEffect(() => {
|
|
135
|
+
let isMounted = true;
|
|
136
|
+
if (item && !Array.isArray(item)) {
|
|
137
|
+
loadDetail(api, item).then((result) => {
|
|
138
|
+
if (isMounted && result) {
|
|
139
|
+
setDetailData(result);
|
|
140
|
+
}
|
|
141
|
+
});
|
|
97
142
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
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
|
-
}
|
|
143
|
+
return () => {
|
|
144
|
+
isMounted = false;
|
|
145
|
+
};
|
|
146
|
+
}, [api, item]);
|
|
147
|
+
useEffect(() => {
|
|
148
|
+
savePreference("EDA_DETAIL_BT", sampleRange.btTotal.toISOString());
|
|
149
|
+
savePreference("EDA_DETAIL_ET", sampleRange.etTotal.toISOString());
|
|
150
|
+
savePreference("EDA_DETAIL_STEP", sampleRange.step);
|
|
151
|
+
}, [sampleRange.btTotal, sampleRange.etTotal, sampleRange.step]);
|
|
152
|
+
return (React.createElement(ConfigProvider, { componentSize: size, variant: variant },
|
|
153
|
+
React.createElement("div", { className: className, style: style },
|
|
154
|
+
React.createElement(SharedSampleRangeContext.Provider, { value: contextValue },
|
|
155
|
+
React.createElement(EdaVectorDataProvider, { api: api },
|
|
156
|
+
isFullscreen && portalTarget ? createPortal(renderTabs, portalTarget) : renderTabs,
|
|
157
|
+
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: {
|
|
158
|
+
header: {
|
|
159
|
+
padding: 0,
|
|
160
|
+
margin: 0
|
|
161
|
+
},
|
|
162
|
+
} },
|
|
163
|
+
React.createElement("div", { style: { width: '100%', height: '100%' }, ref: (el) => {
|
|
164
|
+
if (el && !portalTarget) {
|
|
165
|
+
setPortalTarget(el);
|
|
166
|
+
}
|
|
167
|
+
} })),
|
|
168
|
+
renderActionDialogs())))));
|
|
169
|
+
};
|
|
138
170
|
//# 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, IdType, 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 {AppstoreAddOutlined, ExportOutlined, FileAddOutlined, FolderAddOutlined, 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 {triggerExportToXML, triggerIncludeToScenario, triggerIncludeToGroup, 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 updateValues = useCallback((bt: dayjs.Dayjs, et: dayjs.Dayjs, sampling: EdaSamplingType) => {\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}\r\n });\r\n }, []);\r\n const updatePage = useCallback((page: number) => {\r\n setSampleRange((s) => ({...s, vectorPage: page, vectors: undefined}));\r\n }, []);\r\n const updateVectors = useCallback((vectors: TreeItem[]) => {\r\n setSampleRange((s) => ({...s, vectorPage: 1, vectors: vectors}));\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,\r\n updatePage,\r\n updateVectors,\r\n updateTimeWindow,\r\n updateTotalCount,\r\n }), [sampleRange, updateValues, updatePage, 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 <>\r\n <Button\r\n icon={<ExportOutlined />}\r\n onClick={() => triggerExportToXML(detailData)}\r\n title={i18n(\"Export\")}\r\n />\r\n {!Array.isArray(item) && item && item.type === IdType.VECTOR && (\r\n <>\r\n <Button\r\n icon={<AppstoreAddOutlined/>}\r\n onClick={() => triggerIncludeToGroup(item)}\r\n title={i18n(\"Include vector to group\")}\r\n />\r\n <Button\r\n icon={<FolderAddOutlined/>}\r\n onClick={() => triggerIncludeToScenario(item)}\r\n title={i18n(\"Include vector to scenario\")}\r\n />\r\n </>\r\n )}\r\n {!Array.isArray(item) && item && item.type === IdType.GROUP && (\r\n <Button\r\n icon={<FileAddOutlined/>}\r\n onClick={() => triggerIncludeToGroup(item)}\r\n title={i18n(\"Include vector to group\")}\r\n />\r\n )}\r\n {!Array.isArray(item) && item && item.type === IdType.SCENARIO && (\r\n <Button\r\n icon={<FileAddOutlined/>}\r\n onClick={() => triggerIncludeToScenario(item)}\r\n title={i18n(\"Include vector to scenario\")}\r\n />\r\n )}\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
|
|
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
|
-
|
|
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
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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
|