From 4a620b306e2e0ff208dbea260f998ffce8d08e39 Mon Sep 17 00:00:00 2001
From: zhou zhou <3272660260@qq.com>
Date: 星期五, 06 三月 2026 15:46:05 +0800
Subject: [PATCH] #站点区域

---
 rsf-admin/src/page/basStationArea/BasStationAreaList.jsx |  109 ++++++++++++++++++++++++++----------------------------
 1 files changed, 52 insertions(+), 57 deletions(-)

diff --git a/rsf-admin/src/page/basStationArea/BasStationAreaList.jsx b/rsf-admin/src/page/basStationArea/BasStationAreaList.jsx
index c7d14ce..723a749 100644
--- a/rsf-admin/src/page/basStationArea/BasStationAreaList.jsx
+++ b/rsf-admin/src/page/basStationArea/BasStationAreaList.jsx
@@ -2,10 +2,9 @@
 import { useNavigate } from 'react-router-dom';
 import {
     List,
-    DatagridConfigurable,
     SearchInput,
     TopToolbar,
-    SelectColumnsButton,
+    ColumnsButton,
     EditButton,
     FilterButton,
     CreateButton,
@@ -33,7 +32,6 @@
     DeleteButton,
 } from 'react-admin';
 import { Box, Typography, Card, Stack } from '@mui/material';
-import { styled } from '@mui/material/styles';
 import BasStationAreaCreate from "./BasStationAreaCreate";
 import BasStationAreaPanel from "./BasStationAreaPanel";
 import EmptyData from "../components/EmptyData";
@@ -41,22 +39,10 @@
 import MyExportButton from '../components/MyExportButton';
 import PageDrawer from "../components/PageDrawer";
 import MyField from "../components/MyField";
+import StickyDataTable from "@/page/components/StickyDataTable";
 import { PAGE_DRAWER_WIDTH, OPERATE_MODE, DEFAULT_PAGE_SIZE } from '@/config/setting';
 import * as Common from '@/utils/common';
