@gridsuite/commons-ui 0.165.2 → 0.167.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 (177) hide show
  1. package/dist/components/dialogs/descriptionModificationDialog/DescriptionModificationDialog.d.ts +9 -4
  2. package/dist/components/dialogs/descriptionModificationDialog/DescriptionModificationDialog.js +7 -4
  3. package/dist/components/dialogs/elementSaveDialog/ElementSaveDialog.js +5 -0
  4. package/dist/components/dnd-table/dnd-table-add-rows-dialog.js +5 -0
  5. package/dist/components/dnd-table/dnd-table-bottom-right-buttons.js +2 -2
  6. package/dist/components/dnd-table/dnd-table.d.ts +1 -2
  7. package/dist/components/dnd-table/dnd-table.js +7 -0
  8. package/dist/components/dnd-table/dnd-table.type.d.ts +6 -1
  9. package/dist/components/dnd-table/dnd-table.type.js +1 -0
  10. package/dist/components/filter/HeaderFilterForm.js +5 -0
  11. package/dist/components/filter/expert/ExpertFilterForm.js +4 -0
  12. package/dist/components/filter/explicitNaming/ExplicitNamingFilterForm.js +4 -0
  13. package/dist/components/index.js +22 -7
  14. package/dist/components/inputs/index.js +2 -0
  15. package/dist/components/inputs/reactHookForm/index.js +2 -0
  16. package/dist/components/inputs/reactHookForm/text/DescriptionInput.d.ts +4 -0
  17. package/dist/components/inputs/reactHookForm/text/DescriptionInput.js +85 -0
  18. package/dist/components/inputs/reactHookForm/text/index.d.ts +1 -0
  19. package/dist/components/inputs/reactHookForm/text/index.js +2 -0
  20. package/dist/components/network-modifications/common/properties/PropertiesForm.js +5 -0
  21. package/dist/components/network-modifications/common/properties/PropertyForm.js +5 -0
  22. package/dist/components/network-modifications/substation/creation/SubstationCreationForm.js +5 -0
  23. package/dist/components/parameters/common/ProviderParam.js +8 -3
  24. package/dist/components/parameters/common/{constant.d.ts → constants.d.ts} +3 -0
  25. package/dist/components/parameters/common/{constant.js → constants.js} +6 -0
  26. package/dist/components/parameters/common/contingency-table/columns-definitions.d.ts +27 -0
  27. package/dist/components/parameters/common/contingency-table/columns-definitions.js +102 -0
  28. package/dist/components/parameters/common/contingency-table/contingency-table.d.ts +5 -0
  29. package/dist/components/parameters/common/contingency-table/contingency-table.js +81 -0
  30. package/dist/components/parameters/common/contingency-table/index.d.ts +8 -0
  31. package/dist/components/parameters/common/contingency-table/index.js +9 -0
  32. package/dist/components/parameters/common/contingency-table/types.d.ts +12 -0
  33. package/dist/components/parameters/common/contingency-table/types.js +1 -0
  34. package/dist/components/parameters/common/index.d.ts +1 -1
  35. package/dist/components/parameters/common/index.js +5 -5
  36. package/dist/components/parameters/common/limitreductions/columns-definitions.d.ts +8 -34
  37. package/dist/components/parameters/common/limitreductions/columns-definitions.js +11 -32
  38. package/dist/components/parameters/common/limitreductions/index.d.ts +0 -1
  39. package/dist/components/parameters/common/limitreductions/index.js +1 -4
  40. package/dist/components/parameters/common/limitreductions/limit-reduction-table-cell.js +5 -0
  41. package/dist/components/parameters/common/limitreductions/limit-reductions-table-form.js +5 -0
  42. package/dist/components/parameters/common/name-element-editor/name-element-editor-utils.js +5 -0
  43. package/dist/components/parameters/common/parameter-dnd-table-field.d.ts +9 -0
  44. package/dist/components/parameters/common/parameter-dnd-table-field.js +85 -0
  45. package/dist/components/parameters/common/parameter-field.d.ts +15 -0
  46. package/dist/components/parameters/{loadflow/load-flow-parameter-field.js → common/parameter-field.js} +12 -14
  47. package/dist/components/parameters/common/parameter-table/constants.d.ts +11 -0
  48. package/dist/components/parameters/common/parameter-table/constants.js +12 -0
  49. package/dist/components/parameters/common/parameter-table/index.d.ts +9 -0
  50. package/dist/components/parameters/common/parameter-table/index.js +10 -0
  51. package/dist/components/parameters/common/parameter-table/parameter-table.d.ts +15 -0
  52. package/dist/components/parameters/{sensi/sensitivity-table.js → common/parameter-table/parameter-table.js} +11 -37
  53. package/dist/components/parameters/{sensi → common/parameter-table}/table-cell.js +19 -17
  54. package/dist/components/parameters/{sensi → common/parameter-table}/table-row.d.ts +2 -2
  55. package/dist/components/parameters/common/parameter-table/types.d.ts +26 -0
  56. package/dist/components/parameters/common/parameter-table/types.js +1 -0
  57. package/dist/components/parameters/common/utils.js +1 -1
  58. package/dist/components/parameters/common/voltage-level-table/custom-voltage-level-table-cell.js +6 -1
  59. package/dist/components/parameters/common/widget/parameter-float.js +5 -0
  60. package/dist/components/parameters/common/widget/parameter-line-directory-items-input.js +5 -0
  61. package/dist/components/parameters/common/widget/parameter-line-slider.js +5 -0
  62. package/dist/components/parameters/dynamic-margin-calculation/constants.d.ts +18 -0
  63. package/dist/components/parameters/dynamic-margin-calculation/constants.js +26 -0
  64. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation-dialog.d.ts +6 -0
  65. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation-dialog.js +1 -0
  66. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation-form.d.ts +9 -0
  67. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation-form.js +95 -0
  68. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation-inline.d.ts +10 -0
  69. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation-inline.js +176 -0
  70. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation.type.d.ts +10 -0
  71. package/dist/components/parameters/dynamic-margin-calculation/dynamic-margin-calculation.type.js +8 -0
  72. package/dist/components/parameters/dynamic-margin-calculation/index.d.ts +8 -0
  73. package/dist/components/parameters/dynamic-margin-calculation/index.js +17 -0
  74. package/dist/components/parameters/dynamic-margin-calculation/loads-variations-parameters.d.ts +29 -0
  75. package/dist/components/parameters/dynamic-margin-calculation/loads-variations-parameters.js +154 -0
  76. package/dist/components/parameters/dynamic-margin-calculation/time-delay-parameters.d.ts +24 -0
  77. package/dist/components/parameters/dynamic-margin-calculation/time-delay-parameters.js +62 -0
  78. package/dist/components/parameters/dynamic-margin-calculation/use-dynamic-margin-calculation-parameters-form.d.ts +30 -0
  79. package/dist/components/parameters/dynamic-margin-calculation/use-dynamic-margin-calculation-parameters-form.js +179 -0
  80. package/dist/components/parameters/index.d.ts +1 -0
  81. package/dist/components/parameters/index.js +20 -7
  82. package/dist/components/parameters/loadflow/load-flow-general-parameters.js +10 -6
  83. package/dist/components/parameters/loadflow/load-flow-parameters-content.js +4 -0
  84. package/dist/components/parameters/loadflow/load-flow-parameters-dialog.js +4 -0
  85. package/dist/components/parameters/loadflow/load-flow-parameters-form.js +5 -0
  86. package/dist/components/parameters/loadflow/load-flow-parameters-header.js +6 -2
  87. package/dist/components/parameters/loadflow/load-flow-parameters-inline.js +5 -1
  88. package/dist/components/parameters/loadflow/load-flow-parameters-utils.js +6 -3
  89. package/dist/components/parameters/loadflow/use-load-flow-parameters-form.js +6 -3
  90. package/dist/components/parameters/network-visualizations/map-parameters.js +4 -0
  91. package/dist/components/parameters/network-visualizations/network-area-diagram-parameters.js +5 -0
  92. package/dist/components/parameters/network-visualizations/network-visualizations-form.js +5 -1
  93. package/dist/components/parameters/network-visualizations/network-visualizations-parameters-dialog.js +4 -0
  94. package/dist/components/parameters/network-visualizations/network-visualizations-parameters-inline.js +5 -0
  95. package/dist/components/parameters/network-visualizations/single-line-diagram-parameters.js +4 -0
  96. package/dist/components/parameters/network-visualizations/use-network-visualizations-parameters-form.js +5 -0
  97. package/dist/components/parameters/pcc-min/pcc-min-form-utils.js +5 -0
  98. package/dist/components/parameters/pcc-min/pcc-min-parameters-dialog.js +4 -0
  99. package/dist/components/parameters/pcc-min/pcc-min-parameters-form.js +5 -1
  100. package/dist/components/parameters/pcc-min/pcc-min-parameters-inline.js +5 -1
  101. package/dist/components/parameters/pcc-min/use-pcc-min-parameters-form.js +5 -0
  102. package/dist/components/parameters/security-analysis/columns-definitions.d.ts +63 -0
  103. package/dist/components/parameters/security-analysis/columns-definitions.js +78 -0
  104. package/dist/components/parameters/security-analysis/security-analysis-parameters-dialog.js +5 -0
  105. package/dist/components/parameters/security-analysis/security-analysis-parameters-form.d.ts +4 -1
  106. package/dist/components/parameters/security-analysis/security-analysis-parameters-form.js +32 -13
  107. package/dist/components/parameters/security-analysis/security-analysis-parameters-inline.d.ts +2 -1
  108. package/dist/components/parameters/security-analysis/security-analysis-parameters-inline.js +9 -2
  109. package/dist/components/parameters/security-analysis/security-analysis-parameters-selector.d.ts +3 -2
  110. package/dist/components/parameters/security-analysis/security-analysis-parameters-selector.js +4 -0
  111. package/dist/components/parameters/security-analysis/security-analysis-violations-hiding.js +6 -2
  112. package/dist/components/parameters/security-analysis/types.d.ts +15 -0
  113. package/dist/components/parameters/security-analysis/types.js +1 -0
  114. package/dist/components/parameters/security-analysis/use-security-analysis-parameters-form.d.ts +5 -4
  115. package/dist/components/parameters/security-analysis/use-security-analysis-parameters-form.js +26 -7
  116. package/dist/components/parameters/sensi/columns-definitions.d.ts +7 -25
  117. package/dist/components/parameters/sensi/columns-definitions.js +35 -1
  118. package/dist/components/parameters/sensi/constants.d.ts +0 -2
  119. package/dist/components/parameters/sensi/constants.js +0 -4
  120. package/dist/components/parameters/sensi/index.d.ts +0 -1
  121. package/dist/components/parameters/sensi/index.js +1 -3
  122. package/dist/components/parameters/sensi/sensitivity-Flow-parameters.js +5 -0
  123. package/dist/components/parameters/sensi/sensitivity-analysis-parameters-dialog.js +4 -0
  124. package/dist/components/parameters/sensi/sensitivity-analysis-parameters-form.js +6 -2
  125. package/dist/components/parameters/sensi/sensitivity-analysis-parameters-inline.js +5 -1
  126. package/dist/components/parameters/sensi/sensitivity-parameters-selector.js +27 -19
  127. package/dist/components/parameters/sensi/use-sensitivity-analysis-parameters.js +7 -2
  128. package/dist/components/parameters/sensi/utils.d.ts +2 -1
  129. package/dist/components/parameters/sensi/utils.js +7 -2
  130. package/dist/components/parameters/short-circuit/short-circuit-fields.js +6 -2
  131. package/dist/components/parameters/short-circuit/short-circuit-icc-material-table-cell.js +5 -0
  132. package/dist/components/parameters/short-circuit/short-circuit-parameters-dialog.js +4 -0
  133. package/dist/components/parameters/short-circuit/short-circuit-parameters-form.js +5 -0
  134. package/dist/components/parameters/short-circuit/short-circuit-parameters-inline.js +5 -1
  135. package/dist/components/parameters/short-circuit/short-circuit-parameters-utils.js +5 -1
  136. package/dist/components/parameters/short-circuit/use-short-circuit-parameters-form.js +6 -2
  137. package/dist/components/parameters/voltage-init/equipment-selection-parameters.js +5 -1
  138. package/dist/components/parameters/voltage-init/general-parameters.js +4 -0
  139. package/dist/components/parameters/voltage-init/use-voltage-init-parameters-form.js +5 -0
  140. package/dist/components/parameters/voltage-init/voltage-init-form-utils.js +5 -0
  141. package/dist/components/parameters/voltage-init/voltage-init-parameters-dialog.js +4 -0
  142. package/dist/components/parameters/voltage-init/voltage-init-parameters-form.js +5 -1
  143. package/dist/components/parameters/voltage-init/voltage-init-parameters-inline.js +5 -1
  144. package/dist/components/parameters/voltage-init/voltage-limits-parameters.js +5 -0
  145. package/dist/hooks/index.d.ts +1 -1
  146. package/dist/hooks/index.js +2 -2
  147. package/dist/hooks/use-create-row-data.d.ts +4 -0
  148. package/dist/hooks/{use-create-row-data-sensi.js → use-create-row-data.js} +5 -5
  149. package/dist/index.js +31 -9
  150. package/dist/services/dynamic-margin-calculation.d.ts +5 -0
  151. package/dist/services/dynamic-margin-calculation.js +35 -0
  152. package/dist/services/index.d.ts +1 -0
  153. package/dist/services/index.js +4 -0
  154. package/dist/translations/en/businessErrorsEn.d.ts +3 -0
  155. package/dist/translations/en/businessErrorsEn.js +4 -1
  156. package/dist/translations/en/parameters.d.ts +21 -0
  157. package/dist/translations/en/parameters.js +25 -3
  158. package/dist/translations/fr/businessErrorsFr.d.ts +3 -0
  159. package/dist/translations/fr/businessErrorsFr.js +4 -1
  160. package/dist/translations/fr/parameters.d.ts +21 -0
  161. package/dist/translations/fr/parameters.js +25 -3
  162. package/dist/utils/index.js +3 -0
  163. package/dist/utils/types/dynamic-margin-calculation.type.d.ts +32 -0
  164. package/dist/utils/types/dynamic-margin-calculation.type.js +14 -0
  165. package/dist/utils/types/elementType.d.ts +1 -0
  166. package/dist/utils/types/elementType.js +1 -0
  167. package/dist/utils/types/index.d.ts +1 -0
  168. package/dist/utils/types/index.js +3 -0
  169. package/dist/utils/types/parameters.type.d.ts +4 -2
  170. package/package.json +1 -1
  171. package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.d.ts +0 -29
  172. package/dist/components/parameters/common/limitreductions/limit-reductions-form-util.js +0 -27
  173. package/dist/components/parameters/loadflow/load-flow-parameter-field.d.ts +0 -19
  174. package/dist/components/parameters/sensi/sensitivity-table.d.ts +0 -14
  175. package/dist/hooks/use-create-row-data-sensi.d.ts +0 -4
  176. /package/dist/components/parameters/{sensi → common/parameter-table}/table-cell.d.ts +0 -0
  177. /package/dist/components/parameters/{sensi → common/parameter-table}/table-row.js +0 -0
