From 87c5b57b284b1506e88247d1d7d3027c499f4815 Mon Sep 17 00:00:00 2001 From: zjj <3272660260@qq.com> Date: 星期四, 15 五月 2025 16:09:16 +0800 Subject: [PATCH] # --- rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx | 17 +++- rsf-admin/src/i18n/zh.js | 4 rsf-admin/src/page/basicInfo/basStation/CrossZoneAreaField.jsx | 118 +++++++++++++++++++++++++++++ rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java | 7 + rsf-admin/src/config/setting.js | 2 rsf-admin/src/page/warehouseAreasItem/WarehouseAreasItemList.jsx | 54 ++++++------ 6 files changed, 164 insertions(+), 38 deletions(-) diff --git a/rsf-admin/src/config/setting.js b/rsf-admin/src/config/setting.js index aca143f..901ad17 100644 --- a/rsf-admin/src/config/setting.js +++ b/rsf-admin/src/config/setting.js @@ -25,7 +25,7 @@ export const ABORT_SIGNAL = false; -export const DEFAULT_PAGE_SIZE = 20; +export const DEFAULT_PAGE_SIZE = 10; export const DEFAULT_ITEM_PAGE_SIZE = 10; diff --git a/rsf-admin/src/i18n/zh.js b/rsf-admin/src/i18n/zh.js index ff79c91..3af5173 100644 --- a/rsf-admin/src/i18n/zh.js +++ b/rsf-admin/src/i18n/zh.js @@ -199,9 +199,9 @@ outAble: '鑳藉嚭', useStatus: '鐘舵��', status: '鐘舵��', - area: '鎵�灞炲簱鍖虹被鍨�', + area: '鎵�灞炲簱鍖�', isCrossZone: '鏄惁璺ㄥ尯', - crossZoneArea: '鍙法鍖虹被鍨�', + crossZoneArea: '鍙法搴撳尯', isWcs: '鏄惁WCS绔欑珯鐐�', wcsData: 'wcs鏁版嵁', containerType: '瀹瑰櫒绫诲瀷', diff --git a/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx b/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx index 6509b57..f82f9c9 100644 --- a/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx +++ b/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx @@ -45,6 +45,7 @@ import { PAGE_DRAWER_WIDTH, OPERATE_MODE, DEFAULT_PAGE_SIZE } from '@/config/setting'; import * as Common from '@/utils/common'; import WarehouseAreaField from "./WarehouseAreaField"; +import CrossZoneAreaField from "./CrossZoneAreaField"; const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({ '& .css-1vooibu-MuiSvgIcon-root': { @@ -95,7 +96,7 @@ const [createDialog, setCreateDialog] = useState(false); const [drawerVal, setDrawerVal] = useState(false); - + const [areaFieldDialog, setAreaFieldDialog] = useState(false); return ( <Box display="flex"> <List @@ -147,8 +148,12 @@ label="table.field.basStation.isCrossZone" render={record => record.inAble === 1 ? '鏄�' : '鍚�'} /> - <TextField source="crossZoneArea" label="table.field.basStation.crossZoneArea" /> - + <WrapperField cellClassName="crossZoneArea" label="table.field.basStation.crossZoneArea"> + <CrossZoneAreaField + open={areaFieldDialog} + setOpen={setAreaFieldDialog} + /> + </WrapperField> <FunctionField source="isWcs" label="table.field.basStation.isWcs" @@ -170,16 +175,18 @@ </ReferenceField> <DateField source="createTime" label="common.field.createTime" showTime /> <TextField source="memo" label="common.field.memo" sortable={false} /> - <WrapperField cellClassName="opt" label="common.field.opt"> + <WrapperField cellClassName="opt" label="common.field.opt"> <EditButton sx={{ padding: '1px', fontSize: '.75rem' }} /> <DeleteButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} /> - </WrapperField> + </WrapperField> </StyledDatagrid> + </List> <BasStationCreate open={createDialog} setOpen={setCreateDialog} /> + <PageDrawer title='BasStation Detail' drawerVal={drawerVal} diff --git a/rsf-admin/src/page/basicInfo/basStation/CrossZoneAreaField.jsx b/rsf-admin/src/page/basicInfo/basStation/CrossZoneAreaField.jsx new file mode 100644 index 0000000..115901a --- /dev/null +++ b/rsf-admin/src/page/basicInfo/basStation/CrossZoneAreaField.jsx @@ -0,0 +1,118 @@ +import * as React from 'react'; +import { Stack, Chip, Dialog, DialogTitle, DialogContent, IconButton, CircularProgress } from '@mui/material'; +import { useTranslate, useRecordContext } from 'react-admin'; +import CloseIcon from '@mui/icons-material/Close'; +import request from '@/utils/request'; + +const CrossZoneAreaField = () => { + const translate = useTranslate(); + const record = useRecordContext(); + const [open, setOpen] = React.useState(false); + const [areaNames, setAreaNames] = React.useState([]); + const [loading, setLoading] = React.useState(false); + + const handleOpen = () => { + setOpen(true); + }; + + const handleClose = () => { + setOpen(false); + }; + + const fetchAreaNames = async () => { + if (!record?.areaIds || record.areaIds.length === 0) return; + + setLoading(true); + try { + const res = await request.post(`/warehouseAreas/many/${record.areaIds.join(',')}`); + if (res?.data?.code === 200) { + setAreaNames(res.data.data || []); + } + } catch (error) { + console.error('鑾峰彇鍖哄煙鍚嶇О澶辫触:', error); + } finally { + setLoading(false); + } + }; + + React.useEffect(() => { + if (record?.areaIds && record.areaIds.length > 0) { + fetchAreaNames(); + } + }, [record]); + + if (loading) { + return <CircularProgress size={20} />; + } + + return ( + <> + <Stack + direction="row" + gap={1} + flexWrap="wrap" + onClick={handleOpen} + sx={{ cursor: 'pointer' }} + > + {areaNames.slice(0, 1).map((item, idx) => ( + <Chip + size="small" + key={item.id} + label={item.name || item.id} + /> + ))} + {areaNames.length > 1 && ( + <Chip + size="small" + label={`+${areaNames.length - 1}`} + /> + )} + {areaNames.length === 0 && record.areaIds && record.areaIds.length > 0 && ( + <Chip + size="small" + label={`${record.areaIds.length} 涓尯鍩焋} + /> + )} + </Stack> + + <Dialog + open={open} + onClose={handleClose} + maxWidth="md" + fullWidth + > + <DialogTitle> + {translate('table.field.basStation.crossZoneArea')} + <IconButton + aria-label="close" + onClick={handleClose} + sx={{ + position: 'absolute', + right: 8, + top: 8, + }} + > + <CloseIcon /> + </IconButton> + </DialogTitle> + <DialogContent> + {loading ? ( + <CircularProgress /> + ) : ( + <Stack direction="row" gap={1} flexWrap="wrap" sx={{ mt: 1 }}> + {areaNames.map((item) => ( + <Chip + size="small" + key={item.id} + label={item.name || item.id} + /> + ))} + </Stack> + )} + </DialogContent> + </Dialog> + </> + ); +}; + +export default CrossZoneAreaField; \ No newline at end of file diff --git a/rsf-admin/src/page/warehouseAreasItem/WarehouseAreasItemList.jsx b/rsf-admin/src/page/warehouseAreasItem/WarehouseAreasItemList.jsx index 43d105d..a435d24 100644 --- a/rsf-admin/src/page/warehouseAreasItem/WarehouseAreasItemList.jsx +++ b/rsf-admin/src/page/warehouseAreasItem/WarehouseAreasItemList.jsx @@ -170,17 +170,17 @@ const { data: { code, data, msg }, } = await request.get("/fields/enable/list"); if (code == 200) { const arr = [ - <NumberField source="id" />, - <TextField source="asnCode" label="table.field.warehouseAreasItem.asnCode" />, - <NumberField source="areaId" label="table.field.warehouseAreasItem.areaId" />, - <TextField source="areaName" label="table.field.warehouseAreasItem.areaName" />, - <NumberField source="matnrId" label="table.field.warehouseAreasItem.matnrId" />, - <TextField source="maktx" label="table.field.warehouseAreasItem.matnrName" />, - <TextField source="matnrCode" label="table.field.warehouseAreasItem.matnrCode" />, - <TextField source="trackCode" label="table.field.warehouseAreasItem.barcode" />, - <NumberField source="anfme" label="table.field.warehouseAreasItem.anfme" />, - <NumberField source="workQty" label="table.field.warehouseAreasItem.workQty" />, - <NumberField source="qty" label="table.field.warehouseAreasItem.qty" />, + <NumberField key="id" source="id" />, + <TextField key="asnCode" source="asnCode" label="table.field.warehouseAreasItem.asnCode" />, + <NumberField key="areaId" source="areaId" label="table.field.warehouseAreasItem.areaId" />, + <TextField key="areaName" source="areaName" label="table.field.warehouseAreasItem.areaName" />, + <NumberField key="matnrId" source="matnrId" label="table.field.warehouseAreasItem.matnrId" />, + <TextField key="maktx" source="maktx" label="table.field.warehouseAreasItem.matnrName" />, + <TextField key="matnrCode" source="matnrCode" label="table.field.warehouseAreasItem.matnrCode" />, + <TextField key="trackCode" source="trackCode" label="table.field.warehouseAreasItem.barcode" />, + <NumberField key="anfme" source="anfme" label="table.field.warehouseAreasItem.anfme" />, + <NumberField key="workQty" source="workQty" label="table.field.warehouseAreasItem.workQty" />, + <NumberField key="qty" source="qty" label="table.field.warehouseAreasItem.qty" />, // <MyField source="isptQty" label="table.field.qlyIsptItem.anfme" // onClick={(event, record, val) => { // event.stopPropagation(); @@ -188,25 +188,25 @@ // setDrawerVal(!!drawerVal && drawerVal === val ? null : val); // }} // />, - <TextField source="splrBatch" label="table.field.warehouseAreasItem.splrBtch" />, - <TextField source="batch" label="table.field.warehouseAreasItem.batch" />, - <TextField source="unit" label="table.field.warehouseAreasItem.unit" />, - <TextField source="stockUnit" label="table.field.warehouseAreasItem.stockUnit" />, - <TextField source="brand" label="table.field.warehouseAreasItem.brand" />, - <TextField source="shipperId" label="table.field.warehouseAreasItem.shipperId" />, - <TextField source="splrId" label="table.field.warehouseAreasItem.splrId" />, - <TextField source="isptResult$" label="table.field.warehouseAreasItem.isptResult" sortable={false} />, - <NumberField source="weight" label="table.field.warehouseAreasItem.weight" />, - <TextField source="prodTime" label="table.field.warehouseAreasItem.prodTime" />, + <TextField key="splrBatch" source="splrBatch" label="table.field.warehouseAreasItem.splrBtch" />, + <TextField key="batch" source="batch" label="table.field.warehouseAreasItem.batch" />, + <TextField key="unit" source="unit" label="table.field.warehouseAreasItem.unit" />, + <TextField key="stockUnit" source="stockUnit" label="table.field.warehouseAreasItem.stockUnit" />, + <TextField key="brand" source="brand" label="table.field.warehouseAreasItem.brand" />, + <TextField key="shipperId" source="shipperId" label="table.field.warehouseAreasItem.shipperId" />, + <TextField key="splrId" source="splrId" label="table.field.warehouseAreasItem.splrId" />, + <TextField key="isptResult" source="isptResult$" label="table.field.warehouseAreasItem.isptResult" sortable={false} />, + <NumberField key="weight" source="weight" label="table.field.warehouseAreasItem.weight" />, + <TextField key="prodTime" source="prodTime" label="table.field.warehouseAreasItem.prodTime" />, ] const fields = data.map(el => <TextField key={el.fields} source={`extendFields.[${el.fields}]`} label={el.fieldsAlise} />) const lastArr = [ - <TextField source="updateBy$" label="common.field.updateBy" />, - <DateField source="updateTime" label="common.field.updateTime" showTime />, - <TextField source="createBy$" label="common.field.createBy" />, - <DateField source="createTime" label="common.field.createTime" showTime />, - <BooleanField source="statusBool" label="common.field.status" sortable={false} />, - <TextField source="memo" label="common.field.memo" sortable={false} />, + <TextField key="updateBy" source="updateBy$" label="common.field.updateBy" />, + <DateField key="updateTime" source="updateTime" label="common.field.updateTime" showTime />, + <TextField key="createBy" source="createBy$" label="common.field.createBy" />, + <DateField key="createTime" source="createTime" label="common.field.createTime" showTime />, + <BooleanField key="statusBool" source="statusBool" label="common.field.status" sortable={false} />, + <TextField key="memo" source="memo" label="common.field.memo" sortable={false} />, ] setColumns([...arr, ...fields, ...lastArr]); //filters娣诲姞杩囨护瀛楁 diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java index 5f955a8..ec306f3 100644 --- a/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java +++ b/rsf-server/src/main/java/com/vincent/rsf/server/api/service/impl/MobileServiceImpl.java @@ -924,14 +924,15 @@ */ @Override public R getUnItemByContainer(Map<String, Object> params) { - if (Objects.isNull(params.get("barcode"))) { - throw new CoolException("鍙傛暟涓嶈兘涓虹┖锛侊紒"); + if (Cools.isEmpty(params.get("barcode")) && Cools.isEmpty(params.get("code"))){ + throw new CoolException("瀹瑰櫒鍙蜂笌缁勬墭妗g紪鐮佷笉鑳藉叏涓虹┖"); } //鑾峰彇缁勬嫋鏈敓鎴愪换鍔$殑缁勬嫋妗� // List<Short> asList = Arrays.asList(Short.valueOf(PakinIOStatus.PAKIN_IO_STATUS_DONE.val), Short.valueOf(PakinIOStatus.PAKIN_IO_STATUS_DONE.val)); WaitPakin waitPakin = waitPakinService.getOne(new LambdaQueryWrapper<WaitPakin>() - .eq(WaitPakin::getBarcode, params.get("barcode").toString()) + .eq(!Cools.isEmpty(params.get("barcode")),WaitPakin::getBarcode, params.get("barcode").toString()) + .eq(!Cools.isEmpty(params.get("code")),WaitPakin::getCode, params.get("code").toString()) .eq(WaitPakin::getIoStatus, PakinIOStatus.PAKIN_IO_STATUS_DONE.val)); if (Objects.isNull(waitPakin)) { return R.error("鏈壘鍒拌瀹瑰櫒鐮佺殑缁勬墭鏄庣粏锛岃妫�鏌ョ粍鎵樼姸鎬�"); -- Gitblit v1.9.1