From c438854e1da8d7025ee85e23dd37c2523c488725 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期二, 08 十月 2024 13:17:34 +0800 Subject: [PATCH] # --- zy-acs-flow/src/page/operationRecord/OperationRecordList.jsx | 110 ++++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 77 insertions(+), 33 deletions(-) diff --git a/zy-acs-flow/src/page/operationRecord/OperationRecordList.jsx b/zy-acs-flow/src/page/operationRecord/OperationRecordList.jsx index 8192c27..940424a 100644 --- a/zy-acs-flow/src/page/operationRecord/OperationRecordList.jsx +++ b/zy-acs-flow/src/page/operationRecord/OperationRecordList.jsx @@ -31,15 +31,18 @@ AutocompleteInput, DeleteButton, } from 'react-admin'; -import { Box, Typography, Card, Stack } from '@mui/material'; +import { Box, Typography, Card, Chip } from '@mui/material'; import { styled } from '@mui/material/styles'; import OperationRecordPanel from "./OperationRecordPanel"; import EmptyData from "../components/EmptyData"; import MyExportButton from '../components/MyExportButton'; import PageDrawer from "../components/PageDrawer"; import MyField from "../components/MyField"; -import { PAGE_DRAWER_WIDTH, OPERATE_MODE } from '@/config/setting'; +import { PAGE_DRAWER_WIDTH, OPERATE_MODE, DEFAULT_PAGE_SIZE } from '@/config/setting'; import * as Common from '@/utils/common'; +import rowSx from './rowSx'; +import { format } from 'date-fns'; +import OperationDetail from './OperationDetail' const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({ '& .css-1vooibu-MuiSvgIcon-root': { @@ -48,10 +51,34 @@ '& .RaDatagrid-row': { cursor: 'auto' }, - '& .column-name': { + '& .column-url': { + maxWidth: '16em', + overflow: 'hidden', + textOverflow: 'ellipsis', + whiteSpace: 'nowrap', + }, + '& .column-request': { + maxWidth: '18em', + overflow: 'hidden', + textOverflow: 'ellipsis', + whiteSpace: 'nowrap', + }, + '& .column-response': { + maxWidth: '18em', + overflow: 'hidden', + textOverflow: 'ellipsis', + whiteSpace: 'nowrap', + }, + '& .column-spendTime': { + maxWidth: '9em', }, '& .opt': { width: 200 + }, + '& .RaDatagrid-thead': { + borderLeftColor: 'transparent', + borderLeftWidth: 5, + borderLeftStyle: 'solid', }, })); @@ -63,12 +90,10 @@ <TextInput source="namespace" label="table.field.operationRecord.namespace" />, <TextInput source="url" label="table.field.operationRecord.url" />, <TextInput source="appkey" label="table.field.operationRecord.appkey" />, - <TextInput source="timestamp" label="table.field.operationRecord.timestamp" />, <TextInput source="clientIp" label="table.field.operationRecord.clientIp" />, <TextInput source="request" label="table.field.operationRecord.request" />, <TextInput source="response" label="table.field.operationRecord.response" />, <NumberInput source="spendTime" label="table.field.operationRecord.spendTime" />, - <TextInput source="err" label="table.field.operationRecord.err" />, <SelectInput source="result" label="table.field.operationRecord.result" choices={[ { id: 1, name: '鎴愬姛' }, @@ -76,18 +101,10 @@ ]} />, <ReferenceInput source="userId" reference="user"> - <AutocompleteInput label="table.field.operationRecord.userId" optionText="nickname" /> + <AutocompleteInput label="table.field.operationRecord.userId" optionText="nickname" filterToQuery={(val) => ({ nickname: val })} /> </ReferenceInput>, <TextInput label="common.field.memo" source="memo" />, - <SelectInput - label="common.field.status" - source="status" - choices={[ - { id: '1', name: 'common.enums.statusTrue' }, - { id: '0', name: 'common.enums.statusFalse' }, - ]} - />, ] const OperationRecordList = () => { @@ -107,7 +124,7 @@ }), marginRight: !!drawerVal ? `${PAGE_DRAWER_WIDTH}px` : 0, }} - title={"menu.operationRecord"} + title={"menu.operation"} empty={<EmptyData onClick={() => { setCreateDialog(true) }} />} filters={filters} sort={{ field: "create_time", order: "desc" }} @@ -118,38 +135,36 @@ <MyExportButton /> </TopToolbar> )} - perPage={25} + perPage={DEFAULT_PAGE_SIZE} > <StyledDatagrid preferenceKey='operationRecord' - bulkActionButtons={() => <BulkDeleteButton mutationMode={OPERATE_MODE} />} - rowClick={(id, resource, record) => false} - expand={() => <OperationRecordPanel />} - expandSingle={true} - omit={['id', 'createTime', 'memo']} + bulkActionButtons={false} + rowClick={(id, resource, record) => { + setDrawerVal(!!drawerVal && drawerVal === record ? null : record); + return false; + }} + omit={['appkey', 'statusBool', 'err', 'updateTime', 'createTime', 'memo']} + rowSx={rowSx(drawerVal || null)} > <NumberField source="id" /> <TextField source="namespace" label="table.field.operationRecord.namespace" /> <TextField source="url" label="table.field.operationRecord.url" /> - <TextField source="appkey" label="table.field.operationRecord.appkey" /> - <TextField source="timestamp" label="table.field.operationRecord.timestamp" /> - <TextField source="clientIp" label="table.field.operationRecord.clientIp" /> - <TextField source="request" label="table.field.operationRecord.request" /> - <TextField source="response" label="table.field.operationRecord.response" /> - <NumberField source="spendTime" label="table.field.operationRecord.spendTime" /> - <TextField source="err" label="table.field.operationRecord.err" /> - <TextField source="result$" label="table.field.operationRecord.result" sortable={false} /> <ReferenceField source="userId" label="table.field.operationRecord.userId" reference="user" link={false}> <TextField source="nickname" /> </ReferenceField> - + <TextField source="appkey" label="table.field.operationRecord.appkey" /> + <FormattedTimestampField source="timestamp" label="table.field.operationRecord.timestamp" /> + <NumberField source="spendTime" label="table.field.operationRecord.spendTime" sx={{ fontWeight: 'bold' }} /> + <TextField source="request" label="table.field.operationRecord.request" sortable={false} hidden={!!drawerVal} /> + <TextField source="response" label="table.field.operationRecord.response" sortable={false} hidden={!!drawerVal} /> + <ResultField source="result" label="table.field.operationRecord.result" /> + <TextField source="err" label="table.field.operationRecord.err" /> + <TextField source="clientIp" label="table.field.operationRecord.clientIp" /> <DateField source="updateTime" label="common.field.updateTime" showTime /> <DateField source="createTime" label="common.field.createTime" showTime /> <BooleanField source="statusBool" label="common.field.status" sortable={false} /> <TextField source="memo" label="common.field.memo" sortable={false} /> - <WrapperField cellClassName="opt" label="common.field.opt"> - <DeleteButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} /> - </WrapperField> </StyledDatagrid> </List> <PageDrawer @@ -157,9 +172,38 @@ drawerVal={drawerVal} setDrawerVal={setDrawerVal} > + <OperationDetail + operation={drawerVal} + /> </PageDrawer> </Box> ) } +const FormattedTimestampField = ({ source }) => { + const record = useRecordContext(); + const val = record[source]; + if (!val) return null; + const formattedDate = format(new Date(Number(val)), 'yyyy-MM-dd HH:mm:ss'); + return <span>{formattedDate}</span>; +}; + +const ResultField = ({ source }) => { + const record = useRecordContext(); + const val = record[source]; + return ( + <> + {val === 1 + ? ( + <Chip label="success" color="success" variant="outlined" size="small" /> + ) + : ( + <Chip label="error" color="error" variant="outlined" size="small" /> + ) + } + + </> + ) +} + export default OperationRecordList; -- Gitblit v1.9.1