#
luxiaotao1123
2024-10-15 f01613f2d65ce199c6595de9e29ba96e7e6ac4f9
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>