@tap-payments/os-micro-frontend-shared 0.1.376 → 0.1.377-test.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.
- package/build/components/AnimatedSpinnerIcon/style.d.ts +0 -1
- package/build/components/Chip/style.d.ts +0 -1
- package/build/components/CountBadge/style.d.ts +0 -1
- package/build/components/Dialog/style.d.ts +0 -1
- package/build/components/FlippingCard/style.d.ts +0 -1
- package/build/components/ImageWrapper/ImageWrapper.d.ts +0 -1
- package/build/components/JSONViewer/style.d.ts +0 -1
- package/build/components/LeftPeekRightExpandingChip/style.d.ts +0 -1
- package/build/components/RightLeftExpandingCenterChip/style.d.ts +0 -1
- package/build/components/SearchButton/styles.d.ts +0 -1
- package/build/components/StatusIcons/AuthIcons/style.d.ts +0 -1
- package/build/components/StatusIcons/AuthorizationAutoIcons/style.d.ts +0 -1
- package/build/components/StatusIcons/ChargeStatusIcon/style.d.ts +0 -1
- package/build/components/StatusIcons/SourceIcons/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/ActionCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/AgreementCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/ApplicationStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/AuthenticationCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/AuthenticationStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/AuthenticationTypeCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/BalanceCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/ChannelsCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/CheckoutStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/DestinationStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/DueDateCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/IDButton/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/IntentsStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/InvoiceStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/PayoutReportCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/PayoutStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/ProductsCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/ReferenceCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/RefundChargeCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/RefundStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/SalesChannelCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/SegmentsCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/StatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/TokenStatusCell/style.d.ts +0 -1
- package/build/components/TableCells/CustomCells/style.d.ts +0 -1
- package/build/components/TableHeader/FiltersRow.d.ts +1 -1
- package/build/components/TableHeader/FiltersRow.js +4 -2
- package/build/components/TableHeader/TableHeader.d.ts +1 -1
- package/build/components/TableHeader/TableHeader.js +2 -2
- package/build/components/TableHeader/TableView/CreateViewDialog.d.ts +3 -0
- package/build/components/TableHeader/TableView/CreateViewDialog.js +91 -0
- package/build/components/TableHeader/TableView/CustomViews.js +1 -1
- package/build/components/TableHeader/TableView/TableView.js +0 -1
- package/build/components/TableHeader/TableView/ViewsDropdown.d.ts +5 -0
- package/build/components/TableHeader/TableView/ViewsDropdown.js +189 -0
- package/build/components/TableHeader/TableView/ViewsMenu.d.ts +5 -0
- package/build/components/TableHeader/TableView/ViewsMenu.js +76 -0
- package/build/components/TableHeader/TableView/components/ColumnList.d.ts +3 -0
- package/build/components/TableHeader/TableView/components/ColumnList.js +70 -0
- package/build/components/TableHeader/TableView/components/ViewsSubmenu.d.ts +3 -0
- package/build/components/TableHeader/TableView/components/ViewsSubmenu.js +75 -0
- package/build/components/TableHeader/TableView/components/index.d.ts +2 -0
- package/build/components/TableHeader/TableView/components/index.js +2 -0
- package/build/components/TableHeader/TableView/constants.d.ts +10 -0
- package/build/components/TableHeader/TableView/constants.js +10 -0
- package/build/components/TableHeader/TableView/data.d.ts +5 -0
- package/build/components/TableHeader/TableView/data.js +48 -0
- package/build/components/TableHeader/TableView/hooks/index.d.ts +6 -0
- package/build/components/TableHeader/TableView/hooks/index.js +6 -0
- package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.d.ts +22 -0
- package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.js +86 -0
- package/build/components/TableHeader/TableView/hooks/useDialogPosition.d.ts +8 -0
- package/build/components/TableHeader/TableView/hooks/useDialogPosition.js +16 -0
- package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.d.ts +7 -0
- package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.js +27 -0
- package/build/components/TableHeader/TableView/hooks/useOriginalColumns.d.ts +6 -0
- package/build/components/TableHeader/TableView/hooks/useOriginalColumns.js +18 -0
- package/build/components/TableHeader/TableView/hooks/useSubmenuHover.d.ts +8 -0
- package/build/components/TableHeader/TableView/hooks/useSubmenuHover.js +43 -0
- package/build/components/TableHeader/TableView/hooks/useViewsManager.d.ts +9 -0
- package/build/components/TableHeader/TableView/hooks/useViewsManager.js +62 -0
- package/build/components/TableHeader/TableView/hooks/useViewsMenu.d.ts +44 -0
- package/build/components/TableHeader/TableView/hooks/useViewsMenu.js +177 -0
- package/build/components/TableHeader/TableView/index.d.ts +12 -3
- package/build/components/TableHeader/TableView/index.js +11 -3
- package/build/components/TableHeader/TableView/styles.d.ts +127 -0
- package/build/components/TableHeader/TableView/styles.js +426 -0
- package/build/components/TableHeader/TableView/types.d.ts +182 -0
- package/build/components/TableHeader/TableView/types.js +1 -0
- package/build/components/TableHeader/TableView/utils.d.ts +121 -0
- package/build/components/TableHeader/TableView/utils.js +469 -0
- package/build/components/TableHeader/index.d.ts +1 -0
- package/build/components/TableHeader/type.d.ts +15 -1
- package/build/components/TableReports/components/DownloadButton/style.d.ts +0 -1
- package/build/components/TableReports/style.d.ts +0 -1
- package/build/components/VirtualTables/VirtualTable/VirtualTable.d.ts +1 -1
- package/build/components/VirtualTables/VirtualTable/VirtualTable.js +4 -3
- package/build/components/VirtualTables/components/style.d.ts +0 -1
- package/build/constants/assets.d.ts +1 -0
- package/build/constants/assets.js +1 -0
- package/build/types/table.d.ts +1 -0
- package/build/utils/index.d.ts +1 -0
- package/build/utils/index.js +1 -0
- package/build/utils/skeletonColumns.d.ts +4 -0
- package/build/utils/skeletonColumns.js +17 -0
- package/package.json +4 -3
|
@@ -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,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
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { useState, useRef, useCallback } from 'react';
|
|
2
|
+
export const useNestedSubmenu = () => {
|
|
3
|
+
const [hoveredNestedColumn, setHoveredNestedColumn] = useState(null);
|
|
4
|
+
const [nestedSubmenuAnchorEl, setNestedSubmenuAnchorEl] = useState(null);
|
|
5
|
+
const nestedCloseTimeoutRef = useRef(null);
|
|
6
|
+
const openNestedSubmenu = useCallback((columnName, element) => {
|
|
7
|
+
setHoveredNestedColumn(columnName);
|
|
8
|
+
setNestedSubmenuAnchorEl(element);
|
|
9
|
+
}, []);
|
|
10
|
+
const closeNestedSubmenu = useCallback(() => {
|
|
11
|
+
setHoveredNestedColumn(null);
|
|
12
|
+
setNestedSubmenuAnchorEl(null);
|
|
13
|
+
}, []);
|
|
14
|
+
const cancelNestedClose = useCallback(() => {
|
|
15
|
+
if (nestedCloseTimeoutRef.current) {
|
|
16
|
+
clearTimeout(nestedCloseTimeoutRef.current);
|
|
17
|
+
nestedCloseTimeoutRef.current = null;
|
|
18
|
+
}
|
|
19
|
+
}, []);
|
|
20
|
+
return {
|
|
21
|
+
hoveredNestedColumn,
|
|
22
|
+
nestedSubmenuAnchorEl,
|
|
23
|
+
openNestedSubmenu,
|
|
24
|
+
closeNestedSubmenu,
|
|
25
|
+
cancelNestedClose,
|
|
26
|
+
};
|
|
27
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
export const useOriginalColumns = (defaultColumns) => {
|
|
3
|
+
const [originalColumns, setOriginalColumns] = useState([]);
|
|
4
|
+
const saveOriginalState = useCallback(() => {
|
|
5
|
+
setOriginalColumns(defaultColumns.map((col) => {
|
|
6
|
+
var _a;
|
|
7
|
+
return (Object.assign(Object.assign({}, col), { selected: col.selected, menuItems: (_a = col.menuItems) === null || _a === void 0 ? void 0 : _a.map((item) => (Object.assign(Object.assign({}, item), { selected: item.selected }))) }));
|
|
8
|
+
}));
|
|
9
|
+
}, [defaultColumns]);
|
|
10
|
+
const clearOriginalState = useCallback(() => {
|
|
11
|
+
setOriginalColumns([]);
|
|
12
|
+
}, []);
|
|
13
|
+
return {
|
|
14
|
+
originalColumns,
|
|
15
|
+
saveOriginalState,
|
|
16
|
+
clearOriginalState,
|
|
17
|
+
};
|
|
18
|
+
};
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { useState, useRef, useCallback } from 'react';
|
|
2
|
+
import { SUBMENU_CLOSE_DELAY } from '../constants';
|
|
3
|
+
export const useSubmenuHover = () => {
|
|
4
|
+
const [hoveredColumn, setHoveredColumn] = useState(null);
|
|
5
|
+
const [anchorEl, setAnchorEl] = useState(null);
|
|
6
|
+
const closeTimeoutRef = useRef(null);
|
|
7
|
+
const openSubmenu = useCallback((columnName, element) => {
|
|
8
|
+
if (closeTimeoutRef.current) {
|
|
9
|
+
clearTimeout(closeTimeoutRef.current);
|
|
10
|
+
closeTimeoutRef.current = null;
|
|
11
|
+
}
|
|
12
|
+
setHoveredColumn(columnName);
|
|
13
|
+
setAnchorEl(element);
|
|
14
|
+
}, []);
|
|
15
|
+
const closeSubmenu = useCallback(() => {
|
|
16
|
+
closeTimeoutRef.current = setTimeout(() => {
|
|
17
|
+
setHoveredColumn(null);
|
|
18
|
+
setAnchorEl(null);
|
|
19
|
+
}, SUBMENU_CLOSE_DELAY);
|
|
20
|
+
}, []);
|
|
21
|
+
const cancelClose = useCallback(() => {
|
|
22
|
+
if (closeTimeoutRef.current) {
|
|
23
|
+
clearTimeout(closeTimeoutRef.current);
|
|
24
|
+
closeTimeoutRef.current = null;
|
|
25
|
+
}
|
|
26
|
+
}, []);
|
|
27
|
+
const forceClose = useCallback(() => {
|
|
28
|
+
if (closeTimeoutRef.current) {
|
|
29
|
+
clearTimeout(closeTimeoutRef.current);
|
|
30
|
+
closeTimeoutRef.current = null;
|
|
31
|
+
}
|
|
32
|
+
setHoveredColumn(null);
|
|
33
|
+
setAnchorEl(null);
|
|
34
|
+
}, []);
|
|
35
|
+
return {
|
|
36
|
+
hoveredColumn,
|
|
37
|
+
anchorEl,
|
|
38
|
+
openSubmenu,
|
|
39
|
+
closeSubmenu,
|
|
40
|
+
cancelClose,
|
|
41
|
+
forceClose,
|
|
42
|
+
};
|
|
43
|
+
};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ColumnViewProps } from '../../../../types/index.js';
|
|
2
|
+
import type { UseViewsManagerProps, ViewMenuItem } from '../types';
|
|
3
|
+
export declare const useViewsManager: ({ tableMode, templates, lang }: UseViewsManagerProps) => {
|
|
4
|
+
defaultTemplate: ViewMenuItem | undefined;
|
|
5
|
+
customViews: ViewMenuItem[];
|
|
6
|
+
allTemplates: ViewMenuItem[];
|
|
7
|
+
defaultColumns: ColumnViewProps[];
|
|
8
|
+
updateDefaultColumns: (columns: ColumnViewProps[]) => void;
|
|
9
|
+
};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { useState, useEffect, useMemo, useCallback } from 'react';
|
|
2
|
+
import { transformTemplatesToViewMenuItems, deepCloneColumns } from '../utils';
|
|
3
|
+
export const useViewsManager = ({ tableMode, templates, lang = 'en' }) => {
|
|
4
|
+
const parsedTemplates = useMemo(() => {
|
|
5
|
+
if (!templates || templates.length === 0) {
|
|
6
|
+
return {
|
|
7
|
+
customViews: [],
|
|
8
|
+
defaultTemplate: undefined,
|
|
9
|
+
templateDefaultColumns: [],
|
|
10
|
+
allTemplates: [],
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
const { customViews, defaultTemplate } = transformTemplatesToViewMenuItems(templates, tableMode, lang);
|
|
14
|
+
const allTemplates = defaultTemplate ? [defaultTemplate, ...customViews] : customViews;
|
|
15
|
+
return {
|
|
16
|
+
customViews,
|
|
17
|
+
defaultTemplate,
|
|
18
|
+
templateDefaultColumns: (defaultTemplate === null || defaultTemplate === void 0 ? void 0 : defaultTemplate.submenu) || [],
|
|
19
|
+
allTemplates,
|
|
20
|
+
};
|
|
21
|
+
}, [templates, tableMode, lang]);
|
|
22
|
+
const [defaultColumns, setDefaultColumns] = useState([]);
|
|
23
|
+
const [initializedMode, setInitializedMode] = useState(null);
|
|
24
|
+
useEffect(() => {
|
|
25
|
+
if (initializedMode !== tableMode && parsedTemplates.templateDefaultColumns.length > 0) {
|
|
26
|
+
setDefaultColumns(deepCloneColumns(parsedTemplates.templateDefaultColumns));
|
|
27
|
+
setInitializedMode(tableMode);
|
|
28
|
+
}
|
|
29
|
+
}, [tableMode, parsedTemplates.templateDefaultColumns, initializedMode]);
|
|
30
|
+
const updateDefaultColumns = useCallback((columns) => {
|
|
31
|
+
setDefaultColumns(deepCloneColumns(columns));
|
|
32
|
+
}, []);
|
|
33
|
+
const updatedDefaultTemplate = useMemo(() => {
|
|
34
|
+
if (!parsedTemplates.defaultTemplate) {
|
|
35
|
+
return parsedTemplates.defaultTemplate;
|
|
36
|
+
}
|
|
37
|
+
const columnsToUse = initializedMode !== tableMode ? parsedTemplates.templateDefaultColumns : defaultColumns;
|
|
38
|
+
if (columnsToUse.length === 0) {
|
|
39
|
+
return parsedTemplates.defaultTemplate;
|
|
40
|
+
}
|
|
41
|
+
return Object.assign(Object.assign({}, parsedTemplates.defaultTemplate), { submenu: columnsToUse, columns: columnsToUse.map((col) => col.name) });
|
|
42
|
+
}, [parsedTemplates.defaultTemplate, parsedTemplates.templateDefaultColumns, defaultColumns, initializedMode, tableMode]);
|
|
43
|
+
const updatedAllTemplates = useMemo(() => {
|
|
44
|
+
if (!updatedDefaultTemplate) {
|
|
45
|
+
return parsedTemplates.customViews;
|
|
46
|
+
}
|
|
47
|
+
return [updatedDefaultTemplate, ...parsedTemplates.customViews];
|
|
48
|
+
}, [updatedDefaultTemplate, parsedTemplates.customViews]);
|
|
49
|
+
const effectiveDefaultColumns = useMemo(() => {
|
|
50
|
+
if (initializedMode !== tableMode && defaultColumns.length === 0) {
|
|
51
|
+
return parsedTemplates.templateDefaultColumns;
|
|
52
|
+
}
|
|
53
|
+
return defaultColumns.length > 0 ? defaultColumns : parsedTemplates.templateDefaultColumns;
|
|
54
|
+
}, [initializedMode, tableMode, defaultColumns, parsedTemplates.templateDefaultColumns]);
|
|
55
|
+
return {
|
|
56
|
+
defaultTemplate: updatedDefaultTemplate,
|
|
57
|
+
customViews: parsedTemplates.customViews,
|
|
58
|
+
allTemplates: updatedAllTemplates,
|
|
59
|
+
defaultColumns: effectiveDefaultColumns,
|
|
60
|
+
updateDefaultColumns,
|
|
61
|
+
};
|
|
62
|
+
};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { type MouseEvent } from 'react';
|
|
2
|
+
import type { ColumnViewProps, TableMode } from '../../../../types/index.js';
|
|
3
|
+
import type { ViewMenuItem, LayoutSection } from '../types';
|
|
4
|
+
import type { ViewOption } from '../../type';
|
|
5
|
+
export interface UseViewsMenuProps {
|
|
6
|
+
mode: TableMode;
|
|
7
|
+
onViewChange?: (selectedView?: ViewMenuItem) => void;
|
|
8
|
+
onCreateCustomView?: (data: {
|
|
9
|
+
name: string;
|
|
10
|
+
selectedColumns: ColumnViewProps[];
|
|
11
|
+
layout: LayoutSection;
|
|
12
|
+
}) => Promise<void>;
|
|
13
|
+
onEditCustomView?: (viewId: string, data: {
|
|
14
|
+
name: string;
|
|
15
|
+
selectedColumns: ColumnViewProps[];
|
|
16
|
+
layout: LayoutSection;
|
|
17
|
+
}) => Promise<void>;
|
|
18
|
+
onDeleteCustomView?: (viewId: string) => Promise<void>;
|
|
19
|
+
defaultColumns: ColumnViewProps[];
|
|
20
|
+
defaultTemplate?: ViewMenuItem;
|
|
21
|
+
allTemplates: ViewMenuItem[];
|
|
22
|
+
}
|
|
23
|
+
export declare const useViewsMenu: ({ mode, onViewChange, onCreateCustomView, onEditCustomView, onDeleteCustomView, defaultColumns, defaultTemplate, allTemplates, }: UseViewsMenuProps) => {
|
|
24
|
+
anchorEl: HTMLDivElement | null;
|
|
25
|
+
isCreateDialogOpen: boolean;
|
|
26
|
+
editingView: ViewMenuItem | null;
|
|
27
|
+
selectedViewInfo: ViewOption;
|
|
28
|
+
shouldUseCurrentState: boolean;
|
|
29
|
+
selectedView: ViewMenuItem | undefined;
|
|
30
|
+
currentViewColumns: ColumnViewProps[];
|
|
31
|
+
handleViewButtonClick: (event: MouseEvent<HTMLDivElement>) => void;
|
|
32
|
+
handleCloseViewDropdown: () => void;
|
|
33
|
+
handleSelectedViewInfo: (selected: ViewOption, viewMenuItem?: ViewMenuItem) => void;
|
|
34
|
+
handleOpenCreateDialog: (useCurrentState?: boolean) => void;
|
|
35
|
+
handleOpenEditDialog: (view: ViewMenuItem) => void;
|
|
36
|
+
handleCloseCreateDialog: () => void;
|
|
37
|
+
handleSaveView: (data: {
|
|
38
|
+
name: string;
|
|
39
|
+
selectedColumns: ColumnViewProps[];
|
|
40
|
+
layout: LayoutSection;
|
|
41
|
+
}) => Promise<void>;
|
|
42
|
+
handleDeleteView: (viewId: string) => Promise<void>;
|
|
43
|
+
updateSelectedView: (updatedView: ViewMenuItem) => void;
|
|
44
|
+
};
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { useState, useCallback, useEffect, useRef } from 'react';
|
|
11
|
+
import { deepCloneColumns } from '../utils';
|
|
12
|
+
export const useViewsMenu = ({ mode, onViewChange, onCreateCustomView, onEditCustomView, onDeleteCustomView, defaultColumns, defaultTemplate, allTemplates, }) => {
|
|
13
|
+
const [anchorEl, setAnchorEl] = useState(null);
|
|
14
|
+
const [isCreateDialogOpen, setIsCreateDialogOpen] = useState(false);
|
|
15
|
+
const [editingView, setEditingView] = useState(null);
|
|
16
|
+
const [selectedViewInfo, setSelectedViewInfo] = useState({ id: 'default', label: 'Default' });
|
|
17
|
+
const [shouldUseCurrentState, setShouldUseCurrentState] = useState(false);
|
|
18
|
+
const [selectedView, setSelectedView] = useState(undefined);
|
|
19
|
+
const [currentViewColumns, setCurrentViewColumns] = useState([]);
|
|
20
|
+
const hasInitializedRef = useRef(false);
|
|
21
|
+
const getViewForParent = useCallback((view) => {
|
|
22
|
+
var _a;
|
|
23
|
+
const selectedColumns = ((_a = view.submenu) === null || _a === void 0 ? void 0 : _a.filter((col) => col.selected)) || [];
|
|
24
|
+
return Object.assign(Object.assign({}, view), { submenu: selectedColumns, columns: selectedColumns.map((col) => col.name) });
|
|
25
|
+
}, []);
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
if (hasInitializedRef.current)
|
|
28
|
+
return;
|
|
29
|
+
if (!defaultTemplate)
|
|
30
|
+
return;
|
|
31
|
+
setSelectedView(defaultTemplate);
|
|
32
|
+
setCurrentViewColumns(deepCloneColumns(defaultColumns));
|
|
33
|
+
onViewChange === null || onViewChange === void 0 ? void 0 : onViewChange(getViewForParent(defaultTemplate));
|
|
34
|
+
hasInitializedRef.current = true;
|
|
35
|
+
}, [defaultTemplate, defaultColumns, onViewChange, getViewForParent]);
|
|
36
|
+
useEffect(() => {
|
|
37
|
+
if (!hasInitializedRef.current)
|
|
38
|
+
return;
|
|
39
|
+
if ((selectedView === null || selectedView === void 0 ? void 0 : selectedView.default) && defaultColumns.length > 0) {
|
|
40
|
+
setCurrentViewColumns(deepCloneColumns(defaultColumns));
|
|
41
|
+
}
|
|
42
|
+
}, [defaultColumns, selectedView === null || selectedView === void 0 ? void 0 : selectedView.default]);
|
|
43
|
+
const lastSyncedModeRef = useRef(null);
|
|
44
|
+
useEffect(() => {
|
|
45
|
+
if (!hasInitializedRef.current)
|
|
46
|
+
return;
|
|
47
|
+
if (!selectedView)
|
|
48
|
+
return;
|
|
49
|
+
const needsSync = lastSyncedModeRef.current !== mode;
|
|
50
|
+
if (!needsSync)
|
|
51
|
+
return;
|
|
52
|
+
if (selectedView.default) {
|
|
53
|
+
if (defaultColumns.length === 0)
|
|
54
|
+
return;
|
|
55
|
+
const newView = Object.assign(Object.assign({}, selectedView), { submenu: deepCloneColumns(defaultColumns), columns: defaultColumns.map((col) => col.name) });
|
|
56
|
+
setSelectedView(newView);
|
|
57
|
+
setCurrentViewColumns(deepCloneColumns(defaultColumns));
|
|
58
|
+
lastSyncedModeRef.current = mode;
|
|
59
|
+
onViewChange === null || onViewChange === void 0 ? void 0 : onViewChange(getViewForParent(newView));
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
const updatedTemplate = allTemplates.find((t) => t.templateId === selectedView.templateId || t.id === selectedView.id);
|
|
63
|
+
if (updatedTemplate && updatedTemplate.submenu && updatedTemplate.submenu.length > 0) {
|
|
64
|
+
const newView = Object.assign(Object.assign({}, updatedTemplate), { submenu: deepCloneColumns(updatedTemplate.submenu) });
|
|
65
|
+
setSelectedView(newView);
|
|
66
|
+
setCurrentViewColumns(deepCloneColumns(updatedTemplate.submenu));
|
|
67
|
+
lastSyncedModeRef.current = mode;
|
|
68
|
+
onViewChange === null || onViewChange === void 0 ? void 0 : onViewChange(getViewForParent(newView));
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}, [mode, defaultColumns, selectedView, allTemplates, onViewChange]);
|
|
72
|
+
useEffect(() => {
|
|
73
|
+
if (!hasInitializedRef.current)
|
|
74
|
+
return;
|
|
75
|
+
if (!selectedView)
|
|
76
|
+
return;
|
|
77
|
+
const updatedTemplate = allTemplates.find((t) => {
|
|
78
|
+
const templateId = t.templateId || t.id;
|
|
79
|
+
const selectedId = selectedView.templateId || selectedView.id;
|
|
80
|
+
return templateId === selectedId;
|
|
81
|
+
});
|
|
82
|
+
if (!updatedTemplate)
|
|
83
|
+
return;
|
|
84
|
+
const currentSubmenu = selectedView.submenu || [];
|
|
85
|
+
const updatedSubmenu = updatedTemplate.submenu || [];
|
|
86
|
+
const hasChanged = currentSubmenu.length !== updatedSubmenu.length ||
|
|
87
|
+
currentSubmenu.some((col, idx) => {
|
|
88
|
+
const updatedCol = updatedSubmenu[idx];
|
|
89
|
+
if (!updatedCol)
|
|
90
|
+
return true;
|
|
91
|
+
return col.selected !== updatedCol.selected || col.name !== updatedCol.name;
|
|
92
|
+
});
|
|
93
|
+
if (hasChanged) {
|
|
94
|
+
const fullView = Object.assign(Object.assign({}, updatedTemplate), { submenu: deepCloneColumns(updatedTemplate.submenu || []) });
|
|
95
|
+
setSelectedView(fullView);
|
|
96
|
+
setCurrentViewColumns(deepCloneColumns(updatedTemplate.submenu || []));
|
|
97
|
+
const viewForParent = getViewForParent(fullView);
|
|
98
|
+
onViewChange === null || onViewChange === void 0 ? void 0 : onViewChange(viewForParent);
|
|
99
|
+
}
|
|
100
|
+
}, [allTemplates, selectedView, onViewChange]);
|
|
101
|
+
const handleViewButtonClick = useCallback((event) => {
|
|
102
|
+
setAnchorEl((current) => (current ? null : event.currentTarget));
|
|
103
|
+
}, []);
|
|
104
|
+
const handleCloseViewDropdown = useCallback(() => {
|
|
105
|
+
setAnchorEl(null);
|
|
106
|
+
}, []);
|
|
107
|
+
const handleSelectedViewInfo = useCallback((selected, viewMenuItem) => {
|
|
108
|
+
setSelectedViewInfo(selected);
|
|
109
|
+
const newSelectedView = viewMenuItem || undefined;
|
|
110
|
+
setSelectedView(newSelectedView);
|
|
111
|
+
setCurrentViewColumns(deepCloneColumns((newSelectedView === null || newSelectedView === void 0 ? void 0 : newSelectedView.submenu) || []));
|
|
112
|
+
onViewChange === null || onViewChange === void 0 ? void 0 : onViewChange(newSelectedView ? getViewForParent(newSelectedView) : undefined);
|
|
113
|
+
handleCloseViewDropdown();
|
|
114
|
+
}, [handleCloseViewDropdown, onViewChange, getViewForParent]);
|
|
115
|
+
const updateSelectedView = useCallback((updatedView) => {
|
|
116
|
+
const viewWithNewRefs = Object.assign(Object.assign({}, updatedView), { submenu: updatedView.submenu ? [...updatedView.submenu] : undefined, columns: updatedView.columns ? [...updatedView.columns] : undefined });
|
|
117
|
+
setSelectedView(viewWithNewRefs);
|
|
118
|
+
setCurrentViewColumns(deepCloneColumns(viewWithNewRefs.submenu || []));
|
|
119
|
+
setSelectedViewInfo({ id: viewWithNewRefs.id, label: viewWithNewRefs.label });
|
|
120
|
+
onViewChange === null || onViewChange === void 0 ? void 0 : onViewChange(getViewForParent(viewWithNewRefs));
|
|
121
|
+
}, [onViewChange, getViewForParent]);
|
|
122
|
+
const handleOpenCreateDialog = useCallback((useCurrentState = false) => {
|
|
123
|
+
setEditingView(null);
|
|
124
|
+
setShouldUseCurrentState(useCurrentState);
|
|
125
|
+
setIsCreateDialogOpen(true);
|
|
126
|
+
setAnchorEl(null);
|
|
127
|
+
}, []);
|
|
128
|
+
const handleOpenEditDialog = useCallback((view) => {
|
|
129
|
+
setEditingView(view);
|
|
130
|
+
setShouldUseCurrentState(true);
|
|
131
|
+
setIsCreateDialogOpen(true);
|
|
132
|
+
}, []);
|
|
133
|
+
const handleCloseCreateDialog = useCallback(() => {
|
|
134
|
+
setIsCreateDialogOpen(false);
|
|
135
|
+
setEditingView(null);
|
|
136
|
+
setShouldUseCurrentState(false);
|
|
137
|
+
}, []);
|
|
138
|
+
const handleSaveView = useCallback((data) => __awaiter(void 0, void 0, void 0, function* () {
|
|
139
|
+
if (editingView) {
|
|
140
|
+
const templateId = editingView.templateId || editingView.id;
|
|
141
|
+
yield (onEditCustomView === null || onEditCustomView === void 0 ? void 0 : onEditCustomView(templateId, data));
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
yield (onCreateCustomView === null || onCreateCustomView === void 0 ? void 0 : onCreateCustomView(data));
|
|
145
|
+
}
|
|
146
|
+
}), [editingView, onEditCustomView, onCreateCustomView]);
|
|
147
|
+
const handleDeleteView = useCallback((viewId) => __awaiter(void 0, void 0, void 0, function* () {
|
|
148
|
+
const viewToDelete = allTemplates.find((view) => view.id === viewId || view.templateId === viewId);
|
|
149
|
+
const templateId = (viewToDelete === null || viewToDelete === void 0 ? void 0 : viewToDelete.templateId) || viewId;
|
|
150
|
+
yield (onDeleteCustomView === null || onDeleteCustomView === void 0 ? void 0 : onDeleteCustomView(templateId));
|
|
151
|
+
if ((selectedView === null || selectedView === void 0 ? void 0 : selectedView.id) === viewId || (selectedView === null || selectedView === void 0 ? void 0 : selectedView.templateId) === viewId) {
|
|
152
|
+
setSelectedView(defaultTemplate);
|
|
153
|
+
setCurrentViewColumns(deepCloneColumns(defaultColumns));
|
|
154
|
+
if (defaultTemplate) {
|
|
155
|
+
onViewChange === null || onViewChange === void 0 ? void 0 : onViewChange(getViewForParent(defaultTemplate));
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}), [allTemplates, onDeleteCustomView, selectedView, defaultTemplate, defaultColumns, onViewChange, getViewForParent]);
|
|
159
|
+
return {
|
|
160
|
+
anchorEl,
|
|
161
|
+
isCreateDialogOpen,
|
|
162
|
+
editingView,
|
|
163
|
+
selectedViewInfo,
|
|
164
|
+
shouldUseCurrentState,
|
|
165
|
+
selectedView,
|
|
166
|
+
currentViewColumns,
|
|
167
|
+
handleViewButtonClick,
|
|
168
|
+
handleCloseViewDropdown,
|
|
169
|
+
handleSelectedViewInfo,
|
|
170
|
+
handleOpenCreateDialog,
|
|
171
|
+
handleOpenEditDialog,
|
|
172
|
+
handleCloseCreateDialog,
|
|
173
|
+
handleSaveView,
|
|
174
|
+
handleDeleteView,
|
|
175
|
+
updateSelectedView,
|
|
176
|
+
};
|
|
177
|
+
};
|
|
@@ -1,3 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
export
|
|
3
|
-
export default
|
|
1
|
+
export { default } from './TableView';
|
|
2
|
+
export { default as TableView } from './TableView';
|
|
3
|
+
export { default as DefaultViews } from './DefaultViews';
|
|
4
|
+
export { default as CustomViews } from './CustomViews';
|
|
5
|
+
export { default as ViewsMenu } from './ViewsMenu';
|
|
6
|
+
export { default as ViewsDropdown } from './ViewsDropdown';
|
|
7
|
+
export { default as CreateViewDialog } from './CreateViewDialog';
|
|
8
|
+
export type { ViewMenuItem, CreateCustomViewDialogProps, LayoutSection, ColumnItem, FieldItem, Template, CreateTemplatePayload, UpdateTemplatePayload, } from './types';
|
|
9
|
+
export { transformLayoutToColumns, getColumnsByMode, createCustomViewMenuItem, setViewAsDefault, transformTemplatesToViewMenuItems, convertColumnsToLayoutSection, isDateColumn, getColumnCheckState, } from './utils';
|
|
10
|
+
export { useSubmenuHover, useViewsManager, useViewsMenu } from './hooks';
|
|
11
|
+
export { DIALOG_WIDTH, DIALOG_HEIGHT, MAX_CUSTOM_VIEWS, TEMPLATE_NAME_MAX_LENGTH } from './constants';
|
|
12
|
+
export { defaultViewList, advancedColumns, sheetColumns } from './data';
|
|
@@ -1,3 +1,11 @@
|
|
|
1
|
-
|
|
2
|
-
export
|
|
3
|
-
export default
|
|
1
|
+
export { default } from './TableView';
|
|
2
|
+
export { default as TableView } from './TableView';
|
|
3
|
+
export { default as DefaultViews } from './DefaultViews';
|
|
4
|
+
export { default as CustomViews } from './CustomViews';
|
|
5
|
+
export { default as ViewsMenu } from './ViewsMenu';
|
|
6
|
+
export { default as ViewsDropdown } from './ViewsDropdown';
|
|
7
|
+
export { default as CreateViewDialog } from './CreateViewDialog';
|
|
8
|
+
export { transformLayoutToColumns, getColumnsByMode, createCustomViewMenuItem, setViewAsDefault, transformTemplatesToViewMenuItems, convertColumnsToLayoutSection, isDateColumn, getColumnCheckState, } from './utils';
|
|
9
|
+
export { useSubmenuHover, useViewsManager, useViewsMenu } from './hooks';
|
|
10
|
+
export { DIALOG_WIDTH, DIALOG_HEIGHT, MAX_CUSTOM_VIEWS, TEMPLATE_NAME_MAX_LENGTH } from './constants';
|
|
11
|
+
export { defaultViewList, advancedColumns, sheetColumns } from './data';
|