From 6f5c384b7f838f35e3da4db129a57c76cd54d508 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 04 十一月 2024 10:51:51 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/page/mission/MissionResend.jsx |   49 ++++++++++++++++++++++++++++++++++---------------
 1 files changed, 34 insertions(+), 15 deletions(-)

diff --git a/zy-acs-flow/src/page/mission/MissionResend.jsx b/zy-acs-flow/src/page/mission/MissionResend.jsx
index 10b1a43..85823b3 100644
--- a/zy-acs-flow/src/page/mission/MissionResend.jsx
+++ b/zy-acs-flow/src/page/mission/MissionResend.jsx
@@ -36,6 +36,7 @@
 import DialogCloseButton from "../components/DialogCloseButton";
 import { format } from 'date-fns';
 import ArrowBackIosNewIcon from '@mui/icons-material/ArrowBackIosNew';
+import request from '@/utils/request';
 
 const MissionResend = ({ open, id }) => {
     const redirect = useRedirect();
@@ -136,8 +137,7 @@
                             </Box>
                         )}
 
-                        <ActionTable actionIds={record?.actionIds} />
-
+                        <ActionTable actionIds={record?.actionIds} currCode={record.currCode} handleClose={handleClose} />
                     </Box>
                 </Box>
             </Stack>
@@ -178,9 +178,10 @@
     },
 ];
 
-const ActionTable = ({ actionIds }) => {
+const ActionTable = ({ actionIds, currCode, handleClose }) => {
     const dataProvider = useDataProvider();
     const translate = useTranslate();
+    const notify = useNotify();
     const [actions, setActions] = useState([]);
     const [selected, setSelected] = React.useState([]);
 
@@ -189,6 +190,13 @@
             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);
+                    }
                 }
             })
         }
@@ -222,6 +230,21 @@
         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 (
         <>
@@ -250,7 +273,7 @@
                                 variant="subtitle1"
                                 component="div"
                             >
-                                {selected.length} selected
+                                {selected.length} {translate('common.action.selected')}
                             </Typography>
                         ) : (
                             <Typography
@@ -259,20 +282,16 @@
                                 id="tableTitle"
                                 component="div"
                             >
-                                Actions
+                                {translate('table.field.mission.actions')}
                             </Typography>
                         )}
                         {selected.length > 0 && (
-                            <Tooltip title="Delete">
-                                <IconButton>
-                                    <Button
-                                        onClick={() => {
-                                            alert('clicked');
-                                        }}
-                                    >
-                                        ss
-                                    </Button>
-                                </IconButton>
+                            <Tooltip title="Resend">
+                                <Button
+                                    onClick={resendSubmit}
+                                >
+                                    {translate('ra.action.confirm')}
+                                </Button>
                             </Tooltip>
                         )}
                     </Toolbar>

--
Gitblit v1.9.1