From e1cac1af6129216da66e569ddec892dd1f07fe80 Mon Sep 17 00:00:00 2001
From: chen.lin <1442464845@qq.com>
Date: 星期三, 25 二月 2026 10:14:37 +0800
Subject: [PATCH] 站点复制功能
---
rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx | 64 ++++++++++++++++++++++---------
1 files changed, 45 insertions(+), 19 deletions(-)
diff --git a/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx b/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx
index 092025f..eb4489a 100644
--- a/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx
+++ b/rsf-admin/src/page/basicInfo/basStation/BasStationList.jsx
@@ -33,7 +33,8 @@
DeleteButton,
} from 'react-admin';
-import { Box, Typography, Card, Stack } from '@mui/material';
+import { Box, Typography, Card, Stack, Button } from '@mui/material';
+import ContentCopyIcon from '@mui/icons-material/ContentCopy';
import { styled } from '@mui/material/styles';
import BasStationCreate from "./BasStationCreate";
import BasStationPanel from "./BasStationPanel";
@@ -59,7 +60,7 @@
'& .column-name': {
},
'& .opt': {
- width: 200
+ width: 220
},
}));
@@ -93,7 +94,29 @@
resettable
/>,
]
-
+const CopyButton = ({ setCopyRecord, setCreateDialog }) => {
+ const record = useRecordContext();
+ const translate = useTranslate();
+ if (!record) return null;
+ return (
+ <Button
+ size="small"
+ startIcon={<ContentCopyIcon fontSize="small" />}
+ sx={{ padding: '1px', fontSize: '.75rem', minWidth: 'auto' }}
+ onClick={(e) => {
+ e.stopPropagation();
+ const { id, createTime, updateTime, createBy, updateBy, createBy$, updateBy$, ...rest } = record;
+ const copied = { ...rest };
+ if (record.areaIds) copied.areaIds = [...(Array.isArray(record.areaIds) ? record.areaIds : [])];
+ if (record.containerTypes) copied.containerTypes = [...(Array.isArray(record.containerTypes) ? record.containerTypes : [])];
+ setCopyRecord(copied);
+ setCreateDialog(true);
+ }}
+ >
+ {translate('toolbar.copy')}
+ </Button>
+ );
+};
const BasStationList = () => {
const translate = useTranslate();
@@ -101,6 +124,7 @@
const [drawerVal, setDrawerVal] = useState(false);
const [areaFieldDialog, setAreaFieldDialog] = useState(false);
const [areaFieldDialog2, setAreaFieldDialog2] = useState(false);
+ const [copyRecord, setCopyRecord] = useState(null);
return (
<Box display="flex">
<List
@@ -131,18 +155,28 @@
bulkActionButtons={() => <BulkDeleteButton mutationMode={OPERATE_MODE} />}
rowClick={(id, resource, record) => false}
expandSingle={true}
- omit={['id', 'createTime', 'createBy', 'memo', 'updateBy', 'autoTransfer']}
+ omit={['id', 'createTime', 'createBy', 'createBy$', 'memo', 'updateBy$', 'updateTime', 'autoTransfer', 'isCrossZone', 'isWcs', 'area$', 'memo']}
>
<NumberField source="id" />
- {/* <TextField source="type$" label="table.field.basStation.type" /> */}
+ {/* <TextField source="type$" label="table.field.basStation.type" /> */}
+ <TextField source="stationName" label="table.field.basStation.stationName" />
+ <TextField source="stationId" label="table.field.basStation.stationId" />
<FunctionField
source="type"
label="table.field.basStation.type"
render={record => record.type === 1 ? '鏅�氱珯鐐�' : '鏅鸿兘绔欑偣'}
/>
- <TextField source="stationName" label="table.field.basStation.stationName" />
- <TextField source="stationId" label="table.field.basStation.stationId" />
<TextField source="useStatus$" label="table.field.basStation.useStatus" />
+ <WrapperField cellClassName="containerType" label="table.field.basStation.containerType">
+ <ChipArrayField
+ source="containerTypes$"
+ apiEndpoint="/dictData/many/{ids}"
+ labelField="label"
+ dialogTitle={translate('table.field.basStation.containerType')}
+ initialDisplayCount={1}
+ placeholderText="{count} 涓尯鍩�"
+ />
+ </WrapperField>
<TextField source="barcode" label="table.field.basStation.barcode" />
<FunctionField
source="inAble"
@@ -165,7 +199,6 @@
open={areaFieldDialog}
setOpen={setAreaFieldDialog}
/> */}
-
<ChipArrayField
source="areaIds"
apiEndpoint="/warehouseAreas/many/{ids}"
@@ -180,16 +213,6 @@
label="table.field.basStation.isWcs"
render={record => record.inAble === 1 ? '鏄�' : '鍚�'}
/>
- <WrapperField cellClassName="containerType" label="table.field.basStation.containerType">
- <ChipArrayField
- source="containerTypes$"
- apiEndpoint="/dictData/many/{ids}"
- labelField="label"
- dialogTitle={translate('table.field.basStation.containerType')}
- initialDisplayCount={1}
- placeholderText="{count} 涓尯鍩�"
- />
- </WrapperField>
<FunctionField
source="autoTransfer"
label="table.field.basStation.autoTransfer"
@@ -199,9 +222,10 @@
<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} />
+ {/* <BooleanField source="statusBool" label="common.field.status" sortable={false} /> */}
<TextField source="memo" label="common.field.memo" sortable={false} />
<WrapperField cellClassName="opt" label="common.field.opt">
+ <CopyButton setCopyRecord={setCopyRecord} setCreateDialog={setCreateDialog} />
<EditButton sx={{ padding: '1px', fontSize: '.75rem' }} />
<DeleteButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} />
</WrapperField>
@@ -211,6 +235,8 @@
<BasStationCreate
open={createDialog}
setOpen={setCreateDialog}
+ copyRecord={copyRecord}
+ onClose={() => setCopyRecord(null)}
/>
<PageDrawer
--
Gitblit v1.9.1