@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.
Files changed (100) 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/SearchButton/styles.d.ts +0 -1
  11. package/build/components/StatusIcons/AuthIcons/style.d.ts +0 -1
  12. package/build/components/StatusIcons/AuthorizationAutoIcons/style.d.ts +0 -1
  13. package/build/components/StatusIcons/ChargeStatusIcon/style.d.ts +0 -1
  14. package/build/components/StatusIcons/SourceIcons/style.d.ts +0 -1
  15. package/build/components/TableCells/CustomCells/ActionCell/style.d.ts +0 -1
  16. package/build/components/TableCells/CustomCells/AgreementCell/style.d.ts +0 -1
  17. package/build/components/TableCells/CustomCells/ApplicationStatusCell/style.d.ts +0 -1
  18. package/build/components/TableCells/CustomCells/AuthenticationCell/style.d.ts +0 -1
  19. package/build/components/TableCells/CustomCells/AuthenticationStatusCell/style.d.ts +0 -1
  20. package/build/components/TableCells/CustomCells/AuthenticationTypeCell/style.d.ts +0 -1
  21. package/build/components/TableCells/CustomCells/BalanceCell/style.d.ts +0 -1
  22. package/build/components/TableCells/CustomCells/ChannelsCell/style.d.ts +0 -1
  23. package/build/components/TableCells/CustomCells/CheckoutStatusCell/style.d.ts +0 -1
  24. package/build/components/TableCells/CustomCells/DestinationStatusCell/style.d.ts +0 -1
  25. package/build/components/TableCells/CustomCells/DueDateCell/style.d.ts +0 -1
  26. package/build/components/TableCells/CustomCells/IDButton/style.d.ts +0 -1
  27. package/build/components/TableCells/CustomCells/IntentsStatusCell/style.d.ts +0 -1
  28. package/build/components/TableCells/CustomCells/InvoiceStatusCell/style.d.ts +0 -1
  29. package/build/components/TableCells/CustomCells/PayoutReportCell/style.d.ts +0 -1
  30. package/build/components/TableCells/CustomCells/PayoutStatusCell/style.d.ts +0 -1
  31. package/build/components/TableCells/CustomCells/ProductsCell/style.d.ts +0 -1
  32. package/build/components/TableCells/CustomCells/ReferenceCell/style.d.ts +0 -1
  33. package/build/components/TableCells/CustomCells/RefundChargeCell/style.d.ts +0 -1
  34. package/build/components/TableCells/CustomCells/RefundStatusCell/style.d.ts +0 -1
  35. package/build/components/TableCells/CustomCells/SalesChannelCell/style.d.ts +0 -1
  36. package/build/components/TableCells/CustomCells/SegmentsCell/style.d.ts +0 -1
  37. package/build/components/TableCells/CustomCells/StatusCell/style.d.ts +0 -1
  38. package/build/components/TableCells/CustomCells/TokenStatusCell/style.d.ts +0 -1
  39. package/build/components/TableCells/CustomCells/style.d.ts +0 -1
  40. package/build/components/TableHeader/FiltersRow.d.ts +1 -1
  41. package/build/components/TableHeader/FiltersRow.js +4 -2
  42. package/build/components/TableHeader/TableHeader.d.ts +1 -1
  43. package/build/components/TableHeader/TableHeader.js +2 -2
  44. package/build/components/TableHeader/TableView/CreateViewDialog.d.ts +3 -0
  45. package/build/components/TableHeader/TableView/CreateViewDialog.js +91 -0
  46. package/build/components/TableHeader/TableView/CustomViews.js +1 -1
  47. package/build/components/TableHeader/TableView/TableView.js +0 -1
  48. package/build/components/TableHeader/TableView/ViewsDropdown.d.ts +5 -0
  49. package/build/components/TableHeader/TableView/ViewsDropdown.js +189 -0
  50. package/build/components/TableHeader/TableView/ViewsMenu.d.ts +5 -0
  51. package/build/components/TableHeader/TableView/ViewsMenu.js +76 -0
  52. package/build/components/TableHeader/TableView/components/ColumnList.d.ts +3 -0
  53. package/build/components/TableHeader/TableView/components/ColumnList.js +70 -0
  54. package/build/components/TableHeader/TableView/components/ViewsSubmenu.d.ts +3 -0
  55. package/build/components/TableHeader/TableView/components/ViewsSubmenu.js +75 -0
  56. package/build/components/TableHeader/TableView/components/index.d.ts +2 -0
  57. package/build/components/TableHeader/TableView/components/index.js +2 -0
  58. package/build/components/TableHeader/TableView/constants.d.ts +10 -0
  59. package/build/components/TableHeader/TableView/constants.js +10 -0
  60. package/build/components/TableHeader/TableView/data.d.ts +5 -0
  61. package/build/components/TableHeader/TableView/data.js +48 -0
  62. package/build/components/TableHeader/TableView/hooks/index.d.ts +6 -0
  63. package/build/components/TableHeader/TableView/hooks/index.js +6 -0
  64. package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.d.ts +22 -0
  65. package/build/components/TableHeader/TableView/hooks/useCreateViewDialog.js +86 -0
  66. package/build/components/TableHeader/TableView/hooks/useDialogPosition.d.ts +8 -0
  67. package/build/components/TableHeader/TableView/hooks/useDialogPosition.js +16 -0
  68. package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.d.ts +7 -0
  69. package/build/components/TableHeader/TableView/hooks/useNestedSubmenu.js +27 -0
  70. package/build/components/TableHeader/TableView/hooks/useOriginalColumns.d.ts +6 -0
  71. package/build/components/TableHeader/TableView/hooks/useOriginalColumns.js +18 -0
  72. package/build/components/TableHeader/TableView/hooks/useSubmenuHover.d.ts +8 -0
  73. package/build/components/TableHeader/TableView/hooks/useSubmenuHover.js +43 -0
  74. package/build/components/TableHeader/TableView/hooks/useViewsManager.d.ts +9 -0
  75. package/build/components/TableHeader/TableView/hooks/useViewsManager.js +62 -0
  76. package/build/components/TableHeader/TableView/hooks/useViewsMenu.d.ts +44 -0
  77. package/build/components/TableHeader/TableView/hooks/useViewsMenu.js +177 -0
  78. package/build/components/TableHeader/TableView/index.d.ts +12 -3
  79. package/build/components/TableHeader/TableView/index.js +11 -3
  80. package/build/components/TableHeader/TableView/styles.d.ts +127 -0
  81. package/build/components/TableHeader/TableView/styles.js +426 -0
  82. package/build/components/TableHeader/TableView/types.d.ts +182 -0
  83. package/build/components/TableHeader/TableView/types.js +1 -0
  84. package/build/components/TableHeader/TableView/utils.d.ts +121 -0
  85. package/build/components/TableHeader/TableView/utils.js +469 -0
  86. package/build/components/TableHeader/index.d.ts +1 -0
  87. package/build/components/TableHeader/type.d.ts +15 -1
  88. package/build/components/TableReports/components/DownloadButton/style.d.ts +0 -1
  89. package/build/components/TableReports/style.d.ts +0 -1
  90. package/build/components/VirtualTables/VirtualTable/VirtualTable.d.ts +1 -1
  91. package/build/components/VirtualTables/VirtualTable/VirtualTable.js +4 -3
  92. package/build/components/VirtualTables/components/style.d.ts +0 -1
  93. package/build/constants/assets.d.ts +1 -0
  94. package/build/constants/assets.js +1 -0
  95. package/build/types/table.d.ts +1 -0
  96. package/build/utils/index.d.ts +1 -0
  97. package/build/utils/index.js +1 -0
  98. package/build/utils/skeletonColumns.d.ts +4 -0
  99. package/build/utils/skeletonColumns.js +17 -0
  100. 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,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
+ };
@@ -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,6 @@
1
+ import type { ColumnViewProps } from '../../../../types/index.js';
2
+ export declare const useOriginalColumns: (defaultColumns: ColumnViewProps[]) => {
3
+ originalColumns: ColumnViewProps[];
4
+ saveOriginalState: () => void;
5
+ clearOriginalState: () => void;
6
+ };
@@ -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,8 @@
1
+ export declare const useSubmenuHover: () => {
2
+ hoveredColumn: string | null;
3
+ anchorEl: HTMLElement | null;
4
+ openSubmenu: (columnName: string, element: HTMLElement) => void;
5
+ closeSubmenu: () => void;
6
+ cancelClose: () => void;
7
+ forceClose: () => void;
8
+ };
@@ -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
- import TableView from './TableView';
2
- export * from './TableView';
3
- export default TableView;
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
- import TableView from './TableView';
2
- export * from './TableView';
3
- export default TableView;
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';