|  |  |  | 
|---|
|  |  |  | import { formatDistance } from 'date-fns'; | 
|---|
|  |  |  | import request from '@/utils/request'; | 
|---|
|  |  |  | import { useTheme } from '@mui/material/styles'; | 
|---|
|  |  |  | import { getTaskStsColor } from '@/utils/common'; | 
|---|
|  |  |  | import { getTaskStsColor } from '@/utils/color-util'; | 
|---|
|  |  |  | import ListEmptyTip from "../../components/ListEmptyTip"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const TaskItem = ({ record, now }) => { | 
|---|
|  |  |  | const translate = useTranslate(); | 
|---|
|  |  |  | 
|---|
|  |  |  | <ListItemAvatar> | 
|---|
|  |  |  | <Avatar | 
|---|
|  |  |  | alt={record.seqNum} | 
|---|
|  |  |  | variant="rounded" | 
|---|
|  |  |  | sx={{ | 
|---|
|  |  |  | '& img': { objectFit: 'contain' }, | 
|---|
|  |  |  | fontSize: '0.9rem', | 
|---|
|  |  |  | width: 40, | 
|---|
|  |  |  | height: 40, | 
|---|
|  |  |  | height: 25, | 
|---|
|  |  |  | bgcolor: getTaskStsColor(record.taskSts$), | 
|---|
|  |  |  | }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 
|---|
|  |  |  | </Avatar> | 
|---|
|  |  |  | </ListItemAvatar> | 
|---|
|  |  |  | <ListItemText | 
|---|
|  |  |  | primary={`${record.first_name} ${record.last_name}`} | 
|---|
|  |  |  | primary={<> | 
|---|
|  |  |  | <Stack direction={'row'}> | 
|---|
|  |  |  | <Typography | 
|---|
|  |  |  | variant="body1" | 
|---|
|  |  |  | color="textSecondary" | 
|---|
|  |  |  | component="span" | 
|---|
|  |  |  | sx={{ fontWeight: '600' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {record.taskType$} | 
|---|
|  |  |  | </Typography> | 
|---|
|  |  |  | <Typography | 
|---|
|  |  |  | variant="caption" | 
|---|
|  |  |  | color="textSecondary" | 
|---|
|  |  |  | component="span" | 
|---|
|  |  |  | > | 
|---|
|  |  |  |  -  {record.taskTypeEl} | 
|---|
|  |  |  | </Typography> | 
|---|
|  |  |  | </Stack> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | </>} | 
|---|
|  |  |  | secondary={ | 
|---|
|  |  |  | <> | 
|---|
|  |  |  | {record.title} | 
|---|
|  |  |  |     | 
|---|
|  |  |  | <Typography | 
|---|
|  |  |  | variant="body2" | 
|---|
|  |  |  | color="textSecondary" | 
|---|
|  |  |  | component="span" | 
|---|
|  |  |  | sx={{ fontWeight: 'bold' }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {record.taskSts$} | 
|---|
|  |  |  | </Typography> | 
|---|
|  |  |  | </> | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | <ListItemText | 
|---|
|  |  |  | variant="body2" | 
|---|
|  |  |  | color="textSecondary" | 
|---|
|  |  |  | primary={<> | 
|---|
|  |  |  | <Typography | 
|---|
|  |  |  | variant="body2" | 
|---|
|  |  |  | color="textPrimary" | 
|---|
|  |  |  | component="span" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {record.oriLoc$ || ''}{record.oriSta$ || ''} - {record.destLoc$ || ''}{record.destSta$ || ''} | 
|---|
|  |  |  | </Typography> | 
|---|
|  |  |  | </>} | 
|---|
|  |  |  | secondary={`code: ${record.destCode$ || ''}`} | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | <ListItemSecondaryAction> | 
|---|
|  |  |  | <Typography | 
|---|
|  |  |  | 
|---|
|  |  |  | color="textSecondary" | 
|---|
|  |  |  | component="span" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | last activity{' '} | 
|---|
|  |  |  | last update {' '} | 
|---|
|  |  |  | {formatDistance(record.createTime, now)} ago{' '} | 
|---|
|  |  |  | </Typography> | 
|---|
|  |  |  | </ListItemSecondaryAction> | 
|---|
|  |  |  | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | export const AgvShowTask = ({ agvId, pageSize = 20 }) => { | 
|---|
|  |  |  | export const AgvShowTask = ({ agvId, pageSize = 10 }) => { | 
|---|
|  |  |  | const [currCount, setCurrCount] = useState(pageSize); | 
|---|
|  |  |  | const [records, setRecords] = useState(null); | 
|---|
|  |  |  | const [total, setTotal] = useState(0); | 
|---|
|  |  |  | const translate = useTranslate(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | useEffect(() => { | 
|---|
|  |  |  | const http = async () => { | 
|---|
|  |  |  | 
|---|
|  |  |  | return ( | 
|---|
|  |  |  | <> | 
|---|
|  |  |  | {records.length > 0 ? ( | 
|---|
|  |  |  | <Box m={1}> | 
|---|
|  |  |  | <Box > | 
|---|
|  |  |  | <List> | 
|---|
|  |  |  | {records.map(record => { | 
|---|
|  |  |  | return ( | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | })} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | {currCount < total && ( | 
|---|
|  |  |  | <Button | 
|---|
|  |  |  | onClick={() => | 
|---|
|  |  |  | 
|---|
|  |  |  | fullWidth | 
|---|
|  |  |  | sx={{ mt: 1 }} | 
|---|
|  |  |  | > | 
|---|
|  |  |  | Load more activity | 
|---|
|  |  |  | {translate('common.action.loadMore')} | 
|---|
|  |  |  | </Button> | 
|---|
|  |  |  | )} | 
|---|
|  |  |  | </List> | 
|---|
|  |  |  | </Box> | 
|---|
|  |  |  | ) : ( | 
|---|
|  |  |  | <Typography> | 
|---|
|  |  |  | no data found | 
|---|
|  |  |  | </Typography> | 
|---|
|  |  |  | <ListEmptyTip /> | 
|---|
|  |  |  | )} | 
|---|
|  |  |  |  | 
|---|
|  |  |  | </> | 
|---|