@m4l/components 9.2.60 → 9.2.62-B07072025beta.1

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 (241) hide show
  1. package/@types/types.d.ts +8 -0
  2. package/components/AppBar/AppBar.js +12 -10
  3. package/components/AppBar/slots/AppBarEnum.d.ts +1 -5
  4. package/components/AppBar/slots/AppBarEnum.js +0 -4
  5. package/components/AppBar/slots/AppBarSlots.d.ts +4 -18
  6. package/components/AppBar/slots/AppBarSlots.js +3 -27
  7. package/components/AppBar/styles.js +0 -42
  8. package/components/AppBar/types.d.ts +8 -0
  9. package/components/Chip/Chip.js +9 -10
  10. package/components/Chip/ChipStyles.js +13 -2
  11. package/components/Chip/constants.d.ts +9 -0
  12. package/components/Chip/constants.js +6 -2
  13. package/components/Chip/slots/ChipEnum.d.ts +3 -0
  14. package/components/Chip/slots/ChipEnum.js +6 -1
  15. package/components/Chip/slots/ChipSlots.js +1 -1
  16. package/components/DataGrid/DataGrid.js +17 -3
  17. package/components/DataGrid/Datagrid.styles.js +80 -33
  18. package/components/DataGrid/constants.d.ts +2 -0
  19. package/components/DataGrid/constants.js +7 -3
  20. package/components/DataGrid/contexts/DataGridContext/index.js +77 -30
  21. package/components/DataGrid/contexts/DataGridContext/types.d.ts +5 -2
  22. package/components/DataGrid/dictionary.d.ts +8 -0
  23. package/components/DataGrid/dictionary.js +26 -17
  24. package/components/DataGrid/icons.d.ts +7 -0
  25. package/components/DataGrid/icons.js +8 -1
  26. package/components/DataGrid/slots/DataGridEnum.d.ts +7 -1
  27. package/components/DataGrid/slots/DataGridEnum.js +6 -0
  28. package/components/DataGrid/slots/DataGridSlot.d.ts +6 -0
  29. package/components/DataGrid/slots/DataGridSlot.js +35 -5
  30. package/components/DataGrid/subcomponents/HeaderActions/subcomponents/Filter/index.js +9 -1
  31. package/components/DataGrid/subcomponents/Table/hooks/getDragHeaderRenderer.d.ts +3 -1
  32. package/components/DataGrid/subcomponents/Table/hooks/getDragHeaderRenderer.js +9 -2
  33. package/components/DataGrid/subcomponents/Table/hooks/useHeaderMenuActions.d.ts +6 -0
  34. package/components/DataGrid/subcomponents/Table/hooks/useHeaderMenuActions.js +262 -0
  35. package/components/DataGrid/subcomponents/Table/hooks/useSortColumnsRows.d.ts +6 -4
  36. package/components/DataGrid/subcomponents/Table/hooks/useSortColumnsRows.js +35 -18
  37. package/components/DataGrid/subcomponents/Table/index.js +97 -34
  38. package/components/DataGrid/subcomponents/Table/subcomponents/ActionsColumn.js +1 -1
  39. package/components/DataGrid/subcomponents/Table/subcomponents/DraggableHeaderRenderer.d.ts +1 -0
  40. package/components/DataGrid/subcomponents/Table/subcomponents/DraggableHeaderRenderer.js +79 -4
  41. package/components/DataGrid/subcomponents/Table/subcomponents/HeaderRenderClick/HeaderRenderClick.d.ts +5 -0
  42. package/components/DataGrid/subcomponents/Table/subcomponents/HeaderRenderClick/HeaderRenderClick.js +146 -0
  43. package/components/DataGrid/subcomponents/Table/subcomponents/HeaderRenderClick/index.d.ts +1 -0
  44. package/components/DataGrid/subcomponents/Table/subcomponents/HeaderRenderClick/index.js +1 -0
  45. package/components/DataGrid/subcomponents/Table/subcomponents/HeaderRenderClick/types.d.ts +131 -0
  46. package/components/DataGrid/subcomponents/Table/subcomponents/SelectColumn.js +1 -1
  47. package/components/DataGrid/subcomponents/editors/TextEditor/index.js +1 -1
  48. package/components/DataGrid/tests/HeaderRenderClick.test.d.ts +1 -0
  49. package/components/DataGrid/tests/useHeaderMenuActions.test.d.ts +1 -0
  50. package/components/DataGrid/types.d.ts +53 -0
  51. package/components/DynamicFilter/DynamicFilter.styles.js +99 -90
  52. package/components/DynamicFilter/slots/SlotsEnum.d.ts +0 -3
  53. package/components/DynamicFilter/slots/SlotsEnum.js +0 -3
  54. package/components/DynamicFilter/slots/dynamicFilterSlots.d.ts +0 -9
  55. package/components/DynamicFilter/slots/dynamicFilterSlots.js +3 -19
  56. package/components/DynamicFilter/store/DynamicFilterContext.js +67 -28
  57. package/components/DynamicFilter/subcomponents/FieldTypes/BooleanFilter/index.js +2 -2
  58. package/components/DynamicFilter/subcomponents/FieldTypes/DateTimeFilter/index.js +2 -2
  59. package/components/DynamicFilter/subcomponents/FieldTypes/NumberFilter/index.js +2 -2
  60. package/components/DynamicFilter/subcomponents/FieldTypes/SelectAsyncFilter/index.js +2 -2
  61. package/components/DynamicFilter/subcomponents/FieldTypes/SelectFilter/index.js +2 -2
  62. package/components/DynamicFilter/subcomponents/FieldTypes/StringFilter/index.js +2 -2
  63. package/components/DynamicFilter/subcomponents/FilterActions/FilterActions.js +1 -1
  64. package/components/DynamicFilter/subcomponents/FilterActions/useFilterActions.d.ts +1 -0
  65. package/components/DynamicFilter/subcomponents/FilterActions/useFilterActions.js +2 -1
  66. package/components/DynamicFilter/subcomponents/InputFilter/InputFilter.js +2 -0
  67. package/components/DynamicFilter/subcomponents/PopoverFilter/PopoverFilter.js +24 -18
  68. package/components/DynamicFilter/subcomponents/PopoverFilter/usePopoverFilter.d.ts +3 -3
  69. package/components/DynamicFilter/subcomponents/PopoverMenuFields/PopoverMenuFields.js +4 -1
  70. package/components/DynamicFilter/types.d.ts +3 -0
  71. package/components/DynamicSort/DynamicSort.js +10 -6
  72. package/components/DynamicSort/DynamicSort.styles.js +92 -90
  73. package/components/DynamicSort/slots/DynamicSortSlots.d.ts +0 -9
  74. package/components/DynamicSort/slots/DynamicSortSlots.js +7 -23
  75. package/components/DynamicSort/slots/SlotsEnum.d.ts +1 -4
  76. package/components/DynamicSort/slots/SlotsEnum.js +1 -4
  77. package/components/DynamicSort/store/DynamicSortContext.js +96 -67
  78. package/components/DynamicSort/store/DynamicSortStore.js +53 -4
  79. package/components/DynamicSort/store/types.d.ts +11 -0
  80. package/components/DynamicSort/subcomponents/FieldTypes/StringSort/index.js +2 -2
  81. package/components/DynamicSort/subcomponents/InputSort/InputSort.js +2 -0
  82. package/components/DynamicSort/subcomponents/PopoverSort/PopoverSort.js +22 -17
  83. package/components/DynamicSort/subcomponents/PopoverSort/usePopoverSort.d.ts +3 -3
  84. package/components/DynamicSort/subcomponents/SortActions/SortActions.js +2 -2
  85. package/components/DynamicSort/subcomponents/SortActions/useSortActions.d.ts +2 -0
  86. package/components/DynamicSort/subcomponents/SortActions/useSortActions.js +2 -1
  87. package/components/DynamicSort/types.d.ts +4 -0
  88. package/components/LanguagePopover/LanguagePopover.js +7 -5
  89. package/components/LanguagePopover/LanguagePopover.styles.js +32 -4
  90. package/components/LanguagePopover/slots/LanguagePopoverSlots.d.ts +9 -3
  91. package/components/LanguagePopover/slots/LanguagePopoverSlots.js +1 -3
  92. package/components/LanguagePopover/types.d.ts +6 -1
  93. package/components/LoadingError/slots/LoadingErrorSlots.js +1 -1
  94. package/components/PaperForm/styles.js +2 -1
  95. package/components/PropertyValue/PropertyValue.js +2 -1
  96. package/components/PropertyValue/PropertyValue.styles.js +7 -4
  97. package/components/PropertyValue/types.d.ts +4 -0
  98. package/components/SideBar/SideBar.js +8 -2
  99. package/components/SideBar/constants.d.ts +26 -2
  100. package/components/SideBar/constants.js +20 -10
  101. package/components/SideBar/context/sideBarContext/index.js +17 -4
  102. package/components/SideBar/context/sideBarContext/types.d.ts +14 -1
  103. package/components/SideBar/helpers/getMenuDataWithState/index.js +25 -8
  104. package/components/SideBar/hooks/useCollapse/index.d.ts +1 -0
  105. package/components/SideBar/hooks/useCollapse/index.js +1 -0
  106. package/components/SideBar/hooks/useCollapse/useCollapse.d.ts +11 -0
  107. package/components/SideBar/hooks/useCollapse/useCollapse.js +23 -0
  108. package/components/SideBar/slots/SideBarEnum.d.ts +11 -11
  109. package/components/SideBar/slots/SideBarEnum.js +13 -15
  110. package/components/SideBar/slots/SideBarSlots.d.ts +15 -9
  111. package/components/SideBar/slots/SideBarSlots.js +50 -39
  112. package/components/SideBar/styles.js +4 -6
  113. package/components/SideBar/subcomponents/ContentComponent/index.js +13 -49
  114. package/components/SideBar/subcomponents/ContentComponent/style.js +148 -23
  115. package/components/SideBar/subcomponents/{FooterSidebar → FooterComponent}/index.d.ts +2 -2
  116. package/components/SideBar/subcomponents/{FooterSidebar → FooterComponent}/index.js +8 -15
  117. package/components/SideBar/subcomponents/{FooterSidebar → FooterComponent}/styles.js +8 -2
  118. package/components/SideBar/subcomponents/FooterComponent/types.d.ts +5 -0
  119. package/components/SideBar/subcomponents/HeaderComponent/HeaderComponent.d.ts +5 -0
  120. package/components/SideBar/subcomponents/HeaderComponent/HeaderComponent.js +37 -0
  121. package/components/SideBar/subcomponents/HeaderComponent/index.d.ts +1 -0
  122. package/components/SideBar/subcomponents/HeaderComponent/index.js +1 -0
  123. package/components/SideBar/subcomponents/HeaderComponent/styles.d.ts +2 -0
  124. package/components/SideBar/subcomponents/HeaderComponent/styles.js +43 -0
  125. package/components/SideBar/subcomponents/SideBarDesktop/index.js +4 -3
  126. package/components/SideBar/subcomponents/SideBarDesktop/styles.js +3 -35
  127. package/components/SideBar/subcomponents/SideBarMobile/index.js +1 -1
  128. package/components/SideBar/subcomponents/TreeGroupItems/index.d.ts +5 -0
  129. package/components/SideBar/subcomponents/TreeGroupItems/index.js +51 -0
  130. package/components/SideBar/subcomponents/TreeGroupItems/styles.js +146 -0
  131. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/AdormentIcon/AdormentIcon.d.ts +7 -0
  132. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/AdormentIcon/AdormentIcon.js +12 -0
  133. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/AdormentIcon/types.d.ts +4 -0
  134. package/components/SideBar/subcomponents/{ContentGroups/subcomponents/ContainerMenuItemsMain → TreeGroupItems}/subcomponents/ArrowIcon/index.js +10 -7
  135. package/components/SideBar/subcomponents/{ContentGroups/subcomponents/ContainerMenuItemsMain → TreeGroupItems/subcomponents/NodeMenuItem}/index.d.ts +3 -3
  136. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/NodeMenuItem/index.js +70 -0
  137. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/NodeMenuItem/types.d.ts +10 -0
  138. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/NodeMenuItemMain/NodeMenuItemMain.d.ts +5 -0
  139. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/NodeMenuItemMain/NodeMenuItemMain.js +61 -0
  140. package/components/SideBar/subcomponents/TreeGroupItems/subcomponents/NodeMenuItemMain/index.d.ts +1 -0
  141. package/components/SideBar/subcomponents/TreeGroupItems/types.d.ts +4 -0
  142. package/components/SideBar/types.d.ts +17 -8
  143. package/components/WindowBase/WindowBase.js +7 -1
  144. package/components/WindowBase/WindowBase.styles.js +50 -15
  145. package/components/WindowBase/constants.d.ts +1 -0
  146. package/components/WindowBase/constants.js +5 -1
  147. package/components/WindowBase/slots/WindowBaseEnum.d.ts +2 -1
  148. package/components/WindowBase/slots/WindowBaseEnum.js +1 -0
  149. package/components/WindowBase/slots/WindowBaseSlots.d.ts +3 -0
  150. package/components/WindowBase/slots/WindowBaseSlots.js +6 -1
  151. package/components/WindowBase/subcomponents/Header/HeaderWindowBase.js +11 -5
  152. package/components/WindowBase/subcomponents/Header/types.d.ts +1 -1
  153. package/components/WindowBase/subcomponents/Header/useButtonActions.js +4 -2
  154. package/components/WindowBase/subcomponents/MemoizedIconButton/MemoizedIconButton.d.ts +1 -1
  155. package/components/WindowBase/subcomponents/MemoizedIconButton/MemoizedIconButton.js +1 -1
  156. package/components/WindowBase/subcomponents/MemoizedIconButton/types.d.ts +5 -0
  157. package/components/WindowBase/types.d.ts +16 -0
  158. package/components/areas/components/AreasViewer/subcomponents/Area/subcomponents/Window/Window.js +13 -0
  159. package/components/areas/components/AreasViewer/subcomponents/Area/subcomponents/Window/hooks/useRightActions.js +26 -20
  160. package/components/areas/contexts/AreasContext/store.js +2 -2
  161. package/components/commercial/HamburgerMenu/HamburgerMenu.js +1 -2
  162. package/components/extended/React-Resizable/helpers.js +1 -1
  163. package/components/extended/React-resizable-panels/SplitLayout.js +6 -3
  164. package/components/extended/React-resizable-panels/SplitLayout.styles.js +78 -36
  165. package/components/extended/React-resizable-panels/constants.d.ts +6 -0
  166. package/components/extended/React-resizable-panels/constants.js +5 -1
  167. package/components/extended/React-resizable-panels/slots/SplitLayoutEnum.d.ts +2 -1
  168. package/components/extended/React-resizable-panels/slots/SplitLayoutEnum.js +1 -0
  169. package/components/extended/React-resizable-panels/slots/SplitLayoutSlots.d.ts +3 -0
  170. package/components/extended/React-resizable-panels/slots/SplitLayoutSlots.js +7 -1
  171. package/components/hook-form/RHFAutocomplete/RFHAutocompleteStyles.js +1 -1
  172. package/components/hook-form/RHFPeriod/subcomponents/Period/dictionary.js +5 -4
  173. package/components/hook-form/RHFTextField/RHFTextField.js +1 -0
  174. package/components/hook-form/RHFTextFieldPassword/RHFTextFieldPassword.styles.js +3 -38
  175. package/components/hook-form/RHFormContext/index.d.ts +1 -1
  176. package/components/mui_extended/Accordion/styles.js +10 -2
  177. package/components/mui_extended/Button/Button.js +3 -1
  178. package/components/mui_extended/Button/ButtonStyles.js +6 -1
  179. package/components/mui_extended/Button/types.d.ts +1 -1
  180. package/components/mui_extended/CheckBox/CheckBox.styles.js +2 -1
  181. package/components/mui_extended/Divider/index.d.ts +1 -0
  182. package/components/mui_extended/Divider/index.js +1 -0
  183. package/components/mui_extended/NavLink/NavLink.js +3 -1
  184. package/components/mui_extended/NavLink/NavLink.styles.js +2 -1
  185. package/components/mui_extended/NavLink/types.d.ts +3 -1
  186. package/components/mui_extended/Tab/Tab.styles.js +2 -1
  187. package/components/mui_extended/TabContent/TabContent.styles.js +2 -8
  188. package/components/mui_extended/TextField/TextField.js +1 -1
  189. package/components/mui_extended/TextField/TextField.styles.js +20 -18
  190. package/components/mui_extended/Typography/slots/typographySlots.d.ts +1 -1
  191. package/components/mui_extended/index.d.ts +1 -0
  192. package/hooks/useDynamicFilterAndSort/styles.js +1 -1
  193. package/hooks/useDynamicFilterAndSort/useDynamicFilterAndSort.d.ts +3 -0
  194. package/hooks/useDynamicFilterAndSort/useDynamicFilterAndSort.js +334 -88
  195. package/index.d.ts +1 -0
  196. package/index.js +23 -20
  197. package/package.json +5 -4
  198. package/storybook/components/DataGrid/DataGrid.stories.d.ts +22 -0
  199. package/storybook/components/DataGrid/MswHandles.d.ts +1 -0
  200. package/storybook/components/DataGrid/helpers/filterFieldsSeedData.d.ts +5 -0
  201. package/storybook/components/DataGrid/helpers/getRows.d.ts +4 -0
  202. package/storybook/components/DataGrid/helpers/getRowsWithBackendSimulation.d.ts +9 -0
  203. package/storybook/components/DataGrid/helpers/sortsSeedData.d.ts +5 -0
  204. package/storybook/components/DataGrid/helpers/types.d.ts +1 -0
  205. package/storybook/components/DataGrid/helpers/useSeed.d.ts +3 -0
  206. package/storybook/components/DataGrid/subcomponents/DataGridRender.d.ts +2 -0
  207. package/storybook/components/DynamicFilter/DynamicFilter.stories.d.ts +27 -11
  208. package/storybook/components/DynamicSort/DynamicSort.stories.d.ts +26 -10
  209. package/storybook/components/SideBar/SideBar.stories.d.ts +5 -11
  210. package/storybook/components/SideBar/subcomponents/FooterComponentHost/FooterComponentHost.d.ts +4 -0
  211. package/storybook/components/SideBar/subcomponents/FooterComponentHost/constants.d.ts +3 -0
  212. package/storybook/components/SideBar/subcomponents/FooterComponentHost/index.d.ts +1 -0
  213. package/storybook/components/SideBar/subcomponents/FooterComponentMicrofrontend/FooterComponentMicrofrontend.d.ts +4 -0
  214. package/storybook/components/SideBar/subcomponents/FooterComponentMicrofrontend/FooterComponentMicrofrontend.stories.d.ts +14 -0
  215. package/storybook/components/SideBar/subcomponents/FooterComponentMicrofrontend/constants.d.ts +1 -0
  216. package/storybook/components/SideBar/subcomponents/FooterComponentMicrofrontend/index.d.ts +1 -0
  217. package/storybook/components/SideBar/subcomponents/HeaderComponentHost/HeaderComponentHost.d.ts +5 -0
  218. package/storybook/components/SideBar/subcomponents/HeaderComponentHost/constants.d.ts +1 -0
  219. package/storybook/components/SideBar/subcomponents/HeaderComponentMicrofrontend/HeaderComponentMicrofrontend.d.ts +5 -0
  220. package/storybook/components/SideBar/subcomponents/HeaderComponentMicrofrontend/constants.d.ts +1 -0
  221. package/storybook/components/extended/mui/IconButton/IconButton.stories.d.ts +1 -0
  222. package/storybook/components/extended/mui/TextField/TextFieldText.stories.d.ts +1 -0
  223. package/utils/index.d.ts +1 -0
  224. package/components/SideBar/subcomponents/ContentGroups/index.d.ts +0 -5
  225. package/components/SideBar/subcomponents/ContentGroups/index.js +0 -52
  226. package/components/SideBar/subcomponents/ContentGroups/styles.js +0 -71
  227. package/components/SideBar/subcomponents/ContentGroups/subcomponents/ContainerMenuItemsMain/index.js +0 -63
  228. package/components/SideBar/subcomponents/ContentGroups/subcomponents/ContainerMenuItemsMain/styles.d.ts +0 -2
  229. package/components/SideBar/subcomponents/ContentGroups/subcomponents/ContainerMenuItemsMain/styles.js +0 -47
  230. package/components/SideBar/subcomponents/ContentGroups/subcomponents/ContainerMenuItemsMain/types.d.ts +0 -7
  231. package/components/SideBar/subcomponents/ContentGroups/types.d.ts +0 -4
  232. package/components/SideBar/subcomponents/FooterSidebar/types.d.ts +0 -5
  233. package/components/SideBar/subcomponents/HeaderSidebar/index.d.ts +0 -6
  234. package/components/SideBar/subcomponents/HeaderSidebar/index.js +0 -25
  235. package/components/SideBar/subcomponents/HeaderSidebar/styles.d.ts +0 -2
  236. package/components/SideBar/subcomponents/HeaderSidebar/styles.js +0 -24
  237. package/components/SideBar/subcomponents/HeaderSidebar/types.d.ts +0 -5
  238. /package/components/SideBar/subcomponents/{FooterSidebar → FooterComponent}/styles.d.ts +0 -0
  239. /package/components/SideBar/subcomponents/{ContentGroups → TreeGroupItems}/styles.d.ts +0 -0
  240. /package/components/SideBar/subcomponents/{ContentGroups/subcomponents/ContainerMenuItemsMain → TreeGroupItems}/subcomponents/ArrowIcon/index.d.ts +0 -0
  241. /package/components/SideBar/subcomponents/{ContentGroups/subcomponents/ContainerMenuItemsMain → TreeGroupItems}/subcomponents/ArrowIcon/types.d.ts +0 -0
