@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.
- package/dist/components/announcement/AnnouncementBanner.d.ts +15 -0
- package/dist/components/announcement/AnnouncementBanner.js +87 -0
- package/dist/components/announcement/AnnouncementNotification.d.ts +7 -0
- package/dist/components/announcement/AnnouncementNotification.js +10 -0
- package/dist/components/announcement/index.d.ts +3 -0
- package/dist/components/announcement/index.js +8 -0
- package/dist/components/announcement/useGlobalAnnouncement.d.ts +10 -0
- package/dist/components/announcement/useGlobalAnnouncement.js +48 -0
- package/dist/components/dialogs/customMuiDialog/CustomMuiDialog.js +1 -1
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.js +104 -3
- package/dist/components/inputs/index.js +2 -1
- package/dist/components/inputs/reactHookForm/DirectoryItemsInput.d.ts +1 -0
- package/dist/components/inputs/reactHookForm/DirectoryItemsInput.js +2 -0
- package/dist/components/inputs/reactHookForm/index.js +2 -1
- package/dist/components/inputs/reactHookForm/text/TextInput.d.ts +3 -1
- package/dist/components/inputs/reactHookForm/text/TextInput.js +4 -2
- package/dist/components/inputs/reactHookForm/utils/HelperPreviousValue.js +1 -1
- package/dist/components/parameters/common/ProviderParam.d.ts +7 -0
- package/dist/components/parameters/common/ProviderParam.js +51 -0
- package/dist/components/parameters/common/computing-type.d.ts +20 -0
- package/dist/components/parameters/common/computing-type.js +46 -0
- package/dist/components/parameters/common/constant.d.ts +8 -0
- package/dist/components/parameters/common/constant.js +18 -0
- package/dist/components/parameters/common/index.d.ts +15 -0
- package/dist/components/parameters/common/index.js +61 -0
- package/dist/components/parameters/common/limitreductions/columns-definitions.d.ts +77 -0
- package/dist/components/parameters/common/limitreductions/columns-definitions.js +83 -0
- package/dist/components/parameters/common/limitreductions/index.d.ts +11 -0
- package/dist/components/parameters/common/limitreductions/index.js +21 -0
- package/dist/components/parameters/common/limitreductions/limit-reduction-table-cell.d.ts +5 -0
- package/dist/components/parameters/common/limitreductions/limit-reduction-table-cell.js +38 -0
- package/dist/components/parameters/common/limitreductions/limit-reduction-table-row.d.ts +7 -0
- package/dist/components/parameters/common/limitreductions/limit-reduction-table-row.js +9 -0
- package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.d.ts +29 -0
- package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.js +27 -0
- package/dist/components/parameters/common/limitreductions/limit-reductions-table-form.d.ts +4 -0
- package/dist/components/parameters/common/limitreductions/limit-reductions-table-form.js +87 -0
- package/dist/components/parameters/common/line-separator.d.ts +1 -0
- package/dist/components/parameters/common/line-separator.js +8 -0
- package/dist/components/parameters/common/parameters-creation-dialog.d.ts +13 -0
- package/dist/components/parameters/common/parameters-creation-dialog.js +88 -0
- package/dist/components/parameters/common/parameters.d.ts +20 -0
- package/dist/components/parameters/common/parameters.js +42 -0
- package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-cell.d.ts +6 -0
- package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-cell.js +42 -0
- package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-row.d.ts +8 -0
- package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-row.js +17 -0
- package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table.d.ts +8 -0
- package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table.js +55 -0
- package/dist/components/parameters/common/voltage-level-table/index.d.ts +9 -0
- package/dist/components/parameters/common/voltage-level-table/index.js +8 -0
- package/dist/components/parameters/common/widget/index.d.ts +11 -0
- package/dist/components/parameters/common/widget/index.js +13 -0
- package/dist/components/parameters/common/widget/parameter-float.d.ts +10 -0
- package/dist/components/parameters/common/widget/parameter-float.js +51 -0
- package/dist/components/parameters/common/widget/parameter-group.d.ts +11 -0
- package/dist/components/parameters/common/widget/parameter-group.js +54 -0
- package/dist/components/parameters/common/widget/parameter-line-directory-items-input.d.ts +15 -0
- package/dist/components/parameters/common/widget/parameter-line-directory-items-input.js +55 -0
- package/dist/components/parameters/common/widget/parameter-line-slider.d.ts +12 -0
- package/dist/components/parameters/common/widget/parameter-line-slider.js +70 -0
- package/dist/components/parameters/common/widget/parameter-switch.d.ts +7 -0
- package/dist/components/parameters/common/widget/parameter-switch.js +9 -0
- package/dist/components/parameters/index.d.ts +9 -0
- package/dist/components/parameters/index.js +94 -0
- package/dist/components/parameters/loadflow/constants.d.ts +33 -0
- package/dist/components/parameters/loadflow/constants.js +59 -0
- package/dist/components/parameters/loadflow/index.d.ts +9 -0
- package/dist/components/parameters/loadflow/index.js +31 -0
- package/dist/components/parameters/loadflow/load-flow-general-parameters.d.ts +8 -0
- package/dist/components/parameters/loadflow/load-flow-general-parameters.js +179 -0
- package/dist/components/parameters/loadflow/load-flow-parameter-field.d.ts +19 -0
- package/dist/components/parameters/loadflow/load-flow-parameter-field.js +90 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-content.d.ts +13 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-content.js +82 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-context.d.ts +13 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-context.js +5 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-dialog.d.ts +15 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-dialog.js +112 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-form.d.ts +9 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-form.js +102 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-header.d.ts +12 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-header.js +84 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-inline.d.ts +10 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-inline.js +162 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-provider.d.ts +4 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-provider.js +20 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-utils.d.ts +100 -0
- package/dist/components/parameters/loadflow/load-flow-parameters-utils.js +158 -0
- package/dist/components/parameters/loadflow/use-load-flow-context.d.ts +7 -0
- package/dist/components/parameters/loadflow/use-load-flow-context.js +12 -0
- package/dist/components/parameters/loadflow/use-load-flow-parameters-form.d.ts +32 -0
- package/dist/components/parameters/loadflow/use-load-flow-parameters-form.js +263 -0
- package/dist/components/parameters/parameters-style.d.ts +150 -0
- package/dist/components/parameters/parameters-style.js +146 -0
- package/dist/components/topBar/DevModeBanner.d.ts +1 -0
- package/dist/components/topBar/DevModeBanner.js +42 -0
- package/dist/components/topBar/TopBar.js +302 -305
- package/dist/components/topBar/UserInformationDialog.js +1 -1
- package/dist/components/topBar/index.d.ts +3 -2
- package/dist/components/topBar/index.js +4 -2
- package/dist/hooks/index.d.ts +1 -0
- package/dist/hooks/index.js +3 -0
- package/dist/hooks/use-parameters-backend.d.ts +11 -0
- package/dist/hooks/use-parameters-backend.js +217 -0
- package/dist/index.js +135 -5
- package/dist/services/explore.d.ts +3 -0
- package/dist/services/explore.js +26 -1
- package/dist/services/index.d.ts +1 -0
- package/dist/services/index.js +9 -3
- package/dist/services/loadflow.d.ts +9 -0
- package/dist/services/loadflow.js +59 -0
- package/dist/services/userAdmin.d.ts +3 -3
- package/dist/services/userAdmin.js +9 -1
- package/dist/services/utils.d.ts +3 -8
- package/dist/services/utils.js +5 -0
- package/dist/translations/en/index.d.ts +1 -0
- package/dist/translations/en/index.js +2 -0
- package/dist/translations/en/parameters.d.ts +67 -0
- package/dist/translations/en/parameters.js +64 -0
- package/dist/translations/fr/index.d.ts +1 -0
- package/dist/translations/fr/index.js +2 -0
- package/dist/translations/fr/parameters.d.ts +67 -0
- package/dist/translations/fr/parameters.js +64 -0
- package/dist/utils/constants/notificationsProvider.d.ts +10 -0
- package/dist/utils/constants/notificationsProvider.js +17 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +16 -0
- package/dist/utils/types/dynamic-security-analysis.type.d.ts +13 -0
- package/dist/utils/types/dynamic-security-analysis.type.js +1 -0
- package/dist/utils/types/dynamic-simulation.type.d.ts +111 -0
- package/dist/utils/types/dynamic-simulation.type.js +8 -0
- package/dist/utils/types/index.d.ts +6 -0
- package/dist/utils/types/index.js +11 -0
- package/dist/utils/types/loadflow.type.d.ts +11 -0
- package/dist/utils/types/loadflow.type.js +1 -0
- package/dist/utils/types/metadata.d.ts +1 -0
- package/dist/utils/types/non-evacuated-energy.type.d.ts +60 -0
- package/dist/utils/types/non-evacuated-energy.type.js +12 -0
- package/dist/utils/types/parameters.type.d.ts +41 -0
- package/dist/utils/types/parameters.type.js +12 -0
- package/dist/utils/types/sensitivity-analysis.type.d.ts +101 -0
- package/dist/utils/types/sensitivity-analysis.type.js +16 -0
- package/dist/utils/types/types.d.ts +12 -0
- package/dist/utils/types/types.js +8 -1
- package/package.json +2 -1
- package/dist/components/topBar/MessageBanner.d.ts +0 -6
- 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;
|