@gridsuite/commons-ui 0.98.0 → 0.100.0

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 (149) hide show
  1. package/dist/components/announcement/AnnouncementBanner.d.ts +15 -0
  2. package/dist/components/announcement/AnnouncementBanner.js +87 -0
  3. package/dist/components/announcement/AnnouncementNotification.d.ts +7 -0
  4. package/dist/components/announcement/AnnouncementNotification.js +10 -0
  5. package/dist/components/announcement/index.d.ts +3 -0
  6. package/dist/components/announcement/index.js +8 -0
  7. package/dist/components/announcement/useGlobalAnnouncement.d.ts +10 -0
  8. package/dist/components/announcement/useGlobalAnnouncement.js +48 -0
  9. package/dist/components/dialogs/customMuiDialog/CustomMuiDialog.js +1 -1
  10. package/dist/components/index.d.ts +2 -0
  11. package/dist/components/index.js +104 -3
  12. package/dist/components/inputs/index.js +2 -1
  13. package/dist/components/inputs/reactHookForm/DirectoryItemsInput.d.ts +1 -0
  14. package/dist/components/inputs/reactHookForm/DirectoryItemsInput.js +2 -0
  15. package/dist/components/inputs/reactHookForm/index.js +2 -1
  16. package/dist/components/inputs/reactHookForm/text/TextInput.d.ts +3 -1
  17. package/dist/components/inputs/reactHookForm/text/TextInput.js +4 -2
  18. package/dist/components/inputs/reactHookForm/utils/HelperPreviousValue.js +1 -1
  19. package/dist/components/parameters/common/ProviderParam.d.ts +7 -0
  20. package/dist/components/parameters/common/ProviderParam.js +51 -0
  21. package/dist/components/parameters/common/computing-type.d.ts +20 -0
  22. package/dist/components/parameters/common/computing-type.js +46 -0
  23. package/dist/components/parameters/common/constant.d.ts +8 -0
  24. package/dist/components/parameters/common/constant.js +18 -0
  25. package/dist/components/parameters/common/index.d.ts +15 -0
  26. package/dist/components/parameters/common/index.js +61 -0
  27. package/dist/components/parameters/common/limitreductions/columns-definitions.d.ts +77 -0
  28. package/dist/components/parameters/common/limitreductions/columns-definitions.js +83 -0
  29. package/dist/components/parameters/common/limitreductions/index.d.ts +11 -0
  30. package/dist/components/parameters/common/limitreductions/index.js +21 -0
  31. package/dist/components/parameters/common/limitreductions/limit-reduction-table-cell.d.ts +5 -0
  32. package/dist/components/parameters/common/limitreductions/limit-reduction-table-cell.js +38 -0
  33. package/dist/components/parameters/common/limitreductions/limit-reduction-table-row.d.ts +7 -0
  34. package/dist/components/parameters/common/limitreductions/limit-reduction-table-row.js +9 -0
  35. package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.d.ts +29 -0
  36. package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.js +27 -0
  37. package/dist/components/parameters/common/limitreductions/limit-reductions-table-form.d.ts +4 -0
  38. package/dist/components/parameters/common/limitreductions/limit-reductions-table-form.js +87 -0
  39. package/dist/components/parameters/common/line-separator.d.ts +1 -0
  40. package/dist/components/parameters/common/line-separator.js +8 -0
  41. package/dist/components/parameters/common/parameters-creation-dialog.d.ts +13 -0
  42. package/dist/components/parameters/common/parameters-creation-dialog.js +88 -0
  43. package/dist/components/parameters/common/parameters.d.ts +20 -0
  44. package/dist/components/parameters/common/parameters.js +42 -0
  45. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-cell.d.ts +6 -0
  46. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-cell.js +42 -0
  47. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-row.d.ts +8 -0
  48. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-row.js +17 -0
  49. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table.d.ts +8 -0
  50. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table.js +55 -0
  51. package/dist/components/parameters/common/voltage-level-table/index.d.ts +9 -0
  52. package/dist/components/parameters/common/voltage-level-table/index.js +8 -0
  53. package/dist/components/parameters/common/widget/index.d.ts +11 -0
  54. package/dist/components/parameters/common/widget/index.js +13 -0
  55. package/dist/components/parameters/common/widget/parameter-float.d.ts +10 -0
  56. package/dist/components/parameters/common/widget/parameter-float.js +51 -0
  57. package/dist/components/parameters/common/widget/parameter-group.d.ts +11 -0
  58. package/dist/components/parameters/common/widget/parameter-group.js +54 -0
  59. package/dist/components/parameters/common/widget/parameter-line-directory-items-input.d.ts +15 -0
  60. package/dist/components/parameters/common/widget/parameter-line-directory-items-input.js +55 -0
  61. package/dist/components/parameters/common/widget/parameter-line-slider.d.ts +12 -0
  62. package/dist/components/parameters/common/widget/parameter-line-slider.js +70 -0
  63. package/dist/components/parameters/common/widget/parameter-switch.d.ts +7 -0
  64. package/dist/components/parameters/common/widget/parameter-switch.js +9 -0
  65. package/dist/components/parameters/index.d.ts +9 -0
  66. package/dist/components/parameters/index.js +94 -0
  67. package/dist/components/parameters/loadflow/constants.d.ts +33 -0
  68. package/dist/components/parameters/loadflow/constants.js +59 -0
  69. package/dist/components/parameters/loadflow/index.d.ts +9 -0
  70. package/dist/components/parameters/loadflow/index.js +31 -0
  71. package/dist/components/parameters/loadflow/load-flow-general-parameters.d.ts +8 -0
  72. package/dist/components/parameters/loadflow/load-flow-general-parameters.js +179 -0
  73. package/dist/components/parameters/loadflow/load-flow-parameter-field.d.ts +19 -0
  74. package/dist/components/parameters/loadflow/load-flow-parameter-field.js +90 -0
  75. package/dist/components/parameters/loadflow/load-flow-parameters-content.d.ts +13 -0
  76. package/dist/components/parameters/loadflow/load-flow-parameters-content.js +82 -0
  77. package/dist/components/parameters/loadflow/load-flow-parameters-context.d.ts +13 -0
  78. package/dist/components/parameters/loadflow/load-flow-parameters-context.js +5 -0
  79. package/dist/components/parameters/loadflow/load-flow-parameters-dialog.d.ts +15 -0
  80. package/dist/components/parameters/loadflow/load-flow-parameters-dialog.js +112 -0
  81. package/dist/components/parameters/loadflow/load-flow-parameters-form.d.ts +9 -0
  82. package/dist/components/parameters/loadflow/load-flow-parameters-form.js +102 -0
  83. package/dist/components/parameters/loadflow/load-flow-parameters-header.d.ts +12 -0
  84. package/dist/components/parameters/loadflow/load-flow-parameters-header.js +84 -0
  85. package/dist/components/parameters/loadflow/load-flow-parameters-inline.d.ts +10 -0
  86. package/dist/components/parameters/loadflow/load-flow-parameters-inline.js +162 -0
  87. package/dist/components/parameters/loadflow/load-flow-parameters-provider.d.ts +4 -0
  88. package/dist/components/parameters/loadflow/load-flow-parameters-provider.js +20 -0
  89. package/dist/components/parameters/loadflow/load-flow-parameters-utils.d.ts +100 -0
  90. package/dist/components/parameters/loadflow/load-flow-parameters-utils.js +158 -0
  91. package/dist/components/parameters/loadflow/use-load-flow-context.d.ts +7 -0
  92. package/dist/components/parameters/loadflow/use-load-flow-context.js +12 -0
  93. package/dist/components/parameters/loadflow/use-load-flow-parameters-form.d.ts +32 -0
  94. package/dist/components/parameters/loadflow/use-load-flow-parameters-form.js +263 -0
  95. package/dist/components/parameters/parameters-style.d.ts +150 -0
  96. package/dist/components/parameters/parameters-style.js +146 -0
  97. package/dist/components/topBar/DevModeBanner.d.ts +1 -0
  98. package/dist/components/topBar/DevModeBanner.js +42 -0
  99. package/dist/components/topBar/TopBar.js +302 -305
  100. package/dist/components/topBar/UserInformationDialog.js +1 -1
  101. package/dist/components/topBar/index.d.ts +3 -2
  102. package/dist/components/topBar/index.js +4 -2
  103. package/dist/hooks/index.d.ts +1 -0
  104. package/dist/hooks/index.js +3 -0
  105. package/dist/hooks/use-parameters-backend.d.ts +11 -0
  106. package/dist/hooks/use-parameters-backend.js +217 -0
  107. package/dist/index.js +135 -5
  108. package/dist/services/explore.d.ts +3 -0
  109. package/dist/services/explore.js +26 -1
  110. package/dist/services/index.d.ts +1 -0
  111. package/dist/services/index.js +9 -3
  112. package/dist/services/loadflow.d.ts +9 -0
  113. package/dist/services/loadflow.js +59 -0
  114. package/dist/services/userAdmin.d.ts +3 -3
  115. package/dist/services/userAdmin.js +9 -1
  116. package/dist/services/utils.d.ts +3 -8
  117. package/dist/services/utils.js +5 -0
  118. package/dist/translations/en/index.d.ts +1 -0
  119. package/dist/translations/en/index.js +2 -0
  120. package/dist/translations/en/parameters.d.ts +67 -0
  121. package/dist/translations/en/parameters.js +64 -0
  122. package/dist/translations/fr/index.d.ts +1 -0
  123. package/dist/translations/fr/index.js +2 -0
  124. package/dist/translations/fr/parameters.d.ts +67 -0
  125. package/dist/translations/fr/parameters.js +64 -0
  126. package/dist/utils/constants/notificationsProvider.d.ts +10 -0
  127. package/dist/utils/constants/notificationsProvider.js +17 -0
  128. package/dist/utils/index.d.ts +1 -0
  129. package/dist/utils/index.js +16 -0
  130. package/dist/utils/types/dynamic-security-analysis.type.d.ts +13 -0
  131. package/dist/utils/types/dynamic-security-analysis.type.js +1 -0
  132. package/dist/utils/types/dynamic-simulation.type.d.ts +111 -0
  133. package/dist/utils/types/dynamic-simulation.type.js +8 -0
  134. package/dist/utils/types/index.d.ts +6 -0
  135. package/dist/utils/types/index.js +11 -0
  136. package/dist/utils/types/loadflow.type.d.ts +11 -0
  137. package/dist/utils/types/loadflow.type.js +1 -0
  138. package/dist/utils/types/metadata.d.ts +1 -0
  139. package/dist/utils/types/non-evacuated-energy.type.d.ts +60 -0
  140. package/dist/utils/types/non-evacuated-energy.type.js +12 -0
  141. package/dist/utils/types/parameters.type.d.ts +41 -0
  142. package/dist/utils/types/parameters.type.js +12 -0
  143. package/dist/utils/types/sensitivity-analysis.type.d.ts +101 -0
  144. package/dist/utils/types/sensitivity-analysis.type.js +16 -0
  145. package/dist/utils/types/types.d.ts +12 -0
  146. package/dist/utils/types/types.js +8 -1
  147. package/package.json +2 -1
  148. package/dist/components/topBar/MessageBanner.d.ts +0 -6
  149. package/dist/components/topBar/MessageBanner.js +0 -54
