From bf4a9d88a55a95f54e7c7bf7f397fa6b18258743 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 14 十月 2024 13:33:57 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/page/mission/MissionResend.jsx |  255 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 246 insertions(+), 9 deletions(-)

diff --git a/zy-acs-flow/src/page/mission/MissionResend.jsx b/zy-acs-flow/src/page/mission/MissionResend.jsx
index 09a2a2b..85823b3 100644
--- a/zy-acs-flow/src/page/mission/MissionResend.jsx
+++ b/zy-acs-flow/src/page/mission/MissionResend.jsx
@@ -1,17 +1,12 @@
 import React, { useState, useRef, useEffect, useMemo, useCallback } from "react";
 import {
     useTranslate,
-    EditButton,
-    ReferenceArrayField,
-    ReferenceField,
-    ReferenceManyField,
     ShowBase,
     useDataProvider,
     useNotify,
     useRecordContext,
     useRedirect,
     useRefresh,
-    useUpdate,
 } from 'react-admin';
 import {
     Box,
@@ -24,15 +19,24 @@
     Typography,
     Avatar,
     useTheme,
+    TableContainer,
+    Table,
+    TableBody,
+    TableCell,
+    TableHead,
+    TableRow,
+    Paper,
+    Toolbar,
+    Tooltip,
+    Checkbox,
+    IconButton,
 } from '@mui/material';
+import { alpha } from '@mui/material/styles';
 import { Link } from 'react-router-dom';
 import DialogCloseButton from "../components/DialogCloseButton";
-import { blueGrey, blue } from '@mui/material/colors';
-import MoveToInboxIcon from '@mui/icons-material/MoveToInbox';
 import { format } from 'date-fns';
-import { TaskList } from "./TaskList";
-import { ActionsIterator } from "../action/ActionsIterator";
 import ArrowBackIosNewIcon from '@mui/icons-material/ArrowBackIosNew';
+import request from '@/utils/request';
 
 const MissionResend = ({ open, id }) => {
     const redirect = useRedirect();
@@ -133,6 +137,7 @@
                             </Box>
                         )}
 
+                        <ActionTable actionIds={record?.actionIds} currCode={record.currCode} handleClose={handleClose} />
                     </Box>
                 </Box>
             </Stack>
@@ -140,4 +145,236 @@
     )
 };
 
