@gridsuite/commons-ui 0.98.0 → 0.99.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 (122) hide show
  1. package/dist/components/dialogs/customMuiDialog/CustomMuiDialog.js +1 -1
  2. package/dist/components/index.d.ts +1 -0
  3. package/dist/components/index.js +94 -1
  4. package/dist/components/inputs/index.js +2 -1
  5. package/dist/components/inputs/reactHookForm/DirectoryItemsInput.d.ts +1 -0
  6. package/dist/components/inputs/reactHookForm/DirectoryItemsInput.js +2 -0
  7. package/dist/components/inputs/reactHookForm/index.js +2 -1
  8. package/dist/components/inputs/reactHookForm/utils/HelperPreviousValue.js +1 -1
  9. package/dist/components/parameters/common/ProviderParam.d.ts +7 -0
  10. package/dist/components/parameters/common/ProviderParam.js +51 -0
  11. package/dist/components/parameters/common/computing-type.d.ts +20 -0
  12. package/dist/components/parameters/common/computing-type.js +46 -0
  13. package/dist/components/parameters/common/constant.d.ts +8 -0
  14. package/dist/components/parameters/common/constant.js +18 -0
  15. package/dist/components/parameters/common/index.d.ts +15 -0
  16. package/dist/components/parameters/common/index.js +61 -0
  17. package/dist/components/parameters/common/limitreductions/columns-definitions.d.ts +77 -0
  18. package/dist/components/parameters/common/limitreductions/columns-definitions.js +83 -0
  19. package/dist/components/parameters/common/limitreductions/index.d.ts +11 -0
  20. package/dist/components/parameters/common/limitreductions/index.js +21 -0
  21. package/dist/components/parameters/common/limitreductions/limit-reduction-table-cell.d.ts +5 -0
  22. package/dist/components/parameters/common/limitreductions/limit-reduction-table-cell.js +38 -0
  23. package/dist/components/parameters/common/limitreductions/limit-reduction-table-row.d.ts +7 -0
  24. package/dist/components/parameters/common/limitreductions/limit-reduction-table-row.js +9 -0
  25. package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.d.ts +29 -0
  26. package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.js +27 -0
  27. package/dist/components/parameters/common/limitreductions/limit-reductions-table-form.d.ts +4 -0
  28. package/dist/components/parameters/common/limitreductions/limit-reductions-table-form.js +87 -0
  29. package/dist/components/parameters/common/line-separator.d.ts +1 -0
  30. package/dist/components/parameters/common/line-separator.js +8 -0
  31. package/dist/components/parameters/common/parameters-creation-dialog.d.ts +13 -0
  32. package/dist/components/parameters/common/parameters-creation-dialog.js +88 -0
  33. package/dist/components/parameters/common/parameters.d.ts +20 -0
  34. package/dist/components/parameters/common/parameters.js +42 -0
  35. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-cell.d.ts +6 -0
  36. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-cell.js +42 -0
  37. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-row.d.ts +8 -0
  38. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-row.js +17 -0
  39. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table.d.ts +8 -0
  40. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table.js +55 -0
  41. package/dist/components/parameters/common/voltage-level-table/index.d.ts +9 -0
  42. package/dist/components/parameters/common/voltage-level-table/index.js +8 -0
  43. package/dist/components/parameters/common/widget/index.d.ts +11 -0
  44. package/dist/components/parameters/common/widget/index.js +13 -0
  45. package/dist/components/parameters/common/widget/parameter-float.d.ts +10 -0
  46. package/dist/components/parameters/common/widget/parameter-float.js +51 -0
  47. package/dist/components/parameters/common/widget/parameter-group.d.ts +11 -0
  48. package/dist/components/parameters/common/widget/parameter-group.js +54 -0
  49. package/dist/components/parameters/common/widget/parameter-line-directory-items-input.d.ts +15 -0
  50. package/dist/components/parameters/common/widget/parameter-line-directory-items-input.js +55 -0
  51. package/dist/components/parameters/common/widget/parameter-line-slider.d.ts +12 -0
  52. package/dist/components/parameters/common/widget/parameter-line-slider.js +70 -0
  53. package/dist/components/parameters/common/widget/parameter-switch.d.ts +7 -0
  54. package/dist/components/parameters/common/widget/parameter-switch.js +9 -0
  55. package/dist/components/parameters/index.d.ts +9 -0
  56. package/dist/components/parameters/index.js +94 -0
  57. package/dist/components/parameters/loadflow/constants.d.ts +33 -0
  58. package/dist/components/parameters/loadflow/constants.js +59 -0
  59. package/dist/components/parameters/loadflow/index.d.ts +9 -0
  60. package/dist/components/parameters/loadflow/index.js +31 -0
  61. package/dist/components/parameters/loadflow/load-flow-general-parameters.d.ts +8 -0
  62. package/dist/components/parameters/loadflow/load-flow-general-parameters.js +179 -0
  63. package/dist/components/parameters/loadflow/load-flow-parameter-field.d.ts +19 -0
  64. package/dist/components/parameters/loadflow/load-flow-parameter-field.js +90 -0
  65. package/dist/components/parameters/loadflow/load-flow-parameters-content.d.ts +13 -0
  66. package/dist/components/parameters/loadflow/load-flow-parameters-content.js +82 -0
  67. package/dist/components/parameters/loadflow/load-flow-parameters-context.d.ts +13 -0
  68. package/dist/components/parameters/loadflow/load-flow-parameters-context.js +5 -0
  69. package/dist/components/parameters/loadflow/load-flow-parameters-dialog.d.ts +15 -0
  70. package/dist/components/parameters/loadflow/load-flow-parameters-dialog.js +112 -0
  71. package/dist/components/parameters/loadflow/load-flow-parameters-form.d.ts +9 -0
  72. package/dist/components/parameters/loadflow/load-flow-parameters-form.js +102 -0
  73. package/dist/components/parameters/loadflow/load-flow-parameters-header.d.ts +12 -0
  74. package/dist/components/parameters/loadflow/load-flow-parameters-header.js +84 -0
  75. package/dist/components/parameters/loadflow/load-flow-parameters-inline.d.ts +10 -0
  76. package/dist/components/parameters/loadflow/load-flow-parameters-inline.js +162 -0
  77. package/dist/components/parameters/loadflow/load-flow-parameters-provider.d.ts +4 -0
  78. package/dist/components/parameters/loadflow/load-flow-parameters-provider.js +20 -0
  79. package/dist/components/parameters/loadflow/load-flow-parameters-utils.d.ts +100 -0
  80. package/dist/components/parameters/loadflow/load-flow-parameters-utils.js +158 -0
  81. package/dist/components/parameters/loadflow/use-load-flow-context.d.ts +7 -0
  82. package/dist/components/parameters/loadflow/use-load-flow-context.js +12 -0
  83. package/dist/components/parameters/loadflow/use-load-flow-parameters-form.d.ts +32 -0
  84. package/dist/components/parameters/loadflow/use-load-flow-parameters-form.js +263 -0
  85. package/dist/components/parameters/parameters-style.d.ts +150 -0
  86. package/dist/components/parameters/parameters-style.js +146 -0
  87. package/dist/hooks/index.d.ts +1 -0
  88. package/dist/hooks/index.js +3 -0
  89. package/dist/hooks/use-parameters-backend.d.ts +11 -0
  90. package/dist/hooks/use-parameters-backend.js +217 -0
  91. package/dist/index.js +115 -3
  92. package/dist/services/explore.d.ts +3 -0
  93. package/dist/services/explore.js +26 -1
  94. package/dist/services/index.js +6 -3
  95. package/dist/services/loadflow.d.ts +9 -0
  96. package/dist/services/loadflow.js +59 -0
  97. package/dist/services/utils.d.ts +3 -8
  98. package/dist/services/utils.js +5 -0
  99. package/dist/translations/en/index.d.ts +1 -0
  100. package/dist/translations/en/index.js +2 -0
  101. package/dist/translations/en/parameters.d.ts +67 -0
  102. package/dist/translations/en/parameters.js +64 -0
  103. package/dist/translations/fr/index.d.ts +1 -0
  104. package/dist/translations/fr/index.js +2 -0
  105. package/dist/translations/fr/parameters.d.ts +67 -0
  106. package/dist/translations/fr/parameters.js +64 -0
  107. package/dist/utils/index.js +9 -0
  108. package/dist/utils/types/dynamic-security-analysis.type.d.ts +13 -0
  109. package/dist/utils/types/dynamic-security-analysis.type.js +1 -0
  110. package/dist/utils/types/dynamic-simulation.type.d.ts +111 -0
  111. package/dist/utils/types/dynamic-simulation.type.js +8 -0
  112. package/dist/utils/types/index.d.ts +6 -0
  113. package/dist/utils/types/index.js +9 -0
  114. package/dist/utils/types/loadflow.type.d.ts +11 -0
  115. package/dist/utils/types/loadflow.type.js +1 -0
  116. package/dist/utils/types/non-evacuated-energy.type.d.ts +60 -0
  117. package/dist/utils/types/non-evacuated-energy.type.js +12 -0
  118. package/dist/utils/types/parameters.type.d.ts +41 -0
  119. package/dist/utils/types/parameters.type.js +12 -0
  120. package/dist/utils/types/sensitivity-analysis.type.d.ts +101 -0
  121. package/dist/utils/types/sensitivity-analysis.type.js +16 -0
  122. package/package.json +2 -1