@@ -26,6 +26,11 @@ import "react-papaparse";
26
26
  import "react-csv-downloader";
27
27
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
28
28
  import { PopupConfirmationDialog } from "../../dialogs/popupConfirmationDialog/PopupConfirmationDialog.js";
29
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
30
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
31
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
32
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
33
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
29
34
  import "@react-querybuilder/material";
30
35
  import "../../filter/expert/expertFilterConstants.js";
31
36
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
@@ -36,7 +41,6 @@ import { LabelledButton } from "../common/parameters.js";
36
41
  import { CreateParameterDialog } from "../common/parameters-creation-dialog.js";
37
42
  import "../common/widget/parameter-line-slider.js";
38
43
  import "../common/limitreductions/columns-definitions.js";
39
- import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
40
44
  import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
41
45
  import { UsePccMinParametersForm } from "./use-pcc-min-parameters-form.js";
42
46
  import { PccMinParametersForm } from "./pcc-min-parameters-form.js";
@@ -29,6 +29,11 @@ import "ag-grid-community";
29
29
  import "react-papaparse";
30
30
  import "react-csv-downloader";
31
31
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
32
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
33
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
34
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
35
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
36
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
32
37
  import "@react-querybuilder/material";
33
38
  import "../../filter/expert/expertFilterConstants.js";
