From fc9063d400f115693a5d861acdb76fae09bfb543 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期四, 17 十月 2024 08:32:34 +0800 Subject: [PATCH] # --- zy-acs-flow/src/page/bus/BusCreate.jsx | 242 ++++++++++++++++++++++++++++++++---------------- 1 files changed, 161 insertions(+), 81 deletions(-) diff --git a/zy-acs-flow/src/page/bus/BusCreate.jsx b/zy-acs-flow/src/page/bus/BusCreate.jsx index 1dc547e..8243565 100644 --- a/zy-acs-flow/src/page/bus/BusCreate.jsx +++ b/zy-acs-flow/src/page/bus/BusCreate.jsx @@ -6,6 +6,7 @@ NumberInput, BooleanInput, DateInput, + DateTimeInput, SaveButton, SelectInput, ReferenceInput, @@ -17,6 +18,8 @@ useNotify, Form, useCreateController, + ArrayInput, + SimpleFormIterator, } from 'react-admin'; import { Dialog, @@ -30,12 +33,45 @@ import DialogCloseButton from "../components/DialogCloseButton"; import StatusSelectInput from "../components/StatusSelectInput"; import MemoInput from "../components/MemoInput"; +import request from '@/utils/request'; const BusCreate = (props) => { const { open, setOpen } = props; const translate = useTranslate(); const notify = useNotify(); + + const [locStsIdByStock, setLocStsIdByStock] = useState(null); + const [locStsIdByIdle, setLocStsIdByIdle] = useState(null); + + useEffect(() => { + const queryLocStsByStock = async () => { + request.post('/locSts/list', { + uuid: 'STOCK' + }, { + headers: { + 'Content-Type': 'application/x-www-form-urlencoded' + } + }).then(res => { + setLocStsIdByStock(res.data.data[0]?.id); + }) + } + const queryLocStsByIdle = async () => { + request.post('/locSts/list', { + uuid: 'IDLE' + }, { + headers: { + 'Content-Type': 'application/x-www-form-urlencoded' + } + }).then(res => { + setLocStsIdByIdle(res.data.data[0]?.id); + }) + } + if (open) { + queryLocStsByStock(); + queryLocStsByIdle(); + } + }, [open]) const handleClose = (event, reason) => { if (reason !== "backdropClick") { @@ -48,95 +84,139 @@ notify('common.response.success'); }; - const handleError = async (data) => { - notify('common.response.fail'); + const handleError = async (error) => { + notify(error.message || 'common.response.fail', { type: 'error', messageArgs: { _: error.message } }); }; return ( <> - <CreateBase - record={{}} - transform={(data) => { - return data; - }} - mutationOptions={{ onSuccess: handleSuccess, onError: handleError }} - > - <Dialog - open={open} - onClose={handleClose} - aria-labelledby="form-dialog-title" - fullWidth - disableRestoreFocus - maxWidth="md" // 'xs' | 'sm' | 'md' | 'lg' | 'xl' + {(locStsIdByStock && locStsIdByIdle) && ( + <CreateBase + record={{}} + transform={(data) => { + return data; + }} + mutationOptions={{ onSuccess: handleSuccess, onError: handleError }} > - <Form> - <DialogTitle id="form-dialog-title" sx={{ - position: 'sticky', - top: 0, - backgroundColor: 'background.paper', - zIndex: 1000 - }} - > - {translate('create.title')} - <Box sx={{ position: 'absolute', top: 8, right: 8, zIndex: 1001 }}> - <DialogCloseButton onClose={handleClose} /> - </Box> - </DialogTitle> - <DialogContent> - <Grid container rowSpacing={2} columnSpacing={2}> - <Grid item xs={6} display="flex" gap={1}> - <TextInput - label="table.field.bus.uuid" - source="uuid" - parse={v => v} - autoFocus - /> - </Grid> - <Grid item xs={6} display="flex" gap={1}> - <TextInput - label="table.field.bus.busNo" - source="busNo" - parse={v => v} - /> - </Grid> - <Grid item xs={6} display="flex" gap={1}> - <ReferenceInput - source="busSts" - reference="busSts" - > - <AutocompleteInput - label="table.field.bus.busSts" - optionText="name" - filterToQuery={(val) => ({ name: val })} + <Dialog + open={open} + onClose={handleClose} + aria-labelledby="form-dialog-title" + fullWidth + disableRestoreFocus + maxWidth="md" // 'xs' | 'sm' | 'md' | 'lg' | 'xl' + > + <Form> + <DialogTitle id="form-dialog-title" sx={{ + position: 'sticky', + top: 0, + backgroundColor: 'background.paper', + zIndex: 1000 + }} + > + {translate('create.title')} + <Box sx={{ position: 'absolute', top: 8, right: 8, zIndex: 1001 }}> + <DialogCloseButton onClose={handleClose} /> + </Box> + </DialogTitle> + <DialogContent> + <Grid container rowSpacing={2} columnSpacing={2}> + <Grid item xs={6} display="flex" gap={1}> + <TextInput + label="table.field.bus.busNo" + source="busNo" + parse={v => v} + validate={required()} /> - </ReferenceInput> - </Grid> - <Grid item xs={6} display="flex" gap={1}> - <TextInput - label="table.field.bus.phase" - source="phase" - parse={v => v} - /> - </Grid> + </Grid> + {/* <Grid item xs={6} display="flex" gap={1}> + <DateTimeInput + label="table.field.bus.startTime" + source="startTime" + /> + </Grid> */} - <Grid item xs={6} display="flex" gap={1}> - <StatusSelectInput /> + <Grid item xs={12} display="flex" gap={1}> + <ArrayInput + label="table.field.bus.taskList" + source="taskList" + validate={[required()]} + > + <SimpleFormIterator fullWidth getItemLabel={index => `#${index + 1}`}> + <Box mt={1} /> + <Stack direction="row" spacing={2}> + <ReferenceInput + source="oriSta" + reference="sta" + > + <AutocompleteInput + label="table.field.task.oriSta" + optionText="staNo" + filterToQuery={(val) => ({ staNo: val })} + /> + </ReferenceInput> + <ReferenceInput + source="oriLoc" + reference="loc" + filter={{ locSts: locStsIdByStock }} + > + <AutocompleteInput + label="table.field.task.oriLoc" + optionText="locNo" + filterToQuery={(val) => ({ locNo: val })} + /> + </ReferenceInput> + </Stack> + <Stack direction="row" spacing={2}> + <ReferenceInput + source="destSta" + reference="sta" + > + <AutocompleteInput + label="table.field.task.destSta" + optionText="staNo" + filterToQuery={(val) => ({ staNo: val })} + /> + </ReferenceInput> + <ReferenceInput + source="destLoc" + reference="loc" + filter={{ locSts: locStsIdByIdle }} + > + <AutocompleteInput + label="table.field.task.destLoc" + optionText="locNo" + filterToQuery={(val) => ({ locNo: val })} + /> + </ReferenceInput> + </Stack> + <Stack direction="row" spacing={2} sx={{ maxWidth: '50%' }}> + {/* <TextInput source="seqNum" /> */} + <NumberInput + label="table.field.task.priority" + source="priority" + defaultValue={1} + /> + </Stack> + </SimpleFormIterator> + </ArrayInput> + </Grid> + <Grid item xs={12} display="flex" gap={1}> + <Stack direction="column" spacing={1} width={'100%'}> + <MemoInput /> + </Stack> + </Grid> </Grid> - <Grid item xs={12} display="flex" gap={1}> - <Stack direction="column" spacing={1} width={'100%'}> - <MemoInput /> - </Stack> - </Grid> - </Grid> - </DialogContent> - <DialogActions sx={{ position: 'sticky', bottom: 0, backgroundColor: 'background.paper', zIndex: 1000 }}> - <Toolbar sx={{ width: '100%', justifyContent: 'space-between' }} > - <SaveButton /> - </Toolbar> - </DialogActions> - </Form> - </Dialog> - </CreateBase> + </DialogContent> + <DialogActions sx={{ position: 'sticky', bottom: 0, backgroundColor: 'background.paper', zIndex: 1000 }}> + <Toolbar sx={{ width: '100%', justifyContent: 'space-between' }} > + <SaveButton /> + </Toolbar> + </DialogActions> + </Form> + </Dialog> + </CreateBase> + )} </> ) } -- Gitblit v1.9.1