Skip to content

Commit

Permalink
Merge pull request #295 from Enterwell/stage
Browse files Browse the repository at this point in the history
Stage
  • Loading branch information
AleksandarDev authored Jan 10, 2024
2 parents 52b40fb + 4233dd7 commit d620bde
Show file tree
Hide file tree
Showing 9 changed files with 103 additions and 42 deletions.
1 change: 1 addition & 0 deletions apps/docs/components/ExampleUseDataGrid.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ export function ExampleUseDataGrid() {
};

const dataGrid = useDataGrid({
tableId: 'example-use-data-grid',
columns,
onPage: handleOnPage
});
Expand Down
2 changes: 1 addition & 1 deletion apps/docs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@
"tailwindcss-animate": "1.0.7"
},
"devDependencies": {
"@types/node": "18.19.5",
"@types/node": "18.19.6",
"@types/react": "18.2.47",
"@types/react-dom": "18.2.18",
"autoprefixer": "10.4.16",
Expand Down
2 changes: 1 addition & 1 deletion packages/react-hooks/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
},
"devDependencies": {
"@microsoft/api-extractor": "7.39.1",
"@types/node": "18.19.5",
"@types/node": "18.19.6",
"@types/react": "18.2.47",
"@types/react-dom": "18.2.18",
"eslint-config-custom": "workspace:*",
Expand Down
Empty file.
Empty file.
80 changes: 70 additions & 10 deletions packages/react-mui-hooks/hooks/useDataGrid.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@ import {
type UncapitalizedGridProSlotsComponent,
type GridFilterModel,
type GridColumnResizeParams,
type GridPinnedColumns,
type GridColumnOrderChangeParams,
} from '@mui/x-data-grid-pro';
import { useResizeObserver } from '@enterwell/react-hooks';
import { format } from 'date-fns';
Expand All @@ -48,6 +50,8 @@ const DISPLAY_DATETIME_FORMAT = "dd.MM.yyyy. HH:mm:ss";
const DISPLAY_DATE_FORMAT = "dd.MM.yyyy.";
const columnVisibilityLocalStorageKey = 'muidatagrid-columnvisibility';
const columnSizeLocalStorageKey = 'muidatagrid-columnwidth';
const columnPinningLocalStorageKey = 'muidatagrid-columnpinning';
const columnOrderingLocalStorageKey = 'muidatagrid-columnordering';

const dataGridSx = (theme: Theme) => ({
'& .MuiDataGrid-columnHeader::after': {
Expand Down Expand Up @@ -454,11 +458,12 @@ export function useDataGrid({
};

// Column visibility
const [columnVisibility, setColumnVisibility] = useState(
Boolean(tableId) && localStorage.getItem(`${columnVisibilityLocalStorageKey}-${tableId}`) !== null
? JSON.parse(localStorage.getItem(`${columnVisibilityLocalStorageKey}-${tableId}`) ?? "")
const [columnVisibility, setColumnVisibility] = useState(() => {
const savedColumnVisibility = localStorage.getItem(`${columnVisibilityLocalStorageKey}-${tableId}`);
return Boolean(tableId) && savedColumnVisibility !== null
? JSON.parse(savedColumnVisibility)
: columnVisibilityModel
);
});

/**
* Handles the column visibility model changing.
Expand Down Expand Up @@ -557,15 +562,15 @@ export function useDataGrid({
setIsMobile(window.innerWidth < theme.breakpoints.values.sm);
});

const columnsMemo = useMemo(() => columns.map((c) => {
const columnsMemo = useMemo(() => {
const columnsAdjusted = columns.map((c) => {
// Get column width from local storage
let width: number | null | undefined;

if (tableId) {
const storageValue = localStorage.getItem(`${columnSizeLocalStorageKey}-${tableId}-${c.field}`);

if (storageValue) {
width = Number(storageValue);
const columnSizeStorageValue = localStorage.getItem(`${columnSizeLocalStorageKey}-${tableId}-${c.field}`);
if (columnSizeStorageValue) {
width = Number(columnSizeStorageValue);
}
}

Expand All @@ -587,8 +592,27 @@ export function useDataGrid({
flex: undefined,
width
}
};
});

// Reorder columns based on saves order (if provided)
if (tableId) {
columnsAdjusted.forEach((c) => {
const columnOrderingStorageValue = localStorage.getItem(`${columnOrderingLocalStorageKey}-${tableId}-${c.field}`);
if (!columnOrderingStorageValue) return;

const order = JSON.parse(columnOrderingStorageValue);
if (order != null) {
// Move column to new index
const index = columnsAdjusted.findIndex((x) => x.field === c.field);
columnsAdjusted.splice(index, 1);
columnsAdjusted.splice(order, 0, c);
}
});
}
}), [tableId, columns, headerRenderer, rowHeight]);

return columnsAdjusted;
}, [tableId, columns, headerRenderer, rowHeight]);

/**
* Handles rows scroll end action.
Expand All @@ -611,6 +635,39 @@ export function useDataGrid({
}
};

// Column pinning
const [pinnedColumns, setPinnedColumns] = useState(() => {
const savedPinnedColumns = localStorage.getItem(`${columnPinningLocalStorageKey}-${tableId}`);
return Boolean(tableId) && savedPinnedColumns != null
? JSON.parse(savedPinnedColumns)
: null
});

/**
* Handles pinned columns change action.
*
* @param newPinnedColumns The new pinned columns.
*/
const handlePinnedColumnsChange = (newPinnedColumns: GridPinnedColumns) => {
if (tableId) {
localStorage.setItem(`${columnPinningLocalStorageKey}-${tableId}`, JSON.stringify(newPinnedColumns));
}
setPinnedColumns(newPinnedColumns);
};

/**
* Handles column order change.
*
* @param newColumnOrder The new column order.
*/
const handleColumnOrderChange = (newColumnOrder: GridColumnOrderChangeParams) => {
if (tableId) {
localStorage.setItem(
`${columnOrderingLocalStorageKey}-${tableId}-${newColumnOrder.column.field}`,
JSON.stringify(newColumnOrder.targetIndex));
}
};

return {
props: {
ref: resizeRef,
Expand All @@ -628,6 +685,9 @@ export function useDataGrid({
columnVisibilityModel: columnVisibility,
onColumnVisibilityModelChange: handleColumnVisibilityChange,
onColumnWidthChange: handleOnColumnWidthChange,
onColumnOrderChange: handleColumnOrderChange,
pinnedColumns,
onPinnedColumnsChange: handlePinnedColumnsChange,
pagination: !infiniteLoading && enablePagination,
paginationMode: 'server',
paginationModel: {
Expand Down
2 changes: 1 addition & 1 deletion packages/react-mui-hooks/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
"@microsoft/api-extractor": "7.39.1",
"@mui/material": "5.15.3",
"@mui/x-data-grid-pro": "6.18.7",
"@types/node": "18.19.5",
"@types/node": "18.19.6",
"@types/react": "18.2.47",
"@types/react-dom": "18.2.18",
"date-fns": "2.30.0",
Expand Down
2 changes: 1 addition & 1 deletion packages/react-ui/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
"@mui/system": "5.15.3",
"@mui/x-date-pickers-pro": "5.0.20",
"@mui/x-date-pickers": "5.0.20",
"@types/node": "18.19.5",
"@types/node": "18.19.6",
"@types/react": "18.2.47",
"@types/react-dom": "18.2.18",
"date-fns": "2.30.0",
Expand Down
56 changes: 28 additions & 28 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit d620bde

Please sign in to comment.