34
39
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
@@ -0,0 +1,63 @@
1
+ import { ILimitReductionsByVoltageLevel } from '../common';
2
+ import { default as yup } from '../../../utils/yupConfig';
3
+ import { SAParameters } from './types';
4
+ export declare const getSAParametersFormSchema: (name: string | null, limitReductions?: ILimitReductionsByVoltageLevel[]) => yup.ObjectSchema<{
5
+ flowProportionalThreshold: unknown;
6
+ lowVoltageProportionalThreshold: unknown;
7
+ lowVoltageAbsoluteThreshold: unknown;
8
+ highVoltageProportionalThreshold: unknown;
9
+ highVoltageAbsoluteThreshold: unknown;
10
+ limitReductionsForm: unknown;
11
+ contingencyListsInfos: unknown;
12
+ provider: unknown;
13
+ } & {
14
+ name: string | null | undefined;
15
+ description: string | null | undefined;
16
+ }, yup.AnyObject, {
17
+ flowProportionalThreshold: undefined;
18
+ lowVoltageProportionalThreshold: undefined;
19
+ lowVoltageAbsoluteThreshold: undefined;
20
+ highVoltageProportionalThreshold: undefined;
21
+ highVoltageAbsoluteThreshold: undefined;
22
+ limitReductionsForm: undefined;
23
+ contingencyListsInfos: undefined;
24
+ provider: undefined;
25
+ name: undefined;
26
+ description: undefined;
27
+ }, "">;
28
+ export declare const toFormValueSaParameters: (params: SAParameters) => {
29
+ flowProportionalThreshold: number;
30
+ lowVoltageProportionalThreshold: number;
31
+ lowVoltageAbsoluteThreshold: number;
32
+ highVoltageProportionalThreshold: number;
33
+ highVoltageAbsoluteThreshold: number;
34
+ limitReductionsForm?: undefined;
35
+ contingencyListsInfos: {
36
+ contingencyLists: {
37
+ name: string;
38
+ id: `${string}-${string}-${string}-${string}-${string}`;
39
+ }[];
40
+ description: string;
41
+ activated: boolean;
42
+ }[];
43
+ provider: string;
44
+ } | {
45
+ flowProportionalThreshold: number;
46
+ lowVoltageProportionalThreshold: number;
47
+ lowVoltageAbsoluteThreshold: number;
48
+ highVoltageProportionalThreshold: number;
49
+ highVoltageAbsoluteThreshold: number;
50
+ limitReductionsForm: {
51
+ voltageLevelsForm: string;
52
+ istForm: number;
53
+ }[];
54
+ contingencyListsInfos: {
55
+ contingencyLists: {
56
+ name: string;
57
+ id: `${string}-${string}-${string}-${string}-${string}`;
58
+ }[];
59
+ description: string;
60
+ activated: boolean;
61
+ }[];
62
+ provider: string;
63
+ };
@@ -0,0 +1,78 @@
1
+ import { PARAM_SA_PROVIDER, PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD, CONTINGENCY_LISTS_INFOS } from "../common/constants.js";
2
+ import "react/jsx-runtime";
3
+ import "@mui/material";
4
+ import "react-intl";
5
+ import "react";
6
+ import "../../../utils/conversionUtils.js";
7
+ import "../../../utils/types/equipmentType.js";
8
+ import "@mui/icons-material";
9
+ import "../../../utils/yupConfig.js";
10
+ import "localized-countries";
11
+ import "localized-countries/data/fr";
12
+ import "localized-countries/data/en";
13
+ import "notistack";
14
+ import "react-hook-form";
15
+ import "../../inputs/reactHookForm/provider/CustomFormProvider.js";
16
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
17
+ import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
18
+ import "../../treeViewFinder/TreeViewFinder.js";
19
+ import "../../overflowableText/OverflowableText.js";
20
+ import * as yup from "yup";
21
+ import "../../inputs/reactHookForm/agGridTable/BottomRightButtons.js";
22
+ import "../../customAGGrid/customAggrid.js";
23
+ import "ag-grid-community";
24
+ import "react-papaparse";
25
+ import "react-csv-downloader";
26
+ import "../../inputs/reactHookForm/numbers/RangeInput.js";
27
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
28
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
29
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
30
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
31
+ import "@react-querybuilder/material";
32
+ import "../../filter/expert/expertFilterConstants.js";
33
+ import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
34
+ import "uuid";
35
+ import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
36
+ import "react-querybuilder";
37
+ import "../common/widget/parameter-line-slider.js";
38
+ import { toFormValuesLimitReductions, getLimitReductionsFormSchema } from "../common/limitreductions/columns-definitions.js";
39
+ import "../../filter/HeaderFilterForm.js";
40
+ import { getNameElementEditorSchema } from "../common/name-element-editor/name-element-editor-utils.js";
41
+ import { toFormValuesContingencyListsInfos, getContingencyListsInfosFormSchema } from "../common/contingency-table/columns-definitions.js";
42
+ const getSAParametersFormSchema = (name, limitReductions) => {
43
+ const providerSchema = yup.object().shape({
44
+ [PARAM_SA_PROVIDER]: yup.string().required()
45
+ });
46
+ const contingencyListsInfosSchema = getContingencyListsInfosFormSchema();
47
+ const limitReductionsSchema = getLimitReductionsFormSchema(
48
+ limitReductions?.length ? limitReductions[0].temporaryLimitReductions.length : 0
49
+ );
50
+ const thresholdsSchema = yup.object().shape({
51
+ [PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD]: yup.number().min(0, "NormalizedPercentage").max(100, "NormalizedPercentage").required(),
52
+ [PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD]: yup.number().min(0, "NormalizedPercentage").max(100, "NormalizedPercentage").required(),
53
+ [PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD]: yup.number().required(),
54
+ [PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD]: yup.number().min(0, "NormalizedPercentage").max(100, "NormalizedPercentage").required(),
55
+ [PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD]: yup.number().required()
56
+ });
57
+ return yup.object().shape({
58
+ ...providerSchema.fields,
59
+ ...contingencyListsInfosSchema.fields,
60
+ ...limitReductionsSchema.fields,
61
+ ...thresholdsSchema.fields
62
+ }).concat(getNameElementEditorSchema(name));
63
+ };
64
+ const toFormValueSaParameters = (params) => ({
65
+ [PARAM_SA_PROVIDER]: params[PARAM_SA_PROVIDER],
66
+ ...toFormValuesContingencyListsInfos(params?.[CONTINGENCY_LISTS_INFOS]),
67
+ ...toFormValuesLimitReductions(params?.limitReductions),
68
+ // SA specific form values
69
+ [PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD]: params[PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD] * 100,
70
+ [PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD]: params[PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD] * 100,
71
+ [PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD]: params[PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD],
72
+ [PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD]: params[PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD] * 100,
73
+ [PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD]: params[PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD]
74
+ });
75
+ export {
76
+ getSAParametersFormSchema,
77
+ toFormValueSaParameters
78
+ };
@@ -29,6 +29,10 @@ import "ag-grid-community";
29
29
  import "react-papaparse";
