import React, { useState, useCallback, useMemo } from "react";
|
import {
|
List,
|
DatagridConfigurable,
|
SearchInput,
|
TopToolbar,
|
SelectColumnsButton,
|
FilterButton,
|
WrapperField,
|
useTranslate,
|
FunctionField,
|
TextField,
|
NumberField,
|
DateField,
|
BooleanField,
|
SelectInput,
|
DeleteButton,
|
EditButton,
|
useGetList,
|
} from 'react-admin';
|
import { Box } from '@mui/material';
|
import { styled } from '@mui/material/styles';
|
import GuaranteeCreate from "./GuaranteeCreate";
|
import EmptyData from "../components/EmptyData";
|
import MyCreateButton from "../components/MyCreateButton";
|
import MyExportButton from '../components/MyExportButton';
|
import { DEFAULT_PAGE_SIZE, OPERATE_MODE } from '@/config/setting';
|
import { describeCronExpression } from "./cronUtils";
|
import { DEFAULT_SCOPE_TYPE, SCOPE_FILTER_CHOICES, getScopeLabel } from "./guaranteeConstants";
|
|
const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({
|
'& .css-1vooibu-MuiSvgIcon-root': {
|
height: '.9em'
|
},
|
'& .RaDatagrid-row': {
|
cursor: 'auto'
|
},
|
'& .column-name': {
|
},
|
'& .opt': {
|
width: 200
|
},
|
}));
|
|
const filters = [
|
<SearchInput source="condition" alwaysOn />,
|
<SelectInput
|
source="scopeType"
|
label="table.field.guarantee.scopeType"
|
choices={SCOPE_FILTER_CHOICES}
|
translateChoice
|
resettable
|
/>,
|
<SelectInput
|
label="common.field.status"
|
source="status"
|
choices={[
|
{ id: '1', name: 'common.enums.statusTrue' },
|
{ id: '0', name: 'common.enums.statusFalse' },
|
]}
|
alwaysOn
|
resettable
|
/>,
|
];
|
|
const GuaranteeList = () => {
|
const translate = useTranslate();
|
|
const [createDialog, setCreateDialog] = useState(false);
|
|
const { data: agvModels = [] } = useGetList('agvModel', {
|
pagination: { page: 1, perPage: 200 },
|
sort: { field: 'id', order: 'ASC' },
|
filter: {},
|
});
|
|
const modelNameMap = useMemo(() => {
|
return agvModels.reduce((acc, model) => {
|
acc[model.id] = model.name;
|
return acc;
|
}, {});
|
}, [agvModels]);
|
|
const renderScopeType = useCallback((record) => {
|
if (!record) {
|
return '';
|
}
|
return getScopeLabel(record.scopeType, translate);
|
}, [translate]);
|
|
const renderScopeValue = useCallback((record) => {
|
if (!record) {
|
return '';
|
}
|
if (!record.scopeValue) {
|
return record.scopeType === DEFAULT_SCOPE_TYPE
|
? translate('page.guarantee.scope.globalHelper')
|
: translate('common.enums.na');
|
}
|
if (record.scopeType === 'MODEL') {
|
return modelNameMap[record.scopeValue] || record.scopeValue;
|
}
|
return record.scopeValue;
|
}, [translate, modelNameMap]);
|
|
const renderCron = useCallback((record) => {
|
if (!record || !record.cronExpr) {
|
return translate('common.enums.na');
|
}
|
return describeCronExpression(record.cronExpr, translate);
|
}, [translate]);
|
|
return (
|
<Box display="flex">
|
<List
|
sx={{
|
flexGrow: 1,
|
transition: (theme) =>
|
theme.transitions.create(['all'], {
|
duration: theme.transitions.duration.enteringScreen,
|
}),
|
marginRight: 0,
|
}}
|
title={"menu.guarantee"}
|
empty={<EmptyData onClick={() => { setCreateDialog(true) }} />}
|
filters={filters}
|
sort={{ field: "create_time", order: "desc" }}
|
actions={(
|
<TopToolbar>
|
<FilterButton />
|
<MyCreateButton onClick={() => { setCreateDialog(true) }} />
|
<SelectColumnsButton preferenceKey='guarantee' />
|
<MyExportButton />
|
</TopToolbar>
|
)}
|
perPage={DEFAULT_PAGE_SIZE}
|
>
|
<StyledDatagrid
|
preferenceKey='guarantee'
|
bulkActionButtons={false}
|
rowClick={false}
|
omit={['createBy', 'memo']}
|
>
|
<TextField source="name" label="table.field.guarantee.name" />
|
<FunctionField label="table.field.guarantee.scopeType" render={renderScopeType} />
|
<FunctionField label="table.field.guarantee.scopeValue" render={renderScopeValue} />
|
<FunctionField label="table.field.guarantee.cronExpr" render={renderCron} />
|
<NumberField source="requiredCount" label="table.field.guarantee.requiredCount" />
|
<NumberField source="minSoc" label="table.field.guarantee.minSoc" />
|
<NumberField source="leadTime" label="table.field.guarantee.leadTime" />
|
|
<BooleanField source="statusBool" label="common.field.status" sortable={false} />
|
<DateField source="updateTime" label="common.field.updateTime" showTime />
|
<WrapperField cellClassName="opt" label="common.field.opt">
|
<EditButton sx={{ padding: '1px', fontSize: '.75rem' }} />
|
<DeleteButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} />
|
</WrapperField>
|
</StyledDatagrid>
|
</List>
|
<GuaranteeCreate open={createDialog} setOpen={setCreateDialog} />
|
</Box>
|
)
|
}
|
|
export default GuaranteeList;
|