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