@tap-payments/os-micro-frontend-shared 0.1.374 → 0.1.375-test.1-test.2

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 (95) hide show
  1. package/build/components/AnimatedSpinnerIcon/style.d.ts +0 -1
  2. package/build/components/Chip/style.d.ts +0 -1
  3. package/build/components/CountBadge/style.d.ts +0 -1
  4. package/build/components/Dialog/style.d.ts +0 -1
  5. package/build/components/FlippingCard/style.d.ts +0 -1
  6. package/build/components/ImageWrapper/ImageWrapper.d.ts +0 -1
  7. package/build/components/JSONViewer/style.d.ts +0 -1
  8. package/build/components/LeftPeekRightExpandingChip/style.d.ts +0 -1
  9. package/build/components/RightLeftExpandingCenterChip/style.d.ts +0 -1
  10. package/build/components/Sandbox/style.js +3 -2
  11. package/build/components/SearchButton/styles.d.ts +0 -1
  12. package/build/components/StatusIcons/AuthIcons/style.d.ts +0 -1
  13. package/build/components/StatusIcons/AuthorizationAutoIcons/style.d.ts +0 -1
  14. package/build/components/StatusIcons/ChargeStatusIcon/style.d.ts +0 -1
  15. package/build/components/StatusIcons/SourceIcons/style.d.ts +0 -1
  16. package/build/components/TableCells/CustomCells/ActionCell/style.d.ts +0 -1
  17. package/build/components/TableCells/CustomCells/AgreementCell/style.d.ts +0 -1
  18. package/build/components/TableCells/CustomCells/ApplicationStatusCell/style.d.ts +0 -1
  19. package/build/components/TableCells/CustomCells/AuthenticationCell/style.d.ts +0 -1
  20. package/build/components/TableCells/CustomCells/AuthenticationStatusCell/style.d.ts +0 -1
  21. package/build/components/TableCells/CustomCells/AuthenticationTypeCell/style.d.ts +0 -1
  22. package/build/components/TableCells/CustomCells/BalanceCell/style.d.ts +0 -1
  23. package/build/components/TableCells/CustomCells/ChannelsCell/style.d.ts +0 -1
  24. package/build/components/TableCells/CustomCells/CheckoutStatusCell/style.d.ts +0 -1
  25. package/build/components/TableCells/CustomCells/DestinationStatusCell/style.d.ts +0 -1
  26. package/build/components/TableCells/CustomCells/DueDateCell/style.d.ts +0 -1
  27. package/build/components/TableCells/CustomCells/IDButton/style.d.ts +0 -1
  28. package/build/components/TableCells/CustomCells/IntentsStatusCell/style.d.ts +0 -1
  29. package/build/components/TableCells/CustomCells/InvoiceStatusCell/style.d.ts +0 -1
  30. package/build/components/TableCells/CustomCells/PayoutReportCell/style.d.ts +0 -1
  31. package/build/components/TableCells/CustomCells/PayoutStatusCell/style.d.ts +0 -1
  32. package/build/components/TableCells/CustomCells/ProductsCell/style.d.ts +0 -1
  33. package/build/components/TableCells/CustomCells/ReferenceCell/style.d.ts +0 -1
  34. package/build/components/TableCells/CustomCells/RefundChargeCell/style.d.ts +0 -1
  35. package/build/components/TableCells/CustomCells/RefundStatusCell/style.d.ts +0 -1
  36. package/build/components/TableCells/CustomCells/SalesChannelCell/style.d.ts +0 -1
  37. package/build/components/TableCells/CustomCells/SegmentsCell/style.d.ts +0 -1
  38. package/build/components/TableCells/CustomCells/StatusCell/style.d.ts +0 -1
  39. package/build/components/TableCells/CustomCells/TokenStatusCell/style.d.ts +0 -1
  40. package/build/components/TableCells/CustomCells/style.d.ts +0 -1
  41. package/build/components/TableHeader/FiltersRow.d.ts +1 -1
  42. package/build/components/TableHeader/FiltersRow.js +4 -2
  43. package/build/components/TableHeader/TableHeader.d.ts +1 -1
  44. package/build/components/TableHeader/TableHeader.js +2 -2
  45. package/build/components/TableHeader/TableView/CreateViewDialog.d.ts +3 -0
  46. package/build/components/TableHeader/TableView/CreateViewDialog.js +91 -0
  47. package/build/components/TableHeader/TableView/CustomViews.js +1 -1
  48. package/build/components/TableHeader/TableView/TableView.js +0 -1
  49. package/build/components/TableHeader/TableView/ViewSelector.d.ts +5 -0
  50. package/build/components/TableHeader/TableView/ViewSelector.js +81 -0
  51. package/build/components/TableHeader/TableView/ViewsDropdown.d.ts +5 -0
  52. package/build/components/TableHeader/TableView/ViewsDropdown.js +198 -0
  53. package/build/components/TableHeader/TableView/components/ColumnList.d.ts +3 -0
  54. package/build/components/TableHeader/TableView/components/ColumnList.js +70 -0
  55. package/build/components/TableHeader/TableView/components/ViewsSubmenu.d.ts +3 -0
  56. package/build/components/TableHeader/TableView/components/ViewsSubmenu.js +71 -0
  57. package/build/components/TableHeader/TableView/components/index.d.ts +2 -0
  58. package/build/components/TableHeader/TableView/components/index.js +2 -0
  59. package/build/components/TableHeader/TableView/constants.d.ts +10 -0
  60. package/build/components/TableHeader/TableView/constants.js +10 -0
  61. package/build/components/TableHeader/TableView/data.d.ts +5 -0
  62. package/build/components/TableHeader/TableView/data.js +48 -0
  63. package/build/components/TableHeader/TableView/hooks/index.d.ts +6 -0
  64. package/build/components/TableHeader/TableView/hooks/index.js +6 -0
  65. package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.d.ts +22 -0
  66. package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.js +86 -0
  67. package/build/components/TableHeader/TableView/hooks/useDialogPosition.d.ts +8 -0
  68. package/build/components/TableHeader/TableView/hooks/useDialogPosition.js +16 -0
  69. package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.d.ts +7 -0
  70. package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.js +34 -0
  71. package/build/components/TableHeader/TableView/hooks/useOriginalColumns.d.ts +6 -0
  72. package/build/components/TableHeader/TableView/hooks/useOriginalColumns.js +18 -0
  73. package/build/components/TableHeader/TableView/hooks/useSubmenuHover.d.ts +8 -0
  74. package/build/components/TableHeader/TableView/hooks/useSubmenuHover.js +43 -0
  75. package/build/components/TableHeader/TableView/hooks/useViewSelector.d.ts +50 -0
  76. package/build/components/TableHeader/TableView/hooks/useViewSelector.js +239 -0
  77. package/build/components/TableHeader/TableView/hooks/useViewsManager.d.ts +20 -0
  78. package/build/components/TableHeader/TableView/hooks/useViewsManager.js +96 -0
  79. package/build/components/TableHeader/TableView/index.d.ts +12 -3
  80. package/build/components/TableHeader/TableView/index.js +13 -3
  81. package/build/components/TableHeader/TableView/styles.d.ts +127 -0
  82. package/build/components/TableHeader/TableView/styles.js +426 -0
  83. package/build/components/TableHeader/TableView/types.d.ts +183 -0
  84. package/build/components/TableHeader/TableView/types.js +1 -0
  85. package/build/components/TableHeader/TableView/utils.d.ts +121 -0
  86. package/build/components/TableHeader/TableView/utils.js +463 -0
  87. package/build/components/TableHeader/index.d.ts +1 -0
  88. package/build/components/TableHeader/type.d.ts +15 -1
  89. package/build/components/TableReports/components/DownloadButton/style.d.ts +0 -1
  90. package/build/components/TableReports/style.d.ts +0 -1
  91. package/build/components/VirtualTables/components/style.d.ts +0 -1
  92. package/build/constants/assets.d.ts +2 -0
  93. package/build/constants/assets.js +2 -0
  94. package/build/utils/date.js +5 -3
  95. package/package.json +4 -3
