Skip to content

Commit

Permalink
Merge branch 'main' into implement-connectivity-in-modification-form
Browse files Browse the repository at this point in the history
  • Loading branch information
thangqp authored Jul 16, 2024
2 parents 4b67f26 + 9ac12a7 commit 35464e2
Show file tree
Hide file tree
Showing 16 changed files with 183 additions and 69 deletions.
20 changes: 10 additions & 10 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

52 changes: 49 additions & 3 deletions src/components/diagrams/diagram-pane.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -29,11 +29,15 @@ import {
DIAGRAM_MAP_RATIO_MIN_PERCENTAGE,
DiagramType,
MAP_BOTTOM_OFFSET,
NETWORK_AREA_DIAGRAM_NB_MAX_VOLTAGE_LEVELS,
NoSvg,
useDiagram,
ViewState,
} from './diagram-common';
import { makeDiagramSorter } from './diagram-utils';
import {
getEstimatedNbVoltageLevels,
makeDiagramSorter,
} from './diagram-utils';
import {
isNodeBuilt,
isNodeInNotificationList,
Expand All @@ -45,7 +49,7 @@ import { useNameOrId } from '../utils/equipmentInfosHandler';
import { syncDiagramStateWithSessionStorage } from '../../redux/session-storage';
import SingleLineDiagramContent from './singleLineDiagram/single-line-diagram-content';
import NetworkAreaDiagramContent from './networkAreaDiagram/network-area-diagram-content';
import { useSnackMessage } from '@gridsuite/commons-ui';
import { useDebounce, useSnackMessage } from '@gridsuite/commons-ui';
import { setNetworkAreaDiagramNbVoltageLevels } from '../../redux/actions';
import { useIntl } from 'react-intl';
import {
Expand Down Expand Up @@ -353,6 +357,12 @@ export function DiagramPane({
const networkAreaDiagramDepth = useSelector(
(state) => state.networkAreaDiagramDepth
);
const previousNetworkAreaDiagramDepth = useRef(networkAreaDiagramDepth);

const networkAreaDiagramNbVoltageLevels = useSelector(
(state) => state.networkAreaDiagramNbVoltageLevels
);

const { translate } = useLocalizedCountries();

const notificationIdList = useSelector((state) => state.notificationIdList);
Expand Down Expand Up @@ -550,6 +560,7 @@ export function DiagramPane({

const updateNAD = useCallback(
(diagramStates) => {
previousNetworkAreaDiagramDepth.current = networkAreaDiagramDepth;
const networkAreaIds = [];
let networkAreaViewState = ViewState.OPENED;
diagramStates.forEach((diagramState) => {
Expand Down Expand Up @@ -649,6 +660,28 @@ export function DiagramPane({
});
}
}, []);
// We debounce the updateNAD function to avoid generating unnecessary NADs
const debounceUpdateNAD = useDebounce(updateNAD, 300);

// To allow a small number of fast clicks
// and then stop before we get too close to
// NETWORK_AREA_DIAGRAM_NB_MAX_VOLTAGE_LEVELS
const shouldDebounceUpdateNAD = useCallback(
(networkAreaDiagramDepth) => {
const estimatedNbVoltageLevels = getEstimatedNbVoltageLevels(
previousNetworkAreaDiagramDepth.current,
networkAreaDiagramDepth,
networkAreaDiagramNbVoltageLevels
);
return (
estimatedNbVoltageLevels <
NETWORK_AREA_DIAGRAM_NB_MAX_VOLTAGE_LEVELS ||
previousNetworkAreaDiagramDepth.current >
networkAreaDiagramDepth
);
},
[networkAreaDiagramNbVoltageLevels]
);

// UPDATE DIAGRAM VIEWS
useEffect(() => {
Expand All @@ -664,7 +697,16 @@ export function DiagramPane({
// SLD MANAGEMENT (adding or removing SLDs)
updateSLDs(diagramStates);
// NAD MANAGEMENT (adding, removing or updating the NAD)
updateNAD(diagramStates);
// Here we call either the debounced or the non-debounced function
// to force a server fetch after a few clicks to get the actual number of voltage levels.
// it's ok to do this and doesn't cause two fetches at the end
// beacause the debounced function is recreated after each networkAreaDiagramDepth
// change so the debounce hook clears the debounce timer
if (shouldDebounceUpdateNAD(networkAreaDiagramDepth)) {
debounceUpdateNAD(diagramStates);
} else {
updateNAD(diagramStates);
}
}, [
diagramStates,
visible,
Expand All @@ -673,6 +715,9 @@ export function DiagramPane({
updateDiagramStates,
updateSLDs,
updateNAD,
debounceUpdateNAD,
networkAreaDiagramDepth,
shouldDebounceUpdateNAD,
]);

const displayedDiagrams = views
Expand Down Expand Up @@ -1096,6 +1141,7 @@ export function DiagramPane({
)}
fullscreenWidth={width}
fullscreenHeight={height}
loadingState={diagramView.loadingState}
>
{(diagramView.svgType ===
DiagramType.VOLTAGE_LEVEL ||
Expand Down
31 changes: 31 additions & 0 deletions src/components/diagrams/diagram-utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -52,3 +52,34 @@ const sortByIndex = (a, b, diagramStates) => {
export const makeDiagramSorter = (diagramStates) => {
return (a, b) => sortByAlign(a, b) || sortByIndex(a, b, diagramStates);
};

// estimate the number of voltage levels for a requested depth
// based on the current depth and the previous number of voltage levels
// this allows the user to increase the depth quickly without having to wait
// for the actual number of voltage levels at each step but
// to avoid increasing the depth too much.
// we want this estimation to be slightly pessimistic to avoid bad UX of going to far
// and not being able to do the same thing step by step.
const VL_DEPTH_GROWTH_RATE = 2;
export function getEstimatedNbVoltageLevels(
currentDepth,
requestedDepth,
previousVoltagesNB
) {
// We assume that the number of vl grows exponentially
// real world example :
// depth : number of voltage levels
// 1 : 3
// 2 : 7
// 3 : 13
// 4 : 28
// 5 : 37
// 6 : 51
// 7 : 80
// 8 : 138
// 9 : 221
return (
previousVoltagesNB *
Math.pow(VL_DEPTH_GROWTH_RATE, requestedDepth - currentDepth)
);
}
17 changes: 10 additions & 7 deletions src/components/diagrams/diagram.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,13 @@ const Diagram = (props) => {
(state) => state.networkAreaDiagramNbVoltageLevels
);

const incrementCounterDisabled =
props.loadingState ||
nbVoltageLevels > NETWORK_AREA_DIAGRAM_NB_MAX_VOLTAGE_LEVELS;

const decrementCounterDisabled =
props.loadingState || networkAreaDiagramDepth === 0;

/**
* DIAGRAM CONTROL HANDLERS
*/
Expand Down Expand Up @@ -161,13 +168,8 @@ const Diagram = (props) => {
fullScreenActive={shouldBeFullscreen}
onStartFullScreen={onShowFullScreenHandler}
onStopFullScreen={onHideFullScreenHandler}
incrementCounterDisabled={
nbVoltageLevels >
NETWORK_AREA_DIAGRAM_NB_MAX_VOLTAGE_LEVELS
}
decrementCounterDisabled={
networkAreaDiagramDepth === 0
}
incrementCounterDisabled={incrementCounterDisabled}
decrementCounterDisabled={decrementCounterDisabled}
/>
</Box>
)}
Expand Down Expand Up @@ -198,6 +200,7 @@ Diagram.propTypes = {
height: PropTypes.number,
fullscreenWidth: PropTypes.number,
fullscreenHeight: PropTypes.number,
loadingState: PropTypes.bool,
};

export default Diagram;
Original file line number Diff line number Diff line change
Expand Up @@ -287,9 +287,11 @@ const BatteryModificationDialog = ({
setDataFetchStatus(FetchStatus.SUCCEED);
})
.catch(() => {
setBatteryToModify(null);
setDataFetchStatus(FetchStatus.FAILED);
reset(emptyFormData);
if (editData?.equipmentId !== equipmentId) {
setBatteryToModify(null);
reset(emptyFormData);
}
});
} else {
setValuesAndEmptyOthers();
Expand All @@ -303,6 +305,7 @@ const BatteryModificationDialog = ({
setValue,
setValuesAndEmptyOthers,
reset,
editData,
]
);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -339,9 +339,11 @@ const GeneratorModificationDialog = ({
setDataFetchStatus(FetchStatus.SUCCEED);
})
.catch(() => {
setGeneratorToModify(null);
reset(emptyFormData);
setDataFetchStatus(FetchStatus.FAILED);
if (editData?.equipmentId !== equipmentId) {
setGeneratorToModify(null);
reset(emptyFormData);
}
});
} else {
setValuesAndEmptyOthers();
Expand All @@ -355,6 +357,7 @@ const GeneratorModificationDialog = ({
getValues,
setValue,
setValuesAndEmptyOthers,
editData,
]
);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -328,9 +328,11 @@ const LineModificationDialog = ({
setDataFetchStatus(FetchStatus.SUCCEED);
})
.catch(() => {
setLineToModify(null);
setDataFetchStatus(FetchStatus.FAILED);
reset(emptyFormData);
if (editData?.equipmentId !== equipmentId) {
setLineToModify(null);
reset(emptyFormData);
}
});
} else {
setLineToModify(null);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -212,19 +212,21 @@ const ShuntCompensatorModificationDialog = ({
setLoading(false);
})
.catch((error) => {
setShuntCompensatorInfos(null);
setDataFetchStatus(FetchStatus.FAILED);
if (error.status === 404) {
setIdExists(true);
}
setLoading(false);
reset(emptyFormData);
if (editData?.equipmentId !== equipmentId) {
setShuntCompensatorInfos(null);
reset(emptyFormData);
}
});
} else {
setShuntCompensatorInfos(null);
}
},
[currentNode.id, snackError, studyUuid, reset, getValues]
[currentNode.id, snackError, studyUuid, reset, getValues, editData]
);

useEffect(() => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -760,8 +760,11 @@ const TwoWindingsTransformerModificationDialog = ({
setDataFetchStatus(FetchStatus.SUCCEED);
})
.catch(() => {
setTwtToModify(null);
setDataFetchStatus(FetchStatus.FAILED);
if (editData?.equipmentId !== equipmentId) {
setTwtToModify(null);
reset(emptyFormData);
}
});
} else {
setTwtToModify(null);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -162,16 +162,18 @@ const VoltageLevelModificationDialog = ({
}
})
.catch(() => {
setVoltageLevelInfos(null);
setDataFetchStatus(FetchStatus.FAILED);
reset(emptyFormData);
if (editData?.equipmentId !== equipmentId) {
setVoltageLevelInfos(null);
reset(emptyFormData);
}
});
} else {
setVoltageLevelInfos(null);
reset(emptyFormData, { keepDefaultValues: true });
}
},
[studyUuid, currentNodeUuid, reset, getValues]
[studyUuid, currentNodeUuid, reset, getValues, editData]
);

useEffect(() => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -174,15 +174,15 @@ const VscModificationDialog: React.FC<any> = ({
);

const onEquipmentIdChange = useCallback(
(equipementId: string | null) => {
if (equipementId) {
(equipmentId: string | null) => {
if (equipmentId) {
setDataFetchStatus(FetchStatus.RUNNING);
fetchNetworkElementInfos(
studyUuid,
currentNodeUuid,
EQUIPMENT_TYPES.HVDC_LINE,
EQUIPMENT_INFOS_TYPES.FORM.type,
equipementId,
equipmentId,
true
)
.then((value: any) => {
Expand Down Expand Up @@ -243,10 +243,12 @@ const VscModificationDialog: React.FC<any> = ({
}));
setDataFetchStatus(FetchStatus.SUCCEED);
})
.catch((_error) => {
.catch(() => {
setDataFetchStatus(FetchStatus.FAILED);
setVcsToModify(null);
reset(emptyFormData);
if (editData?.equipmentId !== equipmentId) {
setVcsToModify(null);
reset(emptyFormData);
}
});
} else {
setValuesAndEmptyOthers();
Expand All @@ -260,6 +262,7 @@ const VscModificationDialog: React.FC<any> = ({
getValues,
reset,
setValuesAndEmptyOthers,
editData,
]
);
useEffect(() => {
Expand Down
3 changes: 2 additions & 1 deletion src/components/network/use-save-map.ts
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,8 @@ export const useSaveMap = (): UseSaveMapOutput => {
distDir,
studyUuid,
currentNodeUuid,
equipments
equipments,
nominalVoltages
);
snackInfo({
messageTxt: intl.formatMessage({
Expand Down
Loading

0 comments on commit 35464e2

Please sign in to comment.