@@ -4,4 +4,6 @@ import { HeaderRendererProps } from 'react-data-grid';
4
4
  * Función encargada de retornar el componente de renderizado de cabecera con la capacidad de arrastrar columnas
5
5
  * @param handleColumnsReorder - Función que se ejecuta al reordenar columnas
6
6
  */
7
- export declare const getDragHeaderRenderer: <TRow, TSummaryRow>(handleColumnsReorder: (sourceKey: string, targetKey: string) => void) => FunctionComponent<HeaderRendererProps<TRow, TSummaryRow>>;
7
+ export declare const getDragHeaderRenderer: <TRow, TSummaryRow>(handleColumnsReorder: (sourceKey: string, targetKey: string) => void, options?: {
8
+ openPopover?: (anchorEl: HTMLElement, columnKey: string) => void;
9
+ }) => FunctionComponent<HeaderRendererProps<TRow, TSummaryRow>>;
@@ -1,8 +1,15 @@
1
1
  import { jsx } from "react/jsx-runtime";
2
2
  import { D as DraggableHeaderRenderer } from "../subcomponents/DraggableHeaderRenderer.js";
3
- const getDragHeaderRenderer = (handleColumnsReorder) => {
3
+ const getDragHeaderRenderer = (handleColumnsReorder, options) => {
4
4
  function HeaderRenderer(props) {
5
- return /* @__PURE__ */ jsx(DraggableHeaderRenderer, { ...props, onColumnsReorder: handleColumnsReorder });
5
+ return /* @__PURE__ */ jsx(
6
+ DraggableHeaderRenderer,
7
+ {
8
+ ...props,
9
+ onColumnsReorder: handleColumnsReorder,
10
+ openPopover: options?.openPopover
11
+ }
12
+ );
6
13
  }
7
14
  return HeaderRenderer;
8
15
  };
@@ -0,0 +1,6 @@
1
+ import { Column } from 'react-data-grid';
2
+ import { MenuAction } from '../subcomponents/HeaderRenderClick/types';
3
+ /**
4
+ * Función que retorna las acciones del menu del header de la columna
5
+ */
6
+ export declare function useHeaderMenuActions<Trow, TSummaryRow>(columnKey: string | null, finalColumns: readonly Column<Trow, TSummaryRow>[], defaultSortable: boolean): MenuAction[];
@@ -0,0 +1,262 @@
1
+ import { useMemo, useCallback } from "react";
2
+ import { u as useDataGrid } from "../../../hooks/useDataGrid.js";
3
+ import { useEnvironment, useModuleDictionary } from "@m4l/core";
4
+ import { D as DICTIONARY } from "../../../dictionary.js";
5
+ import { p as pathIcons } from "../../../icons.js";
6
+ function useHeaderMenuActions(columnKey, finalColumns, defaultSortable) {
7
+ const {
8
+ columnsConfig,
9
+ onChangeColumnsConfig,
10
+ setSortColumns,
11
+ sortColumns,
12
+ externalSortSettings,
13
+ externalFilterSettings
14
+ } = useDataGrid();
15
+ const { host_static_assets, environment_assets } = useEnvironment();
16
+ const { getLabel } = useModuleDictionary();
17
+ const column = useMemo(() => {
18
+ return finalColumns.find((c) => c.key === columnKey);
19
+ }, [columnKey, finalColumns]);
20
+ const canSort = useMemo(() => {
21
+ if (!columnKey) {
22
+ return false;
23
+ }
24
+ if (typeof column?.sortable === "boolean") {
25
+ return column.sortable;
26
+ }
27
+ return defaultSortable;
28
+ }, [columnKey, column, defaultSortable]);
29
+ const canSortExternally = useMemo(() => {
30
+ if (!columnKey || !externalSortSettings) {
31
+ return false;
32
+ }
33
+ return externalSortSettings.sortsColumns.includes(columnKey);
34
+ }, [columnKey, externalSortSettings]);
35
+ const currentSort = useMemo(() => {
36
+ if (!columnKey || !externalSortSettings?.sortsApplied) {
37
+ return;
38
+ }
39
+ return externalSortSettings.sortsApplied.find(
40
+ (s) => s.columnKey === columnKey
41
+ );
42
+ }, [columnKey, externalSortSettings?.sortsApplied]);
43
+ const hasExternalSortAsc = useMemo(() => {
44
+ return currentSort?.direction === "asc";
45
+ }, [currentSort]);
46
+ const hasExternalSortDesc = useMemo(() => {
47
+ return currentSort?.direction === "desc";
48
+ }, [currentSort]);
49
+ const isAsc = useMemo(
50
+ () => Boolean(
51
+ columnKey && sortColumns.some(
52
+ (s) => s.columnKey === columnKey && s.direction === "ASC"
53
+ )
54
+ ),
55
+ [columnKey, sortColumns]
56
+ );
57
+ const isDesc = useMemo(
58
+ () => Boolean(
59
+ columnKey && sortColumns.some(
60
+ (s) => s.columnKey === columnKey && s.direction === "DESC"
61
+ )
62
+ ),
63
+ [columnKey, sortColumns]
64
+ );
65
+ const clearLocalSort = useCallback(() => {
66
+ if (!columnKey) {
67
+ return;
68
+ }
69
+ setSortColumns((prev) => prev.filter((s) => s.columnKey !== columnKey));
70
+ }, [columnKey, setSortColumns]);
71
+ const hasAnySortApplied = useMemo(() => {
72
+ return Boolean(currentSort);
73
+ }, [currentSort]);
74
+ const toggleFrozen = useCallback(() => {
75
+ if (!columnKey) {
76
+ return;
77
+ }
78
+ const next = columnsConfig.map(
79
+ (c) => c.key === columnKey ? { ...c, frozen: !c.frozen } : c
80
+ );
81
+ onChangeColumnsConfig(next);
82
+ }, [columnKey, columnsConfig, onChangeColumnsConfig]);
83
+ const toggleVisible = useCallback(() => {
84
+ if (!columnKey) {
85
+ return;
86
+ }
87
+ const next = columnsConfig.map(
88
+ (c) => c.key === columnKey ? { ...c, visible: !c.visible } : c
89
+ );
90
+ onChangeColumnsConfig(next);
91
+ }, [columnKey, columnsConfig, onChangeColumnsConfig]);
92
+ const addExternalSort = useCallback(
93
+ (direction) => {
94
+ if (!columnKey || !column || column?.type === "custom") {
95
+ return null;
96
+ }
97
+ externalSortSettings?.onChange({
98
+ action: "add",
99
+ columnKey,
100
+ direction
101
+ });
102
+ },
103
+ [columnKey, column, externalSortSettings]
104
+ );
105
+ const isRemovable = useMemo(() => {
106
+ return currentSort?.removable;
107
+ }, [currentSort]);
108
+ const addExternalFilter = useCallback(() => {
109
+ if (!columnKey || !column) {
110
+ return null;
111
+ }
112
+ externalFilterSettings?.onChange({
113
+ action: "add",
114
+ columnKey
115
+ });
116
+ }, [columnKey, column, externalFilterSettings]);
117
+ const isAddFilterDisabled = useMemo(() => {
118
+ if (!columnKey || !column) {
119
+ return true;
120
+ }
121
+ if (column.type === "custom") {
122
+ return true;
123
+ }
124
+ const isInFilterColumns = externalFilterSettings?.filterColumns.some(
125
+ (filter) => filter.name === columnKey
126
+ );
127
+ if (!isInFilterColumns) {
128
+ return true;
129
+ }
130
+ const isFilterApplied = externalFilterSettings?.filtersApplied.some(
131
+ (filter) => filter.columnKey === columnKey && filter.isValid
132
+ );
133
+ const isFilterMultiple = externalFilterSettings?.filterColumns.find(
134
+ (filter) => filter.name === columnKey
135
+ )?.multiple;
136
+ return isFilterApplied && !isFilterMultiple;
137
+ }, [columnKey, column, externalFilterSettings]);
138
+ return useMemo(() => {
139
+ if (!columnKey) {
140
+ return [];
141
+ }
142
+ const sortActions = [
143
+ {
144
+ type: "menuItem",
145
+ startIcon: `${host_static_assets}/${environment_assets}/${pathIcons.sortAsc}`,
146
+ label: getLabel(DICTIONARY.ORDER_ASC_COLUMN),
147
+ dataTestId: "sort-ascending",
148
+ /**
149
+ * Función que agrega un sort externo en modo ascendente
150
+ */
151
+ onClick: () => {
152
+ if (externalSortSettings) {
153
+ addExternalSort("asc");
154
+ } else {
155
+ setSortColumns([
156
+ {
157
+ columnKey,
158
+ direction: "ASC"
159
+ }
160
+ ]);
161
+ }
162
+ },
163
+ disabled: !canSort || (externalSortSettings ? !canSortExternally || hasExternalSortAsc : isAsc)
164
+ },
165
+ {
166
+ type: "menuItem",
167
+ startIcon: `${host_static_assets}/${environment_assets}/${pathIcons.sortDesc}`,
168
+ label: getLabel(DICTIONARY.ORDER_DESC_COLUMN),
169
+ dataTestId: "sort-descending",
170
+ /**
171
+ * Función que agrega un sort externo en modo descendente
172
+ */
173
+ onClick: () => {
174
+ if (externalSortSettings) {
175
+ addExternalSort("desc");
176
+ } else {
177
+ setSortColumns([
178
+ {
179
+ columnKey,
180
+ direction: "DESC"
181
+ }
182
+ ]);
183
+ }
184
+ },
185
+ disabled: !canSort || (externalSortSettings ? !canSortExternally || hasExternalSortDesc : isDesc)
186
+ },
187
+ {
188
+ type: "menuItem",
189
+ startIcon: `${host_static_assets}/${environment_assets}/${pathIcons.removeSort}`,
190
+ label: getLabel(DICTIONARY.REMOVE_ORDER_COLUMN),
191
+ dataTestId: "sort-remove",
192
+ /**
193
+ * Función que elimina el sort externo
194
+ */
195
+ onClick: () => {
196
+ if (columnKey) {
197
+ if (externalSortSettings && isRemovable) {
198
+ externalSortSettings.onChange({
199
+ action: "remove",
200
+ columnKey
201
+ });
202
+ return;
203
+ } else {
204
+ clearLocalSort();
205
+ }
206
+ }
207
+ },
208
+ disabled: externalSortSettings ? !hasAnySortApplied || !isRemovable : !(isAsc || isDesc)
209
+ }
210
+ ];
211
+ const filterAction = externalFilterSettings ? [
212
+ {
213
+ type: "menuItem",
214
+ startIcon: `${host_static_assets}/${environment_assets}/${pathIcons.filter2}`,
215
+ label: getLabel(DICTIONARY.ADD_FILTER_COLUMN),
216
+ dataTestId: "filter-add",
217
+ onClick: () => {
218
+ addExternalFilter();
219
+ },
220
+ disabled: isAddFilterDisabled
221
+ }
222
+ ] : [];
223
+ const baseActions = [
224
+ {
225
+ type: "menuItem",
226
+ startIcon: columnsConfig.find((c) => c.key === columnKey)?.frozen ? `${host_static_assets}/${environment_assets}/${pathIcons.unfreezeColumn}` : `${host_static_assets}/${environment_assets}/${pathIcons.freezeColumn}`,
227
+ label: columnsConfig.find((c) => c.key === columnKey)?.frozen ? getLabel(DICTIONARY.UNFREEZE_COLUMN) : getLabel(DICTIONARY.FREEZE_COLUMN),
228
+ onClick: toggleFrozen,
229
+ disabled: !columnsConfig.find((c) => c.key === columnKey)?.visible,
230
+ dataTestId: "toggle-freeze"
231
+ },
232
+ {
233
+ type: "menuItem",
234
+ startIcon: `${host_static_assets}/${environment_assets}/${pathIcons.hideColumn}`,
235
+ label: getLabel(DICTIONARY.HIDE_COLUMN),
236
+ onClick: toggleVisible,
237
+ dataTestId: "hide-column"
238
+ }
239
+ ];
240
+ return [...sortActions, ...filterAction, ...baseActions];
241
+ }, [
242
+ columnKey,
243
+ canSort,
244
+ canSortExternally,
245
+ hasExternalSortAsc,
246
+ hasExternalSortDesc,
247
+ hasAnySortApplied,
248
+ addExternalSort,
249
+ toggleFrozen,
250
+ toggleVisible,
251
+ columnsConfig,
252
+ externalSortSettings,
253
+ externalFilterSettings,
254
+ host_static_assets,
255
+ environment_assets,
256
+ getLabel,
257
+ isAddFilterDisabled
258
+ ]);
259
+ }
260
+ export {
261
+ useHeaderMenuActions as u
262
+ };
@@ -1,11 +1,13 @@
1
- import { Column, SortColumn } from 'react-data-grid';
1
+ import { Column } from 'react-data-grid';
2
2
  /**
3
3
  * Hook encargado de ordenar datos de las columnas y las filas.
4
4
  * Se utiliza para ordenar las columnas y las filas de un DataGrid.
5
5
  */
6
- export declare const useSortColumnsRows: <TRow, TSummaryRow>(sourceColumns: readonly Column<TRow, TSummaryRow>[], sourceRows: readonly TRow[]) => {
6
+ export declare const useSortColumnsRows: <TRow, TSummaryRow>(sourceColumns: readonly Column<TRow, TSummaryRow>[], sourceRows: readonly TRow[], popoverHandlers?: {
7
+ openPopover?: (anchorEl: HTMLElement, columnKey: string) => void;
8
+ }) => {
7
9
  finalColumns: readonly Column<TRow, TSummaryRow>[];
8
- sortColumns: readonly SortColumn[];
9
- setSortColumns: import('react').Dispatch<import('react').SetStateAction<readonly SortColumn[]>>;
10
+ sortColumns: import('react-data-grid').SortColumn[];
11
+ setSortColumns: import('react').Dispatch<import('react').SetStateAction<import('react-data-grid').SortColumn[]>>;
10
12
  finalRows: readonly TRow[];
11
13
  };
@@ -6,7 +6,7 @@ import { useModuleSkeleton, getPropertyByString } from "@m4l/core";
6
6
  import { u as useFilters } from "../../../hooks/useFilters.js";
7
7
  import { u as useDataGrid } from "../../../hooks/useDataGrid.js";
8
8
  import { S as SkeletonFormatter } from "../subcomponents/SkeletonFormatter/index.js";
9
- import { c as DATAGRID_SELECT_COLUMN_KEY } from "../../../constants.js";
9
+ import { d as DATAGRID_SELECT_COLUMN_KEY } from "../../../constants.js";
10
10
  function getComparator(columns, sortColumn) {
11
11
  const column = columns.find((d) => d.key === sortColumn);
12
12
  let typeOrder = "string";
@@ -43,15 +43,13 @@ const getInOrderColumns = (columns, hasCheckedRows, columnsConfig, columnsWidths
43
43
  const columnConfigIndex = getColumIndex(column.key, columnsConfig);
44
44
  const visible = columnConfigIndex > -1 ? columnsConfig[columnConfigIndex].visible : true;
45
45
  return !column.hidden && visible;
46
- }).sort(
47
- (a, b) => {
48
- let indexA = getColumIndex(a.key, columnsConfig);
49
- indexA = indexA === -1 ? columnsConfig.length : indexA;
50
- let indexB = getColumIndex(b.key, columnsConfig);
51
- indexB = indexB === -1 ? columnsConfig.length : indexB;
52
- return indexA - indexB;
53
- }
54
- ).map((columnSorted) => {
46
+ }).sort((a, b) => {
47
+ let indexA = getColumIndex(a.key, columnsConfig);
48
+ indexA = indexA === -1 ? columnsConfig.length : indexA;
49
+ let indexB = getColumIndex(b.key, columnsConfig);
50
+ indexB = indexB === -1 ? columnsConfig.length : indexB;
51
+ return indexA - indexB;
52
+ }).map((columnSorted) => {
55
53
  const columnConfigIndex = getColumIndex(columnSorted.key, columnsConfig);
56
54
  return {
57
55
  ...columnSorted,
@@ -83,21 +81,26 @@ const getAligByType = (columnType) => {
83
81
  }
84
82
  return "left";
85
83
  };
86
- const useSortColumnsRows = (sourceColumns, sourceRows) => {
84
+ const useSortColumnsRows = (sourceColumns, sourceRows, popoverHandlers) => {
87
85
  const {
88
86
  columnsConfig,
89
87
  columnsWidths,
90
88
  onChangeColumnsOrder,
91
89
  rowActionsGetter,
92
90
  checkedRows,
93
- onCheckedRowsChange
91
+ onCheckedRowsChange,
92
+ sortColumns,
93
+ setSortColumns
94
94
  } = useDataGrid();
95
- const [columns, setColumns] = useState(() => []);
96
- const [sortColumns, setSortColumns] = useState([]);
95
+ const [columns, setColumns] = useState(
96
+ () => []
97
+ );
97
98
  const isSkeleton = useModuleSkeleton();
98
99
  const { activeFilters, filters } = useFilters();
99
100
  const findKeyInColumns = (key, cols) => {
100
- const index = cols.findIndex((column) => key === column.key && column.hidden === false);
101
+ const index = cols.findIndex(
102
+ (column) => key === column.key && column.hidden === false
103
+ );
101
104
  return index !== -1;
102
105
  };
103
106
  useEffect(() => {
@@ -119,7 +122,12 @@ const useSortColumnsRows = (sourceColumns, sourceRows) => {
119
122
  }
120
123
  }, [sourceColumns, columnsConfig, rowActionsGetter]);
121
124
  const finalColumns = useMemo(() => {
122
- const DragAndDropHeaderRenderer = getDragHeaderRenderer(onChangeColumnsOrder);
125
+ const DragAndDropHeaderRenderer = getDragHeaderRenderer(
126
+ onChangeColumnsOrder,
127
+ {
128
+ openPopover: popoverHandlers?.openPopover
129
+ }
130
+ );
123
131
  return columns.map((c) => {
124
132
  const cellClass = c.align !== void 0 ? `rdg-cell-align-${c.align}` : `rdg-cell-align-${getAligByType(c.type)}`;
125
133
  const newColumn = {
@@ -143,7 +151,13 @@ const useSortColumnsRows = (sourceColumns, sourceRows) => {
143
151
  newColumn.headerRenderer = DragAndDropHeaderRenderer;
144
152
  return newColumn;
145
153
  });
146
- }, [isSkeleton, columns, activeFilters, onChangeColumnsOrder]);
154
+ }, [
155
+ isSkeleton,
156
+ columns,
157
+ activeFilters,
158
+ onChangeColumnsOrder,
159
+ popoverHandlers
160
+ ]);
147
161
  const finalRows = useMemo(() => {
148
162
  const nextRows = sourceRows.filter((r) => {
149
163
  if (!filters || filters.size === 0) {
@@ -154,7 +168,10 @@ const useSortColumnsRows = (sourceColumns, sourceRows) => {
154
168
  for (let i = 0; i < filters.size; i++) {
155
169
  const entry = iterator.next().value;
156
170
  const columnKey = entry?.[0] ?? "";
157
- const columnFilter = entry?.[1] ?? { value: "", customFilter: void 0 };
171
+ const columnFilter = entry?.[1] ?? {
172
+ value: "",
173
+ customFilter: void 0
174
+ };
158
175
  let valCell;
159
176
  const valueMaybeString = getPropertyByString(r, columnKey);
160
177
  let fixedValue;
@@ -1,5 +1,5 @@
1
- import { jsx } from "react/jsx-runtime";
2
- import { useRef, useEffect } from "react";
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { useMemo, useState, useRef, useEffect } from "react";
3
3
  import DataGrid from "react-data-grid";
4
4
  import { DndProvider } from "react-dnd";
5
5
  import { HTML5Backend } from "react-dnd-html5-backend";
@@ -9,15 +9,52 @@ import { u as useSortColumnsRows } from "./hooks/useSortColumnsRows.js";
9
9
  import { u as useFilters } from "../../hooks/useFilters.js";
10
10
  import { u as useDataGrid } from "../../hooks/useDataGrid.js";
11
11
  import { l as TableContainerStyled, T as TableWrapperDataGridStyled } from "../../slots/DataGridSlot.js";
12
+ import { u as useHeaderMenuActions } from "./hooks/useHeaderMenuActions.js";
13
+ import { H as HeaderRenderClick } from "./subcomponents/HeaderRenderClick/HeaderRenderClick.js";
12
14
  function Table(props) {
13
- const { columns, rows, onRowsChange, rowKeyGetter, selectedRows, onSelectedRowsChange } = props;
14
- const { finalColumns, sortColumns, setSortColumns, finalRows } = useSortColumnsRows(
15
+ const {
15
16
  columns,
16
- rows
17
+ rows,
18
+ onRowsChange,
19
+ rowKeyGetter,
20
+ selectedRows,
21
+ onSelectedRowsChange
22
+ } = props;
23
+ const { finalColumns, finalRows } = useSortColumnsRows(
24
+ columns,
25
+ rows,
26
+ useMemo(
27
+ () => ({
28
+ /**
29
+ * Función que abre el menú de acciones para una columna
30
+ */
31
+ openPopover: (anchorEl, columnKey) => {
32
+ if (anchorEl instanceof HTMLDivElement) {
33
+ setPopoverState({
34
+ anchorEl,
35
+ columnKey
36
+ });
37
+ }
38
+ }
39
+ }),
40
+ []
41
+ )
17
42
  );
18
43
  const { activeFilters } = useFilters();
19
- const { onChangeColumnWidth, setRowsCount, currentRowHeight, currentRowHeaderHeight, size } = useDataGrid();
44
+ const {
45
+ onChangeColumnWidth,
46
+ setRowsCount,
47
+ currentRowHeight,
48
+ currentRowHeaderHeight,
49
+ size,
50
+ sortColumns,
51
+ setSortColumns
52
+ } = useDataGrid();
20
53
  const ref_data_grid = useRef(null);
54
+ const [popoverState, setPopoverState] = useState({
55
+ anchorEl: null,
56
+ columnKey: null
57
+ });
21
58
  const onRowClick = (row) => {
22
59
  if (selectedRows && onSelectedRowsChange) {
23
60
  if (selectedRows.entries().next().value) {
@@ -32,11 +69,17 @@ function Table(props) {
32
69
  useEffect(() => {
33
70
  let columnIndice = 0;
34
71
  for (const column of finalColumns) {
35
- const index = sortColumns.findIndex((sortColumn) => column.key === sortColumn.columnKey);
72
+ const index = sortColumns.findIndex(
73
+ (sortColumn) => column.key === sortColumn.columnKey
74
+ );
36
75
  if (index !== -1) {
37
- ref_data_grid.current?.element?.querySelector(`[role="columnheader"][aria-colindex="${columnIndice + 1}"]`)?.setAttribute("aria-columnsort", `${sortColumns[index].direction}`);
76
+ ref_data_grid.current?.element?.querySelector(
77
+ `[role="columnheader"][aria-colindex="${columnIndice + 1}"]`
78
+ )?.setAttribute("aria-columnsort", `${sortColumns[index].direction}`);
38
79
  } else {
39
- ref_data_grid.current?.element?.querySelector(`[role="columnheader"][aria-colindex="${columnIndice + 1}"]`)?.removeAttribute("aria-columnsort");
80
+ ref_data_grid.current?.element?.querySelector(
81
+ `[role="columnheader"][aria-colindex="${columnIndice + 1}"]`
82
+ )?.removeAttribute("aria-columnsort");
40
83
  }
41
84
  columnIndice++;
42
85
  }
@@ -47,31 +90,51 @@ function Table(props) {
47
90
  const onColumnResize = (idx, width) => {
48
91
  onChangeColumnWidth(finalColumns[idx].key, width);
49
92
  };
50
- const onChangeSort = (newSortColumns) => {
51
- setSortColumns(newSortColumns);
52
- };
53
- return /* @__PURE__ */ jsx(TableContainerStyled, { id: "WrapperTable", children: /* @__PURE__ */ jsx(TableWrapperDataGridStyled, { ownerState: { size }, children: /* @__PURE__ */ jsx(DndProvider, { backend: HTML5Backend, context: window, children: /* @__PURE__ */ jsx(
54
- DataGrid,
55
- {
56
- className: "rdg-light",
57
- ref: ref_data_grid,
58
- headerRowHeight: activeFilters ? currentRowHeaderHeight + filterHeight : currentRowHeaderHeight,
59
- columns: finalColumns,
60
- sortColumns,
61
- onSortColumnsChange: onChangeSort,
62
- onColumnResize,
63
- rows: finalRows,
64
- onRowsChange,
65
- selectedRows,
66
- onSelectedRowsChange,
67
- onRowClick,
68
- rowHeight: currentRowHeight,
69
- rowKeyGetter,
70
- cellNavigationMode: "LOOP_OVER_ROW",
71
- components: { checkboxFormatter: CheckboxFormatter },
72
- defaultColumnOptions: { resizable: true, sortable: true }
73
- }
74
- ) }) }) });
93
+ const defaultColumnOptions = { resizable: true, sortable: true };
94
+ const menuActions = useHeaderMenuActions(
95
+ popoverState.columnKey,
96
+ finalColumns,
97
+ defaultColumnOptions.sortable
98
+ );
99
+ return /* @__PURE__ */ jsx(TableContainerStyled, { id: "WrapperTable", children: /* @__PURE__ */ jsxs(TableWrapperDataGridStyled, { ownerState: { size }, children: [
100
+ /* @__PURE__ */ jsx(DndProvider, { backend: HTML5Backend, context: window, children: /* @__PURE__ */ jsx(
101
+ DataGrid,
102
+ {
103
+ className: "rdg-light",
104
+ ref: ref_data_grid,
105
+ headerRowHeight: activeFilters ? currentRowHeaderHeight + filterHeight : currentRowHeaderHeight,
106
+ columns: finalColumns,
107
+ sortColumns,
108
+ onSortColumnsChange: setSortColumns,
109
+ onColumnResize,
110
+ rows: finalRows,
111
+ onRowsChange,
112
+ selectedRows,
113
+ onSelectedRowsChange,
114
+ onRowClick,
115
+ rowHeight: currentRowHeight,
116
+ rowKeyGetter,
117
+ cellNavigationMode: "LOOP_OVER_ROW",
118
+ components: { checkboxFormatter: CheckboxFormatter },
119
+ defaultColumnOptions
120
+ }
121
+ ) }),
122
+ popoverState.columnKey && popoverState.anchorEl instanceof HTMLDivElement && /* @__PURE__ */ jsx(
123
+ HeaderRenderClick,
124
+ {
125
+ externalOpen: popoverState.anchorEl,
126
+ onOpen: (open) => {
127
+ if (!open) {
128
+ setPopoverState({
129
+ anchorEl: null,
130
+ columnKey: null
131
+ });
132
+ }
133
+ },
134
+ menuActions
135
+ }
136
+ )
137
+ ] }) });
75
138
  }
76
139
  export {
77
140
  Table as T
@@ -1,7 +1,7 @@
1
1
  import { jsx, Fragment } from "react/jsx-runtime";
2
2
  import { u as useDataGrid } from "../../../hooks/useDataGrid.js";
3
3
  import { useTheme } from "@mui/material";
4
- import { d as DATAGRID_SEMANTIC_WIDTHS, e as DATAGRID_ACTIONS_COLUMN_KEY } from "../../../constants.js";
4
+ import { e as DATAGRID_SEMANTIC_WIDTHS, f as DATAGRID_ACTIONS_COLUMN_KEY } from "../../../constants.js";
5
5
  import { M as MenuActions } from "../../../../MenuActions/MenuActions.js";
6
6
  function ActionsFormatter(props) {
7
7
  const { rowActionsGetter } = useDataGrid();
@@ -1,6 +1,7 @@
1
1
  import { HeaderRendererProps } from 'react-data-grid';
2
2
  interface DraggableHeaderRendererProps<TRow> extends HeaderRendererProps<TRow> {
3
3
  onColumnsReorder: (sourceKey: string, targetKey: string) => void;
4
+ openPopover?: (anchorEl: HTMLElement, columnKey: string) => void;
4
5
  }
5
6
  /**
6
7
  * TODO: Documentar