@@ -0,0 +1,198 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React, { useMemo } from 'react';
3
+ import Popper from '@mui/material/Popper';
4
+ import Box from '@mui/material/Box';
5
+ import Typography from '@mui/material/Typography';
6
+ import Divider from '@mui/material/Divider';
7
+ import Button from '@mui/material/Button';
8
+ import { useTranslation } from 'react-i18next';
9
+ import { bluePlusIcon, editIcon, smallBlueCheckIcon, blackRightArrowIcon } from '../../../constants/index.js';
10
+ import { Menu, Tooltip } from '../../index.js';
11
+ import { useSubmenuHover, useOriginalColumns } from './hooks';
12
+ import { MAX_CUSTOM_VIEWS } from './constants';
13
+ import { ViewsSubmenu } from './components/ViewsSubmenu';
14
+ import { ListStyled, DropdownStyled, MenuItem as StyledMenuItem, Space, SpaceAfter, SubmenuContainer, SaveCustomViewBox, SaveCustomViewInnerBox, ButtonsContainer, CancelButtonSx, OkayButtonSx, ModifiedTextSx, } from './styles';
15
+ import { deepCloneColumns, toggleSingleColumn, toggleSubItem, getSubmenuItems, hasSubmenu, areAllCurrentColumnsSelected, areSomeCurrentColumnsSelected, toggleAllCurrentColumns, areColumnsEqual, } from './utils';
16
+ function ViewsDropdown({ open, selectedViewInfo, setSelectedViewInfo, onSelect, setViews, anchorEl, onCreateCustomView, customViews = [], onEditCustomView, onSaveDefaultColumns, defaultColumns = [], setDefaultColumns, updateSelectedView, mode = 'default', defaultTemplate, }) {
17
+ const { t } = useTranslation();
18
+ const { hoveredColumn: hoveredItem, anchorEl: submenuAnchorEl, openSubmenu: handleMenuItemHover, closeSubmenu: handleMenuItemLeave, cancelClose: handleSubmenuEnter, forceClose: forceCloseSubmenu, } = useSubmenuHover();
19
+ const [hoveredCustomView, setHoveredCustomView] = React.useState(null);
20
+ const [isModified, setIsModified] = React.useState(false);
21
+ // Track original columns when submenu opens
22
+ const { originalColumns, saveOriginalState, clearOriginalState } = useOriginalColumns(defaultColumns);
23
+ // Build the view list (default template + custom views)
24
+ // Use actual defaultTemplate from props instead of static defaultViewList
25
+ const viewList = useMemo(() => {
26
+ const list = [];
27
+ if (defaultTemplate) {
28
+ list.push(defaultTemplate);
29
+ }
30
+ return [...list, ...customViews];
31
+ }, [defaultTemplate, customViews]);
32
+ // Get columns for hovered submenu
33
+ const currentSubmenuColumns = useMemo(() => {
34
+ if (!hoveredItem)
35
+ return [];
36
+ const item = viewList.find((i) => i.id === hoveredItem);
37
+ return item ? getSubmenuItems(item, defaultColumns) : [];
38
+ }, [hoveredItem, defaultColumns, viewList]);
39
+ const allCurrentSelected = useMemo(() => areAllCurrentColumnsSelected(currentSubmenuColumns), [currentSubmenuColumns]);
40
+ const someCurrentSelected = useMemo(() => areSomeCurrentColumnsSelected(currentSubmenuColumns, allCurrentSelected), [currentSubmenuColumns, allCurrentSelected]);
41
+ // Check if columns have been modified from original
42
+ const hasChanges = useMemo(() => {
43
+ if (originalColumns.length === 0)
44
+ return false;
45
+ return !areColumnsEqual(defaultColumns, originalColumns);
46
+ }, [defaultColumns, originalColumns]);
47
+ // Handle clicking on a view item
48
+ const handleViewClick = (item) => {
49
+ forceCloseSubmenu();
50
+ clearOriginalState();
51
+ let viewToPass;
52
+ if (item.default) {
53
+ // For default template, use defaultColumns (which is the default template's working copy)
54
+ const columns = defaultColumns.length > 0 ? defaultColumns : (defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.submenu) || [];
55
+ viewToPass = Object.assign(Object.assign({}, item), { submenu: deepCloneColumns(columns), columns: columns.map((col) => col.name) });
56
+ }
57
+ else if (item.isCustom) {
58
+ viewToPass = item;
59
+ }
60
+ setSelectedViewInfo(item, viewToPass);
61
+ };
62
+ // Toggle column selection
63
+ const toggleColumnSelection = (columnName) => {
64
+ if (!setDefaultColumns)
65
+ return;
66
+ const newColumns = toggleSingleColumn(defaultColumns, columnName);
67
+ setDefaultColumns(newColumns);
68
+ };
69
+ // Toggle nested item
70
+ const toggleNestedItem = (columnName, subItemName) => {
71
+ if (!setDefaultColumns)
72
+ return;
73
+ const newColumns = toggleSubItem(defaultColumns, columnName, subItemName);
74
+ setDefaultColumns(newColumns);
75
+ };
76
+ // Reorder columns
77
+ const handleReorder = (reorderedColumnNames) => {
78
+ if (!setDefaultColumns)
79
+ return;
80
+ const reorderedColumns = reorderedColumnNames
81
+ .map((name) => defaultColumns.find((column) => column.name === name))
82
+ .filter((column) => Boolean(column));
83
+ setDefaultColumns(reorderedColumns);
84
+ };
85
+ // Select all columns
86
+ const handleSelectAll = () => {
87
+ if (!setDefaultColumns)
88
+ return;
89
+ const newColumns = toggleAllCurrentColumns(defaultColumns, !allCurrentSelected);
90
+ setDefaultColumns(newColumns);
91
+ };
92
+ // Reset to original
93
+ const handleReset = () => {
94
+ if (!setDefaultColumns || originalColumns.length === 0)
95
+ return;
96
+ setDefaultColumns(deepCloneColumns(originalColumns));
97
+ };
98
+ // Open submenu
99
+ const handleOpenSubmenu = (itemId, element) => {
100
+ saveOriginalState();
101
+ handleMenuItemHover(itemId, element);
102
+ };
103
+ // Close submenu and restore if no changes saved
104
+ const handleSubmenuLeave = () => {
105
+ // Restore original columns if not saved
106
+ if (originalColumns.length > 0 && setDefaultColumns) {
107
+ setDefaultColumns(deepCloneColumns(originalColumns));
108
+ }
109
+ clearOriginalState();
110
+ forceCloseSubmenu();
111
+ };
112
+ // Cancel changes
113
+ const handleCancel = () => {
114
+ if (setDefaultColumns && originalColumns.length > 0) {
115
+ setDefaultColumns(deepCloneColumns(originalColumns));
116
+ }
117
+ clearOriginalState();
118
+ forceCloseSubmenu();
119
+ };
120
+ // Save changes
121
+ const handleOkay = () => {
122
+ var _a;
123
+ // Check if we're viewing the default template
124
+ const isViewingDefault = selectedViewInfo.id === (defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.id) || selectedViewInfo.id === 'default' || (defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.default) === true;
125
+ console.log('🔵 handleOkay:', {
126
+ isViewingDefault,
127
+ hasChanges,
128
+ selectedViewInfoId: selectedViewInfo.id,
129
+ defaultTemplateId: defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.id,
130
+ columnsCount: defaultColumns.length,
131
+ });
132
+ if (isViewingDefault && defaultTemplate && defaultColumns.length > 0) {
133
+ // Save changes if any
134
+ if (hasChanges) {
135
+ onSaveDefaultColumns === null || onSaveDefaultColumns === void 0 ? void 0 : onSaveDefaultColumns(defaultColumns);
136
+ setIsModified(true);
137
+ }
138
+ // ALWAYS update the selected view to reflect current column state
139
+ // CRITICAL: Create a NEW object with NEW array references to trigger re-renders
140
+ if (updateSelectedView) {
141
+ const updatedView = Object.assign(Object.assign({}, defaultTemplate), { id: defaultTemplate.id + '', submenu: [...deepCloneColumns(defaultColumns)], columns: [...defaultColumns.map((col) => col.name)] });
142
+ console.log('🟢 Calling updateSelectedView with:', (_a = updatedView.submenu) === null || _a === void 0 ? void 0 : _a.length, 'columns');
143
+ updateSelectedView(updatedView);
144
+ }
145
+ }
146
+ clearOriginalState();
147
+ forceCloseSubmenu();
148
+ };
149
+ // Save as custom view
150
+ const handleSaveAsCustomView = (e) => {
151
+ e.stopPropagation();
152
+ clearOriginalState();
153
+ forceCloseSubmenu();
154
+ onCreateCustomView === null || onCreateCustomView === void 0 ? void 0 : onCreateCustomView(true);
155
+ };
156
+ const shouldDimNewCustomView = customViews.length >= MAX_CUSTOM_VIEWS;
157
+ return (_jsxs(DropdownStyled, Object.assign({ "data-testid": "ViewsDropdown" }, { children: [_jsx(Popper, Object.assign({ open: open, anchorEl: anchorEl, placement: "bottom-start" }, { children: _jsxs(ListStyled, { children: [_jsx(Typography, Object.assign({ sx: {
158
+ paddingX: 1.25,
159
+ py: 1.1,
160
+ fontWeight: 500,
161
+ fontSize: 11,
162
+ color: '#8D8D94',
163
+ } }, { children: "View" })), _jsx(Divider, {}), viewList.map((item) => (_jsxs(StyledMenuItem, Object.assign({ onMouseEnter: (e) => {
164
+ if (item.isCustom) {
165
+ setHoveredCustomView(item.id);
166
+ }
167
+ else if (hasSubmenu(item, defaultColumns)) {
168
+ handleOpenSubmenu(item.id, e.currentTarget);
169
+ }
170
+ }, onMouseLeave: () => {
171
+ if (item.isCustom) {
172
+ setHoveredCustomView(null);
173
+ }
174
+ else if (hasSubmenu(item, defaultColumns)) {
175
+ handleMenuItemLeave();
176
+ }
177
+ }, onClick: () => handleViewClick(item), sx: { position: 'relative', cursor: 'pointer', pr: 1.5 } }, { children: [item.id === selectedViewInfo.id ? _jsx("img", { style: { width: 15, height: 15 }, src: smallBlueCheckIcon, alt: "check" }) : _jsx(Space, {}), _jsxs("span", Object.assign({ style: { flex: 1, fontSize: 11 } }, { children: [item.label, item.default && item.id === selectedViewInfo.id && isModified && _jsx("span", Object.assign({ style: ModifiedTextSx }, { children: "(Modified)" }))] })), item.isCustom && hoveredCustomView === item.id && (_jsx("img", { src: editIcon, alt: "edit", style: { width: 12, height: 12, cursor: 'pointer' }, onClick: (e) => {
178
+ e.stopPropagation();
179
+ onEditCustomView === null || onEditCustomView === void 0 ? void 0 : onEditCustomView(item);
180
+ } })), !item.isCustom && hasSubmenu(item, defaultColumns) && _jsx("img", { src: blackRightArrowIcon, alt: "arrow", style: { height: 12 } })] }), item.id))), _jsx(Tooltip, Object.assign({ title: "Limit reached. Delete a view to create a new one.", placement: "left", disableHoverListener: !shouldDimNewCustomView }, { children: _jsxs(StyledMenuItem, Object.assign({ sx: {
181
+ border: 'none',
182
+ opacity: shouldDimNewCustomView ? 0.5 : 1,
183
+ cursor: shouldDimNewCustomView ? 'not-allowed' : 'pointer',
184
+ }, onClick: (e) => {
185
+ if (shouldDimNewCustomView) {
186
+ e.stopPropagation();
187
+ return;
188
+ }
189
+ e.stopPropagation();
190
+ handleSubmenuLeave();
191
+ onCreateCustomView === null || onCreateCustomView === void 0 ? void 0 : onCreateCustomView(false);
192
+ } }, { children: [_jsx(Space, {}), _jsxs(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', gap: 0.5 } }, { children: [_jsx("img", { src: bluePlusIcon, alt: "icon", style: { opacity: shouldDimNewCustomView ? 0.5 : 1, width: 10, height: 10 } }), _jsx("span", Object.assign({ style: { color: shouldDimNewCustomView ? '#999' : '#1F88D0', fontSize: 11, fontWeight: 500 } }, { children: t('New Custom View') }))] })), _jsx(SpaceAfter, {})] })) }))] }) })), hoveredItem && submenuAnchorEl && currentSubmenuColumns.length > 0 && (_jsx(Menu, Object.assign({ open: Boolean(hoveredItem), anchorEl: submenuAnchorEl, placement: "auto-end", onMouseEnter: handleSubmenuEnter, onMouseLeave: handleSubmenuLeave, modifiers: [
193
+ { name: 'offset', options: { offset: [-4, 0] } },
194
+ { name: 'preventOverflow', enabled: true },
195
+ { name: 'flip', enabled: true },
196
+ ] }, { children: _jsxs(SubmenuContainer, { children: [_jsx(ViewsSubmenu, { columns: currentSubmenuColumns, allCurrentSelected: allCurrentSelected, someCurrentSelected: someCurrentSelected, onSelectAll: handleSelectAll, onReset: handleReset, onColumnToggle: toggleColumnSelection, onNestedItemToggle: toggleNestedItem, onReorder: handleReorder, anchorEl: submenuAnchorEl, isModified: hasChanges }), _jsx(SaveCustomViewBox, { children: _jsx(Tooltip, Object.assign({ title: "Limit reached. Delete a view to create a new one.", placement: "left", disableHoverListener: !shouldDimNewCustomView }, { children: _jsxs(SaveCustomViewInnerBox, Object.assign({ disabled: shouldDimNewCustomView, onClick: shouldDimNewCustomView ? undefined : handleSaveAsCustomView }, { children: [_jsx(Typography, Object.assign({ sx: { fontSize: 11, color: 'text.secondary' } }, { children: "Save as a custom view" })), _jsxs(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', gap: 0.5 } }, { children: [_jsx("img", { src: bluePlusIcon, alt: "add", style: { width: 10, height: 10, opacity: shouldDimNewCustomView ? 0.5 : 1 } }), _jsx(Typography, Object.assign({ sx: { fontSize: 10, fontWeight: 600, color: shouldDimNewCustomView ? '#999' : '#1F88D0' } }, { children: "Custom View" }))] }))] })) })) }), _jsxs(ButtonsContainer, { children: [_jsx(Button, Object.assign({ variant: "text", onClick: handleCancel, sx: CancelButtonSx }, { children: "Cancel" })), _jsx(Button, Object.assign({ variant: "contained", onClick: handleOkay, sx: OkayButtonSx }, { children: "Okay" }))] })] }) })))] })));
197
+ }
198
+ export default React.memo(ViewsDropdown);
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ import type { ColumnListProps } from '../types';
3
+ export declare const ColumnList: React.FC<ColumnListProps>;
@@ -0,0 +1,70 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import React from 'react';
3
+ import { Box, Typography, Link, Popper, Divider } from '@mui/material';
4
+ import { Reorder } from 'framer-motion';
5
+ import { dragIcon, rightArrow, viewIcon } from '../../../../constants/index.js';
6
+ import { Checkbox, MenuItem } from '../../../index.js';
7
+ import { isDateColumn, getColumnCheckState } from '../utils';
8
+ import { ColumnListContainer, SelectAllHeader, ColumnItemRow, DragIconWrapper, CheckboxWrapper, SubmenuPaper, checkboxSx } from '../styles';
9
+ export const ColumnList = ({ selectedColumns, columnNames, allSelected, someSelected, hoveredColumn, anchorEl, onReorder, onColumnToggle, onSubItemToggle, onSelectAll, onResetToDefault, onSubmenuEnter, onSubmenuLeave, onCancelClose, }) => {
10
+ return (_jsxs(ColumnListContainer, { children: [_jsxs(SelectAllHeader, { children: [_jsx(DragIconWrapper, { children: _jsx("img", { src: viewIcon, alt: "drag", style: { width: 16, height: 16, opacity: 0.5 } }) }), _jsx(CheckboxWrapper, Object.assign({ onClick: (e) => {
11
+ e.stopPropagation();
12
+ onSelectAll();
13
+ } }, { children: _jsx(Checkbox, { checked: allSelected, indeterminate: someSelected, size: "small", sx: checkboxSx, onChange: (e) => {
14
+ e.stopPropagation();
15
+ onSelectAll();
16
+ }, onClick: (e) => {
17
+ e.stopPropagation();
18
+ } }) })), _jsx(Typography, Object.assign({ onClick: (e) => {
19
+ e.stopPropagation();
20
+ onSelectAll();
21
+ }, sx: { flex: 1, fontSize: 13, fontWeight: 500, color: 'text.primary', ml: 0.75, cursor: 'pointer' } }, { children: "Select All" })), _jsx(Link, Object.assign({ component: "button", type: "button", onClick: (e) => {
22
+ e.stopPropagation();
23
+ onResetToDefault();
24
+ }, underline: "none", sx: { fontSize: 13, fontWeight: 500, cursor: 'pointer', color: 'common.blue' } }, { children: "Reset to default" }))] }), _jsx(Box, Object.assign({ sx: { flex: 1, overflowY: 'auto', minHeight: 0 } }, { children: _jsx(Reorder.Group, Object.assign({ axis: "y", onReorder: onReorder, values: columnNames, style: { listStyle: 'none', padding: 0, margin: 0 } }, { children: selectedColumns.map((column) => {
25
+ var _a;
26
+ const isDate = isDateColumn(column.name);
27
+ const hasSubmenu = column.menuItems && column.menuItems.length > 0;
28
+ const { checked, indeterminate } = getColumnCheckState(column);
29
+ return (_jsxs(Reorder.Item, Object.assign({ value: column.name, drag: !isDate, dragListener: !isDate, transition: { duration: 0 }, whileDrag: { zIndex: 9999, boxShadow: '0 4px 12px rgba(0,0,0,0.15)', scale: 1 }, style: {
30
+ listStyle: 'none',
31
+ margin: 0,
32
+ padding: 0,
33
+ position: 'relative',
34
+ zIndex: 1,
35
+ backgroundColor: '#fff',
36
+ width: '100%',
37
+ willChange: 'transform',
38
+ }, onDragStart: (e) => {
39
+ const target = e.target;
40
+ if (target.closest('[role="checkbox"]') ||
41
+ target.closest('input[type="checkbox"]') ||
42
+ target.closest('[class*="CheckboxWrapper"]')) {
43
+ e.preventDefault();
44
+ }
45
+ } }, { children: [_jsxs(ColumnItemRow, Object.assign({ isHovered: hoveredColumn === column.name, isDate: isDate, onMouseEnter: (e) => hasSubmenu && onSubmenuEnter(column.name, e.currentTarget), onMouseLeave: () => hasSubmenu && onSubmenuLeave(), onClick: (e) => {
46
+ if (e.target.closest('[role="checkbox"]') || e.target.closest('input[type="checkbox"]')) {
47
+ e.stopPropagation();
48
+ }
49
+ }, sx: { width: '100%', position: 'relative' } }, { children: [_jsx(DragIconWrapper, { children: _jsx("img", { src: dragIcon, alt: "drag", draggable: false, style: { width: 16, height: 16, cursor: isDate ? 'default' : 'grab', pointerEvents: 'none' } }) }), _jsx(CheckboxWrapper, Object.assign({ onMouseDown: (e) => {
50
+ e.stopPropagation();
51
+ }, onPointerDown: (e) => {
52
+ e.stopPropagation();
53
+ } }, { children: _jsx(Checkbox, { checked: checked, indeterminate: indeterminate, onChange: (e) => {
54
+ e.stopPropagation();
55
+ onColumnToggle(column.name);
56
+ }, onClick: (e) => {
57
+ e.stopPropagation();
58
+ }, disabled: isDate, size: "small", sx: checkboxSx }) })), _jsx(Typography, Object.assign({ sx: { flex: 1, fontSize: 13, fontWeight: 400, color: 'text.primary', ml: 1 } }, { children: column.label || column.name })), hasSubmenu && (_jsx(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', ml: 1, flexShrink: 0 } }, { children: _jsx("img", { src: rightArrow, alt: "arrow", style: { width: 12, height: 12 } }) })))] })), hasSubmenu && (_jsx(Popper, Object.assign({ open: hoveredColumn === column.name, anchorEl: anchorEl, placement: "right-start", sx: { zIndex: 10000 }, modifiers: [
59
+ {
60
+ name: 'offset',
61
+ options: {
62
+ offset: [0, 0],
63
+ },
64
+ },
65
+ ] }, { children: _jsxs(Box, Object.assign({ onMouseEnter: onCancelClose, onMouseLeave: onSubmenuLeave, sx: { display: 'flex', pl: 0.5 } }, { children: [_jsx(Box, { sx: { width: 8, height: '100%', position: 'absolute', left: -8, top: 0, bottom: 0 } }), _jsx(SubmenuPaper, { children: (_a = column.menuItems) === null || _a === void 0 ? void 0 : _a.map((subItem, subItemIndex) => {
66
+ var _a, _b;
67
+ return (_jsxs(React.Fragment, { children: [_jsx(MenuItem, Object.assign({ isSelected: subItem.selected, onClick: () => onSubItemToggle(column.name, subItem.name) }, { children: subItem.label || subItem.name })), subItemIndex < ((_b = (_a = column.menuItems) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0) - 1 && _jsx(Divider, {})] }, subItem.name));
68
+ }) })] })) })))] }), column.name));
69
+ }) })) }))] }));
70
+ };
@@ -0,0 +1,3 @@
1
+ import React from 'react';
2
+ import type { ViewsSubmenuProps } from '../types';
3
+ export declare const ViewsSubmenu: React.FC<ViewsSubmenuProps>;
@@ -0,0 +1,71 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import React, { useMemo } from 'react';
3
+ import { Box, Typography, Divider, Popper } from '@mui/material';
4
+ import { Reorder } from 'framer-motion';
5
+ import { Checkbox, MenuItem } from '../../../index.js';
6
+ import { blackRightArrowIcon } from '../../../../constants/index.js';
7
+ import { getColumnCheckState, isDateColumn } from '../utils';
8
+ import { ResetHeaderBox, ResetCheckboxSx, ColumnItemsContainer, SubmenuPaper } from '../styles';
9
+ import { useNestedSubmenu } from '../hooks/useNestedSubmenu';
10
+ export const ViewsSubmenu = ({ columns, allCurrentSelected, someCurrentSelected, onSelectAll, onReset, onColumnToggle, onNestedItemToggle, onReorder, anchorEl, isModified = false, }) => {
11
+ const { hoveredNestedColumn, nestedSubmenuAnchorEl, openNestedSubmenu, closeNestedSubmenu, cancelNestedClose } = useNestedSubmenu();
12
+ const columnNames = useMemo(() => columns.map((col) => col.name), [columns]);
13
+ return (_jsxs(_Fragment, { children: [_jsxs(ResetHeaderBox, { children: [_jsx(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', gap: 1 } }, { children: _jsx(Checkbox, { checked: allCurrentSelected, indeterminate: someCurrentSelected, onChange: (e) => {
14
+ e.stopPropagation();
15
+ onSelectAll();
16
+ }, onClick: (e) => {
17
+ e.stopPropagation();
18
+ }, sx: ResetCheckboxSx }) })), _jsx(Typography, Object.assign({ component: "button", onClick: (e) => {
19
+ e.stopPropagation();
20
+ onReset();
21
+ }, sx: {
22
+ fontSize: 11,
23
+ fontWeight: 500,
24
+ color: '#1F88D0',
25
+ background: 'none',
26
+ border: 'none',
27
+ cursor: 'pointer',
28
+ padding: 0,
29
+ opacity: isModified ? 1 : 0.5,
30
+ '&:hover': {
31
+ textDecoration: 'underline',
32
+ },
33
+ } }, { children: "Reset" }))] }), _jsx(Divider, {}), _jsx(ColumnItemsContainer, { children: _jsx(Reorder.Group, Object.assign({ axis: "y", onReorder: onReorder, values: columnNames, style: { listStyle: 'none', padding: 0, margin: 0 } }, { children: columns.map((column, columnIndex) => {
34
+ var _a;
35
+ const hasNestedSubmenu = column.menuItems && column.menuItems.length > 0;
36
+ const { checked, indeterminate } = getColumnCheckState(column);
37
+ const isDate = isDateColumn(column.name);
38
+ return (_jsxs(Reorder.Item, Object.assign({ value: column.name, drag: !isDate, dragListener: !isDate, transition: { duration: 0 }, whileDrag: { zIndex: 9999, boxShadow: '0 4px 12px rgba(0,0,0,0.15)', scale: 1.02 }, style: {
39
+ listStyle: 'none',
40
+ margin: 0,
41
+ padding: 0,
42
+ position: 'relative',
43
+ zIndex: 1,
44
+ backgroundColor: '#fff',
45
+ width: '100%',
46
+ willChange: 'transform',
47
+ }, onDragStart: (e) => {
48
+ const target = e.target;
49
+ if (target.closest('[role="checkbox"]') ||
50
+ target.closest('input[type="checkbox"]') ||
51
+ target.closest('[class*="CheckboxWrapper"]')) {
52
+ e.preventDefault();
53
+ }
54
+ } }, { children: [_jsxs(Box, Object.assign({ sx: { position: 'relative' }, onMouseEnter: (e) => hasNestedSubmenu && openNestedSubmenu(column.name, e.currentTarget), onMouseLeave: () => hasNestedSubmenu && closeNestedSubmenu() }, { children: [_jsxs(Box, Object.assign({ sx: {
55
+ display: 'flex',
56
+ alignItems: 'center',
57
+ justifyContent: 'space-between',
58
+ width: '100%',
59
+ } }, { children: [_jsx(MenuItem, Object.assign({ isSelected: hasNestedSubmenu ? checked : column.selected, isIndeterminate: hasNestedSubmenu ? indeterminate : false, onClick: () => onColumnToggle(column.name), sx: { flex: 1, display: 'flex', alignItems: 'center' } }, { children: _jsx("span", { children: column.label || column.name }) })), hasNestedSubmenu && (_jsx(Box, Object.assign({ sx: { display: 'flex', alignItems: 'center', pr: 1, pointerEvents: 'none' } }, { children: _jsx("img", { src: blackRightArrowIcon, alt: "arrow", style: { height: 12 } }) })))] })), hasNestedSubmenu && (_jsx(Popper, Object.assign({ open: hoveredNestedColumn === column.name, anchorEl: nestedSubmenuAnchorEl, placement: "right-start", sx: { zIndex: 10000 }, modifiers: [
60
+ {
61
+ name: 'offset',
62
+ options: {
63
+ offset: [0, 0],
64
+ },
65
+ },
66
+ ] }, { children: _jsxs(Box, Object.assign({ onMouseEnter: cancelNestedClose, onMouseLeave: closeNestedSubmenu, sx: { display: 'flex', pl: 0.5 } }, { children: [_jsx(Box, { sx: { width: 8, height: '100%', position: 'absolute', left: -8, top: 0, bottom: 0 } }), _jsx(SubmenuPaper, { children: (_a = column.menuItems) === null || _a === void 0 ? void 0 : _a.map((subItem, subItemIndex) => {
67
+ var _a, _b;
68
+ return (_jsxs(React.Fragment, { children: [_jsx(MenuItem, Object.assign({ isSelected: subItem.selected, onClick: () => onNestedItemToggle(column.name, subItem.name) }, { children: subItem.label || subItem.name })), subItemIndex < ((_b = (_a = column.menuItems) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0) - 1 && _jsx(Divider, {})] }, subItem.name));
69
+ }) })] })) })))] })), columnIndex < columns.length - 1 && _jsx(Divider, {})] }), column.name));
70
+ }) })) })] }));
71
+ };
@@ -0,0 +1,2 @@
1
+ export { ColumnList } from './ColumnList';
2
+ export { ViewsSubmenu } from './ViewsSubmenu';
@@ -0,0 +1,2 @@
1
+ export { ColumnList } from './ColumnList';
2
+ export { ViewsSubmenu } from './ViewsSubmenu';
@@ -0,0 +1,10 @@
1
+ export declare const DIALOG_WIDTH = 450;
2
+ export declare const DIALOG_HEIGHT = 600;
3
+ export declare const SUBMENU_CLOSE_DELAY = 150;
4
+ export declare const MAX_CUSTOM_VIEWS = 3;
5
+ export declare const TEMPLATE_NAME_MAX_LENGTH = 20;
6
+ export declare const DATE_COLUMN_CONFIG: {
7
+ readonly name: "date";
8
+ readonly label: "Date";
9
+ readonly selected: true;
10
+ };
@@ -0,0 +1,10 @@
1
+ export const DIALOG_WIDTH = 450;
2
+ export const DIALOG_HEIGHT = 600;
3
+ export const SUBMENU_CLOSE_DELAY = 150;
4
+ export const MAX_CUSTOM_VIEWS = 3;
5
+ export const TEMPLATE_NAME_MAX_LENGTH = 20;
6
+ export const DATE_COLUMN_CONFIG = {
7
+ name: 'date',
8
+ label: 'Date',
9
+ selected: true,
10
+ };
@@ -0,0 +1,5 @@
1
+ import type { ColumnViewProps } from '../../../types/index.js';
2
+ import type { ViewMenuItem } from './types';
3
+ export declare const advancedColumns: ColumnViewProps[];
4
+ export declare const sheetColumns: ColumnViewProps[];
5
+ export declare const defaultViewList: ViewMenuItem[];
@@ -0,0 +1,48 @@
1
+ export const advancedColumns = [
2
+ {
3
+ name: 'customer',
4
+ label: 'Customer',
5
+ selected: true,
6
+ menuItems: [
7
+ { name: 'customer_id', label: 'ID', selected: true },
8
+ { name: 'customer_name', label: 'Name', selected: true },
9
+ { name: 'customer_email', label: 'Email', selected: true },
10
+ { name: 'customer_phone', label: 'Phone', selected: false },
11
+ ],
12
+ },
13
+ {
14
+ name: 'transaction',
15
+ label: 'Transaction',
16
+ selected: true,
17
+ menuItems: [
18
+ { name: 'transaction_id', label: 'Transaction ID', selected: true },
19
+ { name: 'transaction_amount', label: 'Amount', selected: true },
20
+ { name: 'transaction_status', label: 'Status', selected: false },
21
+ { name: 'transaction_type', label: 'Type', selected: false },
22
+ ],
23
+ },
24
+ {
25
+ name: 'payment',
26
+ label: 'Payment',
27
+ selected: false,
28
+ menuItems: [
29
+ { name: 'payment_method', label: 'Method', selected: false },
30
+ { name: 'payment_card', label: 'Card', selected: false },
31
+ { name: 'payment_bank', label: 'Bank', selected: false },
32
+ ],
33
+ },
34
+ ];
35
+ export const sheetColumns = [
36
+ { name: 'customerID', label: 'Customer ID', selected: true },
37
+ { name: 'customerName', label: 'Customer Name', selected: true },
38
+ { name: 'amount', label: 'Amount', selected: true },
39
+ { name: 'status', label: 'Status', selected: false },
40
+ { name: 'currency', label: 'Currency', selected: false },
41
+ { name: 'reference', label: 'Reference', selected: true },
42
+ ];
43
+ export const defaultViewList = [
44
+ {
45
+ label: 'Default',
46
+ id: 'default',
47
+ },
48
+ ];
@@ -1,3 +1,9 @@
1
1
  export { useSubMenu } from './useSubMenu';
2
2
  export { useViewColumns } from './useViewColumns';
3
3
  export { useColumnItem } from './useColumnItem';
4
+ export { useViewsManager } from './useViewsManager';
5
+ export { useViewSelector } from './useViewSelector';
6
+ export { useSubmenuHover } from './useSubmenuHover';
7
+ export { useOriginalColumns } from './useOriginalColumns';
8
+ export { useNestedSubmenu } from './useNestedSubmenu';
9
+ export { useCreateViewDialog } from './useCreateViewDialog';
@@ -1,3 +1,9 @@
1
1
  export { useSubMenu } from './useSubMenu';
2
2
  export { useViewColumns } from './useViewColumns';
3
3
  export { useColumnItem } from './useColumnItem';
4
+ export { useViewsManager } from './useViewsManager';
5
+ export { useViewSelector } from './useViewSelector';
6
+ export { useSubmenuHover } from './useSubmenuHover';
7
+ export { useOriginalColumns } from './useOriginalColumns';
8
+ export { useNestedSubmenu } from './useNestedSubmenu';
9
+ export { useCreateViewDialog } from './useCreateViewDialog';
@@ -0,0 +1,22 @@
1
+ /// <reference types="react" />
2
+ import type { ColumnViewProps } from '../../../../types/index.js';
3
+ import type { UseCreateViewDialogProps } from '../types';
4
+ export declare const useCreateViewDialog: ({ open, availableColumns, defaultColumns, editingView, tableViews }: UseCreateViewDialogProps) => {
5
+ templateName: string;
6
+ setTemplateName: import("react").Dispatch<import("react").SetStateAction<string>>;
7
+ selectedColumns: ColumnViewProps[];
8
+ columnNames: string[];
9
+ allSelected: boolean;
10
+ someSelected: boolean;
11
+ isNameValid: boolean;
12
+ hoveredColumn: string | null;
13
+ anchorEl: HTMLElement | null;
14
+ openSubmenu: (columnName: string, element: HTMLElement) => void;
15
+ closeSubmenu: () => void;
16
+ cancelClose: () => void;
17
+ handleReorder: (reorderedNames: string[]) => void;
18
+ handleColumnToggle: (columnName: string) => void;
19
+ handleSubItemToggle: (columnName: string, subItemName: string) => void;
20
+ handleSelectAll: () => void;
21
+ handleResetToDefault: () => void;
22
+ };
@@ -0,0 +1,86 @@
1
+ import { useState, useEffect, useMemo, useRef } from 'react';
2
+ import { DATE_COLUMN_CONFIG, TEMPLATE_NAME_MAX_LENGTH } from '../constants';
3
+ import { initializeEditingColumns, initializeCreateColumns, initializeCreateColumnsWithCurrentState, resetColumnsToDefault, toggleColumn, toggleSubItem, toggleAllColumns, areAllColumnsSelected, areSomeColumnsSelected, isValidTemplateName, } from '../utils';
4
+ import { useSubmenuHover } from './useSubmenuHover';
5
+ export const useCreateViewDialog = ({ open, availableColumns, defaultColumns, editingView, tableViews = [] }) => {
6
+ const [templateName, setTemplateName] = useState(() => (editingView === null || editingView === void 0 ? void 0 : editingView.label) || '');
7
+ const [selectedColumns, setSelectedColumns] = useState([]);
8
+ const previousOpenRef = useRef(false);
9
+ const { hoveredColumn, anchorEl, openSubmenu, closeSubmenu, cancelClose } = useSubmenuHover();
10
+ const dateColumn = DATE_COLUMN_CONFIG;
11
+ useEffect(() => {
12
+ var _a, _b;
13
+ if (!open) {
14
+ previousOpenRef.current = false;
15
+ return;
16
+ }
17
+ const wasClosed = !previousOpenRef.current;
18
+ if (wasClosed && open) {
19
+ if (editingView) {
20
+ // Use the saved submenu from editingView if available, otherwise fall back to defaultColumns
21
+ const savedColumns = editingView.submenu && editingView.submenu.length > 0 ? editingView.submenu : defaultColumns;
22
+ const otherColumns = initializeEditingColumns(savedColumns, availableColumns);
23
+ setSelectedColumns([dateColumn, ...otherColumns]);
24
+ // Ensure templateName is set to editingView.label (fallback to empty string if undefined)
25
+ const nameToSet = ((_a = editingView.label) === null || _a === void 0 ? void 0 : _a.trim()) || '';
26
+ setTemplateName(nameToSet);
27
+ }
28
+ else {
29
+ const otherColumns = tableViews && tableViews.length > 0
30
+ ? initializeCreateColumnsWithCurrentState(availableColumns, tableViews)
31
+ : initializeCreateColumns(availableColumns);
32
+ setSelectedColumns([dateColumn, ...otherColumns]);
33
+ setTemplateName('');
34
+ }
35
+ }
36
+ else if (open && editingView) {
37
+ // Update templateName when editingView changes while dialog is open
38
+ const nameToSet = ((_b = editingView.label) === null || _b === void 0 ? void 0 : _b.trim()) || '';
39
+ setTemplateName(nameToSet);
40
+ }
41
+ previousOpenRef.current = open;
42
+ }, [open, editingView === null || editingView === void 0 ? void 0 : editingView.id, editingView === null || editingView === void 0 ? void 0 : editingView.label, editingView === null || editingView === void 0 ? void 0 : editingView.submenu, availableColumns, defaultColumns, tableViews, dateColumn]);
43
+ const columnNames = useMemo(() => selectedColumns.map((col) => col.name), [selectedColumns]);
44
+ const allSelected = useMemo(() => areAllColumnsSelected(selectedColumns), [selectedColumns]);
45
+ const someSelected = useMemo(() => areSomeColumnsSelected(selectedColumns, allSelected), [selectedColumns, allSelected]);
46
+ const isNameValid = useMemo(() => isValidTemplateName(templateName, TEMPLATE_NAME_MAX_LENGTH), [templateName]);
47
+ const handleReorder = (reorderedNames) => {
48
+ const reorderedColumns = reorderedNames
49
+ .map((name) => selectedColumns.find((col) => col.name === name))
50
+ .filter((col) => Boolean(col));
51
+ setSelectedColumns(reorderedColumns);
52
+ };
53
+ const handleColumnToggle = (columnName) => {
54
+ setSelectedColumns((prev) => toggleColumn(prev, columnName));
55
+ };
56
+ const handleSubItemToggle = (columnName, subItemName) => {
57
+ setSelectedColumns((prev) => toggleSubItem(prev, columnName, subItemName));
58
+ };
59
+ const handleSelectAll = () => {
60
+ setSelectedColumns((prev) => toggleAllColumns(prev, !allSelected));
61
+ };
62
+ const handleResetToDefault = () => {
63
+ const columnsSource = defaultColumns.length > 0 ? defaultColumns : availableColumns;
64
+ const otherColumns = resetColumnsToDefault(columnsSource);
65
+ setSelectedColumns([dateColumn, ...otherColumns]);
66
+ };
67
+ return {
68
+ templateName,
69
+ setTemplateName,
70
+ selectedColumns,
71
+ columnNames,
72
+ allSelected,
73
+ someSelected,
74
+ isNameValid,
75
+ hoveredColumn,
76
+ anchorEl,
77
+ openSubmenu,
78
+ closeSubmenu,
79
+ cancelClose,
80
+ handleReorder,
81
+ handleColumnToggle,
82
+ handleSubItemToggle,
83
+ handleSelectAll,
84
+ handleResetToDefault,
85
+ };
86
+ };
@@ -0,0 +1,8 @@
1
+ export declare const useDialogPosition: (dialogWidth: number, dialogHeight: number) => {
2
+ position: {
3
+ x: number;
4
+ y: number;
5
+ };
6
+ resetPosition: () => void;
7
+ updatePosition: (x: number, y: number) => void;
8
+ };
@@ -0,0 +1,16 @@
1
+ import { useState, useCallback } from 'react';
2
+ export const useDialogPosition = (dialogWidth, dialogHeight) => {
3
+ const [position, setPosition] = useState({ x: 0, y: 0 });
4
+ const resetPosition = useCallback(() => {
5
+ const centerX = window.innerWidth / 2 - dialogWidth / 2;
6
+ const centerY = window.innerHeight / 2 - dialogHeight / 2;
7
+ setPosition({
8
+ x: Math.max(0, centerX),
9
+ y: Math.max(0, centerY),
10
+ });
11
+ }, [dialogWidth, dialogHeight]);
12
+ const updatePosition = useCallback((x, y) => {
13
+ setPosition({ x, y });
14
+ }, []);
15
+ return { position, resetPosition, updatePosition };
16
+ };
@@ -0,0 +1,7 @@
1
+ export declare const useNestedSubmenu: () => {
2
+ hoveredNestedColumn: string | null;
3
+ nestedSubmenuAnchorEl: HTMLElement | null;
4
+ openNestedSubmenu: (columnName: string, element: HTMLElement) => void;
5
+ closeNestedSubmenu: () => void;
6
+ cancelNestedClose: () => void;
7
+ };