30
30
  import "react-csv-downloader";
31
31
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
32
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
33
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
34
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
35
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
32
36
  import "@react-querybuilder/material";
33
37
  import "../../filter/expert/expertFilterConstants.js";
34
38
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
@@ -92,6 +96,7 @@ function SecurityAnalysisParametersDialog({
92
96
  SecurityAnalysisParametersForm,
93
97
  {
94
98
  securityAnalysisMethods,
99
+ showContingencyCount: false,
95
100
  isDeveloperMode,
96
101
  renderTitleFields: () => {
97
102
  return /* @__PURE__ */ jsx(
@@ -1,7 +1,10 @@
1
1
  import { ReactNode } from 'react';
2
+ import { UUID } from 'node:crypto';
2
3
  import { UseSecurityAnalysisParametersFormReturn } from './use-security-analysis-parameters-form';
3
- export declare function SecurityAnalysisParametersForm({ securityAnalysisMethods, renderTitleFields, renderActions, isDeveloperMode, }: Readonly<{
4
+ export declare function SecurityAnalysisParametersForm({ securityAnalysisMethods, fetchContingencyCount, showContingencyCount, renderTitleFields, renderActions, isDeveloperMode, }: Readonly<{
4
5
  securityAnalysisMethods: UseSecurityAnalysisParametersFormReturn;
6
+ fetchContingencyCount?: (contingencyListIds: UUID[] | null) => Promise<number>;
7
+ showContingencyCount: boolean;
5
8
  renderTitleFields?: () => ReactNode;
6
9
  renderActions?: () => ReactNode;
7
10
  isDeveloperMode: boolean;
@@ -23,6 +23,11 @@ import "react-papaparse";
23
23
  import "react-csv-downloader";
24
24
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
25
25
  import { MuiSelectInput } from "../../inputs/reactHookForm/selectInputs/MuiSelectInput.js";
26
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
27
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
28
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
29
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
30
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
26
31
  import "@react-querybuilder/material";
27
32
  import "../../filter/expert/expertFilterConstants.js";
28
33
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
@@ -30,13 +35,14 @@ import "uuid";
30
35
  import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
31
36
  import "react-querybuilder";
32
37
  import { parametersStyles } from "../parameters-style.js";
33
- import { PARAM_SA_PROVIDER } from "../common/constant.js";
38
+ import { PARAM_SA_PROVIDER } from "../common/constants.js";
34
39
  import { LineSeparator } from "../common/line-separator.js";
35
- import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
36
40
  import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
37
41
  import "../common/widget/parameter-line-slider.js";
38
42
  import "../common/limitreductions/columns-definitions.js";
39
43
  import { SecurityAnalysisParametersSelector } from "./security-analysis-parameters-selector.js";
44
+ import { ContingencyTable } from "../common/contingency-table/contingency-table.js";
45
+ import "../common/contingency-table/columns-definitions.js";
40
46
  const styles = {
41
47
  securityAnalysisParameters: {
42
48
  flexGrow: 1,
@@ -51,6 +57,8 @@ const styles = {
51
57
  };
52
58
  function SecurityAnalysisParametersForm({
53
59
  securityAnalysisMethods,
60
+ fetchContingencyCount,
61
+ showContingencyCount,
54
62
  renderTitleFields,
55
63
  renderActions,
56
64
  isDeveloperMode
@@ -106,23 +114,34 @@ function SecurityAnalysisParametersForm({
106
114
  overflow: "auto",
107
115
  paddingLeft: 1
108
116
  },
109
- children: /* @__PURE__ */ jsx(
117
+ children: /* @__PURE__ */ jsxs(
110
118
  Grid,
111
119
  {
112
120
  container: true,
113
121
  sx: mergeSx(parametersStyles.scrollableGrid, {
114
122
  maxHeight: "100%"
115
123
  }),
116
- children: /* @__PURE__ */ jsx(
117
- SecurityAnalysisParametersSelector,
118
- {
119
- params: securityAnalysisMethods.params,
120
- currentProvider: securityAnalysisMethods.currentProvider?.trim(),
121
- isDeveloperMode,
122
- defaultLimitReductions: securityAnalysisMethods.defaultLimitReductions
123
- }
124
- )
125
- }
124
+ children: [
125
+ /* @__PURE__ */ jsx(Grid, { children: /* @__PURE__ */ jsx(
126
+ ContingencyTable,
127
+ {
128
+ showContingencyCount,
129
+ fetchContingencyCount
130
+ }
131
+ ) }),
132
+ /* @__PURE__ */ jsx(Grid, { container: true, paddingTop: 4, paddingBottom: 2, children: /* @__PURE__ */ jsx(LineSeparator, {}) }),
133
+ /* @__PURE__ */ jsx(
134
+ SecurityAnalysisParametersSelector,
135
+ {
136
+ params: securityAnalysisMethods.params,
137
+ currentProvider: securityAnalysisMethods.currentProvider?.trim(),
138
+ isDeveloperMode,
139
+ defaultLimitReductions: securityAnalysisMethods.defaultLimitReductions
140
+ }
141
+ )
142
+ ]
143
+ },
144
+ "securityAnalysisParameters"
126
145
  )
127
146
  }
128
147
  )
@@ -1,9 +1,10 @@
1
1
  import { UUID } from 'node:crypto';
2
2
  import { UseParametersBackendReturnProps } from '../../../utils';
3
3
  import { ComputingType } from '../common';
4
- export declare function SecurityAnalysisParametersInline({ studyUuid, parametersBackend, setHaveDirtyFields, isDeveloperMode, }: Readonly<{
4
+ export declare function SecurityAnalysisParametersInline({ studyUuid, parametersBackend, fetchContingencyCount, setHaveDirtyFields, isDeveloperMode, }: Readonly<{
5
5
  studyUuid: UUID | null;
6
6
  parametersBackend: UseParametersBackendReturnProps<ComputingType.SECURITY_ANALYSIS>;
7
+ fetchContingencyCount: (contingencyListIds: UUID[] | null) => Promise<number>;
7
8
  setHaveDirtyFields: (isDirty: boolean) => void;
8
9
  isDeveloperMode: boolean;
9
10
  }>): import("react/jsx-runtime").JSX.Element;
@@ -31,6 +31,11 @@ import "react-papaparse";
31
31
  import "react-csv-downloader";
32
32
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
33
33
  import { PopupConfirmationDialog } from "../../dialogs/popupConfirmationDialog/PopupConfirmationDialog.js";
34
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
35
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
36
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
37
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
38
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
34
39
  import "@react-querybuilder/material";
35
40
  import "../../filter/expert/expertFilterConstants.js";
36
41
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
@@ -39,14 +44,14 @@ import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
39
44
  import "react-querybuilder";
40
45
  import "../common/widget/parameter-line-slider.js";
41
46
  import "../common/limitreductions/columns-definitions.js";
42
- import { toFormValueSaParameters } from "../common/limitreductions/limit-reductions-form-util.js";
43
47
  import { useSecurityAnalysisParametersForm } from "./use-security-analysis-parameters-form.js";
44
48
  import { SecurityAnalysisParametersForm } from "./security-analysis-parameters-form.js";
45
- import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
46
49
  import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
50
+ import { toFormValueSaParameters } from "./columns-definitions.js";
47
51
  function SecurityAnalysisParametersInline({
48
52
  studyUuid,
49
53
  parametersBackend,
54
+ fetchContingencyCount,
50
55
  setHaveDirtyFields,
51
56
  isDeveloperMode
52
57
  }) {
@@ -93,6 +98,8 @@ function SecurityAnalysisParametersInline({
93
98
  SecurityAnalysisParametersForm,
94
99
  {
95
100
  securityAnalysisMethods,
101
+ fetchContingencyCount,
102
+ showContingencyCount: true,
96
103
  isDeveloperMode,
97
104
  renderActions: () => {
98
105
  return /* @__PURE__ */ jsxs(Fragment, { children: [
@@ -1,6 +1,7 @@
1
- import { ILimitReductionsByVoltageLevel, ISAParameters } from '../common';
1
+ import { ILimitReductionsByVoltageLevel } from '../common';
2
+ import { SAParameters } from './types';
2
3
  export declare function SecurityAnalysisParametersSelector({ params, currentProvider, isDeveloperMode, defaultLimitReductions, }: Readonly<{
3
- params: ISAParameters | null;
4
+ params: SAParameters | null;
4
5
  currentProvider?: string;
5
6
  isDeveloperMode: boolean;
6
7
  defaultLimitReductions: ILimitReductionsByVoltageLevel[];
@@ -24,6 +24,10 @@ import "ag-grid-community";
24
24
  import "react-papaparse";
25
25
  import "react-csv-downloader";
26
26
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
27
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
28
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
29
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
30
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
27
31
  import "@react-querybuilder/material";
28
32
  import "../../filter/expert/expertFilterConstants.js";
29
33
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
@@ -23,14 +23,18 @@ import "react-papaparse";
23
23
  import "react-csv-downloader";
24
24
  import { FloatInput } from "../../inputs/reactHookForm/numbers/FloatInput.js";
25
25
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
26
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
27
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
28
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
29
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
30
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
26
31
  import "@react-querybuilder/material";
27
32
  import "../../filter/expert/expertFilterConstants.js";
28
33
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
29
34
  import "uuid";
30
35
  import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
31
36
  import "react-querybuilder";
32
- import { PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD, PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD } from "../common/constant.js";
33
- import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
37
+ import { PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD, PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD } from "../common/constants.js";
34
38
  import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
35
39
  import "../common/widget/parameter-line-slider.js";
36
40
  import "../common/limitreductions/columns-definitions.js";
@@ -0,0 +1,15 @@
1
+ import { UUID } from 'node:crypto';
2
+ import { CONTINGENCY_LISTS_INFOS, PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_PROVIDER } from '../common/constants';
3
+ import { ContingencyListsInfos } from '../common/contingency-table/types';
4
+ import { ILimitReductionsByVoltageLevel } from '../common/limitreductions/columns-definitions';
5
+ export interface SAParameters {
6
+ uuid?: UUID;
7
+ [PARAM_SA_PROVIDER]: string;
8
+ [CONTINGENCY_LISTS_INFOS]: ContingencyListsInfos[];
9
+ limitReductions: ILimitReductionsByVoltageLevel[];
10
+ [PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD]: number;
11
+ [PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD]: number;
12
+ [PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD]: number;
13
+ [PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD]: number;
14
+ [PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD]: number;
15
+ }
@@ -3,7 +3,8 @@ import { ObjectSchema } from 'yup';
3
3
  import { Dispatch, SetStateAction } from 'react';
4
4
  import { UUID } from 'node:crypto';
5
5
  import { UseParametersBackendReturnProps } from '../../../utils';
6
- import { ComputingType, ILimitReductionsByVoltageLevel, ISAParameters } from '../common';
6
+ import { ComputingType, ILimitReductionsByVoltageLevel } from '../common';
7
+ import { SAParameters } from './types';
7
8
  export interface UseSecurityAnalysisParametersFormReturn {
8
9
  formMethods: UseFormReturn;
9
10
  formSchema: ObjectSchema<any>;
@@ -12,9 +13,9 @@ export interface UseSecurityAnalysisParametersFormReturn {
12
13
  label: string;
13
14
  }[];
14
15
  defaultLimitReductions: ILimitReductionsByVoltageLevel[];
15
- toFormValueSaParameters: (_params: ISAParameters) => any;
16
- formatNewParams: (formData: Record<string, any>) => ISAParameters;
17
- params: ISAParameters | null;
16
+ toFormValueSaParameters: (_params: SAParameters) => any;
17
+ formatNewParams: (formData: Record<string, any>) => SAParameters;
18
+ params: SAParameters | null;
18
19
  currentProvider: string | undefined;
19
20
  setCurrentProvider: Dispatch<SetStateAction<string | undefined>>;
20
21
  paramsLoaded: boolean;
@@ -8,7 +8,7 @@ import "../../../utils/types/equipmentType.js";
8
8
  import "react/jsx-runtime";
9
9
  import "@mui/icons-material";
10
10
  import "../../../utils/yupConfig.js";
11
- import { PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD, PARAM_SA_PROVIDER } from "../common/constant.js";
11
+ import { PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD, PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD, PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD, CONTINGENCY_LISTS_INFOS, PARAM_SA_PROVIDER, CONTINGENCY_LISTS } from "../common/constants.js";
12
12
  import "@mui/material";
13
13
  import "react-intl";
14
14
  import { updateParameter } from "../../../services/explore.js";
@@ -22,13 +22,16 @@ import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
22
22
  import "../../treeViewFinder/TreeViewFinder.js";
23
23
  import "../../overflowableText/OverflowableText.js";
24
24
  import "yup";
25
- import { DESCRIPTION, NAME } from "../../inputs/reactHookForm/constants.js";
26
25
  import "../../inputs/reactHookForm/agGridTable/BottomRightButtons.js";
27
26
  import "../../customAGGrid/customAggrid.js";
28
27
  import "ag-grid-community";
29
28
  import "react-papaparse";
30
29
  import "react-csv-downloader";
31
30
  import "../../inputs/reactHookForm/numbers/RangeInput.js";
31
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
32
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
33
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
34
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
32
35
  import "@react-querybuilder/material";
33
36
  import "../../filter/expert/expertFilterConstants.js";
34
37
  import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
@@ -36,10 +39,11 @@ import "uuid";
36
39
  import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
37
40
  import "react-querybuilder";
38
41
  import "../common/widget/parameter-line-slider.js";
39
- import { getSAParametersFromSchema, LIMIT_REDUCTIONS_FORM, IST_FORM, LIMIT_DURATION_FORM } from "../common/limitreductions/columns-definitions.js";
40
- import { toFormValuesLimitReductions, toFormValueSaParameters } from "../common/limitreductions/limit-reductions-form-util.js";
42
+ import { LIMIT_REDUCTIONS_FORM, IST_FORM, LIMIT_DURATION_FORM, toFormValuesLimitReductions } from "../common/limitreductions/columns-definitions.js";
41
43
  import "../../filter/HeaderFilterForm.js";
42
44
  import { getNameElementEditorEmptyFormData } from "../common/name-element-editor/name-element-editor-utils.js";
45
+ import { getSAParametersFormSchema, toFormValueSaParameters } from "./columns-definitions.js";
46
+ import { ACTIVATED, DESCRIPTION, NAME, ID } from "../common/parameter-table/constants.js";
43
47
  const useSecurityAnalysisParametersForm = (parametersBackend, parametersUuid, name, description) => {
44
48
  const [providers, provider, , , , params, , updateParameters, , , defaultLimitReductions] = parametersBackend;
45
49
  const [currentProvider, setCurrentProvider] = useState(params?.provider);
@@ -52,12 +56,13 @@ const useSecurityAnalysisParametersForm = (parametersBackend, parametersUuid, na
52
56
  }, [providers]);
53
57
  const paramsLoaded = useMemo(() => !!params && !!currentProvider, [currentProvider, params]);
54
58
  const formSchema = useMemo(() => {
55
- return getSAParametersFromSchema(name, params?.limitReductions);
59
+ return getSAParametersFormSchema(name, params?.limitReductions);
56
60
  }, [name, params?.limitReductions]);
57
61
  const formMethods = useForm({
58
62
  defaultValues: {
59
63
  ...getNameElementEditorEmptyFormData(name, description),
60
64
  [PARAM_SA_PROVIDER]: provider,
65
+ [CONTINGENCY_LISTS_INFOS]: [],
61
66
  [LIMIT_REDUCTIONS_FORM]: [],
62
67
  [PARAM_SA_FLOW_PROPORTIONAL_THRESHOLD]: null,
63
68
  [PARAM_SA_LOW_VOLTAGE_PROPORTIONAL_THRESHOLD]: null,
@@ -68,7 +73,20 @@ const useSecurityAnalysisParametersForm = (parametersBackend, parametersUuid, na
68
73
  resolver: yupResolver(formSchema)
69
74
  });
70
75
  const { reset, watch } = formMethods;
71
- const watchProvider = watch("provider");
76
+ const watchProvider = watch(PARAM_SA_PROVIDER);
77
+ const toContingencyListsInfos = useCallback(
78
+ (formContingencyListsInfos) => {
79
+ return formContingencyListsInfos.map((contingencyListsInfos) => ({
80
+ [CONTINGENCY_LISTS]: contingencyListsInfos[CONTINGENCY_LISTS]?.map((c) => ({
81
+ [ID]: c[ID],
82
+ [NAME]: c[NAME]
83
+ })),
84
+ [DESCRIPTION]: contingencyListsInfos[DESCRIPTION],
85
+ [ACTIVATED]: contingencyListsInfos[ACTIVATED]
86
+ }));
87
+ },
88
+ []
89
+ );
72
90
  const toLimitReductions = useCallback(
73
91
  (formLimits) => {
74
92
  if (!params?.limitReductions) {
@@ -99,10 +117,11 @@ const useSecurityAnalysisParametersForm = (parametersBackend, parametersUuid, na
99
117
  [PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD]: formData[PARAM_SA_LOW_VOLTAGE_ABSOLUTE_THRESHOLD],
100
118
  [PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD]: formData[PARAM_SA_HIGH_VOLTAGE_PROPORTIONAL_THRESHOLD] / 100,
101
119
  [PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD]: formData[PARAM_SA_HIGH_VOLTAGE_ABSOLUTE_THRESHOLD],
120
+ [CONTINGENCY_LISTS_INFOS]: toContingencyListsInfos(formData[CONTINGENCY_LISTS_INFOS]),
102
121
  limitReductions: toLimitReductions(formData[LIMIT_REDUCTIONS_FORM])
103
122
  };
104
123
  },
105
- [toLimitReductions]
124
+ [toContingencyListsInfos, toLimitReductions]
106
125
  );
107
126
  const onSaveInline = useCallback(
108
127
  (formData) => {
@@ -1,4 +1,5 @@
1
1
  import { ElementType, EquipmentType } from '../../../utils';
2
+ import { ColumnsDef, Parameters } from '../common/parameter-table';
2
3
  export declare const MONITORED_BRANCHES_EQUIPMENT_TYPES: EquipmentType[];
3
4
  export declare const INJECTION_DISTRIBUTION_TYPES: {
4
5
  id: string;
@@ -13,26 +14,7 @@ export declare const MONITORED_VOLTAGE_LEVELS_EQUIPMENT_TYPES: EquipmentType[];
13
14
  export declare const INJECTIONS_EQUIPMENT_TYPES: EquipmentType[];
14
15
  export declare const EQUIPMENTS_IN_VOLTAGE_REGULATION_TYPES: EquipmentType[];
15
16
  export declare const HVDC_EQUIPMENT_TYPES: EquipmentType[];
16
- export interface ISensiParameters {
17
- columnsDef: IColumnsDef[];
18
- name: string;
19
- }
20
- export interface IColumnsDef {
21
- label: string;
22
- dataKey: string;
23
- initialValue: boolean | string | string[] | number;
24
- editable?: boolean;
25
- directoryItems?: boolean;
26
- menuItems?: boolean;
27
- equipmentTypes?: any[];
28
- elementType?: string;
29
- titleId?: string;
30
- checkboxItems?: boolean;
31
- floatItems?: boolean;
32
- textItems?: boolean;
33
- width?: string;
34
- }
35
- export declare const COLUMNS_DEFINITIONS_INJECTIONS_SET: IColumnsDef[];
17
+ export declare const COLUMNS_DEFINITIONS_INJECTIONS_SET: ColumnsDef[];
36
18
  export declare const COLUMNS_DEFINITIONS_INJECTIONS: ({
37
19
  label: string;
38
20
  dataKey: string;
@@ -205,11 +187,11 @@ export declare const COLUMNS_DEFINITIONS_NODES: ({
205
187
  elementType?: undefined;
206
188
  titleId?: undefined;
207
189
  })[];
208
- export declare const SensiInjectionsSet: ISensiParameters;
209
- export declare const SensiInjection: ISensiParameters;
210
- export declare const SensiHvdcs: ISensiParameters;
211
- export declare const SensiPsts: ISensiParameters;
212
- export declare const SensiNodes: ISensiParameters;
190
+ export declare const SensiInjectionsSet: Parameters;
191
+ export declare const SensiInjection: Parameters;
192
+ export declare const SensiHvdcs: Parameters;
193
+ export declare const SensiPsts: Parameters;
194
+ export declare const SensiNodes: Parameters;
213
195
  export declare enum SensiTabValues {
214
196
  'SensitivityBranches' = 0,
215
197
  'SensitivityNodes' = 1
@@ -1,10 +1,44 @@
1
- import { MONITORED_BRANCHES, INJECTIONS, DISTRIBUTION_TYPE, CONTINGENCIES, ACTIVATED, SENSITIVITY_TYPE, HVDC_LINES, PSTS, SUPERVISED_VOLTAGE_LEVELS, EQUIPMENTS_IN_VOLTAGE_REGULATION, PARAMETER_SENSI_INJECTIONS_SET, PARAMETER_SENSI_INJECTION, PARAMETER_SENSI_HVDC, PARAMETER_SENSI_PST, PARAMETER_SENSI_NODES } from "./constants.js";
1
+ import { MONITORED_BRANCHES, INJECTIONS, DISTRIBUTION_TYPE, SENSITIVITY_TYPE, HVDC_LINES, PSTS, SUPERVISED_VOLTAGE_LEVELS, EQUIPMENTS_IN_VOLTAGE_REGULATION, PARAMETER_SENSI_INJECTIONS_SET, PARAMETER_SENSI_INJECTION, PARAMETER_SENSI_HVDC, PARAMETER_SENSI_PST, PARAMETER_SENSI_NODES } from "./constants.js";
2
2
  import "../../../utils/conversionUtils.js";
3
3
  import { ElementType } from "../../../utils/types/elementType.js";
4
4
  import { EquipmentType } from "../../../utils/types/equipmentType.js";
5
5
  import "react/jsx-runtime";
6
6
  import "@mui/icons-material";
7
7
  import "../../../utils/yupConfig.js";
8
+ import { CONTINGENCIES } from "../common/constants.js";
9
+ import "@mui/material";
10
+ import "react-intl";
11
+ import "react";
12
+ import "localized-countries";
13
+ import "localized-countries/data/fr";
14
+ import "localized-countries/data/en";
15
+ import "notistack";
16
+ import "react-hook-form";
17
+ import "../../inputs/reactHookForm/provider/CustomFormProvider.js";
18
+ import "../../dialogs/descriptionModificationDialog/DescriptionModificationDialog.js";
19
+ import "../../dialogs/elementSaveDialog/ElementSaveDialog.js";
20
+ import "../../treeViewFinder/TreeViewFinder.js";
21
+ import "../../overflowableText/OverflowableText.js";
22
+ import "yup";
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 "../../inputs/reactHookForm/numbers/RangeInput.js";
29
+ import "@material-symbols/svg-400/outlined/left_panel_open.svg?react";
30
+ import "@material-symbols/svg-400/outlined/arrows_output.svg?react";
31
+ import "@material-symbols/svg-400/outlined/left_panel_close.svg?react";
32
+ import "@material-symbols/svg-400/outlined/add_notes.svg?react";
33
+ import "@react-querybuilder/material";
34
+ import "../../filter/expert/expertFilterConstants.js";
35
+ import "../../inputs/reactQueryBuilder/CustomReactQueryBuilder.js";
36
+ import "uuid";
37
+ import "../../inputs/reactQueryBuilder/PropertyValueEditor.js";
38
+ import "react-querybuilder";
39
+ import "../common/widget/parameter-line-slider.js";
40
+ import "../common/limitreductions/columns-definitions.js";
41
+ import { ACTIVATED } from "../common/parameter-table/constants.js";
8
42
  const MONITORED_BRANCHES_EQUIPMENT_TYPES = [EquipmentType.LINE, EquipmentType.TWO_WINDINGS_TRANSFORMER];
9
43
  const INJECTION_DISTRIBUTION_TYPES = [
10
44
  { id: "PROPORTIONAL", label: "Proportional" },
@@ -4,8 +4,6 @@
4
4
  * License, v. 2.0. If a copy of the MPL was not distributed with this
5
5
  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
6
6
  */
7
- export declare const ACTIVATED = "activated";
8
- export declare const CONTINGENCIES = "contingencies";
9
7
  export declare const EQUIPMENTS_IN_VOLTAGE_REGULATION = "equipmentsInVoltageRegulation";
10
8
  export declare const SUPERVISED_VOLTAGE_LEVELS = "monitoredVoltageLevels";
11
9
  export declare const MONITORED_BRANCHES = "monitoredBranches";