+const headCells = [
+    {
+        id: 'actionType',
+        numeric: false,
+        disablePadding: true,
+        label: 'table.field.action.actionType',
+    },
+    {
+        id: 'code',
+        numeric: true,
+        disablePadding: false,
+        label: 'table.field.action.code',
+    },
+    {
+        id: 'taskId',
+        numeric: true,
+        disablePadding: false,
+        label: 'table.field.action.taskId',
+    },
+    {
+        id: 'val',
+        numeric: true,
+        disablePadding: false,
+        label: 'table.field.action.val',
+    },
+    {
+        id: 'params',
+        numeric: true,
+        disablePadding: false,
+        label: 'table.field.action.params',
+    },
+];
+
+const ActionTable = ({ actionIds, currCode, handleClose }) => {
+    const dataProvider = useDataProvider();
+    const translate = useTranslate();
+    const notify = useNotify();
+    const [actions, setActions] = useState([]);
+    const [selected, setSelected] = React.useState([]);
+
+    useEffect(() => {
+        if (actionIds?.length > 0) {
+            dataProvider.getMany('action', { ids: actionIds }).then(res => {
+                if (res.data?.length > 0) {
+                    setActions(res.data);
+
+                    // init selected
+                    const indexOfCurrCode = res.data.findIndex(item => item.code === currCode);
+                    if (indexOfCurrCode !== -1) {
+                        const selectedIds = res.data.slice(indexOfCurrCode).map(item => item.id);
+                        setSelected(selectedIds);
+                    }
+                }
+            })
+        }
+    }, [actionIds])
+
+    const handleSelectAllClick = (event) => {
+        if (event.target.checked) {
+            const newSelected = actions.map((n) => n.id);
+            setSelected(newSelected);
+            return;
+        }
+        setSelected([]);
+    };
+
+    const handleClick = (event, id) => {
+        const selectedIndex = selected.indexOf(id);
+        let newSelected = [];
+
+        if (selectedIndex === -1) {
+            newSelected = newSelected.concat(selected, id);
+        } else if (selectedIndex === 0) {
+            newSelected = newSelected.concat(selected.slice(1));
+        } else if (selectedIndex === selected.length - 1) {
+            newSelected = newSelected.concat(selected.slice(0, -1));
+        } else if (selectedIndex > 0) {
+            newSelected = newSelected.concat(
+                selected.slice(0, selectedIndex),
+                selected.slice(selectedIndex + 1),
+            );
+        }
+        setSelected(newSelected);
+    };
+
+    const resendSubmit = () => {
+        if (!!selected?.length) {
+            request.post("/mission/resend", selected.map(id => ({ id }))).then(res => {
+                const { code, msg, data } = res.data;
+                if (code === 200) {
+                    notify(msg || 'common.response.success', { type: 'success', messageArgs: { _: msg } });
+                    handleClose();
+                } else {
+                    notify(msg || 'common.response.fail', { type: 'error', messageArgs: { _: msg } });
+                }
+            }).catch(error => {
+                notify(error.message || 'common.response.fail', { type: 'error', messageArgs: { _: error.message } });
+            })
+        }
+    }
+
+    return (
+        <>
+            <Box sx={{ width: '100%' }}>
+                <Paper sx={{
+                    width: '100%',
+                    mb: 2,
+                }}>
+                    <Toolbar
+                        sx={[
+                            {
+                                pl: { sm: 2 },
+                                pr: { xs: 1, sm: 1 },
+                                minHeight: '52.5px !important',
+                            },
+                            selected.length > 0 && {
+                                bgcolor: (theme) =>
+                                    alpha(theme.palette.primary.main, theme.palette.action.activatedOpacity),
+                            },
+                        ]}
+                    >
+                        {selected.length > 0 ? (
+                            <Typography
+                                sx={{ flex: '1 1 100%' }}
+                                color="inherit"
+                                variant="subtitle1"
+                                component="div"
+                            >
+                                {selected.length} {translate('common.action.selected')}
+                            </Typography>
+                        ) : (
+                            <Typography
+                                sx={{ flex: '1 1 100%' }}
+                                variant="subtitle1"
+                                id="tableTitle"
+                                component="div"
+                            >
+                                {translate('table.field.mission.actions')}
+                            </Typography>
+                        )}
+                        {selected.length > 0 && (
+                            <Tooltip title="Resend">
+                                <Button
+                                    onClick={resendSubmit}
+                                >
+                                    {translate('ra.action.confirm')}
+                                </Button>
+                            </Tooltip>
+                        )}
+                    </Toolbar>
+                    <TableContainer>
+                        <Table
+                            sx={{ minWidth: 750 }}
+                            aria-labelledby="tableTitle"
+                            // size={dense ? 'small' : 'medium'}
+                            size="small"
+                        >
+                            <TableHead>
+                                <TableRow>
+                                    <TableCell padding="checkbox">
+                                        <Checkbox
+                                            color="primary"
+                                            indeterminate={selected.length > 0 && selected.length < actions.length}
+                                            checked={actions.length > 0 && selected.length === actions.length}
+                                            onChange={handleSelectAllClick}
+                                            inputProps={{
+                                                'aria-label': 'select all desserts',
+                                            }}
+                                        />
+                                    </TableCell>
+                                    {headCells.map((headCell) => (
+                                        <TableCell
+                                            key={headCell.id}
+                                            align={headCell.numeric ? 'right' : 'left'}
+                                            padding={headCell.disablePadding ? 'none' : 'normal'}
+                                        >
+                                            {translate(headCell.label)}
+                                        </TableCell>
+                                    ))}
+                                </TableRow>
+                            </TableHead>
+                            <TableBody>
+                                {actions?.map((row, index) => {
+                                    const isItemSelected = selected.includes(row.id);
+                                    const labelId = `action-table-checkbox-${index}`;
+
+                                    return (
+                                        <TableRow
+                                            hover
+                                            onClick={(event) => handleClick(event, row.id)}
+                                            role="checkbox"
+                                            aria-checked={isItemSelected}
+                                            tabIndex={-1}
+                                            key={row.id}
+                                            selected={isItemSelected}
+                                            sx={{ cursor: 'pointer' }}
+                                        >
+                                            <TableCell padding="checkbox">
+                                                <Checkbox
+                                                    color="primary"
+                                                    checked={isItemSelected}
+                                                    inputProps={{
+                                                        'aria-labelledby': labelId,
+                                                    }}
+                                                />
+                                            </TableCell>
+                                            <TableCell
+                                                component="th"
+                                                id={labelId}
+                                                scope="row"
+                                                padding="none"
+                                            >
+                                                [ {row.priority} ]
+                                                &nbsp;&nbsp;
+                                                {row.actionType$}
+                                            </TableCell>
+                                            <TableCell align="right">{row.code}</TableCell>
+                                            <TableCell align="right">{row.taskId$}</TableCell>
+                                            <TableCell align="right">{row.val}</TableCell>
+                                            <TableCell align="right">{row.params}</TableCell>
+                                        </TableRow>
+                                    );
+                                })}
+                            </TableBody>
+                        </Table>
+                    </TableContainer>
+                </Paper>
+            </Box>
+        </>
+    )
+}
+
 export default MissionResend;
\ No newline at end of file

--
Gitblit v1.9.1