@@ -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;
@@ -0,0 +1,146 @@
1
+ const parametersStyles = {
2
+ title: (theme) => ({
3
+ padding: theme.spacing(2)
4
+ }),
5
+ minWidthMedium: (theme) => ({
6
+ minWidth: theme.spacing(20)
7
+ }),
8
+ parameterName: (theme) => ({
9
+ fontWeight: "bold",
10
+ marginTop: theme.spacing(1)
11
+ }),
12
+ controlItem: {
13
+ justifyContent: "flex-end",
14
+ flexGrow: 1
15
+ },
16
+ controlParametersItem: {
17
+ justifyContent: "flex-start",
18
+ flexGrow: 1,
19
+ height: "fit-content",
20
+ paddingBottom: 4
21
+ },
22
+ button: (theme) => ({
23
+ marginBottom: theme.spacing(2),
24
+ marginLeft: theme.spacing(1)
25
+ }),
26
+ subgroupParameters: (theme) => ({
27
+ marginTop: theme.spacing(2),
28
+ marginBottom: theme.spacing(1)
29
+ }),
30
+ subgroupParametersAccordion: {
31
+ "&:before": {
32
+ display: "none"
33
+ },
34
+ background: "none"
35
+ },
36
+ subgroupParametersAccordionSummary: (theme) => ({
37
+ flexDirection: "row-reverse",
38
+ "& .MuiAccordionSummary-expandIconWrapper": {
39
+ transform: "rotate(-90deg)"
40
+ },
41
+ "& .MuiAccordionSummary-expandIconWrapper.Mui-expanded": {
42
+ transform: "rotate(0deg)"
43
+ },
44
+ "& .MuiAccordionSummary-content": {
45
+ marginLeft: theme.spacing(0)
46
+ }
47
+ }),
48
+ subgroupParametersAccordionDetails: (theme) => ({
49
+ padding: theme.spacing(0)
50
+ }),
51
+ marginTopButton: {
52
+ marginTop: "10px",
53
+ position: "sticky",
54
+ bottom: 0
55
+ },
56
+ scrollableGrid: (theme) => ({
57
+ overflowY: "auto",
58
+ overflowX: "hidden",
59
+ maxHeight: "85%",
60
+ // TODO This needs to be refactored
61
+ paddingRight: theme.spacing(2),
62
+ paddingTop: theme.spacing(2),
63
+ paddingBottom: theme.spacing(1),
64
+ flexGrow: 1
65
+ }),
66
+ singleItem: (theme) => ({
67
+ display: "flex",
68
+ flex: "auto",
69
+ alignItems: "flex-start",
70
+ justifyContent: "space-between",
71
+ marginTop: theme.spacing(1),
72
+ marginBottom: theme.spacing(1)
73
+ }),
74
+ firstTextField: (theme) => ({
75
+ marginLeft: theme.spacing(3)
76
+ }),
77
+ secondTextField: (theme) => ({
78
+ marginLeft: theme.spacing(3),
79
+ marginRight: theme.spacing(2)
80
+ }),
81
+ singleTextField: (theme) => ({
82
+ display: "flex",
83
+ marginRight: theme.spacing(2),
84
+ marginLeft: theme.spacing(1)
85
+ }),
86
+ tooltip: (theme) => ({
87
+ marginLeft: theme.spacing(1)
88
+ }),
89
+ text: (theme) => ({
90
+ display: "flex",
91
+ marginBottom: theme.spacing(1),
92
+ marginTop: theme.spacing(1)
93
+ }),
94
+ multipleItems: (theme) => ({
95
+ display: "flex",
96
+ flex: "auto",
97
+ alignItems: "flex-start",
98
+ justifyContent: "space-between",
99
+ marginTop: theme.spacing(1),
100
+ marginBottom: theme.spacing(1)
101
+ }),
102
+ tabWithError: (theme) => ({
103
+ "&.Mui-selected": { color: theme.palette.error.main },
104
+ color: theme.palette.error.main
105
+ }),
106
+ tabWithErrorIndicator: (theme) => ({
107
+ backgroundColor: theme.palette.error.main
108
+ }),
109
+ panel: (theme) => ({
110
+ marginTop: theme.spacing(2),
111
+ marginBottom: theme.spacing(1)
112
+ }),
113
+ adjustExistingLimitsInfo: (theme) => ({
114
+ display: "flex",
115
+ alignItems: "center",
116
+ marginTop: theme.spacing(1),
117
+ marginBottom: theme.spacing(1)
118
+ }),
119
+ circularProgress: (theme) => ({
120
+ marginRight: theme.spacing(2),
121
+ color: theme.palette.primary.contrastText
122
+ }),
123
+ icon: (theme) => ({
124
+ width: theme.spacing(3)
125
+ }),
126
+ modificationsTitle: (theme) => ({
127
+ display: "flex",
128
+ alignItems: "center",
129
+ margin: theme.spacing(0),
130
+ padding: theme.spacing(1),
131
+ backgroundColor: theme.palette.primary.main,
132
+ color: theme.palette.primary.contrastText,
133
+ overflow: "hidden"
134
+ })
135
+ };
136
+ function getTabIndicatorStyle(tabIndexesWithError, index) {
137
+ return tabIndexesWithError.includes(index) ? parametersStyles.tabWithErrorIndicator : void 0;
138
+ }
139
+ function getTabStyle(tabIndexesWithError, index) {
140
+ return tabIndexesWithError.includes(index) ? parametersStyles.tabWithError : void 0;
141
+ }
142
+ export {
143
+ getTabIndicatorStyle,
144
+ getTabStyle,
145
+ parametersStyles
146
+ };
@@ -15,3 +15,4 @@ export * from './usePrevious';
15
15
  export * from './useSnackMessage';
