From 433319090f418717863afeafc413bb6da9355c43 Mon Sep 17 00:00:00 2001 From: CHEYNE Date: Thu, 22 Feb 2024 20:40:16 +0800 Subject: [PATCH] [#1735] fix(web): fix sorting and filtering of the metalakes table (#2309) ### What changes were proposed in this pull request? Fix sorting and filtering of the metalakes table. image ### Why are the changes needed? Fix: #1735 Fix: #2072 ### Does this PR introduce _any_ user-facing change? N/A ### How was this patch tested? N/A --- web/app/ui/MetalakeList.js | 96 ++++++++++++++++++++++---------------- 1 file changed, 55 insertions(+), 41 deletions(-) diff --git a/web/app/ui/MetalakeList.js b/web/app/ui/MetalakeList.js index 01535ce08f0..3db054b1ce3 100644 --- a/web/app/ui/MetalakeList.js +++ b/web/app/ui/MetalakeList.js @@ -7,8 +7,8 @@ import { useEffect, useCallback, useState, Fragment } from 'react' import Link from 'next/link' -import { Box, Grid, Card, IconButton, Typography, Portal, Tooltip } from '@mui/material' -import { DataGrid, GridToolbar } from '@mui/x-data-grid' +import { Box, Grid, Card, Typography, Portal, Tooltip } from '@mui/material' +import { DataGrid, GridActionsCellItem, GridToolbar } from '@mui/x-data-grid' import Icon from '@/components/Icon' @@ -26,7 +26,7 @@ function TableToolbar(props) { <> document.getElementById('filter-panel')}> - + @@ -49,7 +49,7 @@ const MetalakeList = () => { const [openConfirmDelete, setOpenConfirmDelete] = useState(false) const [confirmCacheData, setConfirmCacheData] = useState(null) - const handleDeleteMetalake = name => { + const handleDeleteMetalake = name => () => { setOpenConfirmDelete(true) setConfirmCacheData(name) } @@ -66,7 +66,7 @@ const MetalakeList = () => { setConfirmCacheData(null) } - const handleShowEditDialog = data => { + const handleShowEditDialog = data => () => { setDialogType('update') setOpenDialog(true) setDialogData(data) @@ -76,7 +76,7 @@ const MetalakeList = () => { setValue(val) }, []) - const handleShowDetails = row => { + const handleShowDetails = row => () => { setDrawerData(row) setOpenDrawer(true) } @@ -108,6 +108,7 @@ const MetalakeList = () => { minWidth: 230, disableColumnMenu: true, filterable: true, + type: 'string', field: 'name', headerName: 'Name', renderCell: ({ row }) => { @@ -142,7 +143,9 @@ const MetalakeList = () => { flex: 0.15, minWidth: 150, disableColumnMenu: true, + type: 'string', field: 'createdBy', + valueGetter: params => `${params.row.audit?.creator}`, headerName: 'Created by', renderCell: ({ row }) => { return ( @@ -156,12 +159,13 @@ const MetalakeList = () => { flex: 0.15, minWidth: 150, disableColumnMenu: true, - valueGetter: params => `${params.row.audit?.createTime}`, + type: 'dateTime', field: 'createdAt', + valueGetter: params => new Date(params.row.audit?.createTime), headerName: 'Created at', renderCell: ({ row }) => { return ( - + {formatToDateTime(row.audit?.createTime)} ) @@ -170,40 +174,48 @@ const MetalakeList = () => { { flex: 0.1, minWidth: 90, - sortable: false, - disableColumnMenu: true, - field: 'actions', + type: 'actions', headerName: 'Actions', - renderCell: ({ row }) => ( - <> - theme.palette.text.secondary }} - onClick={() => handleShowDetails(row)} - > - - - - theme.palette.text.secondary }} - onClick={() => handleShowEditDialog(row)} - > - - - - theme.palette.error.light }} - onClick={() => handleDeleteMetalake(row.name)} - > - - - - ) + field: 'actions', + getActions: ({ row }) => [ + } + onClick={handleShowDetails(row)} + sx={{ + '& svg': { + fontSize: '24px' + } + }} + />, + } + onClick={handleShowEditDialog(row)} + sx={{ + '& svg': { + fontSize: '24px' + } + }} + />, + } + label='Delete' + title='Delete' + onClick={handleDeleteMetalake(row.name)} + sx={{ + '& svg': { + fontSize: '24px', + color: theme => theme.palette.error.light + } + }} + /> + ] } ] @@ -238,6 +250,8 @@ const MetalakeList = () => { rows={store.filteredMetalakes} columns={columns} disableRowSelectionOnClick + onCellClick={(params, event) => event.stopPropagation()} + onRowClick={(params, event) => event.stopPropagation()} pageSizeOptions={[10, 25, 50]} paginationModel={paginationModel} onPaginationModelChange={setPaginationModel}