-
-const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({
-    '& .css-1vooibu-MuiSvgIcon-root': {
-        height: '.9em'
-    },
-    '& .RaDatagrid-row': {
-        cursor: 'auto'
-    },
-    '& .column-name': {
-    },
-    '& .opt': {
-        width: 200
-    },
-}));
+import useTableLayout from '@/utils/useTableLayout';
 
 const filters = [
     <SearchInput source="condition" alwaysOn />,
@@ -97,8 +83,14 @@
     const [createDialog, setCreateDialog] = useState(false);
     const [drawerVal, setDrawerVal] = useState(false);
 
+    const { boxMaxWidth, boxMaxHeight } = useTableLayout(drawerVal);
+
     return (
-        <Box display="flex">
+        <Box display="flex" sx={{
+            '& .opt': {
+                width: 200
+            }
+        }}>
             <List
                 sx={{
                     flexGrow: 1,
@@ -116,52 +108,55 @@
                     <TopToolbar>
                         <FilterButton />
                         <MyCreateButton onClick={() => { setCreateDialog(true) }} />
-                        <SelectColumnsButton preferenceKey='basStationArea' />
+                        <ColumnsButton storeKey='basStationArea' />
                         <MyExportButton />
                     </TopToolbar>
                 )}
                 perPage={DEFAULT_PAGE_SIZE}
             >
-                <StyledDatagrid
-                    preferenceKey='basStationArea'
-                    bulkActionButtons={() => <BulkDeleteButton mutationMode={OPERATE_MODE} />}
-                    rowClick={(id, resource, record) => false}
-                    expand={() => <BasStationAreaPanel />}
-                    expandSingle={true}
-                    omit={['id', 'createTime', 'createBy', 'memo']}
+                <Box
+                    sx={{
+                        position: 'relative',
+                        maxHeight: boxMaxHeight,
+                        maxWidth: boxMaxWidth,
+                        overflowX: 'auto',
+                        overflowY: 'auto',
+                        '& .MuiTableCell-root': {
+                            whiteSpace: 'nowrap',
+                        }
+                    }}
                 >
-                    <NumberField source="id" />
-                    <NumberField source="type" label="table.field.basStationArea.type" />
-                    <TextField source="stationAreaName" label="table.field.basStationArea.stationAreaName" />
-                    <NumberField source="inAble" label="table.field.basStationArea.inAble" />
-                    <NumberField source="outAble" label="table.field.basStationArea.outAble" />
-                    <TextField source="useStatus" label="table.field.basStationArea.useStatus" />
-                    <NumberField source="area" label="table.field.basStationArea.area" />
-                    <NumberField source="isCrossZone" label="table.field.basStationArea.isCrossZone" />
-                    <TextField source="crossZoneArea" label="table.field.basStationArea.crossZoneArea" />
-                    <NumberField source="isWcs" label="table.field.basStationArea.isWcs" />
-                    <TextField source="wcsData" label="table.field.basStationArea.wcsData" />
-                    <TextField source="containerType" label="table.field.basStationArea.containerType" />
-                    <TextField source="barcode" label="table.field.basStationArea.barcode" />
-                    <NumberField source="autoTransfer" label="table.field.basStationArea.autoTransfer" />
-                    <TextField source="stationAreaId" label="table.field.basStationArea.stationAreaId" />
-                    <TextField source="stationAlias" label="table.field.basStationArea.stationAlias" />
+                    <StickyDataTable
+                        storeKey='basStationArea'
+                        bulkActionButtons={<BulkDeleteButton mutationMode={OPERATE_MODE} />}
+                        rowClick={(id, resource, record) => false}
+                        stickyRight={['opt']}
+                        expandSingle={true}
+                        hiddenColumns={['id', 'createTime', 'createBy', 'memo']}
+                    >
+                        <NumberField source="id" />
+                        <TextField source="stationAreaName" label="table.field.basStationArea.stationAreaName" />
+                        <NumberField source="area" label="table.field.basStationArea.area" />
+                        <TextField source="containerType" label="table.field.basStationArea.containerType" />
+                        <TextField source="stationAreaId" label="table.field.basStationArea.stationAreaId" />
+                        <TextField source="stationAlias" label="table.field.basStationArea.stationAlias" />
 
-                    <ReferenceField source="updateBy" label="common.field.updateBy" reference="user" link={false} sortable={false}>
-                        <TextField source="nickname" />
-                    </ReferenceField>
-                    <DateField source="updateTime" label="common.field.updateTime" showTime />
-                    <ReferenceField source="createBy" label="common.field.createBy" reference="user" link={false} sortable={false}>
-                        <TextField source="nickname" />
-                    </ReferenceField>
-                    <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} />
-                    <WrapperField cellClassName="opt" label="common.field.opt">
-                        <EditButton sx={{ padding: '1px', fontSize: '.75rem' }} />
-                        <DeleteButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} />
-                    </WrapperField>
-                </StyledDatagrid>
+                        <ReferenceField source="updateBy" label="common.field.updateBy" reference="user" link={false} sortable={false}>
+                            <TextField source="nickname" />
+                        </ReferenceField>
+                        <DateField source="updateTime" label="common.field.updateTime" showTime />
+                        <ReferenceField source="createBy" label="common.field.createBy" reference="user" link={false} sortable={false}>
+                            <TextField source="nickname" />
+                        </ReferenceField>
+                        <DateField source="createTime" label="common.field.createTime" showTime />
+
+                        <WrapperField source="opt" cellClassName="opt" label="common.field.opt">
+                            <EditButton sx={{ padding: '1px', fontSize: '.75rem' }} />
+                            <DeleteButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} />
+                        </WrapperField>
+                    </StickyDataTable>
+                </Box>
+
             </List>
             <BasStationAreaCreate
                 open={createDialog}

--
Gitblit v1.9.1