16
16
  export * from './useFormatLabelWithUnit';
17
17
  export * from './useSelectAppearance';
18
+ export * from './use-parameters-backend';
@@ -10,7 +10,9 @@ import { usePrevious } from "./usePrevious.js";
10
10
  import { useSnackMessage } from "./useSnackMessage.js";
11
11
  import { useFormatLabelWithUnit } from "./useFormatLabelWithUnit.js";
12
12
  import { useSelectAppearance } from "./useSelectAppearance.js";
13
+ import { OptionalServicesStatus, useParametersBackend } from "./use-parameters-backend.js";
13
14
  export {
15
+ OptionalServicesStatus,
14
16
  getComputedLanguage,
15
17
  getSystemLanguage,
16
18
  useConfidentialityWarning,
@@ -19,6 +21,7 @@ export {
19
21
  useIntlRef,
20
22
  useLocalizedCountries,
21
23
  useModificationLabelComputer,
24
+ useParametersBackend,
22
25
  usePredefinedProperties,
23
26
  usePrevious,
24
27
  useSelectAppearance,
@@ -0,0 +1,11 @@
1
+ import { UUID } from 'crypto';
2
+ import { User } from 'oidc-client';
3
+ import { ComputingType } from '../components/parameters/common/computing-type';
4
+ import { ILimitReductionsByVoltageLevel } from '../components/parameters/common/limitreductions/columns-definitions';
5
+ import { ParametersInfos, SpecificParametersInfos, UseParametersBackendReturnProps } from '../utils/types/parameters.type';
6
+ export declare enum OptionalServicesStatus {
7
+ Up = "UP",
8
+ Down = "DOWN",
9
+ Pending = "PENDING"
10
+ }
11
+ export declare const useParametersBackend: <T extends ComputingType>(user: User | null, studyUuid: UUID | null, type: T, optionalServiceStatus: OptionalServicesStatus | undefined, backendFetchProviders: () => Promise<string[]>, backendFetchProvider: ((studyUuid: UUID) => Promise<string>) | null, backendFetchDefaultProvider: () => Promise<string>, backendUpdateProvider: ((studyUuid: UUID, newProvider: string) => Promise<void>) | null, backendFetchParameters: (studyUuid: UUID) => Promise<ParametersInfos<T>>, backendUpdateParameters?: (studyUuid: UUID, newParam: ParametersInfos<T> | null) => Promise<any>, backendFetchSpecificParametersDescription?: () => Promise<SpecificParametersInfos>, backendFetchDefaultLimitReductions?: () => Promise<ILimitReductionsByVoltageLevel[]>) => UseParametersBackendReturnProps<T>;