@@ -0,0 +1,158 @@
1
+ import { LIMIT_REDUCTIONS_FORM, IST_FORM, LIMIT_DURATION_FORM } from "../common/limitreductions/columns-definitions.js";
2
+ import { HVDC_AC_EMULATION, CONNECTED_COMPONENT_MODE, COUNTRIES_TO_BALANCE, BALANCE_TYPE, DC, PHASE_SHIFTER_REGULATION_ON, TRANSFORMER_VOLTAGE_CONTROL_ON, DC_POWER_FACTOR, DC_USE_TRANSFORMER_RATIO, SHUNT_COMPENSATOR_VOLTAGE_CONTROL_ON, DISTRIBUTED_SLACK, WRITE_SLACK_BUS, READ_SLACK_BUS, TWT_SPLIT_SHUNT_ADMITTANCE, USE_REACTIVE_LIMITS, VOLTAGE_INIT_MODE, COMMON_PARAMETERS, SPECIFIC_PARAMETERS, PARAM_PROVIDER_OPENLOADFLOW, PARAM_LIMIT_REDUCTION, DEFAULT_LIMIT_REDUCTION_VALUE } from "./constants.js";
3
+ import { toFormValuesLimitReductions } from "../common/limitreductions/limit-reductions-form-util.js";
4
+ import "../../../utils/yupConfig.js";
5
+ import { ParameterType } from "../../../utils/types/parameters.type.js";
6
+ import "react/jsx-runtime";
7
+ import "react-intl";
8
+ import "@mui/material";
9
+ import { NAME, DESCRIPTION_INPUT } from "../../inputs/reactHookForm/DirectoryItemsInput.js";
10
+ import "react-hook-form";
11
+ import "../../inputs/reactHookForm/agGridTable/BottomRightButtons.js";
12
+ import "react";
13
+ import "../../customAGGrid/customAggrid.js";
14
+ import "ag-grid-community";
15
+ import "react-papaparse";
16
+ import "react-csv-downloader";
17
+ import * as yup from "yup";
18
+ import "../../inputs/reactHookForm/provider/CustomFormProvider.js";
19
+ import "@mui/icons-material";
20
+ import "../../inputs/reactHookForm/numbers/RangeInput.js";
21
+ import "localized-countries";
22
+ import "localized-countries/data/fr";
23
+ import "localized-countries/data/en";
24
+ import "../../../utils/conversionUtils.js";
25
+ import "../../../utils/types/equipmentType.js";
26
+ import "notistack";
27
+ import "@react-querybuilder/material";
28
+ import "../../filter/expert/expertFilterConstants.js";
29
+ import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
30
+ import "uuid";
31
+ import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
32
+ import "react-querybuilder";
33
+ var TabValues = /* @__PURE__ */ ((TabValues2) => {
34
+ TabValues2["GENERAL"] = "General";
35
+ TabValues2["LIMIT_REDUCTIONS"] = "LimitReductions";
36
+ return TabValues2;
37
+ })(TabValues || {});
38
+ const getBasicLoadFlowParametersFormSchema = () => {
39
+ return yup.object().shape({
40
+ [TRANSFORMER_VOLTAGE_CONTROL_ON]: yup.boolean().required(),
41
+ [PHASE_SHIFTER_REGULATION_ON]: yup.boolean().required(),
42
+ [DC]: yup.boolean().required(),
43
+ [BALANCE_TYPE]: yup.string().required(),
44
+ [COUNTRIES_TO_BALANCE]: yup.array().of(yup.string()).required(),
45
+ [CONNECTED_COMPONENT_MODE]: yup.string().required(),
46
+ [HVDC_AC_EMULATION]: yup.boolean().required()
47
+ });
48
+ };
49
+ const getAdvancedLoadFlowParametersFormSchema = () => {
50
+ return yup.object().shape({
51
+ [VOLTAGE_INIT_MODE]: yup.string().required(),
52
+ [USE_REACTIVE_LIMITS]: yup.boolean().required(),
53
+ [TWT_SPLIT_SHUNT_ADMITTANCE]: yup.boolean().required(),
54
+ [READ_SLACK_BUS]: yup.boolean().required(),
55
+ [WRITE_SLACK_BUS]: yup.boolean().required(),
56
+ [DISTRIBUTED_SLACK]: yup.boolean().required(),
57
+ [SHUNT_COMPENSATOR_VOLTAGE_CONTROL_ON]: yup.boolean().required(),
58
+ [DC_USE_TRANSFORMER_RATIO]: yup.boolean().required(),
59
+ [DC_POWER_FACTOR]: yup.number().required().positive("dcPowerFactorGreaterThan0").max(1, "dcPowerFactorLessOrEqualThan1")
60
+ });
61
+ };
62
+ const getDialogLoadFlowParametersFormSchema = (name) => {
63
+ const shape = {};
64
+ if (name) {
65
+ shape[NAME] = yup.string().required();
66
+ shape[DESCRIPTION_INPUT] = yup.string();
67
+ }
68
+ return shape;
69
+ };
70
+ const getCommonLoadFlowParametersFormSchema = () => {
71
+ return yup.object().shape({
72
+ [COMMON_PARAMETERS]: yup.object().shape({
73
+ ...getBasicLoadFlowParametersFormSchema().fields,
74
+ ...getAdvancedLoadFlowParametersFormSchema().fields
75
+ })
76
+ });
77
+ };
78
+ const getSpecificLoadFlowParametersFormSchema = (specificParameters) => {
79
+ const shape = {};
80
+ specificParameters == null ? void 0 : specificParameters.forEach((param) => {
81
+ switch (param.type) {
82
+ case ParameterType.STRING:
83
+ shape[param.name] = yup.string().required();
84
+ break;
85
+ case ParameterType.DOUBLE:
86
+ shape[param.name] = yup.number().required();
87
+ break;
88
+ case ParameterType.INTEGER:
89
+ shape[param.name] = yup.number().required();
90
+ break;
91
+ case ParameterType.BOOLEAN:
92
+ shape[param.name] = yup.boolean().required();
93
+ break;
94
+ case ParameterType.STRING_LIST:
95
+ shape[param.name] = yup.array().of(yup.string()).required();
96
+ break;
97
+ default:
98
+ shape[param.name] = yup.mixed().required();
99
+ }
100
+ });
101
+ return yup.object().shape({
102
+ [SPECIFIC_PARAMETERS]: yup.object().shape(shape)
103
+ });
104
+ };
105
+ const getDefaultSpecificParamsValues = (specificParams) => {
106
+ return specificParams == null ? void 0 : specificParams.reduce((acc, param) => {
107
+ if (param.type === ParameterType.STRING_LIST && param.defaultValue === null) {
108
+ acc[param.name] = [];
109
+ } else if ((param.type === ParameterType.DOUBLE || param.type === ParameterType.INTEGER) && Number.isNaN(Number(param.defaultValue))) {
110
+ acc[param.name] = 0;
111
+ } else {
112
+ acc[param.name] = param.defaultValue;
113
+ }
114
+ return acc;
115
+ }, {});
116
+ };
117
+ const setSpecificParameters = (provider, specificParamsDescriptions, formMethods) => {
118
+ const specificParams = provider ? (specificParamsDescriptions == null ? void 0 : specificParamsDescriptions[provider]) ?? [] : [];
119
+ const specificParamsValues = getDefaultSpecificParamsValues(specificParams);
120
+ formMethods.setValue(SPECIFIC_PARAMETERS, specificParamsValues);
121
+ };
122
+ const setLimitReductions = (provider, defaultLimitReductions, formMethods) => {
123
+ if (provider === PARAM_PROVIDER_OPENLOADFLOW) {
124
+ formMethods.setValue(
125
+ LIMIT_REDUCTIONS_FORM,
126
+ toFormValuesLimitReductions(defaultLimitReductions)[LIMIT_REDUCTIONS_FORM]
127
+ );
128
+ formMethods.setValue(PARAM_LIMIT_REDUCTION, null);
129
+ } else {
130
+ formMethods.setValue(PARAM_LIMIT_REDUCTION, DEFAULT_LIMIT_REDUCTION_VALUE);
131
+ formMethods.setValue(LIMIT_REDUCTIONS_FORM, []);
132
+ }
133
+ };
134
+ const mapLimitReductions = (vlLimits, formLimits, indexVl) => {
135
+ const vlLNewLimits = {
136
+ ...vlLimits,
137
+ permanentLimitReduction: formLimits[indexVl][IST_FORM]
138
+ };
139
+ vlLimits.temporaryLimitReductions.forEach((temporaryLimit, index) => {
140
+ vlLNewLimits.temporaryLimitReductions[index] = {
141
+ ...temporaryLimit,
142
+ reduction: formLimits[indexVl][LIMIT_DURATION_FORM + index]
143
+ };
144
+ });
145
+ return vlLNewLimits;
146
+ };
147
+ export {
148
+ TabValues,
149
+ getAdvancedLoadFlowParametersFormSchema,
150
+ getBasicLoadFlowParametersFormSchema,
151
+ getCommonLoadFlowParametersFormSchema,
152
+ getDefaultSpecificParamsValues,
153
+ getDialogLoadFlowParametersFormSchema,
154
+ getSpecificLoadFlowParametersFormSchema,
155
+ mapLimitReductions,
156
+ setLimitReductions,
157
+ setSpecificParameters
158
+ };
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Copyright (c) 2025, RTE (http://www.rte-france.com)
3
+ * This Source Code Form is subject to the terms of the Mozilla Public
4
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
5
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/.
6
+ */
7
+ export declare const useLoadFlowContext: () => import('./load-flow-parameters-context').LoadFlowContextProps;
@@ -0,0 +1,12 @@
1
+ import { useContext } from "react";
2
+ import { LoadFlowContext } from "./load-flow-parameters-context.js";
3
+ const useLoadFlowContext = () => {
4
+ const context = useContext(LoadFlowContext);
5
+ if (!context) {
6
+ throw new Error("useLoadFlowContext must be used within a LoadFlowProvider");
7
+ }
8
+ return context;
9
+ };
10
+ export {
11
+ useLoadFlowContext
12
+ };
@@ -0,0 +1,32 @@
1
+ import { FieldErrors, UseFormReturn } from 'react-hook-form';
2
+ import { Dispatch, SetStateAction, SyntheticEvent } from 'react';
3
+ import { ObjectSchema } from 'yup';
4
+ import { UUID } from 'crypto';
5
+ import { TabValues } from './load-flow-parameters-utils';
6
+ import { LoadFlowParametersInfos } from '../../../utils/types/loadflow.type';
7
+ import { SpecificParameterInfos, UseParametersBackendReturnProps } from '../../../utils/types/parameters.type';
8
+ import { ComputingType } from '../common';
9
+ import { ILimitReductionsByVoltageLevel } from '../common/limitreductions/columns-definitions';
10
+ export interface UseLoadFlowParametersFormReturn {
11
+ formMethods: UseFormReturn;
12
+ formSchema: ObjectSchema<any>;
13
+ selectedTab: TabValues;
14
+ handleTabChange: (event: SyntheticEvent, newValue: TabValues) => void;
15
+ tabIndexesWithError: TabValues[];
16
+ formattedProviders: {
17
+ id: string;
18
+ label: string;
19
+ }[];
20
+ specificParameters: SpecificParameterInfos[];
21
+ defaultLimitReductions: ILimitReductionsByVoltageLevel[];
22
+ toLoadFlowFormValues: (_params: LoadFlowParametersInfos) => any;
23
+ formatNewParams: (formData: Record<string, any>) => LoadFlowParametersInfos;
24
+ params: LoadFlowParametersInfos | null;
25
+ currentProvider: string | undefined;
26
+ setCurrentProvider: Dispatch<SetStateAction<string | undefined>>;
27
+ paramsLoaded: boolean;
28
+ onValidationError: (errors: FieldErrors) => void;
29
+ onSaveInline: (formData: Record<string, any>) => void;
30
+ onSaveDialog: (formData: Record<string, any>) => void;
31
+ }
32
+ export declare const useLoadFlowParametersForm: (parametersBackend: UseParametersBackendReturnProps<ComputingType.LOAD_FLOW>, enableDeveloperMode: boolean, parametersUuid: UUID | null, name: string | null, description: string | null) => UseLoadFlowParametersFormReturn;
@@ -0,0 +1,263 @@
1
+ import { useForm } from "react-hook-form";
2
+ import { yupResolver } from "@hookform/resolvers/yup";
3
+ import { useState, useCallback, useMemo, useEffect } from "react";
4
+ import { TabValues, getDefaultSpecificParamsValues, getSpecificLoadFlowParametersFormSchema, getCommonLoadFlowParametersFormSchema, getDialogLoadFlowParametersFormSchema, mapLimitReductions, setSpecificParameters, setLimitReductions } from "./load-flow-parameters-utils.js";
5
+ import { ParameterType } from "../../../utils/types/parameters.type.js";
6
+ import { PROVIDER } from "../common/constant.js";
7
+ import "react/jsx-runtime";
8
+ import "@mui/material";
9
+ import "react-intl";
10
+ import "../../../utils/types/equipmentType.js";
11
+ import { updateParameter } from "../../../services/explore.js";
12
+ import "localized-countries";
13
+ import "localized-countries/data/fr";
14
+ import "localized-countries/data/en";
15
+ import "notistack";
16
+ import "../../inputs/reactHookForm/provider/CustomFormProvider.js";
17
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
18
+ import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
19
+ import "@mui/icons-material";
20
+ import { ElementType } from "../../../utils/types/elementType.js";
21
+ import "../../treeViewFinder/TreeViewFinder.js";
22
+ import { DESCRIPTION_INPUT, NAME } from "../../inputs/reactHookForm/DirectoryItemsInput.js";
23
+ import "../../inputs/reactHookForm/agGridTable/BottomRightButtons.js";
24
+ import "../../customAGGrid/customAggrid.js";
25
+ import "ag-grid-community";
26
+ import "react-papaparse";
27
+ import "react-csv-downloader";
28
+ import * as yup from "yup";
29
+ import "../../inputs/reactHookForm/numbers/RangeInput.js";
30
+ import "../../../utils/conversionUtils.js";
31
+ import "../../../utils/yupConfig.js";
32
+ import "@react-querybuilder/material";
33
+ import "../../filter/expert/expertFilterConstants.js";
34
+ import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
35
+ import "uuid";
36
+ import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
37
+ import "react-querybuilder";
38
+ import "../common/widget/parameter-line-slider.js";
39
+ import { getLimitReductionsFormSchema, LIMIT_REDUCTIONS_FORM } from "../common/limitreductions/columns-definitions.js";
40
+ import { toFormValuesLimitReductions } from "../common/limitreductions/limit-reductions-form-util.js";
41
+ import { PARAM_LIMIT_REDUCTION, SPECIFIC_PARAMETERS, COMMON_PARAMETERS, PARAM_PROVIDER_OPENLOADFLOW } from "./constants.js";
42
+ const useLoadFlowParametersForm = (parametersBackend, enableDeveloperMode, parametersUuid, name, description) => {
43
+ const [
44
+ providers,
45
+ provider,
46
+ ,
47
+ ,
48
+ ,
49
+ params,
50
+ ,
51
+ updateParameters,
52
+ ,
53
+ specificParamsDescriptions,
54
+ defaultLimitReductions
55
+ ] = parametersBackend;
56
+ const [currentProvider, setCurrentProvider] = useState(params == null ? void 0 : params.provider);
57
+ const [selectedTab, setSelectedTab] = useState(TabValues.GENERAL);
58
+ const [tabIndexesWithError, setTabIndexesWithError] = useState([]);
59
+ const handleTabChange = useCallback((event, newValue) => {
60
+ setSelectedTab(newValue);
61
+ }, []);
62
+ const specificParametersValues = useMemo(() => {
63
+ const specificParams = currentProvider ? specificParamsDescriptions == null ? void 0 : specificParamsDescriptions[currentProvider] : void 0;
64
+ return getDefaultSpecificParamsValues(specificParams);
65
+ }, [currentProvider, specificParamsDescriptions]);
66
+ const specificParameters = useMemo(() => {
67
+ const specificParams = currentProvider ? specificParamsDescriptions == null ? void 0 : specificParamsDescriptions[currentProvider] : void 0;
68
+ return specificParams == null ? void 0 : specificParams.map((param) => ({
69
+ name: param.name,
70
+ type: param.type,
71
+ label: param.label,
72
+ description: param.description,
73
+ possibleValues: param.possibleValues,
74
+ defaultValue: param.defaultValue
75
+ }));
76
+ }, [currentProvider, specificParamsDescriptions]);
77
+ const formSchema = useMemo(() => {
78
+ var _a;
79
+ return yup.object({
80
+ ...getDialogLoadFlowParametersFormSchema(name),
81
+ [PROVIDER]: yup.string().required(),
82
+ [PARAM_LIMIT_REDUCTION]: yup.number().nullable(),
83
+ ...getCommonLoadFlowParametersFormSchema().fields,
84
+ ...getLimitReductionsFormSchema(
85
+ (params == null ? void 0 : params.limitReductions) ? (_a = params.limitReductions[0]) == null ? void 0 : _a.temporaryLimitReductions.length : 0
86
+ ).fields,
87
+ ...getSpecificLoadFlowParametersFormSchema(specificParameters).fields
88
+ });
89
+ }, [name, params == null ? void 0 : params.limitReductions, specificParameters]);
90
+ const formMethods = useForm({
91
+ defaultValues: {
92
+ [NAME]: name,
93
+ [DESCRIPTION_INPUT]: description,
94
+ [PROVIDER]: provider,
95
+ [PARAM_LIMIT_REDUCTION]: null,
96
+ [COMMON_PARAMETERS]: {
97
+ ...params == null ? void 0 : params.commonParameters
98
+ },
99
+ [SPECIFIC_PARAMETERS]: {
100
+ ...specificParametersValues
101
+ },
102
+ [LIMIT_REDUCTIONS_FORM]: []
103
+ },
104
+ resolver: yupResolver(formSchema)
105
+ });
106
+ const { watch, reset } = formMethods;
107
+ const watchProvider = watch("provider");
108
+ const toLimitReductions = useCallback(
109
+ (formLimits) => {
110
+ if ((formLimits == null ? void 0 : formLimits.length) === 0) {
111
+ return [];
112
+ }
113
+ if (watchProvider === PARAM_PROVIDER_OPENLOADFLOW) {
114
+ if (!(params == null ? void 0 : params.limitReductions)) {
115
+ return defaultLimitReductions.map(
116
+ (vlLimits, indexVl) => mapLimitReductions(vlLimits, formLimits, indexVl)
117
+ );
118
+ }
119
+ return params == null ? void 0 : params.limitReductions.map(
120
+ (vlLimits, indexVl) => mapLimitReductions(vlLimits, formLimits, indexVl)
121
+ );
122
+ }
123
+ return [];
124
+ },
125
+ [defaultLimitReductions, params == null ? void 0 : params.limitReductions, watchProvider]
126
+ );
127
+ const getSpecificParametersPerProvider = (formData, _specificParametersValues) => {
128
+ return Object.keys(formData[SPECIFIC_PARAMETERS]).reduce(
129
+ (acc, key) => {
130
+ if (_specificParametersValues[key].toString() !== formData[SPECIFIC_PARAMETERS][key].toString()) {
131
+ acc[key] = formData[SPECIFIC_PARAMETERS][key].toString();
132
+ }
133
+ return acc;
134
+ },
135
+ {}
136
+ );
137
+ };
138
+ const formatNewParams = useCallback(
139
+ (formData) => {
140
+ return {
141
+ provider: formData[PROVIDER],
142
+ limitReduction: formData[PARAM_LIMIT_REDUCTION],
143
+ commonParameters: {
144
+ ...formData[COMMON_PARAMETERS]
145
+ },
146
+ specificParametersPerProvider: {
147
+ [formData.provider]: getSpecificParametersPerProvider(formData, specificParametersValues)
148
+ },
149
+ limitReductions: toLimitReductions(formData[LIMIT_REDUCTIONS_FORM])
150
+ };
151
+ },
152
+ [specificParametersValues, toLimitReductions]
153
+ );
154
+ const toLoadFlowFormValues = useCallback(
155
+ (_params) => {
156
+ const specificParams = _params.provider ? specificParamsDescriptions == null ? void 0 : specificParamsDescriptions[_params.provider] : void 0;
157
+ const specificParamsPerProvider = _params.specificParametersPerProvider[_params.provider];
158
+ const formatted = specificParams == null ? void 0 : specificParams.reduce((acc, param) => {
159
+ if (specificParamsPerProvider && Object.prototype.hasOwnProperty.call(specificParamsPerProvider, param.name)) {
160
+ if (param.type === ParameterType.BOOLEAN) {
161
+ acc[param.name] = specificParamsPerProvider[param.name] === "true";
162
+ } else if (param.type === ParameterType.STRING_LIST) {
163
+ acc[param.name] = specificParamsPerProvider[param.name] !== "" ? specificParamsPerProvider[param.name].split(",") : [];
164
+ } else {
165
+ acc[param.name] = specificParamsPerProvider[param.name];
166
+ }
167
+ } else {
168
+ acc[param.name] = getDefaultSpecificParamsValues([param])[param.name];
169
+ }
170
+ return acc;
171
+ }, {});
172
+ return {
173
+ [PROVIDER]: _params.provider,
174
+ [PARAM_LIMIT_REDUCTION]: _params.limitReduction,
175
+ [COMMON_PARAMETERS]: {
176
+ ..._params.commonParameters
177
+ },
178
+ [SPECIFIC_PARAMETERS]: {
179
+ ...formatted
180
+ },
181
+ ...toFormValuesLimitReductions(_params.limitReductions)
182
+ };
183
+ },
184
+ [specificParamsDescriptions]
185
+ );
186
+ const paramsLoaded = useMemo(() => !!params && !!currentProvider, [currentProvider, params]);
187
+ const formattedProviders = useMemo(() => {
188
+ return Object.entries(providers).filter(([key]) => !key.includes("DynaFlow") || enableDeveloperMode).map(([key, value]) => ({
189
+ id: key,
190
+ label: value
191
+ }));
192
+ }, [providers, enableDeveloperMode]);
193
+ const onValidationError = useCallback(
194
+ (errors) => {
195
+ const tabsInError = [];
196
+ if ((errors == null ? void 0 : errors[LIMIT_REDUCTIONS_FORM]) && TabValues.LIMIT_REDUCTIONS !== selectedTab) {
197
+ tabsInError.push(TabValues.LIMIT_REDUCTIONS);
198
+ }
199
+ if (((errors == null ? void 0 : errors[SPECIFIC_PARAMETERS]) || (errors == null ? void 0 : errors[COMMON_PARAMETERS]) || (errors == null ? void 0 : errors[PROVIDER])) && TabValues.GENERAL !== selectedTab) {
200
+ tabsInError.push(TabValues.GENERAL);
201
+ }
202
+ setTabIndexesWithError(tabsInError);
203
+ },
204
+ [selectedTab]
205
+ );
206
+ const onSaveInline = useCallback(
207
+ (formData) => {
208
+ setTabIndexesWithError([]);
209
+ updateParameters(formatNewParams(formData));
210
+ },
211
+ [updateParameters, formatNewParams]
212
+ );
213
+ const onSaveDialog = useCallback(
214
+ (formData) => {
215
+ if (parametersUuid) {
216
+ setTabIndexesWithError([]);
217
+ updateParameter(
218
+ parametersUuid,
219
+ formatNewParams(formData),
220
+ formData[NAME],
221
+ ElementType.LOADFLOW_PARAMETERS,
222
+ formData[DESCRIPTION_INPUT] ?? ""
223
+ );
224
+ }
225
+ },
226
+ [parametersUuid, formatNewParams]
227
+ );
228
+ useEffect(() => {
229
+ if (!params) {
230
+ return;
231
+ }
232
+ reset(toLoadFlowFormValues(params));
233
+ }, [paramsLoaded, params, reset, specificParamsDescriptions, toLoadFlowFormValues]);
234
+ useEffect(() => {
235
+ if (watchProvider !== currentProvider) {
236
+ setCurrentProvider(watchProvider);
237
+ setSpecificParameters(watchProvider, specificParamsDescriptions, formMethods);
238
+ setLimitReductions(watchProvider, defaultLimitReductions, formMethods);
239
+ }
240
+ }, [currentProvider, defaultLimitReductions, formMethods, specificParamsDescriptions, watchProvider]);
241
+ return {
242
+ formMethods,
243
+ formSchema,
244
+ selectedTab,
245
+ handleTabChange,
246
+ tabIndexesWithError,
247
+ formattedProviders,
248
+ specificParameters,
249
+ defaultLimitReductions,
250
+ toLoadFlowFormValues,
251
+ formatNewParams,
252
+ params,
253
+ currentProvider,
254
+ setCurrentProvider,
255
+ paramsLoaded,
256
+ onValidationError,
257
+ onSaveInline,
258
+ onSaveDialog
259
+ };
260
+ };
261
+ export {
262
+ useLoadFlowParametersForm
263
+ };
@@ -0,0 +1,150 @@
1
+ import { Theme } from '@mui/material';
2
+ /**
3
+ * Styles use in parameter forms
4
+ * @deprecated to discourage its use outside of intended components
5
+ */
6
+ export declare const parametersStyles: {
7
+ title: (theme: Theme) => {
8
+ padding: string;
9
+ };
10
+ minWidthMedium: (theme: Theme) => {
11
+ minWidth: string;
12
+ };
13
+ parameterName: (theme: Theme) => {
14
+ fontWeight: string;
15
+ marginTop: string;
16
+ };
17
+ controlItem: {
18
+ justifyContent: string;
19
+ flexGrow: number;
20
+ };
21
+ controlParametersItem: {
22
+ justifyContent: string;
23
+ flexGrow: number;
24
+ height: string;
25
+ paddingBottom: number;
26
+ };
27
+ button: (theme: Theme) => {
28
+ marginBottom: string;
29
+ marginLeft: string;
30
+ };
31
+ subgroupParameters: (theme: Theme) => {
32
+ marginTop: string;
33
+ marginBottom: string;
34
+ };
35
+ subgroupParametersAccordion: {
36
+ '&:before': {
37
+ display: string;
38
+ };
39
+ background: string;
40
+ };
41
+ subgroupParametersAccordionSummary: (theme: Theme) => {
42
+ flexDirection: string;
43
+ '& .MuiAccordionSummary-expandIconWrapper': {
44
+ transform: string;
45
+ };
46
+ '& .MuiAccordionSummary-expandIconWrapper.Mui-expanded': {
47
+ transform: string;
48
+ };
49
+ '& .MuiAccordionSummary-content': {
50
+ marginLeft: string;
51
+ };
52
+ };
53
+ subgroupParametersAccordionDetails: (theme: Theme) => {
54
+ padding: string;
55
+ };
56
+ marginTopButton: {
57
+ marginTop: string;
58
+ position: string;
59
+ bottom: number;
60
+ };
61
+ scrollableGrid: (theme: Theme) => {
62
+ overflowY: string;
63
+ overflowX: string;
64
+ maxHeight: string;
65
+ paddingRight: string;
66
+ paddingTop: string;
67
+ paddingBottom: string;
68
+ flexGrow: number;
69
+ };
70
+ singleItem: (theme: Theme) => {
71
+ display: string;
72
+ flex: string;
73
+ alignItems: string;
74
+ justifyContent: string;
75
+ marginTop: string;
76
+ marginBottom: string;
77
+ };
78
+ firstTextField: (theme: Theme) => {
79
+ marginLeft: string;
80
+ };
81
+ secondTextField: (theme: Theme) => {
82
+ marginLeft: string;
83
+ marginRight: string;
84
+ };
85
+ singleTextField: (theme: Theme) => {
86
+ display: string;
87
+ marginRight: string;
88
+ marginLeft: string;
89
+ };
90
+ tooltip: (theme: Theme) => {
91
+ marginLeft: string;
92
+ };
93
+ text: (theme: Theme) => {
94
+ display: string;
95
+ marginBottom: string;
96
+ marginTop: string;
97
+ };
98
+ multipleItems: (theme: Theme) => {
99
+ display: string;
100
+ flex: string;
101
+ alignItems: string;
102
+ justifyContent: string;
103
+ marginTop: string;
104
+ marginBottom: string;
105
+ };
106
+ tabWithError: (theme: Theme) => {
107
+ '&.Mui-selected': {
108
+ color: string;
109
+ };
110
+ color: string;
111
+ };
112
+ tabWithErrorIndicator: (theme: Theme) => {
113
+ backgroundColor: string;
114
+ };
115
+ panel: (theme: Theme) => {
116
+ marginTop: string;
117
+ marginBottom: string;
118
+ };
119
+ adjustExistingLimitsInfo: (theme: Theme) => {
120
+ display: string;
121
+ alignItems: string;
122
+ marginTop: string;
123
+ marginBottom: string;
124
+ };
125
+ circularProgress: (theme: Theme) => {
126
+ marginRight: string;
127
+ color: string;
128
+ };
129
+ icon: (theme: Theme) => {
130
+ width: string;
131
+ };
132
+ modificationsTitle: (theme: Theme) => {
133
+ display: string;
134
+ alignItems: string;
135
+ margin: string;
136
+ padding: string;
137
+ backgroundColor: string;
138
+ color: string;
139
+ overflow: string;
140
+ };
141
+ };
142
+ export declare function getTabIndicatorStyle<T extends number | string>(tabIndexesWithError: T[], index: T): ((theme: Theme) => {
143
+ backgroundColor: string;
144
+ }) | undefined;
145
+ export declare function getTabStyle<T extends number | string>(tabIndexesWithError: T[], index: T): ((theme: Theme) => {
146
+ '&.Mui-selected': {
147
+ color: string;
148
+ };
149
+ color: string;
150
+ }) | undefined;