From 56ca28233a84c5aa3ca93cae266b2d008ea348e1 Mon Sep 17 00:00:00 2001
From: lbq <1065079612@qq.com>
Date: 星期三, 24 十二月 2025 09:54:13 +0800
Subject: [PATCH] Web页面优化

---
 rsf-admin/src/page/basicInfo/warehouse/WarehouseList.jsx                                         |    6 
 rsf-admin/src/page/orders/preparation/MatPreparationPublic.jsx                                   |  483 +++++++++++
 rsf-admin/src/page/system/menu/MenuList.jsx                                                      |   68 +
 rsf-admin/src/page/system/role/AssignPermissions.jsx                                             |    6 
 rsf-admin/src/page/dashboard/NbPie.jsx                                                           |    2 
 rsf-admin/src/page/dashboard/NbList.jsx                                                          |  199 +++-
 rsf-admin/src/layout/SubMenu.jsx                                                                 |  120 ++
 rsf-admin/src/page/dashboard/NbCard.jsx                                                          |  365 +++++++-
 rsf-admin/src/page/orders/asnOrder/AsnOrderItemList.jsx                                          |    7 
 rsf-admin/src/themes/ThemeSwapper.jsx                                                            |    4 
 rsf-admin/src/i18n/zh.js                                                                         |   45 
 rsf-admin/src/page/orders/outStock/OutOrderList.jsx                                              |   10 
 rsf-admin/src/i18n/en.js                                                                         |    2 
 rsf-admin/src/page/ResourceContent.js                                                            |    3 
 rsf-admin/src/page/orders/outStock/OutOrderItemList.jsx                                          |    7 
 rsf-admin/src/page/orders/asnOrder/AsnOrderList.jsx                                              |   12 
 rsf-admin/src/layout/MyMenu.jsx                                                                  |  166 +++
 rsf-admin/src/page/basicInfo/companys/CompanysList.jsx                                           |    7 
 rsf-admin/src/page/basicInfo/matnrGroup/MatnrGroupList.jsx                                       |   10 
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatPreparationController.java |   96 ++
 rsf-admin/src/layout/Logo.jsx                                                                    |    8 
 rsf-admin/src/page/orders/preparation/MatPreparationList.jsx                                     |  422 ++++++++++
 rsf-admin/src/page/orders/preparation/MatPreparationPanel.jsx                                    |   89 ++
 rsf-admin/src/page/orders/preparation/index.jsx                                                  |   18 
 rsf-admin/src/page/system/role/RoleList.jsx                                                      |   15 
 rsf-admin/src/layout/AppBar.jsx                                                                  |   34 
 rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx                                                 |   48 
 rsf-admin/src/page/orders/preparation/MatPreparationItemList.jsx                                 |  209 ++++
 28 files changed, 2,198 insertions(+), 263 deletions(-)

diff --git a/rsf-admin/src/i18n/en.js b/rsf-admin/src/i18n/en.js
index b4c4cc8..2e3b8db 100644
--- a/rsf-admin/src/i18n/en.js
+++ b/rsf-admin/src/i18n/en.js
@@ -217,7 +217,7 @@
         locDeadReport: 'Locs Dead Report',
         stockStatistic: 'Stock Statistic',
         statisticCount: 'Statistic Count',
-
+        preparation:"澶囨枡鍗�",
     },
     table: {
         field: {
diff --git a/rsf-admin/src/i18n/zh.js b/rsf-admin/src/i18n/zh.js
index ee0284b..c56d5f1 100644
--- a/rsf-admin/src/i18n/zh.js
+++ b/rsf-admin/src/i18n/zh.js
@@ -172,7 +172,7 @@
         companys: '寰�鏉ヤ紒涓�',
         serialRuleItem: '缂栫爜瑙勫垯瀛愯〃',
         serialRule: '缂栫爜瑙勫垯',
-        asnOrder: '鏀惰揣閫氱煡鍗�',
+        asnOrder: '鍏ュ簱閫氱煡鍗�',
         asnOrderItem: '鏀惰揣鏄庣粏',
         asnOrderLog: '鏀惰揣鍘嗗彶鍗�',
         asnOrderItemLog: '鏀惰揣鍘嗗彶鏄庣粏',
@@ -228,6 +228,10 @@
         inStatisticItem: '鏃ュ叆搴撴槑缁嗘煡璇�',
         outStatisticItem: '鏃ュ嚭搴撴槑缁嗘煡璇�',
         statisticCount: '鏃ュ嚭鍏ュ簱姹囨�荤粺璁�',
+        preparation: '澶囨枡鍗�',
+        check: '鐩樼偣绠$悊',
+        abnormal: '寮傚父绠$悊',
+        platform: '骞冲彴绠$悊'
     },
     table: {
         field: {
@@ -394,7 +398,7 @@
                 nromNum: "鏍囧寘鏁伴噺",
                 unit: "鍗曚綅",
                 purUnit: "閲囪喘鍗曚綅",
-                stockUnit: "搴撳瓨鍗曚綅",
+                stockUnit: "浣跨敤缁勭粐", //"搴撳瓨鍗曚綅",
                 stockLevel: "ABC鍒嗙被",
                 isLabelMange: "鏍囩绠$悊",
                 safeQty: "瀹夊叏鍊�",
@@ -406,14 +410,14 @@
                 flagCheck: "鍏嶆",
             },
             matnrGroup: {
-                name: "鍚嶇О",
-                code: "缂栫爜",
+                name: "鐗╂枡鍒嗙粍鍚嶇О",
+                code: "鐗╂枡鍒嗙粍缂栫爜",
                 parentId: "涓婄骇鏍囪瘑",
                 parCode: "涓婄骇缂栫爜",
             },
             warehouse: {
                 name: "浠撳簱鍚嶇О",
-                code: "缂栫爜",
+                code: "浠撳簱缂栫爜",
                 factory: "宸ュ巶",
                 address: "鍦板潃",
                 longitude: "缁忓害",
@@ -460,7 +464,7 @@
             loc: {
                 warehouseId: "鎵�灞炰粨搴�",
                 areaId: "鎵�灞炲簱鍖�",
-                code: "缂栫爜",
+                code: "搴撲綅缂栫爜",
                 type: "绫诲瀷",
                 name: "鍚嶇О",
                 flagLogic: "铏氭嫙搴撲綅",
@@ -601,10 +605,10 @@
                 color: "棰滆壊",
             },
             companys: {
-                code: "浼佷笟缂栫爜",
+                code: "缂栫爜",
                 name: "鍚嶇О",
                 nameEn: "鑻辨枃鍒悕",
-                breifCode: "鍔╄鐮�",
+                breifCode: "鏄电О",  //鍔╄鐮�
                 type: "绫诲瀷",
                 contact: "鑱旂郴浜�",
                 tel: "鑱旂郴鐢佃瘽",
@@ -647,8 +651,8 @@
                 poId: "PO鏍囪瘑",
                 type: "鍗曟嵁绫诲瀷",
                 wkType: "涓氬姟绫诲瀷",
-                anfme: "璁″垝鏁伴噺",
-                qty: "瀹屾垚鏁伴噺",
+                anfme: "搴旀敹鏁伴噺",
+                qty: "瀹炴敹鏁伴噺",
                 logisNo: "鐗╂祦鍗曞彿",
                 arrTime: "棰勮鍒拌揪鏃堕棿",
                 rleStatus: "閲婃斁鐘舵��",
@@ -793,13 +797,13 @@
                 spec: "瑙勬牸",
                 model: "鍨嬪彿",
                 matnrCode: "鐗╂枡缂栫爜",
-                anfme: "璁″垝鏁伴噺",
+                anfme: "搴旀敹鏁伴噺",
                 stockUnit: "鍗曚綅",
                 isptResult: "璐ㄦ缁撴灉",
                 purQty: "閲囪喘閲�",
                 purUnit: "閲囪喘鍗曚綅",
                 unit: '鍗曚綅',
-                qty: "瀹屾垚鏁�",
+                qty: "瀹炴敹鏁伴噺",
                 safeQty: '鍚堟牸鏁�',
                 disQty: '涓嶅悎鏍兼暟',
                 splrBatch: "鎵规",
@@ -1055,6 +1059,23 @@
                 stockLocs: "搴撳瓨浣嶇疆",
                 stockQty: "搴撳瓨鏁伴噺",
             },
+            preparation: {
+                orderCode: "澶囨枡鍗曞彿",
+                orderStatus: "澶囨枡鐘舵��",
+                orderTime: "鏃堕棿",
+                anfme: "澶囨枡鏁伴噺",
+            },
+            preparationItem: {
+                matnrId: "鐗╂枡ID",
+                matnrCode: "鐗╂枡缂栫爜",
+                maktx: "鐗╂枡鍚嶇О",
+                unit: "鍗曚綅",
+                spec: "瑙勬牸",
+                model: "鍨嬪彿",
+                anfme: "澶囨枡鏁伴噺",
+                workQty: "瀹屾垚鏁伴噺",
+                status: "澶囨枡鐘舵��",
+            },
             task: {
                 taskCode: "浠诲姟鍙�",
                 taskStatus: "鐘舵��",
diff --git a/rsf-admin/src/layout/AppBar.jsx b/rsf-admin/src/layout/AppBar.jsx
index a9d3a88..892e82a 100644
--- a/rsf-admin/src/layout/AppBar.jsx
+++ b/rsf-admin/src/layout/AppBar.jsx
@@ -1,8 +1,7 @@
 import * as React from 'react';
-import { AppBar, TitlePortal } from 'react-admin';
+import { AppBar } from 'react-admin';
 import { Box, useMediaQuery } from '@mui/material';
 
-// https://www.base64-image.de/
 import Logo from './Logo';
 import { AppBarToolbar } from './AppBarToolbar';
 
@@ -10,16 +9,39 @@
     const isLargeEnough = useMediaQuery(theme =>
         theme.breakpoints.up('sm')
     );
+    
     return (
         <AppBar
             color="secondary"
             toolbar={<AppBarToolbar />}
+            sx={{
+                // 闅愯棌鏈�宸︿晶鐨勮彍鍗曟寜閽�
+                '& .RaAppBar-menuButton': {
+                    display: 'none !important',
+                },
+                // 璋冩暣宸ュ叿鏍忓竷灞�
+                '& .RaAppBar-toolbar': {
+                    paddingLeft: '4px !important', // 鏈�灏忓乏杈硅窛
+                    justifyContent: 'flex-start',
+                    gap: 2, // 鍏冪礌涔嬮棿鐨勯棿璺�
+                }
+            }}
         >
-            <TitlePortal />
-            {isLargeEnough && <Logo />}
-            {isLargeEnough && <Box component="span" sx={{ flex: 1 }} />}
+            {/* Logo 瀹屽叏闈犲乏 */}
+            {isLargeEnough && (
+                <Box sx={{ 
+                    display: 'flex', 
+                    alignItems: 'center',
+                    minWidth: 'auto', // 涓嶉檺鍒跺搴�
+                }}>
+                    <Logo />
+                </Box>
+            )}
+            
+            {/* 寮规�х┖闂村皢宸ュ叿鏍忔寜閽帹鍒板彸渚� */}
+            <Box component="span" sx={{ flex: 1 }} />
         </AppBar>
     );
 };
 
-export default CustomAppBar;
+export default CustomAppBar;
\ No newline at end of file
diff --git a/rsf-admin/src/layout/Logo.jsx b/rsf-admin/src/layout/Logo.jsx
index f3efa10..8933472 100644
--- a/rsf-admin/src/layout/Logo.jsx
+++ b/rsf-admin/src/layout/Logo.jsx
@@ -12,12 +12,12 @@
             <svg
                 xmlns="http://www.w3.org/2000/svg"
                 xmlSpace="preserve"
-                width={200}
+                width={145}
                 height={30}
                 {...param}
             >
                 <image
-                    width={200}
+                    width={145}
                     height={30}
                     href=""
                 />
@@ -30,12 +30,12 @@
             <svg
                 xmlns="http://www.w3.org/2000/svg"
                 xmlSpace="preserve"
-                width={200}
+                width={145}
                 height={30}
                 {...param}
             >
                 <image
-                    width={200}
+                    width={145}
                     height={30}
                     href=""
                 />
diff --git a/rsf-admin/src/layout/MyMenu.jsx b/rsf-admin/src/layout/MyMenu.jsx
index f671891..9e6b379 100644
--- a/rsf-admin/src/layout/MyMenu.jsx
+++ b/rsf-admin/src/layout/MyMenu.jsx
@@ -59,45 +59,106 @@
     if (IconComponent) {
       return <IconComponent />;
     } else {
-      return <KeyboardArrowDownIcon />
+      return <KeyboardArrowDownIcon />;
     }
   };
 
-  const generateMenu = (permissions) => {
-    return permissions.map((node) => {
-      if (node.children) {
-        return (
-          <SubMenu
-            key={node.id}
-            handleToggle={() => handleToggle(node.route)}
-            isOpen={state[node.route]}
-            name={node.name}
-            dense={dense}
-            icon={getIcon(node.icon)}
-          >
-            {generateMenu(node.children)}
-          </SubMenu>
-        );
-      } else {
-        if (node.component) {
-          return (
-            <MenuItemLink
-              key={node.id}
-              to={node.component} // correspond to Resource.name
-              state={{ _scrollToTop: true }}
-              // primaryText={translate(`resources.orders.name`, {
-              //     smart_count: 2,
-              // })}
-              primaryText={node.name}
-              leftIcon={getIcon(node.icon)}
-              dense={dense}
-              // sx={{ '& .RaMenuItemLink-icon': { visibility: 'hidden' } }}
-            />
-          );
-        }
+  // 妫�鏌ヨ彍鍗曟槸鍚﹁閫変腑
+  const isSelected = (component) => {
+    if (!component) return false;
+    const currentPath = location.pathname.replace("/", "");
+    return currentPath === component;
+  };
+
+  // 妫�鏌ョ埗绾ц彍鍗曟槸鍚︽湁瀛愯彍鍗曡閫変腑
+  const hasSelectedChild = (node) => {
+    if (!node.children) return false;
+    return node.children.some(child => {
+      if (child.children) {
+        return hasSelectedChild(child);
       }
+      return isSelected(child.component);
     });
   };
+
+  // 鍦� MyMenu 缁勪欢鐨� generateMenu 鍑芥暟涓紝纭繚 MenuItemLink 涔熷乏瀵归綈
+  const generateMenu = (permissions) => {
+    return permissions.map((node) => {
+        if (node.children) {
+            const selected = isSelected(node.component) || hasSelectedChild(node);
+            return (
+                <SubMenu
+                    key={node.id}
+                    handleToggle={() => handleToggle(node.route)}
+                    isOpen={state[node.route]}
+                    name={node.name}
+                    dense={dense}
+                    icon={getIcon(node.icon)}
+                    isSelected={selected}
+                >
+                    {generateMenu(node.children)}
+                </SubMenu>
+            );
+        } else {
+            if (node.component) {
+                const selected = isSelected(node.component);
+                // 鍦� generateMenu 鍑芥暟涓殑 MenuItemLink 閮ㄥ垎
+                return (
+                    <MenuItemLink
+                        key={node.id}
+                        to={node.component}
+                        state={{ _scrollToTop: true }}
+                        primaryText={translate(node.name)}
+                        leftIcon={getIcon(node.icon)}
+                        dense={dense}
+                        sx={{
+                            backgroundColor: selected ? 'rgba(25, 118, 210, 0.08) !important' : 'transparent',
+                            color: selected ? '#1976d2 !important' : 'text.secondary',
+                            '&:hover': {
+                                backgroundColor: selected ? 'rgba(25, 118, 210, 0.12) !important' : 'rgba(0, 0, 0, 0.04)',
+                            },
+                            borderLeft: 'none',
+                            borderRadius: '4px',
+                            margin: '2px 8px',
+                            width: 'calc(100% - 16px)',
+                            transition: 'all 0.2s ease-in-out',
+                            
+                            // 缂╁皬鏁翠綋闂磋窛
+                            padding: '6px 8px', // 鍑忓皯鍐呰竟璺�
+                            minHeight: '36px', // 绋嶅井鍑忓皬楂樺害
+                            
+                            '& .RaMenuItemLink-icon': {
+                                color: selected ? '#1976d2 !important' : 'text.secondary',
+                                minWidth: '32px !important', // 缂╁皬鍥炬爣鍖哄煙瀹藉害
+                                marginRight: '4px', // 缂╁皬鍥炬爣鍜屾枃瀛楅棿璺�
+                                display: 'flex',
+                                alignItems: 'center',
+                                justifyContent: 'center', // 鍥炬爣灞呬腑鏄剧ず
+                            },
+                            
+                            fontWeight: selected ? 600 : 400,
+                            
+                            // 纭繚鏂囧瓧鍐呭宸﹀榻�
+                            '& .MuiListItemText-root': {
+                                margin: 0,
+                                '& .MuiTypography-root': {
+                                    textAlign: 'left',
+                                    justifyContent: 'flex-start',
+                                    fontSize: '0.875rem', // 绋嶅井鍑忓皬瀛椾綋澶у皬
+                                    lineHeight: '1.3',
+                                }
+                            },
+                        }}
+                    />
+                );
+            }
+        }
+    });
+  };
+
+  // 妫�鏌ュ浐瀹氳彍鍗曟槸鍚﹂�変腑
+  const isDashboardSelected = location.pathname === '/dashboard';
+  const isSettingsSelected = location.pathname === '/settings';
 
   return isPending ? (
     <div>Waiting for permissions...</div>
@@ -112,19 +173,54 @@
             easing: theme.transitions.easing.sharp,
             duration: theme.transitions.duration.leavingScreen,
           }),
+        // 鑿滃崟瀹瑰櫒鏍峰紡
+        '& .MuiMenuItem-root': {
+          boxSizing: 'border-box',
+        }
       }}
     >
       <Menu.Item
         to="/dashboard"
         primaryText="menu.dashboard"
         leftIcon={<DashboardIcon />}
+        sx={{
+          backgroundColor: isDashboardSelected ? 'rgba(25, 118, 210, 0.08) !important' : 'transparent',
+          color: isDashboardSelected ? '#1976d2 !important' : 'text.secondary',
+          '&:hover': {
+            backgroundColor: isDashboardSelected ? 'rgba(25, 118, 210, 0.12) !important' : 'rgba(0, 0, 0, 0.04)',
+          },
+          borderLeft: isDashboardSelected ? '3px solid #1976d2' : '3px solid transparent',
+          borderRadius: '0 4px 4px 0',
+          margin: '1px 0',
+          width: '100%',
+          transition: 'all 0.2s ease-in-out',
+          '& .MuiListItemIcon-root': {
+            color: isDashboardSelected ? '#1976d2 !important' : 'text.secondary',
+            minWidth: 40,
+          }
+        }}
       />
       {permissions && generateMenu(permissions)}
-      {/* <Menu.ResourceItems /> */}
       <Menu.Item
         to="/settings"
         primaryText="menu.settings"
         leftIcon={<PersonIcon />}
+        sx={{
+          backgroundColor: isSettingsSelected ? 'rgba(25, 118, 210, 0.08) !important' : 'transparent',
+          color: isSettingsSelected ? '#1976d2 !important' : 'text.secondary',
+          '&:hover': {
+            backgroundColor: isSettingsSelected ? 'rgba(25, 118, 210, 0.12) !important' : 'rgba(0, 0, 0, 0.04)',
+          },
+          borderLeft: isSettingsSelected ? '3px solid #1976d2' : '3px solid transparent',
+          borderRadius: '0 4px 4px 0',
+          margin: '1px 0',
+          width: '100%',
+          transition: 'all 0.2s ease-in-out',
+          '& .MuiListItemIcon-root': {
+            color: isSettingsSelected ? '#1976d2 !important' : 'text.secondary',
+            minWidth: 40,
+          }
+        }}
       />
     </Box>
   );
@@ -173,4 +269,4 @@
   }
 
   return [];
-};
+};
\ No newline at end of file
diff --git a/rsf-admin/src/layout/SubMenu.jsx b/rsf-admin/src/layout/SubMenu.jsx
index a0e937e..7296516 100644
--- a/rsf-admin/src/layout/SubMenu.jsx
+++ b/rsf-admin/src/layout/SubMenu.jsx
@@ -9,33 +9,104 @@
     Collapse,
     Tooltip,
 } from '@mui/material';
-import ExpandMore from '@mui/icons-material/ExpandMore';
 import { useTranslate, useSidebarState } from 'react-admin';
 import KeyboardArrowDownIcon from '@mui/icons-material/KeyboardArrowDown';
 import KeyboardArrowRightIcon from '@mui/icons-material/KeyboardArrowRight';
+
 const SubMenu = (props) => {
-    const { handleToggle, isOpen, name, icon, children, dense } = props;
+    const { handleToggle, isOpen, name, icon, children, dense, isSelected = false } = props;
     const translate = useTranslate();
     const [sidebarIsOpen] = useSidebarState();
 
     const header = (
-       <MenuItem dense={dense} onClick={handleToggle} sx={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>
-            <Box sx={{ display: 'flex', alignItems: 'center', flex: 1 }}>
-                <ListItemIcon sx={{ minWidth: 40, color: 'text.secondary', display: 'flex', alignItems: 'center' }}>
+        <MenuItem 
+            dense={dense} 
+            onClick={handleToggle} 
+            sx={{ 
+                display: 'flex', 
+                alignItems: 'center', 
+                justifyContent: 'space-between',
+                backgroundColor: isSelected ? 'rgba(25, 118, 210, 0.08) !important' : 'transparent',
+                color: isSelected ? '#1976d2 !important' : 'text.secondary',
+                '&:hover': {
+                    backgroundColor: isSelected ? 'rgba(25, 118, 210, 0.12) !important' : 'rgba(0, 0, 0, 0.04)',
+                },
+                borderLeft: 'none',
+                borderRadius: '4px',
+                margin: '2px 6px',
+                width: 'calc(100% - 16px)',
+                transition: 'all 0.2s ease-in-out',
+                boxSizing: 'border-box',
+                minHeight: '40px',
+                padding: '8px 12px',
+                
+                // 纭繚鍐呭鍖哄煙瀹屽叏宸﹀榻�
+                '& .MuiMenuItem-root': {
+                    justifyContent: 'flex-start',
+                }
+            }}
+        >
+            <Box sx={{ 
+                display: 'flex', 
+                alignItems: 'center', 
+                flex: 1,
+                justifyContent: 'flex-start',
+                minWidth: 0,
+                // 纭繚鍥炬爣鍜屾枃瀛楃揣瀵嗗榻�
+                gap: '8px',
+            }}>
+                <ListItemIcon sx={{ 
+                    minWidth: '32px !important', // 绋嶅井鍑忓皬鍥炬爣鍖哄煙瀹藉害
+                    color: isSelected ? '#1976d2 !important' : 'text.secondary',
+                    display: 'flex', 
+                    alignItems: 'center',
+                    justifyContent: 'flex-start',
+                    margin: 0, // 绉婚櫎margin
+                    flexShrink: 0,
+                }}>
                     {icon}
                 </ListItemIcon>
-                <Typography variant="inherit" color="textSecondary" sx={{ ml: 1, display: 'flex', alignItems: 'center' }}>
-                    {translate(name)}
-                </Typography>
+                {sidebarIsOpen && (
+                    <Typography 
+                        variant="inherit" 
+                        sx={{ 
+                            color: isSelected ? '#1976d2 !important' : 'text.secondary',
+                            fontWeight: isSelected ? 600 : 400,
+                            flex: 1,
+                            minWidth: 0,
+                            overflow: 'hidden',
+                            textOverflow: 'ellipsis',
+                            whiteSpace: 'nowrap',
+                            textAlign: 'left',
+                            lineHeight: '1.5',
+                        }}
+                    >
+                        {translate(name)}
+                    </Typography>
+                )}
             </Box>
-            <Box sx={{ display: 'flex', alignItems: 'center', minWidth: 24 }}>
-                {isOpen ? <KeyboardArrowDownIcon fontSize="small" sx={{color: 'text.secondary'}} /> : <KeyboardArrowRightIcon fontSize="small" sx={{color: 'text.secondary'}} />}
-            </Box>
+            
+            {/* 绠ご鍥炬爣 */}
+            {sidebarIsOpen && (
+                <Box sx={{ 
+                    display: 'flex', 
+                    alignItems: 'center', 
+                    minWidth: '20px',
+                    justifyContent: 'flex-end',
+                    flexShrink: 0,
+                    marginLeft: '8px',
+                }}>
+                    {isOpen ? 
+                        <KeyboardArrowDownIcon fontSize="small" sx={{color: isSelected ? '#1976d2 !important' : 'text.secondary'}} /> : 
+                        <KeyboardArrowRightIcon fontSize="small" sx={{color: isSelected ? '#1976d2 !important' : 'text.secondary'}} />
+                    }
+                </Box>
+            )}
         </MenuItem>
     );
 
     return (
-        <div>
+        <Box sx={{ width: '100%' }}>
             {sidebarIsOpen || isOpen ? (
                 header
             ) : (
@@ -48,27 +119,18 @@
                     dense={dense}
                     component="div"
                     disablePadding
-                    // sx={{
-                    //     '& .MuiMenuItem-root': {
-                    //         transition:
-                    //             'padding-left 195ms cubic-bezier(0.4, 0, 0.6, 1) 0ms',
-                    //         paddingLeft: theme =>
-                    //             sidebarIsOpen
-                    //                 ? theme.spacing(4)
-                    //                 : theme.spacing(2),
-                    //     },
-                    //     // 鏄剧ず浜岀骇鑿滃崟鐨刬con
-                    //     '& .RaMenuItemLink-icon': {
-                    //         visibility: 'visible !important',
-                    //         minWidth: '24px'
-                    //     }
-                    // }}
+                    sx={{
+                        paddingLeft: 2,
+                        '& .MuiMenuItem-root': {
+                            paddingLeft: 3,
+                        },
+                    }}
                 >
                     {children}
                 </List>
             </Collapse>
-        </div>
+        </Box>
     );
 };
 
-export default SubMenu;
+export default SubMenu;
\ No newline at end of file
diff --git a/rsf-admin/src/page/ResourceContent.js b/rsf-admin/src/page/ResourceContent.js
index 5b835c3..f9764f6 100644
--- a/rsf-admin/src/page/ResourceContent.js
+++ b/rsf-admin/src/page/ResourceContent.js
@@ -63,6 +63,7 @@
 import outStatisticItem from './statistics/outStockItem';
 import inStatisticItem from './statistics/inStockItem';
 import statisticCount from './statistics/stockStatisticNum';
+import preparation from "./orders/preparation";
 
 const ResourceContent = (node) => {
   switch (node.component) {
@@ -184,6 +185,8 @@
       return inStatisticItem;
     case "statisticCount":
       return statisticCount;
+    case "preparation":
+      return preparation;
     default:
       return {
         list: ListGuesser,
diff --git a/rsf-admin/src/page/basicInfo/companys/CompanysList.jsx b/rsf-admin/src/page/basicInfo/companys/CompanysList.jsx
index 069abe4..46178ae 100644
--- a/rsf-admin/src/page/basicInfo/companys/CompanysList.jsx
+++ b/rsf-admin/src/page/basicInfo/companys/CompanysList.jsx
@@ -134,15 +134,14 @@
                     preferenceKey='companys'
                     bulkActionButtons={() => <BulkDeleteButton mutationMode={OPERATE_MODE} />}
                     rowClick={(id, resource, record) => false}
-                    omit={['id', 'createTime', 'createBy', 'memo','createBy$','updateBy$','statusBool','province','city','address']}
+                    omit={['id', 'nameEn', 'contact', 'tel', 'email', 'pcode', 'createTime', 'createBy', 'memo','createBy$','updateBy$', 'updateTime','statusBool','province','city','address']}
                 >
                     <NumberField source="id" />
                     <TextField source="code" label="table.field.companys.code" />
-                    <TextField source="name" label="table.field.companys.name" />
-                    
+                    <TextField source="name" label="table.field.companys.name" />                    
                     <TextField source="nameEn" label="table.field.companys.nameEn" />
                     <TextField source="breifCode" label="table.field.companys.breifCode" />
-                    <DictField source="type" label="table.field.companys.type" dictTypeCode={'sys_companys_type'} />
+                    {/* <DictField source="type" label="table.field.companys.type" dictTypeCode={'sys_companys_type'} /> */}
                     <TextField source="contact" label="table.field.companys.contact" />
                     <TextField source="tel" label="table.field.companys.tel" />
                     <TextField source="email" label="table.field.companys.email" />
diff --git a/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx b/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx
index 78c34a1..ef49214 100644
--- a/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx
+++ b/rsf-admin/src/page/basicInfo/matnr/MatnrList.jsx
@@ -171,38 +171,38 @@
                     <NumberField key="id" source="id" />,
                     <TextField key="code" source="code" label="table.field.matnr.code" />,
                     <TooltipField key="name" source="name" label="table.field.matnr.name" cellClassName="name" />,                    
-                    <TextField key="shipperId$" source="shipperId$" label="table.field.matnr.shipperId" />,
+                    // <TextField key="shipperId$" source="shipperId$" label="table.field.matnr.shipperId" />,
                     <ReferenceField key="groupId" source="groupId" label="table.field.matnr.groupId" reference="matnrGroup" link={false} sortable={false}>
                         <TextField source="name" />
                     </ReferenceField>,
-                    <TextField key="platCode" source="platCode" label="table.field.matnr.platCode" />,
+                    // <TextField key="platCode" source="platCode" label="table.field.matnr.platCode" />,
                     <TextField key="spec" source="spec" label="table.field.matnr.spec" />,
                     <TextField key="model" source="model" label="table.field.matnr.model" />,
-                    <NumberField key="weight" source="weight" label="table.field.matnr.weight" />,
-                    <TextField key="describle" source="describle" label="table.field.matnr.describle" />,
-                    <NumberField key="nromNum" source="nromNum" label="table.field.matnr.nromNum" />,
+                    // <NumberField key="weight" source="weight" label="table.field.matnr.weight" />,
+                    // <TextField key="describle" source="describle" label="table.field.matnr.describle" />,
+                    // <NumberField key="nromNum" source="nromNum" label="table.field.matnr.nromNum" />,
                     <TextField key="unit" source="unit" label="table.field.matnr.unit" />,
-                    <TextField key="purchaseUnit" source="purchaseUnit" label="table.field.matnr.purUnit" />,
+                    // <TextField key="purchaseUnit" source="purchaseUnit" label="table.field.matnr.purUnit" />,
                     <TextField key="stockUnit" source="stockUnit" label="table.field.matnr.stockUnit" />,
-                    <TextField key="stockLeval$" source="stockLeval$" label="table.field.matnr.stockLevel" sortable={false} />,
-                    <TextField key="flagLabelMange$" source="flagLabelMange$" label="table.field.matnr.isLabelMange" sortable={false} />,
-                    <NumberField key="safeQty" source="safeQty" label="table.field.matnr.safeQty" />,
-                    <NumberField key="minQty" source="minQty" label="table.field.matnr.minQty" />,
-                    <NumberField key="maxQty" source="maxQty" label="table.field.matnr.maxQty" />,
-                    <NumberField key="stagn" source="stagn" label="table.field.matnr.stagn" />,
-                    <NumberField key="valid" source="valid" label="table.field.matnr.valid" />,
-                    <NumberField key="validWarn" source="validWarn" label="table.field.matnr.validWarn" />,
-                    <BooleanField key="flagCheck" source="flagCheck" label="table.field.matnr.flagCheck" sortable={false} />,
-                    <ReferenceField key="updateBy" source="updateBy" label="common.field.updateBy" reference="user" link={false} sortable={false}>
-                        <TextField source="nickname" />
-                    </ReferenceField>,
-                    <DateField key="updateTime" source="updateTime" label="common.field.updateTime" showTime />,
-                    <ReferenceField key="createBy" source="createBy" label="common.field.createBy" reference="user" link={false} sortable={false}>
-                        <TextField source="nickname" />
-                    </ReferenceField>,
-                    <DateField key="createTime" source="createTime" label="common.field.createTime" showTime />,
+                    // <TextField key="stockLeval$" source="stockLeval$" label="table.field.matnr.stockLevel" sortable={false} />,
+                    // <TextField key="flagLabelMange$" source="flagLabelMange$" label="table.field.matnr.isLabelMange" sortable={false} />,
+                    // <NumberField key="safeQty" source="safeQty" label="table.field.matnr.safeQty" />,
+                    // <NumberField key="minQty" source="minQty" label="table.field.matnr.minQty" />,
+                    // <NumberField key="maxQty" source="maxQty" label="table.field.matnr.maxQty" />,
+                    // <NumberField key="stagn" source="stagn" label="table.field.matnr.stagn" />,
+                    // <NumberField key="valid" source="valid" label="table.field.matnr.valid" />,
+                    // <NumberField key="validWarn" source="validWarn" label="table.field.matnr.validWarn" />,
+                    // <BooleanField key="flagCheck" source="flagCheck" label="table.field.matnr.flagCheck" sortable={false} />,
+                    // <ReferenceField key="updateBy" source="updateBy" label="common.field.updateBy" reference="user" link={false} sortable={false}>
+                    //     <TextField source="nickname" />
+                    // </ReferenceField>,
+                    // <DateField key="updateTime" source="updateTime" label="common.field.updateTime" showTime />,
+                    // <ReferenceField key="createBy" source="createBy" label="common.field.createBy" reference="user" link={false} sortable={false}>
+                    //     <TextField source="nickname" />
+                    // </ReferenceField>,
+                    // <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} />,
+                    // <TextField key="memo" source="memo" label="common.field.memo" sortable={false} />,
                 ]
                 const fields = data.map(el => <TextField key={el.fields} source={`extendFields.[${el.fields}]`} label={el.fieldsAlise} />)
                 const opt = <WrapperField key="opt" cellClassName="fixed" className="fixed" label="common.field.opt">
diff --git a/rsf-admin/src/page/basicInfo/matnrGroup/MatnrGroupList.jsx b/rsf-admin/src/page/basicInfo/matnrGroup/MatnrGroupList.jsx
index 74b125e..93a152c 100644
--- a/rsf-admin/src/page/basicInfo/matnrGroup/MatnrGroupList.jsx
+++ b/rsf-admin/src/page/basicInfo/matnrGroup/MatnrGroupList.jsx
@@ -50,11 +50,11 @@
         label: 'table.field.matnrGroup.name',
         Width: 100,
     },
-    {
-        id: 'parentId',
-        label: 'table.field.matnrGroup.parentId',
-        minWidth: 100,
-    }
+    // {
+    //     id: 'parCode',
+    //     label: 'table.field.matnrGroup.parCode',
+    //     minWidth: 100,
+    // }
 ];
 
 const getIconComponent = (iconStr) => {
diff --git a/rsf-admin/src/page/basicInfo/warehouse/WarehouseList.jsx b/rsf-admin/src/page/basicInfo/warehouse/WarehouseList.jsx
index f16724d..2a73389 100644
--- a/rsf-admin/src/page/basicInfo/warehouse/WarehouseList.jsx
+++ b/rsf-admin/src/page/basicInfo/warehouse/WarehouseList.jsx
@@ -129,13 +129,13 @@
                     preferenceKey='warehouse'
                     bulkActionButtons={() => <BulkDeleteButton mutationMode={OPERATE_MODE} />}
                     rowClick={(id, resource, record) => false} 
-                    omit={['id', 'createTime', 'createBy', 'memo', 'longitude', 'latgitude', 'length', 'width', 'height']}
+                    omit={['id', 'factory', 'createTime', 'createBy', 'memo', 'longitude', 'latgitude', 'length', 'width', 'height']}
                 >
                     <NumberField source="id" />
-                    <TextField source="factory" label="table.field.warehouse.factory" />
-                    <TextField source="name" label="table.field.warehouse.name" />
                     <TextField source="code" label="table.field.warehouse.code" />
+                    <TextField source="name" label="table.field.warehouse.name" />
                     <TextField source="address" label="table.field.warehouse.address" />
+                    <TextField source="factory" label="table.field.warehouse.factory" />
                     <TextField source="longitude" label="table.field.warehouse.longitude" />
                     <TextField source="latgitude" label="table.field.warehouse.latgitude" />
                     <NumberField source="length" label="table.field.warehouse.length" />
diff --git a/rsf-admin/src/page/dashboard/NbCard.jsx b/rsf-admin/src/page/dashboard/NbCard.jsx
index 80c8772..b1f1ac4 100644
--- a/rsf-admin/src/page/dashboard/NbCard.jsx
+++ b/rsf-admin/src/page/dashboard/NbCard.jsx
@@ -25,74 +25,329 @@
 const NbCard = (props) => {
     const { tasks, total, ...rset } = props;
     const translate = useTranslate();
+    
+    // 鐘舵�佺鐞嗗睆骞曢珮搴�
+    const [screenHeight, setScreenHeight] = React.useState(window.innerHeight);
+    const [containerHeight, setContainerHeight] = React.useState('100vh');
 
-    const display = 'display';
+    // 鐩戝惉绐楀彛澶у皬鍙樺寲
+    React.useEffect(() => {
+        const handleResize = () => {
+            setScreenHeight(window.innerHeight);
+        };
+
+        window.addEventListener('resize', handleResize);
+        
+        // 璁$畻瀹瑰櫒楂樺害锛堝噺鍘诲彲鑳界殑澶撮儴瀵艰埅鏍忛珮搴︼級
+        const calculateContainerHeight = () => {
+            const headerHeight = 64; // 鍋囪澶撮儴瀵艰埅鏍忛珮搴︿负64px
+            const padding = 16; // 涓婁笅杈硅窛
+            return `calc(${screenHeight}px - ${headerHeight + padding * 2}px)`;
+        };
+        
+        setContainerHeight(calculateContainerHeight());
+
+        return () => {
+            window.removeEventListener('resize', handleResize);
+        };
+    }, [screenHeight]);
 
     return (
-        <>
+        <Box sx={{
+            height: containerHeight, // 鍔ㄦ�佽绠楃殑楂樺害
+            maxHeight: 690, //containerHeight,
+            display: 'flex',
+            flexDirection: 'column',
+            minHeight: '400px', // 鏈�灏忛珮搴︿繚璇�
+            // overflowY: 'auto'
+        }}>
             <CardWithIcon
                 icon={CommentIcon}
                 title={translate('page.dashboard.pending_reviews')}
                 subtitle={total}
                 {...rset}
+                sx={{
+                    flex: 1,
+                    display: 'flex',
+                    flexDirection: 'column',
+                    height: '100%',
+                    minHeight: 0,
+                }}
             >
-                <List sx={{ display }}>
-                    {tasks?.map((record) => (
-                        <ListItem key={record.id} disablePadding>
-                            <ListItemButton
-                                alignItems="flex-start"
-                                component={Link}
-                                to={`/task/${record.id}`}
-                            >
-                                <Grid container item md={12}>
-                                    <Box sx={{ display: 'flex' }}>
-                                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                                            <Typography color="textSecondary">{translate("table.field.task.taskCode")}锛�</Typography>
-                                            <Typography color="textSecondary">{record?.taskCode}</Typography>
-                                        </Box>
-                                    </Box>
-                                    <Box sx={{ display: 'flex' }}>
-                                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                                            <Typography color="textSecondary">{translate("table.field.task.taskType")}锛�</Typography>
-                                            <Typography color="textSecondary" maxWidth="200" overflow="hidden">{record?.taskType$}</Typography>
-                                        </Box>
-                                    </Box>
-                                    <Box sx={{ display: 'flex' }}>
-                                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                                            <Typography color="textSecondary">{translate("table.field.task.taskStatus")}锛�</Typography>
-                                            <Typography color="textSecondary">{record?.taskStatus$}</Typography>
-                                        </Box>
-                                    </Box>
-                                    <Box sx={{ display: 'flex' }}>
-                                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                                            <Typography color="textSecondary">{translate("table.field.task.startTime")}锛�</Typography>
-                                            <Typography color="textSecondary">{record?.createTime}</Typography>
-                                        </Box>
-                                    </Box>
-                                </Grid>
-                            </ListItemButton>
-                            <Spacer />
-                        </ListItem>
-                    ))}
-                </List>
-                <Box flexGrow={1}>&nbsp;</Box>
-                {/* <Button
-                    sx={{ borderRadius: 0 }}
-                    component={Link}
-                    to="/task"
-                    size="small"
-                    color="primary"
-                >
-                    <Box p={1} sx={{ color: 'primary.main' }}>
-                        {translate('pos.dashboard.all_reviews')}
+                {/* 鍐呭瀹瑰櫒 - 鑷�傚簲楂樺害 */}
+                <Box sx={{ 
+                    flex: 1,
+                    display: 'flex',
+                    flexDirection: 'column',
+                    minHeight: 0,
+                    height: '100%',
+                }}>
+                    {/* 鍒楄〃鍖哄煙 - 鑷姩婊氬姩 */}
+                    <Box sx={{
+                        flex: 1,
+                        overflow: 'auto',
+                        minHeight: 0,
+                        '&::-webkit-scrollbar': {
+                            width: '6px',
+                        },
+                        '&::-webkit-scrollbar-track': {
+                            background: 'transparent',
+                        },
+                        '&::-webkit-scrollbar-thumb': {
+                            background: '#ccc',
+                            borderRadius: '3px',
+                            '&:hover': {
+                                background: '#aaa',
+                            }
+                        }
+                    }}>
+                        <List sx={{ py: 0, minHeight: 'min-content' }}>
+                            {tasks?.length > 0 ? (
+                                tasks.map((record) => (
+                                    <ListItem 
+                                        key={record.id} 
+                                        disablePadding
+                                        sx={{
+                                            borderBottom: '1px solid',
+                                            borderColor: 'divider',
+                                            '&:last-child': {
+                                                borderBottom: 'none',
+                                            }
+                                        }}
+                                    >
+                                        <ListItemButton
+                                            component={Link}
+                                            to={`/task/${record.id}`}
+                                            sx={{
+                                                py: 1.5,
+                                                px: 2,
+                                                '&:hover': {
+                                                    backgroundColor: 'action.hover',
+                                                }
+                                            }}
+                                        >
+                                            <Grid container spacing={1}>
+                                                {/* 绗竴琛岋細浠诲姟缂栫爜鍜岀被鍨� */}
+                                                <Grid item xs={12} sx={{ display: 'flex', alignItems: 'center' }}>
+                                                    <Box sx={{ 
+                                                        display: 'flex', 
+                                                        alignItems: 'center', 
+                                                        minWidth: 0, 
+                                                        flex: 1,
+                                                        mr: 2
+                                                    }}>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                fontWeight: 600,
+                                                                color: 'primary.main',
+                                                                minWidth: '80px',
+                                                                flexShrink: 0,
+                                                            }}
+                                                        >
+                                                            {translate("table.field.task.taskCode")}锛�
+                                                        </Typography>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                color: 'text.primary',
+                                                                fontWeight: 500,
+                                                                overflow: 'hidden',
+                                                                textOverflow: 'ellipsis',
+                                                                whiteSpace: 'nowrap',
+                                                            }}
+                                                        >
+                                                            {record?.taskCode}
+                                                        </Typography>
+                                                    </Box>
+                                                    
+                                                    <Box sx={{ 
+                                                        display: 'flex', 
+                                                        alignItems: 'center', 
+                                                        minWidth: 0, 
+                                                        flex: 1
+                                                    }}>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                fontWeight: 600,
+                                                                color: 'primary.main',
+                                                                minWidth: '80px',
+                                                                flexShrink: 0,
+                                                            }}
+                                                        >
+                                                            {translate("table.field.task.taskType")}锛�
+                                                        </Typography>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                color: 'text.primary',
+                                                                overflow: 'hidden',
+                                                                textOverflow: 'ellipsis',
+                                                                whiteSpace: 'nowrap',
+                                                            }}
+                                                            title={record?.taskType$}
+                                                        >
+                                                            {record?.taskType$}
+                                                        </Typography>
+                                                    </Box>
+                                                </Grid>
+
+                                                {/* 绗簩琛岋細鐘舵�佸拰鏃堕棿 */}
+                                                <Grid item xs={12} sx={{ display: 'flex', alignItems: 'center' }}>
+                                                    <Box sx={{ 
+                                                        display: 'flex', 
+                                                        alignItems: 'center', 
+                                                        minWidth: 0, 
+                                                        flex: 1,
+                                                        mr: 2
+                                                    }}>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                fontWeight: 600,
+                                                                color: 'primary.main',
+                                                                minWidth: '80px',
+                                                                flexShrink: 0,
+                                                            }}
+                                                        >
+                                                            {translate("table.field.task.taskStatus")}锛�
+                                                        </Typography>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                color: getStatusColor(record?.taskStatus$),
+                                                                fontWeight: 600,
+                                                                px: 1,
+                                                                py: 0.5,
+                                                                borderRadius: 1,
+                                                                backgroundColor: getStatusBackground(record?.taskStatus$),
+                                                                fontSize: '0.75rem',
+                                                            }}
+                                                        >
+                                                            {record?.taskStatus$}
+                                                        </Typography>
+                                                    </Box>
+                                                    
+                                                    <Box sx={{ 
+                                                        display: 'flex', 
+                                                        alignItems: 'center', 
+                                                        minWidth: 0, 
+                                                        flex: 1
+                                                    }}>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                fontWeight: 600,
+                                                                color: 'primary.main',
+                                                                minWidth: '80px',
+                                                                flexShrink: 0,
+                                                            }}
+                                                        >
+                                                            {translate("table.field.task.startTime")}锛�
+                                                        </Typography>
+                                                        <Typography 
+                                                            variant="body2" 
+                                                            sx={{ 
+                                                                color: 'text.secondary',
+                                                                fontFamily: 'monospace',
+                                                                fontSize: '0.875rem',
+                                                            }}
+                                                        >
+                                                            {formatDateTime(record?.createTime)}
+                                                        </Typography>
+                                                    </Box>
+                                                </Grid>
+                                            </Grid>
+                                        </ListItemButton>
+                                    </ListItem>
+                                ))
+                            ) : (
+                                // 绌虹姸鎬佹彁绀� - 灞呬腑鏄剧ず
+                                <Box sx={{ 
+                                    display: 'flex', 
+                                    alignItems: 'center', 
+                                    justifyContent: 'center', 
+                                    height: '100%',
+                                    minHeight: 120,
+                                    color: 'text.secondary'
+                                }}>
+                                    <Typography variant="body2">
+                                        {translate('common.noData')}
+                                    </Typography>
+                                </Box>
+                            )}
+                        </List>
                     </Box>
-                </Button> */}
+
+                    {/* 搴曢儴鎸夐挳鍖哄煙 - 鍥哄畾鍦ㄥ簳閮� */}
+                    {tasks?.length > 0 && (
+                        <Box sx={{ 
+                            borderTop: '1px solid', 
+                            borderColor: 'divider',
+                            flexShrink: 0,
+                            mt: 'auto',
+                        }}>
+                            <Button
+                                component={Link}
+                                to="/task"
+                                size="small"
+                                color="primary"
+                                fullWidth
+                                sx={{
+                                    borderRadius: 0,
+                                    py: 1,
+                                    fontSize: '0.875rem',
+                                    fontWeight: 500,
+                                }}
+                            >
+                                {translate('pos.dashboard.all_reviews')}
+                            </Button>
+                        </Box>
+                    )}
+                </Box>
             </CardWithIcon>
-        </>
+        </Box>
     );
 };
 
-const Spacer = () => <span style={{ width: '1em', }} />;
+// 鐘舵�侀鑹叉槧灏�
+const getStatusColor = (status) => {
+    const statusMap = {
+        'pending': 'warning.main',
+        'completed': 'success.main',
+        'processing': 'info.main',
+        'cancelled': 'error.main',
+        'failed': 'error.main',
+    };
+    return statusMap[status?.toLowerCase()] || 'text.secondary';
+};
 
+// 鐘舵�佽儗鏅壊
+const getStatusBackground = (status) => {
+    const backgroundMap = {
+        'pending': 'warning.light',
+        'completed': 'success.light',
+        'processing': 'info.light',
+        'cancelled': 'error.light',
+        'failed': 'error.light',
+    };
+    return backgroundMap[status?.toLowerCase()] || 'grey.100';
+};
 
-export default NbCard;
+// 鏍煎紡鍖栨棩鏈熸椂闂�
+const formatDateTime = (dateTime) => {
+    if (!dateTime) return '-';
+    try {
+        return new Date(dateTime).toLocaleDateString('zh-CN', {
+            month: '2-digit',
+            day: '2-digit',
+            hour: '2-digit',
+            minute: '2-digit'
+        });
+    } catch {
+        return dateTime;
+    }
+};
+
+export default NbCard;
\ No newline at end of file
diff --git a/rsf-admin/src/page/dashboard/NbList.jsx b/rsf-admin/src/page/dashboard/NbList.jsx
index 3794797..a2b879b 100644
--- a/rsf-admin/src/page/dashboard/NbList.jsx
+++ b/rsf-admin/src/page/dashboard/NbList.jsx
@@ -21,12 +21,27 @@
     return (
         <Card sx={{
             flex: 1,
+            boxShadow: 2,
+            maxWidth: 598,
+            marginTop: 1
         }}>
-            <CardHeader title={translate('page.dashboard.list.stock')} />
-            <Box sx={{ maxHeight: 500, overflowY: 'auto',}}>
-                <List dense={true}>
+            <CardHeader 
+                title={translate('page.dashboard.list.stock')}
+                sx={{ 
+                    pb: 1,
+                    '& .MuiCardHeader-title': {
+                        fontSize: '1.1rem',
+                        fontWeight: 600,
+                    }
+                }} 
+            />
+            <Box sx={{ maxHeight: 500, overflowY: 'auto' }}>
+                <List dense={true} sx={{ py: 0 }}>
                     {deadStock.map(record => (
-                        <PendingOrder key={`record?.id + ${Math.random().toString(36).substr(2, 9)} `} order={record} />
+                        <PendingOrder 
+                            key={`${record?.id}_${Math.random().toString(36).substr(2, 9)}`} 
+                            order={record} 
+                        />
                     ))}
                 </List>
             </Box>
@@ -37,71 +52,131 @@
 export const PendingOrder = (props) => {
     const { order } = props;
     const translate = useTranslate();
-    // const { referenceRecord: customer, isPending } = useReference({
-    //     reference: 'customers',
-    //     id: order.id,
-    // });
 
     return (
-        <ListItem disablePadding>
-            {/* component={Link} to={`/locItem/${order.id}`} */}
-            <ListItemButton >
-                {/* <ListItemAvatar>
-                    {isPending ? (
-                        <Avatar />
-                    ) : (
-                        <Avatar
-                            src={`${customer?.avatar}?size=32x32`}
-                            sx={{ bgcolor: 'background.paper' }}
-                            alt={`${customer?.first_name} ${customer?.last_name}`}
-                        />
-                    )}
-                </ListItemAvatar> */}
-                {/* <ListItemText
-                    primary={new Date(order.createTime).toLocaleString('en-GB')}
-                    secondary={translate('page.dashboard.list.stock', {
-                        name: order.maktx
-                    })}
-                >
-       
-                </ListItemText> */}
-                <Grid container item md={12}>
-                    <Box sx={{ display: 'flex' }}>
-                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                            <Typography color="textSecondary">{translate("table.field.asnOrderItem.matnrCode")}锛�</Typography>
-                            <Typography color="textSecondary">{order?.matnrCode}</Typography>
+        <ListItem 
+            disablePadding
+            sx={{
+                borderBottom: '1px solid',
+                borderColor: 'divider',
+                '&:last-child': {
+                    borderBottom: 'none',
+                }
+            }}
+        >
+            <ListItemButton 
+                sx={{
+                    py: 1.5,
+                    '&:hover': {
+                        backgroundColor: 'action.hover',
+                    }
+                }}
+            >
+                <Grid container spacing={1}>
+                    {/* 绗竴琛岋細鐗╂枡缂栫爜鍜屽悕绉� */}
+                    <Grid item xs={12} sx={{ display: 'flex', alignItems: 'center' }}>
+                        <Box sx={{ display: 'flex', alignItems: 'center', minWidth: 0, flex: 1 }}>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    fontWeight: 600,
+                                    color: 'primary.main',
+                                    minWidth: '120px',
+                                    flexShrink: 0,
+                                }}
+                            >
+                                {translate("table.field.asnOrderItem.matnrCode")}锛�
+                            </Typography>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    color: 'text.primary',
+                                    overflow: 'hidden',
+                                    textOverflow: 'ellipsis',
+                                    whiteSpace: 'nowrap',
+                                }}
+                            >
+                                {order?.matnrCode}
+                            </Typography>
                         </Box>
-                    </Box>
-                    <Box sx={{ display: 'flex' }}>
-                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                            <Typography color="textSecondary">{translate("table.field.asnOrderItem.maktx")}锛�</Typography>
-                            <Typography color="textSecondary" maxWidth="200" overflow="hidden">{order?.maktx}</Typography>
+                        
+                        <Box sx={{ display: 'flex', alignItems: 'center', minWidth: 0, flex: 1 }}>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    fontWeight: 600,
+                                    color: 'primary.main',
+                                    minWidth: '80px',
+                                    flexShrink: 0,
+                                }}
+                            >
+                                {translate("table.field.asnOrderItem.maktx")}锛�
+                            </Typography>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    color: 'text.primary',
+                                    overflow: 'hidden',
+                                    textOverflow: 'ellipsis',
+                                    whiteSpace: 'nowrap',
+                                }}
+                                title={order?.maktx} // 娣诲姞title鎻愮ず瀹屾暣鍐呭
+                            >
+                                {order?.maktx}
+                            </Typography>
                         </Box>
-                    </Box>
-                    <Box sx={{ display: 'flex' }}>
-                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                            <Typography color="textSecondary">{translate("table.field.asnOrderItem.anfme")}锛�</Typography>
-                            <Typography color="textSecondary">{order?.anfme}</Typography>
+                    </Grid>
+
+                    {/* 绗簩琛岋細鏁伴噺鍜屾棩鏈� */}
+                    <Grid item xs={12} sx={{ display: 'flex', alignItems: 'center' }}>
+                        <Box sx={{ display: 'flex', alignItems: 'center', minWidth: 0, flex: 1 }}>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    fontWeight: 600,
+                                    color: 'primary.main',
+                                    minWidth: '120px',
+                                    flexShrink: 0,
+                                }}
+                            >
+                                {translate("table.field.asnOrderItem.anfme")}锛�
+                            </Typography>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    color: 'text.primary',
+                                    fontWeight: 500,
+                                }}
+                            >
+                                {order?.anfme}
+                            </Typography>
                         </Box>
-                    </Box>
-                    <Box sx={{ display: 'flex' }}>
-                        <Box sx={{ display: 'flex', padding: '1em' }}>
-                            <Typography color="textSecondary">{translate("table.field.locItem.deadTime")}锛�</Typography>
-                            <Typography color="textSecondary">{order?.deadTime}</Typography>
+                        
+                        <Box sx={{ display: 'flex', alignItems: 'center', minWidth: 0, flex: 1 }}>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    fontWeight: 600,
+                                    color: 'primary.main',
+                                    minWidth: '120px',
+                                    flexShrink: 0,
+                                }}
+                            >
+                                {translate("table.field.locItem.deadTime")}锛�
+                            </Typography>
+                            <Typography 
+                                variant="body2" 
+                                sx={{ 
+                                    color: order?.deadTime ? 'error.main' : 'text.secondary',
+                                    fontWeight: order?.deadTime ? 600 : 400,
+                                    fontFamily: 'monospace',
+                                }}
+                            >
+                                {order?.deadTime || '-'}
+                            </Typography>
                         </Box>
-                    </Box>
+                    </Grid>
                 </Grid>
-                {/* <ListItemSecondaryAction>
-                    <Box
-                        component="span"
-                        sx={{
-                            marginRight: '1em',
-                            color: 'text.primary',
-                        }}
-                    >
-                        {order.deadTime}
-                    </Box>
-                </ListItemSecondaryAction> */}
             </ListItemButton>
         </ListItem>
     );
diff --git a/rsf-admin/src/page/dashboard/NbPie.jsx b/rsf-admin/src/page/dashboard/NbPie.jsx
index c614e70..e973ad9 100644
--- a/rsf-admin/src/page/dashboard/NbPie.jsx
+++ b/rsf-admin/src/page/dashboard/NbPie.jsx
@@ -13,7 +13,9 @@
         <>
             <Card sx={{
                 width: '100%',
+                maxWidth: 598,
                 maxHeight: 570,
+                marginTop: 1,
                 flexDirection: 'column',
                 flex: '1',
                 '& a': {
diff --git a/rsf-admin/src/page/orders/asnOrder/AsnOrderItemList.jsx b/rsf-admin/src/page/orders/asnOrder/AsnOrderItemList.jsx
index 070c3a7..0edff6f 100644
--- a/rsf-admin/src/page/orders/asnOrder/AsnOrderItemList.jsx
+++ b/rsf-admin/src/page/orders/asnOrder/AsnOrderItemList.jsx
@@ -201,6 +201,11 @@
         <TextField source="qrcode" label="table.field.asnOrderItem.qrcode" />,
         <TextField source="trackCode" label="table.field.asnOrderItem.barcode" />,
         <TextField source="packName" label="table.field.asnOrderItem.packName" />,
+
+        // 閾跺骇鏂板
+        <TextField source="trackCode" label="浠撳簱" />,
+        <TextField source="trackCode" label="琛屽唴鍙�" />,
+        <TextField source="packName" label="璁″垝璺熻釜鍙�" />,
       ]
       const fields = data.map(el => <TextField key={el.fields} source={`extendFields.[${el.fields}]`} label={el.fieldsAlise} />)
       const lastArr = [
@@ -238,7 +243,7 @@
           preferenceKey='asnOrderItem'
           bulkActionButtons={false}
           rowClick={(id, resource, record) => false}
-          omit={['id', 'orderId', 'orderCode', 'poDetlId', 'poDetlCode', 'matnrId', 'spec', 'model', 'purQty', 'purUnit', 'qrcode', 'trackCode', 'splrCode', 'platWorkCode', 'projectCode']}
+          omit={['id', 'orderId', 'orderCode', 'poDetlId', 'matnrId', 'spec', 'model', 'purQty', 'purUnit', 'qrcode', 'trackCode', 'splrCode', 'platWorkCode', 'projectCode']}
         >
           {columns.map((column) => column)}
         </StyledDatagrid>}
diff --git a/rsf-admin/src/page/orders/asnOrder/AsnOrderList.jsx b/rsf-admin/src/page/orders/asnOrder/AsnOrderList.jsx
index 11ed2a0..3f38817 100644
--- a/rsf-admin/src/page/orders/asnOrder/AsnOrderList.jsx
+++ b/rsf-admin/src/page/orders/asnOrder/AsnOrderList.jsx
@@ -158,16 +158,24 @@
             </>}
           rowClick={false}
           expandSingle={true}
-          omit={['id', 'createTime', 'createBy', 'memo', 'logisNo', 'poId', 'rleStatus$', 'createBy$']}
+          omit={['id', 'code', 'poId', 'arrTime', 'createTime', 'createBy', 'memo', 'logisNo', 'updateBy$', 'updateTime', 'rleStatus$', 'createBy$']}
         >
           <NumberField source="id" />
-          <TextField source="code" label="table.field.asnOrder.code" />
+          {/* <TextField source="code" label="table.field.asnOrder.code" /> */}
           <TextField source="poCode" label="table.field.asnOrder.poCode" />
           <NumberField source="poId" label="table.field.asnOrder.poId" />
           <TextField source="type$" label="table.field.asnOrder.type" />
           <TextField cellClassName="wkType" source="wkType$" label="table.field.asnOrder.wkType" />
           <NumberField source="anfme" label="table.field.asnOrder.anfme" />
           <NumberField source="qty" label="table.field.asnOrder.qty" />
+
+          {/* 閾跺骇鏂板 */}
+          <TextField source="purchaseOrgName" label="閲囪喘缁勭粐" />
+          <TextField source="purchaseUserName" label="閲囪喘鍛�" />
+          <TextField source="purchaseDate" label="閲囪喘鏃ユ湡" />
+          <TextField source="supplierId" label="渚涘簲鍟嗙紪鐮�" />
+          <TextField source="supplierName" label="渚涘簲鍟�" />          
+
           <DateField source="arrTime" label="table.field.asnOrder.arrTime" showTime />
           <TextField source="rleStatus$" label="table.field.asnOrder.rleStatus" sortable={false} />
           <TextField source="logisNo" label="table.field.asnOrder.logisNo" />
diff --git a/rsf-admin/src/page/orders/outStock/OutOrderItemList.jsx b/rsf-admin/src/page/orders/outStock/OutOrderItemList.jsx
index c78604b..6188628 100644
--- a/rsf-admin/src/page/orders/outStock/OutOrderItemList.jsx
+++ b/rsf-admin/src/page/orders/outStock/OutOrderItemList.jsx
@@ -193,6 +193,11 @@
         <TextField source="qrcode" label="table.field.outStockItem.qrcode" />,
         <TextField source="trackCode" label="table.field.outStockItem.barcode" />,
         <TextField source="packName" label="table.field.outStockItem.packName" />,
+
+        // 閾跺骇鏂板
+        <TextField source="trackCode" label="浠撳簱" />,
+        <TextField source="trackCode" label="琛屽唴鍙�" />,
+        <TextField source="packName" label="璁″垝璺熻釜鍙�" />,
       ]
       const fields = data.map(el => <TextField key={el.fields} source={`extendFields.[${el.fields}]`} label={el.fieldsAlise} />)
       const lastArr = [
@@ -230,7 +235,7 @@
           preferenceKey='asnOrderItem'
           bulkActionButtons={false}
           rowClick={(id, resource, record) => false}
-          omit={['id', 'orderId', 'orderCode', 'poDetlId', 'poDetlCode', 'platOrderCode','matnrId', 'spec', 'model', 'purQty', 'purUnit', 'qrcode', 'trackCode', 'splrCode', 'platWorkCode', 'projectCode']}
+          omit={['id', 'orderId', 'orderCode', 'poDetlId', 'poDetlCode', 'platOrderCode','matnrId', 'spec', 'model', 'purQty', 'purUnit', 'qrcode', 'trackCode', 'splrCode', 'platWorkCode', 'projectCode', 'workQty']}
         >
           {columns.map((column) => column)}
         </StyledDatagrid>}
diff --git a/rsf-admin/src/page/orders/outStock/OutOrderList.jsx b/rsf-admin/src/page/orders/outStock/OutOrderList.jsx
index 0e759e7..ef38068 100644
--- a/rsf-admin/src/page/orders/outStock/OutOrderList.jsx
+++ b/rsf-admin/src/page/orders/outStock/OutOrderList.jsx
@@ -173,7 +173,7 @@
           bulkActionButtons={<PublicTaskButton setWaveRule={setWaveRule} setSelectIds={setSelectIds} />}
           rowClick={false}
           expandSingle={true}
-          omit={['id', 'createTime', 'createBy$', 'memo', 'rleStatus$']}
+          omit={['id', 'code', 'createTime', 'createBy$', 'memo', 'rleStatus$', 'logisNo', 'updateBy$', 'workQty', 'updateTime']}
         >
           <NumberField source="id" />
           <TextField source="code" label="table.field.outStock.code" />
@@ -191,6 +191,14 @@
           <DateField source="createTime" label="common.field.createTime" showTime />
           <BillStatusField cellClassName="status" source="exceStatus" label="table.field.outStock.exceStatus" />
           <TextField source="memo" label="common.field.memo" sortable={false} />
+
+          {/* 閾跺骇鏂板 */}
+          <TextField source="saleOrgName" label="閿�鍞粍缁�" />
+          <TextField source="saleUserName" label="閿�鍞憳" />
+          <TextField source="saleDate" label="鍑哄簱鏃ユ湡" />
+          <TextField source="customerId" label="瀹㈡埛缂栫爜" />
+          <TextField source="customerName" label="瀹㈡埛" />     
+
           <WrapperField cellClassName="opt" label="common.field.opt" >
             <MyButton setCreateDialog={setManualDialog} setmodalType={setmodalType} />
             <EditButton label="toolbar.detail" icon={(<DetailsIcon />)}></EditButton>
diff --git a/rsf-admin/src/page/orders/preparation/MatPreparationItemList.jsx b/rsf-admin/src/page/orders/preparation/MatPreparationItemList.jsx
new file mode 100644
index 0000000..86a8c30
--- /dev/null
+++ b/rsf-admin/src/page/orders/preparation/MatPreparationItemList.jsx
@@ -0,0 +1,209 @@
+import React, { useState, useRef, useEffect, useMemo, useCallback } from "react";
+import { useFetcher, useNavigate } from 'react-router-dom';
+import {
+    List,
+    DatagridConfigurable,
+    SearchInput,
+    TopToolbar,
+    SelectColumnsButton,
+    FilterButton,
+    useTranslate,
+    TextField,
+    NumberField,
+    DateField,
+    BooleanField,
+    ReferenceField,
+    TextInput,
+    useRefresh,
+    DateInput,
+    useNotify,
+    SelectInput,
+    useListContext,
+    NumberInput,
+    useGetRecordId,
+} from 'react-admin';
+import { PAGE_DRAWER_WIDTH, OPERATE_MODE, DEFAULT_PAGE_SIZE } from '@/config/setting';
+import { Box, Typography, Card, Stack, LinearProgress } from '@mui/material';
+import MyCreateButton from "../components/MyCreateButton";
+import PageDrawer from "../components/PageDrawer";
+import { styled } from '@mui/material/styles';
+// import TaskItemCreate from "./TaskItemCreate";
+import request from '@/utils/request';
+
+const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({
+    '& .css-1vooibu-MuiSvgIcon-root': {
+        height: '.9em'
+    },
+    '& .RaDatagrid-row': {
+        cursor: 'auto',
+        maring: '1em'
+    },
+    '& .column-name': {
+    },
+    '& .opt': {
+        width: 220
+    },
+}));
+
+const filters = [
+    <SearchInput source="condition" alwaysOn />,
+    // <DateInput label='common.time.after' source="timeStart" />,
+    // <DateInput label='common.time.before' source="timeEnd" />,
+    <NumberInput source="taskId" label="table.field.taskItem.taskId" />,
+    <NumberInput source="orderId" label="table.field.taskItem.orderId" />,
+    <NumberInput source="orderType" label="table.field.taskItem.orderType" />,
+    <NumberInput source="orderItemId" label="table.field.taskItem.orderItemId" />,
+    <NumberInput source="matnrId" label="table.field.taskItem.matnrId" />,
+    <TextInput source="maktx" label="table.field.taskItem.maktx" />,
+    <TextInput source="matnrCode" label="table.field.taskItem.matnrCode" />,
+    <TextInput source="unit" label="table.field.taskItem.unit" />,
+    <NumberInput source="anfme" label="table.field.taskItem.anfme" />,
+    <TextInput source="platOrderCode" label="table.field.asnOrderItem.platOrderCode" />,
+    <TextInput source="platWorkCode" label="table.field.asnOrderItem.platWorkCode" />,
+    <TextInput source="projectCode" label="table.field.asnOrderItem.projectCode" />,
+    <TextInput source="batch" label="table.field.taskItem.batch" />,
+    <TextInput source="spec" label="table.field.taskItem.spec" />,
+    <TextInput source="model" label="table.field.taskItem.model" />,
+    <TextInput label="common.field.memo" source="memo" />,
+    <SelectInput
+        label="common.field.status"
+        source="status"
+        choices={[
+            { id: '1', name: 'common.enums.statusTrue' },
+            { id: '0', name: 'common.enums.statusFalse' },
+        ]}
+        resettable
+    />,
+]
+
+const MatPreparationItemList = () => {
+    const translate = useTranslate();
+    const [createDialog, setCreateDialog] = useState(false);
+    const [drawerVal, setDrawerVal] = useState(false);
+    const recordId = useGetRecordId();
+
+    return (
+        <Box display="flex">
+            <List
+                resource="preparationItem"
+                sx={{
+                    flexGrow: 1,
+                    transition: (theme) =>
+                        theme.transitions.create(['all'], {
+                            duration: theme.transitions.duration.enteringScreen,
+                        }),
+                    marginRight: !!drawerVal ? `${PAGE_DRAWER_WIDTH}px` : 0,
+                }}
+                title={"menu.preparationItem"}
+                empty={false}
+                pagination={false}
+                filters={filters}
+                filter={{ taskId: recordId }}
+                sort={{ field: "create_time", order: "desc" }}
+                actions={(
+                    <TopToolbar>
+                        <FilterButton />
+                        {/* <MyCreateButton onClick={() => { setCreateDialog(true) }} /> */}
+                        <SelectColumnsButton preferenceKey='preparationItem' />
+                        {/* <MyExportButton /> */}
+                    </TopToolbar>
+                )}
+                perPage={DEFAULT_PAGE_SIZE}
+            >
+                <DynamicFields />
+            </List>
+            <TaskItemCreate
+                open={createDialog}
+                setOpen={setCreateDialog} />
+            <PageDrawer
+                title='PreparationItem Detail'
+                drawerVal={drawerVal}
+                setDrawerVal={setDrawerVal}
+            >
+            </PageDrawer>
+        </Box>
+    )
+}
+
+export default MatPreparationItemList;
+
+
+const DynamicFields = (props) => {
+    const translate = useTranslate();
+    const notify = useNotify();
+    const [columns, setColumns] = useState([]);
+    const { isLoading } = useListContext();
+    const refresh = useRefresh();
+    useEffect(() => {
+        getDynamicFields();
+    }, []);
+
+    const getDynamicFields = async () => {
+        const { data: { code, data, msg }, } = await request.get("/fields/enable/list");
+        if (code == 200) {
+            const arr = [
+                <NumberField source="id" />,
+                // <NumberField source="taskId" label="table.field.taskItem.taskId" />,
+                // <NumberField source="orderId" label="table.field.taskItem.orderId" />,
+                // <NumberField source="orderType$" label="table.field.taskItem.orderType" />,
+                // <NumberField source="wkType$" label="table.field.taskItem.wkType" />,
+                <NumberField source="orderItemId" label="table.field.taskItem.orderItemId" />,
+                <NumberField source="matnrId" label="table.field.taskItem.matnrId" />,
+                <TextField source="maktx" label="table.field.taskItem.maktx" />,
+                <TextField source="matnrCode" label="table.field.taskItem.matnrCode" />,
+                <TextField source="unit" label="table.field.taskItem.unit" />,
+                <NumberField source="anfme" label="table.field.taskItem.anfme" />,
+                <TextField source="platOrderCode" label="table.field.asnOrderItem.platOrderCode" />,
+                <TextField source="platWorkCode" label="table.field.asnOrderItem.platWorkCode" />,
+                <TextField source="projectCode" label="table.field.asnOrderItem.projectCode" />,
+                <TextField source="batch" label="table.field.taskItem.batch" />,
+                <TextField source="isptResult$" label="table.field.taskItem.isptResult" />,
+                <TextField source="spec" label="table.field.taskItem.spec" />,
+                <TextField source="model" label="table.field.taskItem.model" />,
+            ]
+            const fields = data.map(el => <TextField key={el.fields} source={`extendFields.[${el.fields}]`} label={el.fieldsAlise} />)
+            const lastArr = [
+                <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} />,
+            ]
+            setColumns([...arr, ...fields, ...lastArr]);
+        } else {
+            notify(msg);
+        }
+    }
+
+    return (
+        <Box sx={{ position: 'relative', minHeight: "60vh", }}>
+            {isLoading && (
+                <LinearProgress
+                    sx={{
+                        height: "2px",
+                        position: 'absolute',
+                        top: 0,
+                        left: 0,
+                        right: 0,
+                    }}
+                />
+            )}
+            {columns.length > 0 &&
+                <StyledDatagrid
+                    preferenceKey='preparationItem'
+                    bulkActionButtons={false}
+                    rowClick={false}
+                    // expand={() => <TaskItemPanel />}
+                    expandSingle={true}
+                    omit={['id', 'createTime', 'createBy', 'memo', 'taskId', 'orderId', 'orderItemId', 'matnrId', 'platWorkCode', 'projectCode','statusBool']}
+                >
+                    {columns.map((column) => column)}
+                </StyledDatagrid>}
+        </Box>
+    )
+}
diff --git a/rsf-admin/src/page/orders/preparation/MatPreparationList.jsx b/rsf-admin/src/page/orders/preparation/MatPreparationList.jsx
new file mode 100644
index 0000000..206a82d
--- /dev/null
+++ b/rsf-admin/src/page/orders/preparation/MatPreparationList.jsx
@@ -0,0 +1,422 @@
+import React, { useState, useRef, useEffect, useMemo, useCallback } from "react";
+import { useNavigate } from 'react-router-dom';
+import request from '@/utils/request';
+
+import {
+    List,
+    DatagridConfigurable,
+    SearchInput,
+    TopToolbar,
+    SelectColumnsButton,
+    FilterButton,
+    BulkDeleteButton,
+    WrapperField,
+    useRecordContext,
+    useTranslate,
+    useNotify,
+    useRefresh,
+    TextField,
+    NumberField,
+    DateField,
+    AutocompleteInput,
+    BooleanField,
+    TextInput,
+    DateInput,
+    SelectInput,
+    NumberInput,
+    Button,
+    EditButton,
+} from 'react-admin';
+import { Box, Typography, Card, Stack, Drawer } from '@mui/material';
+import { styled } from '@mui/material/styles';
+import SwapVertIcon from '@mui/icons-material/SwapVert';
+import AlignVerticalTopIcon from '@mui/icons-material/AlignVerticalTop';
+import TaskAltIcon from '@mui/icons-material/TaskAlt';
+import CancelIcon from '@mui/icons-material/Cancel';
+import PageDrawer from "../../components/PageDrawer";
+import MatPreparationPanel from "./MatPreparationPanel";
+import MyField from "../../components/MyField";
+import ConfirmButton from "../../components/ConfirmButton";
+import { PAGE_DRAWER_WIDTH, OPERATE_MODE, DEFAULT_PAGE_SIZE, AUTO_RUN_CHECK_ORDERS } from '@/config/setting';
+import PlayArrowOutlinedIcon from '@mui/icons-material/PlayArrowOutlined';
+import PauseIcon from '@mui/icons-material/Pause';
+import PauseCircleOutlineIcon from '@mui/icons-material/PauseCircleOutline';
+import * as Common from '@/utils/common';
+import ColorizeOutlinedIcon from '@mui/icons-material/ColorizeOutlined';
+import GradingOutlinedIcon from '@mui/icons-material/GradingOutlined';
+
+const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({
+    '& .css-1vooibu-MuiSvgIcon-root': {
+        height: '.9em'
+    },
+    '& .RaDatagrid-row': {
+        cursor: 'auto'
+    },
+    '& .column-name': {
+    },
+    '& .opt': {
+        width: 248
+    },
+    '& .MuiTableCell-root': {
+    whiteSpace: 'nowrap',
+    overflow: 'visible',
+    textOverflow: 'unset'
+    }
+
+}));
+
+
+const MatPreparationList = (props) => {
+    const translate = useTranslate();
+    const refresh = useRefresh();
+    const [drawerVal, setDrawerVal] = useState(false);
+    const [autoExce, setAutoExce] = useState(false);
+    const dict = JSON.parse(localStorage.getItem('sys_dicts'))?.filter(dict => (dict.dictTypeCode == 'sys_warehouse_type')) || [];
+
+    useEffect(() => {
+        // getConfig()
+    }, [])
+
+    // const getConfig = async () => {
+    //     const { data: { code, data, msg } } = await request.get('/config/flag/' + AUTO_RUN_CHECK_ORDERS);
+    //     if (code === 200) {
+    //         setAutoExce(JSON.parse(data?.val))
+    //     }
+    // }
+
+    // useEffect(() => {
+    //     const interval = setInterval(() => {
+    //         refresh();
+    //     }, 5000); // 姣�5绉掑埛鏂颁竴娆�
+
+    //     return () => clearInterval(interval); // 娓呴櫎瀹氭椂鍣�
+    // }, [refresh])
+
+    const filters = [
+        <SearchInput source="condition" alwaysOn />,
+        // <DateInput label='common.time.after' source="timeStart" />,
+        // <DateInput label='common.time.before' source="timeEnd" />,
+        <TextInput source="orderCode" label="table.field.preparation.orderCode" />,
+        <NumberInput source="orderStatus" label="table.field.preparation.orderStatus" />,
+        <DateInput source="orderTime" label="table.field.preparation.orderTime" />,
+        <NumberInput source="anfme" label="table.field.preparation.anfme" />,
+
+        // <AutocompleteInput choices={dict} optionText='label' optionValue="value" source="warehType" label="table.field.task.warehType" />,
+        // <TextInput source="orgLoc" label="table.field.task.orgLoc" />,
+        // <TextInput source="orgSite" label="table.field.task.orgSite" />,
+        // <TextInput source="targLoc" label="table.field.task.targLoc" />,
+        // <TextInput source="targSite" label="table.field.task.targSite" />,
+        // <TextInput source="barcode" label="table.field.task.barcode" />,
+        // <TextInput source="robotCode" label="table.field.task.robotCode" />,
+        // <NumberInput source="exceStatus" label="table.field.task.exceStatus" />,
+        // <TextInput source="expDesc" label="table.field.task.expDesc" />,
+        // <NumberInput source="sort" label="table.field.task.sort" />,
+        // <TextInput source="expCode" label="table.field.task.expCode" />,
+        // <DateInput source="startTime" label="table.field.task.startTime" />,
+        // <DateInput source="endTime" label="table.field.task.endTime" />,
+        // <TextInput label="common.field.memo" source="memo" />,
+        // <SelectInput
+        //     label="common.field.status"
+        //     source="status"
+        //     choices={[
+        //         { id: '1', name: 'common.enums.statusTrue' },
+        //         { id: '0', name: 'common.enums.statusFalse' },
+        //     ]}
+        //     resettable
+        // />,
+    ]
+
+    return (
+        <Box display="flex">
+            <List
+                queryOptions={{ refetchInterval: 5000 }}
+                sx={{
+                    flexGrow: 1,
+                    transition: (theme) =>
+                        theme.transitions.create(['all'], {
+                            duration: theme.transitions.duration.enteringScreen,
+                        }),
+                    marginRight: !!drawerVal ? `${PAGE_DRAWER_WIDTH}px` : 0,
+                }}
+                title={"menu.preparation"}
+                empty={false}
+                filters={filters}
+                sort={{ field: "sort", order: "desc" }}
+                actions={(
+                    <TopToolbar>
+                        <BulkAutoStartButton autoExce={autoExce} setAutoExce={setAutoExce}/>
+                        <BulkAutoPauseButton autoExce={autoExce} setAutoExce={setAutoExce} />
+                        <FilterButton />
+                        <SelectColumnsButton preferenceKey='preparation' />
+                    </TopToolbar>
+                )}
+                perPage={DEFAULT_PAGE_SIZE}
+            >
+                <StyledDatagrid
+                    preferenceKey='preparation'
+                    bulkActionButtons={false}
+                    rowClick={false}
+                    expand={<MatPreparationPanel />}
+                    expandSingle={true}
+                    omit={['id', 'sort', 'taskCode', 'createTime', 'createBy$', 'memo', 'robotCode', 'exceStatus', 'expDesc', 'expCode', 'status','warehType$']}
+                >
+                    <NumberField source="id" />
+                    <TextField source="taskCode" label="澶囨枡鍙�" />
+                    <NumberField source="status" label="table.field.task.exceStatus" />
+                    <DateField source="startTime" label="table.field.task.startTime" />
+                    <NumberField source="sort" label="鏁伴噺" />
+                    {/* table.field.task.sort */}
+                    
+                    {/* <TextField source="taskCode" label="table.field.task.taskCode" />
+                    <NumberField source="taskStatus$" label="table.field.task.taskStatus" />
+                    <NumberField source="taskType$" label="table.field.task.taskType" />
+                    <NumberField source="warehType$" label="table.field.task.warehType" />
+                    <TextField source="orgLoc" label="table.field.task.orgLoc" />
+                    <TextField source="orgSite" label="table.field.task.orgSite" />
+                    <TextField source="targLoc" label="table.field.task.targLoc" />
+                    <TextField source="targSite" label="table.field.task.targSite" />
+                    <TextField source="barcode" label="table.field.task.barcode" />
+                    <TextField source="robotCode" label="table.field.task.robotCode" />
+                    <NumberField source="exceStatus" label="table.field.task.exceStatus" />
+                    <TextField source="expDesc" label="table.field.task.expDesc" />
+                    <NumberField source="sort" label="table.field.task.sort" />
+                    <TextField source="expCode" label="table.field.task.expCode" />
+                    <TextField source="updateBy$" label="common.field.updateBy" />
+                    <TextField source="createBy$" label="common.field.createBy" />
+                    <DateField source="updateTime" label="common.field.updateTime" showTime />
+                    <DateField source="createTime" label="common.field.createTime" showTime />
+                    <TextField source="memo" label="common.field.memo" sortable={false} /> */}
+                    <WrapperField cellClassName="opt" label="common.field.opt" onClick={(e) => e.stopPropagation()} >
+                        <EditButton label="toolbar.detail" />
+                        <DoneButton sx={{ padding: '1px', fontSize: '.75rem' }} ></DoneButton>
+                        <CancelButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} />
+                        <CheckButton />
+                        <PickButton />
+                        <SetTopButton />
+                    </WrapperField>
+                </StyledDatagrid>
+            </List>
+            <PageDrawer
+                title='Preparation Detail'
+                drawerVal={drawerVal}
+                setDrawerVal={setDrawerVal}
+            >
+            </PageDrawer>
+        </Box>
+    )
+}
+
+export default MatPreparationList;
+
+/**
+ * 鐩樼偣
+ * @returns te
+ */
+const CheckButton = () => {
+    const record = useRecordContext();
+    const notify = useNotify();
+    const refresh = useRefresh();
+
+    const checkClick = async () => {
+        const { data: { code, data, msg } } = await request.post(`/task/check/` + record.id);
+        if (code === 200) {
+            notify(msg);
+            refresh();
+        } else {
+            notify(msg);
+        }
+    }
+
+    return (record?.taskStatus == 199 && record?.taskType == 107 ? <ConfirmButton label={"toolbar.check"} startIcon={<GradingOutlinedIcon />} onConfirm={checkClick} /> : <></>)
+}
+
+/**鑷姩涓嬪彂浠诲姟**/
+const BulkAutoStartButton = ({ autoExce, setAutoExce }) => {
+    const notify = useNotify();
+    const startClick = async () => {
+        setAutoExce(true)
+        const { data: { code, data, msg } } = await request.post('/config/byFlag', { val: true, flag: 'AUTO_RUN_CHECK_ORDERS' });
+        if (code === 200) {
+            notify(msg);
+        } else {
+            notify(msg);
+        }
+    }
+    return (
+        !autoExce ? <Button label="toolbar.autoStartLocs" onClick={startClick} startIcon={<PlayArrowOutlinedIcon />} /> : <></>
+    )
+}
+
+const BulkAutoPauseButton = ({ autoExce, setAutoExce }) => {
+    const notify = useNotify();
+    const pauseClick = async () => {
+        const { data: { code, data, msg } } = await request.post('/config/byFlag', { val: false, flag: 'AUTO_RUN_CHECK_ORDERS' });
+        if (code === 200) {
+            notify(msg);
+            setAutoExce(false)
+        } else {
+            notify(msg);
+        }
+    }
+    return (
+        autoExce ? <Button label="toolbar.pause" onClick={pauseClick} startIcon={<PauseIcon />} /> : <></>
+    )
+}
+
+
+/**
+ * 鎷f枡鍑哄簱
+ * @returns 
+ */
+const PickButton = () => {
+    const record = useRecordContext();
+    const notify = useNotify();
+    const refresh = useRefresh();
+
+    const pickClick = async () => {
+        const { data: { code, data, msg } } = await request.post(`/task/pick/` + record.id);
+        if (code === 200) {
+            notify(msg);
+            refresh();
+        } else {
+            notify(msg);
+        }
+    }
+
+    return (
+        record?.taskStatus == 199 && record?.taskType == 103 ? <ConfirmButton label={"toolbar.pick"} startIcon={<ColorizeOutlinedIcon />} onConfirm={pickClick} /> : <></>
+    )
+}
+
+
+/**
+ * 瀹屾垚鎿嶄綔
+ * @returns 
+ */
+const DoneButton = (props) => {
+    const record = useRecordContext();
+    const notify = useNotify();
+    const refresh = useRefresh();
+    const clickComplete = () => {
+        completeTask(record)
+    };
+    //瀹屾垚浠诲姟
+    const completeTask = async (row) => {
+        const { data: { code, data, msg } } = await request.post(`task/complete/` + row.id);
+        if (code === 200) {
+            notify(msg);
+            refresh();
+        } else {
+            notify(msg);
+        }
+    }
+    return (
+        ((record?.taskStatus < 98) || (record?.taskType >= 101 && record?.taskStatus < 198)) || (record?.taskType == 11 && record?.taskStatus == 101) ? (<ConfirmButton label={"toolbar.complete"} color="secondary" startIcon={<TaskAltIcon />} onConfirm={clickComplete} />) : (<></>)
+    )
+}
+
+/**
+ * 鍙栨秷鎸夐挳
+ * @returns 
+ */
+const CancelButton = () => {
+    const record = useRecordContext();
+    const notify = useNotify();
+    const refresh = useRefresh();
+    const clickCancel = () => {
+        cancleTask(record)
+    };
+    //鍙栨秷浠诲姟
+    const cancleTask = async (row) => {
+        const { data: { code, data, msg } } = await request.post(`/task/remove/` + row.id);
+        if (code === 200) {
+            notify(msg);
+            refresh();
+        } else {
+            notify(msg);
+        }
+    }
+    return (
+        (record.taskStatus == 1 || record.taskStatus == 101) && (record.taskType == 1 || record.taskType == 101 || record.taskType == 10 || record.taskType == 107 || record.taskType == 103 || record.taskType == 11) ?
+            <ConfirmButton
+                onConfirm={clickCancel}
+                startIcon={<CancelIcon />}
+                label={"toolbar.cancel"}>
+            </ConfirmButton>
+            :
+            <></>
+    )
+}
+/**
+ *  缃《鎿嶄綔
+ * @returns 
+ */
+const SetTopButton = () => {
+    const record = useRecordContext();
+    const notify = useNotify();
+    const refresh = useRefresh();
+    const clickTop = (event) => {
+        event.stopPropagation();
+        topTask(record)
+    };
+    //缃《浠诲姟
+    const topTask = async (row) => {
+        const { data: { code, data, msg } } = await request.post(`/task/top/` + row.id);
+        if (code === 200) {
+            notify(msg);
+            refresh();
+        } else {
+            notify(msg);
+        }
+    }
+    return (
+        (record.taskStatus == 1 || record.taskStatus == 101) && (record.taskType == 1 || record.taskType == 101 || record.taskType == 10 || record.taskType == 103 || record.taskType == 11) ?
+            <Button
+                onClick={clickTop}
+                label="toolbar.top">
+                <AlignVerticalTopIcon />
+            </Button>
+            :
+            <></>
+    )
+}
+
+/**
+ * 鎵归噺鍙栨秷
+ * @returns 
+ */
+const BulkCancelButton = () => {
+    const record = useRecordContext();
+    const clickCancel = () => {
+        cancleTask([record])
+    };
+    //鍙栨秷浠诲姟
+    const cancleTask = async (row) => { }
+    return (
+        <Button
+            onClick={clickCancel}
+            label="toolbar.cancel">
+            <CancelIcon />
+        </Button>
+    )
+}
+
+/**
+ * 鎵归噺鎺掑簭
+ * @returns 
+ */
+const BulkResortButton = () => {
+    const record = useRecordContext();
+    const bulkResort = () => {
+        resortTask([record])
+    };
+    //鎵归噺鎺掑簭
+    const resortTask = async (row) => { }
+    return (
+        <Button
+            onClick={bulkResort}
+            label="toolbar.resort">
+            <SwapVertIcon />
+        </Button>
+    )
+}
diff --git a/rsf-admin/src/page/orders/preparation/MatPreparationPanel.jsx b/rsf-admin/src/page/orders/preparation/MatPreparationPanel.jsx
new file mode 100644
index 0000000..7939c3b
--- /dev/null
+++ b/rsf-admin/src/page/orders/preparation/MatPreparationPanel.jsx
@@ -0,0 +1,89 @@
+import React, { useState, useRef, useEffect, useMemo } from "react";
+import { Box } from '@mui/material';
+import {
+    List,
+    DatagridConfigurable,
+    useRecordContext,
+    useTranslate,
+    TextField,
+    NumberField,
+    DateField,
+    BooleanField,
+    ReferenceField,
+} from 'react-admin';
+import { styled } from '@mui/material/styles';
+import PageDrawer from "../../components/PageDrawer";
+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
+    },
+}));
+
+const MatPreparationPanel = () => {
+    const record = useRecordContext();
+    const translate = useTranslate();
+    const [createDialog, setCreateDialog] = useState(false);
+    const [drawerVal, setDrawerVal] = useState(false);
+    return (
+        <>
+            <Box display="flex">
+                <List resource="preparationItem"
+                    sx={{
+                        flexGrow: 1,
+                        transition: (theme) =>
+                            theme.transitions.create(['all'], {
+                                duration: theme.transitions.duration.enteringScreen,
+                            }),
+                        marginRight: !!drawerVal ? `${PAGE_DRAWER_WIDTH}px` : 0,
+                    }}
+                    filter={{ taskId: record.id }}
+                    // title={"menu.taskItem"}
+                    pagination={false}
+                    empty={false}
+                    actions={false}
+                >
+                    <StyledDatagrid
+                        preferenceKey='preparationItem'
+                        bulkActionButtons={false}
+                        rowClick={false}
+                        expandSingle
+                        omit={['id', 'taskId', 'createTime', 'createBy$', 'memo', 'taskId', 'orderId', 'orderItemId', 'matnrId']}
+                    >
+                        <NumberField source="id" />
+                        {/* <NumberField source="taskId" label="table.field.taskItem.taskId" /> */}
+                        <NumberField source="orderId" label="table.field.preparationItem.orderId" />
+                        <NumberField source="orderType$" label="table.field.preparationItem.orderType" />
+                        {/* <TextField source="sourceCode" label="table.field.taskItem.sourceCode" /> */}
+                        <NumberField source="orderItemId" label="table.field.preparationItem.orderItemId" />
+                        <NumberField source="matnrId" label="table.field.preparationItem.matnrId" />
+                        <TextField source="maktx" label="table.field.preparationItem.maktx" />
+                        <TextField source="matnrCode" label="table.field.preparationItem.matnrCode" />
+                        <TextField source="unit" label="table.field.preparationItem.unit" />
+                        <NumberField source="anfme" label="table.field.preparationItem.anfme" />
+                        <TextField source="batch" label="table.field.preparationItem.batch" />
+                        <TextField source="spec" label="table.field.preparationItem.spec" />
+                        <TextField source="model" label="table.field.preparationItem.model" />
+                        {/* <TextField source="updateBy$" label="common.field.updateBy"/>
+                        <TextField source="createBy$" label="common.field.createBy"/>
+                        <DateField source="updateTime" label="common.field.updateTime" showTime />
+                        <DateField source="createTime" label="common.field.createTime" showTime />
+                        <TextField source="memo" label="common.field.memo" sortable={false} /> */}
+                    </StyledDatagrid>
+                </List>
+            </Box>
+        </>
+    );
+};
+
+export default MatPreparationPanel;
diff --git a/rsf-admin/src/page/orders/preparation/MatPreparationPublic.jsx b/rsf-admin/src/page/orders/preparation/MatPreparationPublic.jsx
new file mode 100644
index 0000000..a1cfb21
--- /dev/null
+++ b/rsf-admin/src/page/orders/preparation/MatPreparationPublic.jsx
@@ -0,0 +1,483 @@
+import { Box, Card, Grid, LinearProgress, Select, MenuItem, ListItemText } from "@mui/material";
+import React, { useState, useRef, useEffect, useMemo } from "react";
+import {
+    List,
+    DatagridConfigurable,
+    SearchInput,
+    TopToolbar,
+    Button,
+    SelectColumnsButton,
+    EditButton,
+    FilterButton,
+    CreateButton,
+    ExportButton,
+    BulkDeleteButton,
+    WrapperField,
+    useRecordContext,
+    useTranslate,
+    useNotify,
+    useListContext,
+    FunctionField,
+    TextField,
+    NumberField,
+    DateField,
+    BooleanField,
+    ReferenceField,
+    TextInput,
+    DateTimeInput,
+    DateInput,
+    SelectInput,
+    NumberInput,
+    ReferenceInput,
+    ReferenceArrayInput,
+    AutocompleteInput,
+    DeleteButton,
+    SimpleForm,
+    required,
+    Form,
+    useRefresh,
+    useRedirect,
+    useRecordSelection,
+} from 'react-admin';
+import { PAGE_DRAWER_WIDTH, OPERATE_MODE, DEFAULT_PAGE_SIZE, DEFAULT_ITEM_PAGE_SIZE, DEFAULT_TYPE } from '@/config/setting';
+import { styled } from '@mui/material/styles';
+import { DataGrid, useGridApiContext, GridActionsCellItem, useGridApiRef } from '@mui/x-data-grid';
+import request from '@/utils/request';
+import ConfirmationNumberOutlinedIcon from '@mui/icons-material/ConfirmationNumberOutlined';
+import CloseSharpIcon from '@mui/icons-material/CloseSharp';
+import ConfirmButton from '../../components/ConfirmButton';
+import { Delete, Edit, Add } from '@mui/icons-material';
+// import OutStockSiteDialog from "./OutStockSiteDialog";
+
+const StyledDatagrid = styled(DatagridConfigurable)(({ theme }) => ({
+    '& .css-1vooibu-MuiSvgIcon-root': {
+        height: '.9em'
+    },
+    '& .RaDatagrid-row': {
+        cursor: 'auto'
+    },
+    '& .column-maktx': {
+        width: 200
+    },
+
+    mt: '60px'
+    // '& .RaBulkActionsToolbar-toolbar': {
+    //     display: 'none'
+    // }
+
+}));
+
+const MatPerparationPublic = (props) => {
+    const { record, open, setOpen, setManualDialog } = props;
+    const notify = useNotify();
+    const gridRef = useGridApiRef();
+    const [rows, setRows] = useState([]);
+    const [fetchRows, setFetchRows] = useState([]);
+    const translate = useTranslate();
+    const [rowSelectedIds, setRowSelectedIds] = useState([]);
+    const [selectedMatnr, setSelectedMatnr] = useState([]);
+    const [selectedIds, setSelectedIds] = useState([]);
+    const [formData, setFormData] = useState({ orderId: record?.id, waveId: DEFAULT_TYPE });
+    const [dialog, setDialog] = useState(false);
+    const [selectedValue, setSelectedValue] = useState({});
+
+    useEffect(() => {
+        if (selectedMatnr.length < 1) {
+            setRows(fetchRows)
+        } else {
+            const mas = fetchRows.filter(item => selectedMatnr.includes(item.matnrCode));
+            setRows(mas)
+        }
+    }, [selectedMatnr])
+
+
+    const ComfirmButton = () => {
+        const { selectedIds, data } = useListContext();
+        const handleRowClick = () => {
+            console.log(selectedIds);
+            
+            const ids = data.filter(item => selectedIds.includes(item.id)).map(item => item.id);
+            setRowSelectedIds(ids);
+            const mas = data.filter(item => selectedIds.includes(item.id)).map(item => item.matnrCode);
+            //璁剧疆搴撲綅淇℃伅绛涢�夋潯浠�
+            setSelectedMatnr(mas);
+        }
+
+        return (
+            <Button label="toolbar.confirm" size="medium" onClick={handleRowClick} />
+        )
+    };
+
+    const handleClickOpen = () => {
+        setDialog(true);
+    };
+
+    const handleClose = (value) => {
+        setDialog(false);
+        setSelectedValue(value);
+        if (selectedIds.length == 0) {
+            const newRows = rows.map(item => {
+                return {
+                    ...item,
+                    siteNo: value?.site
+                }
+            })
+            setRows(newRows);
+        } else {
+            const newRows = rows.map(item => {
+                return selectedIds.includes(item?.id) ? {
+                    ...item,
+                    siteNo: value?.site
+                } : item
+            })
+            setRows(newRows);
+        }
+    };
+
+    useEffect(() => {
+        getWaveRule()
+    }, [open])
+
+    const getWaveRule = async () => {
+        if (formData.waveId == null && formData.waveId == undefined) {
+            return
+        }
+        const { data: { code, data, msg } } = await request.post('/outStock/order/getOutTaskItems', { ...formData });
+        if (code === 200) {
+            // setRows(data)
+            setFetchRows(data)
+        } else {
+            notify(msg);
+        }
+    }
+
+    const handleChange = (value, name) => {
+        setFormData((prevData) => ({
+            ...prevData,
+            [name]: value
+        }));
+    };
+
+
+    return (
+        <>
+            <Box>
+                <Grid sx={{ display: "flex" }} container rowSpacing={2} columnSpacing={2}>
+                    <Grid item xl={5.7} gap={2} >
+                        <Card>
+                            <Form>
+                                <ReferenceInput
+                                    source="type"
+                                    reference="waveRule"
+                                >
+                                    <AutocompleteInput
+                                        label="table.field.waveRule.type"
+                                        onChange={(e) => handleChange(e, 'waveId')}
+                                        defaultValue={15}
+                                        value={formData.type}
+                                        validate={required()}
+                                    />
+                                </ReferenceInput>
+                            </Form>
+                            <List
+                                resource="outStockItem"
+                                storeKey='outStockItem'
+                                sx={{
+                                    flexGrow: 1,
+                                    transition: (theme) =>
+                                        theme.transitions.create(['all'], {
+                                            duration: theme.transitions.duration.enteringScreen,
+                                        }),
+                                }}
+                                title={"menu.outStockItem"}
+                                empty={false}
+                                filter={{ orderId: record?.id, deleted: 0 }}
+                                sort={{ field: "create_time", order: "desc" }}
+                                actions={false}
+                                pagination={false}
+                                perPage={DEFAULT_ITEM_PAGE_SIZE}
+                            >
+                                <LinearProgress
+                                    sx={{ height: "2px", position: 'absolute', top: 0, left: 0, right: 0, }}
+                                />
+                                <StyledDatagrid
+                                    storeKey={"matPerparationPublic"}
+                                    preferenceKey='outStockItem'
+                                    bulkActionButtons={<>
+                                        <ComfirmButton />
+                                    </>}
+                                    omit={['id', 'splrName', 'qty', 'poCode',]}
+                                >
+                                    <NumberField source="id" />
+                                    <TextField source="asnCode" label="table.field.outStockItem.orderCode" />
+                                    <TextField source="poCode" label="table.field.outStockItem.poCode" />
+                                    <TextField source="matnrCode" label="table.field.outStockItem.matnrCode" />
+                                    <TextField source="maktx" label="table.field.outStockItem.maktx" />
+                                    <NumberField source="anfme" label="table.field.outStockItem.anfme" />
+                                    <NumberField source="workQty" label="table.field.outStockItem.workQty" />
+                                    <NumberField source="qty" label="table.field.outStockItem.qty" />
+                                    <TextField source="stockUnit" label="table.field.outStockItem.stockUnit" />
+                                    <TextField source="splrName" label="table.field.outStockItem.splrName" />
+                                </StyledDatagrid>
+                            </List>
+                        </Card>
+                    </Grid>
+                    <Grid item xl={6.3} gap={2}>
+                        <Card sx={{ minHeight: 1050, height: 'calc(100% - 10px)', width: '100%' }}>
+                            <Box>
+                                <PreviewTable
+                                    rows={rows}
+                                    gridRef={gridRef}
+                                    setRows={setRows}
+                                    record={record}
+                                    formData={formData}
+                                    selectedIds={selectedIds}
+                                    setDialog={setDialog}
+                                    setSelectedIds={setSelectedIds}
+                                />
+                            </Box>
+                            <Box sx={{ textAlign: 'center' }}>
+                                <CloseButton setOpen={setOpen} />
+                                <SubmitButton selectedIds={selectedIds} setSelectedIds={setSelectedIds} gridRef={gridRef} record={record} />
+                            </Box>
+                        </Card>
+                    </Grid>
+                </Grid>
+                <Grid>
+                    <OutStockSiteDialog
+                        selectedValue={selectedValue}
+                        open={dialog}
+                        onClose={handleClose}
+                    />
+                </Grid>
+            </Box>
+        </>
+    );
+}
+
+const PreviewTable = ({ rows, gridRef, setRows, record, selectedIds, setSelectedIds, setDialog, formData }) => {
+    gridRef.current = useGridApiRef();
+    const translate = useTranslate();
+
+    useEffect(() => {
+        if (selectedIds.length > 0) {
+            console.log(selectedIds);
+        }
+    }, [selectedIds])
+
+    const baseColumns = [
+        // { field: 'id', headerName: 'ID', width: 40 },
+        { field: 'locCode', headerName: '搴撲綅', width: 110 },
+        { field: 'barcode', headerName: '瀹瑰櫒', width: 120 },
+        { field: 'matnrCode', headerName: '鐗╂枡缂栫爜', width: 120 },
+        { field: 'batch', headerName: '鎵规', width: 90 },
+        { field: 'unit', headerName: '鍗曚綅', width: 60 },
+        { field: 'outQty', headerName: '鍑哄簱鏁伴噺', width: 110, },
+        {
+            field: 'anfme', headerName: '搴撳瓨鏁伴噺', width: 110,
+            renderCell: (params) => (
+                <OutStockAnfme value={params.value} />
+            )
+        },
+        {
+            field: 'siteNo',
+            headerName: '鍑哄簱鍙�',
+            width: 90,
+            type: 'singleSelect',
+            editable: true,
+            renderCell: (params) => (
+                <OutStockSiteNo value={params.value} />
+            ),
+            renderEditCell: (params) => (
+                <OutStockSite {...params} />
+            ),
+        },
+    ]
+
+    const optAction = {
+        field: 'actions',
+        type: 'actions',
+        headerName: translate('common.field.opt'),
+        with: 120,
+        getActions: (params) => [
+            <GridActionsCellItem
+                icon={<Delete />}
+                label="Delete"
+                onClick={() => handleDelete(params.row, rows, setRows)}
+            />,
+        ]
+    }
+
+    const columns = (formData.waveId == 15 || formData.waveId == 16) ? [...baseColumns] : [...baseColumns, optAction];
+
+    /**
+     * 鍒犻櫎浜嬩欢
+     * @param {*} params 
+     */
+    const handleDelete = (params, rows, setRows) => {
+        const outRows = rows.filter(row => {
+            return row.id !== params.id
+        })
+        setRows(outRows)
+    }
+
+    const OutStockAnfme = React.memo(function OutStockAnfme(props) {
+        const { value } = props;
+        return (
+            value > 0 ?
+                <Box sx={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>
+                    <span>{value}</span>
+                </Box>
+                :
+                <Box sx={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>
+                    <span style={{ color: 'red' }}>{translate('common.edit.title.insuffInventory')}</span>
+                </Box>
+        );
+    });
+
+    const OutStockSiteNo = React.memo(function OutStockSiteNo(props) {
+        const { value } = props;
+        if (!value) {
+            return null;
+        }
+        return (
+            <Box sx={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>
+                <span>{value}</span>
+            </Box>
+        );
+    });
+
+    const CustomToolBar = () => {
+        const selectSiteNo = () => {
+            setDialog(true)
+        }
+        return (
+            <Box sx={{
+                p: 1,
+                display: 'flex',
+                justifyContent: 'flex-end',
+                borderTop: '1px solid rgba(224, 224, 224, 1)'
+            }}>
+                <Button
+                    onClick={selectSiteNo}
+                    variant="outlined"
+                    label="toolbar.modiftySite"
+                    size="medium"
+                    sx={{ mr: 1 }} />
+            </Box>
+        );
+    }
+
+    const OutStockSite = (params) => {
+        const { id, field, siteNo, row: { staNos } } = params;
+        const apiRef = useGridApiContext();
+        const handleChange = async (event) => {
+            await apiRef.current.setEditCellValue(
+                { id, field, value: event.target.value },
+                event,
+            );
+            apiRef.current.stopCellEditMode({ id, field });
+        };
+
+        const handleClose = (event, reason) => {
+            if (reason === 'backdropClick') {
+                apiRef.current.stopCellEditMode({ id, field });
+            }
+        };
+
+        return (
+            <Select
+                value={siteNo}
+                onChange={handleChange}
+                MenuProps={{
+                    onClose: handleClose,
+                }}
+                sx={{
+                    height: '100%',
+                    '& .MuiSelect-select': {
+                        display: 'flex',
+                        alignItems: 'center',
+                        pl: 1,
+                    },
+                }}
+                autoFocus
+                fullWidth
+                open
+            >
+                {staNos.map((option) => {
+                    return (
+                        <MenuItem
+                            key={option}
+                            value={option.staNo}
+                        >
+                            <ListItemText sx={{ overflow: 'hidden' }} primary={option.staNo} />
+                        </MenuItem>
+                    );
+                })}
+            </Select >
+        )
+    }
+
+    return (
+        <DataGrid
+            storeKey={"locItemPreview"}
+            rows={rows}
+            columns={columns}
+            slots={{ toolbar: CustomToolBar }}
+            apiRef={gridRef}
+            checkboxSelection
+            disableRowSelectionOnClick
+            hideFooterPagination={true}  // 闅愯棌鍒嗛〉鎺т欢
+            hideFooter={false}
+            onRowSelectionModelChange={(ids) => {
+                setSelectedIds(ids)
+            }}
+        />
+    )
+}
+
+
+//鎻愪氦鎸夐挳
+const SubmitButton = ({ selectedIds, setSelectedIds, gridRef, record }) => {
+    const notify = useNotify();
+    const refresh = useRefresh();
+    const redirect = useRedirect();
+    const submit = async () => {
+        const items = gridRef.current?.getSortedRows();
+        const { data: { code, data, msg } } = await request.post('/outStock/generate/tasks', { items, outId: record?.id });
+        if (code == 200) {
+            refresh();
+            redirect("/task")
+        } else {
+            notify(msg);
+        }
+    }
+    return (
+        <ConfirmButton
+            label="toolbar.allComfirm"
+            variant="contained"
+            size="medium"
+            onConfirm={submit}
+        />
+    )
+}
+
+//鍏抽棴鎸夐挳
+const CloseButton = ({ setOpen }) => {
+    const close = () => {
+        setOpen(false)
+    }
+    return (
+        <Button
+            label="toolbar.close"
+            variant="outlined"
+            size="medium"
+            onClick={close}
+            startIcon={<CloseSharpIcon />}
+            sx={{ margin: '3.5em' }} />
+    )
+}
+
+export default MatPerparationPublic;
+
+
diff --git a/rsf-admin/src/page/orders/preparation/index.jsx b/rsf-admin/src/page/orders/preparation/index.jsx
new file mode 100644
index 0000000..6214961
--- /dev/null
+++ b/rsf-admin/src/page/orders/preparation/index.jsx
@@ -0,0 +1,18 @@
+import React, { useState, useRef, useEffect, useMemo } from "react";
+import {
+    ListGuesser,
+    EditGuesser,
+    ShowGuesser,
+} from "react-admin";
+
+import MatPreparationList from "./MatPreparationList";
+// import TaskEdit from "./TaskEdit";
+
+export default {
+    list: MatPreparationList,
+    // edit: TaskEdit,
+    show: ShowGuesser,
+    recordRepresentation: (record) => {
+        return `${record.id}`
+    }
+};
diff --git a/rsf-admin/src/page/system/menu/MenuList.jsx b/rsf-admin/src/page/system/menu/MenuList.jsx
index ab0e3c7..5c50e52 100644
--- a/rsf-admin/src/page/system/menu/MenuList.jsx
+++ b/rsf-admin/src/page/system/menu/MenuList.jsx
@@ -127,6 +127,8 @@
     textOverflow: 'ellipsis',
     whiteSpace: 'nowrap',
     maxWidth: 600,
+    // 纭繚鎵�鏈夊崟鍏冩牸鏈夊熀鏈殑鍐呰竟璺�
+    padding: '8px 16px',
 }));
 
 const TreeTableRow = (props) => {
@@ -139,15 +141,41 @@
 
     const isOpen = openNodes[row.id] || false;
 
+    // 鏇存槑鏄剧殑閫忔槑搴︽笎鍙�
+    const getOpacity = (currentDepth) => {
+        // 绗竴绾э細100%锛岀浜岀骇锛�75%锛岀涓夌骇锛�50%锛岀鍥涚骇锛�40%
+        const opacities = [1, 0.9, 0.8, 0.7];
+        return opacities[currentDepth] || 0.4;
+    };
+
+    const opacity = getOpacity(depth);
+
     return (
         <React.Fragment>
-            <StyledTableRow hover tabIndex={-1} key={row.id}>
-                <StyledTableCell sx={{ padding: 0 }}>
-                    {row.children && (
+            <StyledTableRow 
+                hover 
+                tabIndex={-1} 
+                key={row.id}
+                sx={{
+                    opacity: depth > 0 ? opacity : 1,
+                    // 娣诲姞鑳屾櫙鑹叉笎鍙樺寮烘晥鏋�
+                    backgroundColor: depth > 0 ? `rgba(0, 0, 0, ${0.02 * (3 - depth)})` : 'inherit',
+                }}
+            >
+                <StyledTableCell sx={{ 
+                    padding: 0, 
+                    width: 60,
+                    // 杩涗竴姝ュ噺灏忕缉杩涜窛绂诲埌12px
+                    paddingLeft: depth * 4
+                }}>
+                    {row.children && row.children.length > 0 && (
                         <IconButton
                             aria-label="expand row"
                             size="small"
                             onClick={() => toggleNode(row.id)}
+                            sx={{
+                                opacity: depth > 0 ? opacity : 1,
+                            }}
                         >
                             {isOpen ? <KeyboardArrowDownIcon /> : <KeyboardArrowRightIcon />}
                         </IconButton>
@@ -164,10 +192,20 @@
                                 key={column.id}
                                 align={column.align || 'left'}
                                 style={{
-                                    paddingLeft: idx === 0 && (depth * 16 + 16),
-                                    opacity: column.id === 'icon' && .6
+                                    // 鍚嶇О鍒椾篃浣跨敤12px缂╄繘
+                                    paddingLeft: idx === 0 ? (depth * 24 + 16) : 16,
+                                    // opacity: column.id === 'icon' && .6
                                 }}
-                                onClick={() => toggleNode(row.id)}
+                                onClick={() => column.id === 'name' && toggleNode(row.id)}
+                                sx={{
+                                    opacity: column.id === 'icon' ? 0.6 : (depth > 0 ? opacity : 1),
+                                    color: depth > 0 ? `rgba(0, 0, 0, ${opacity})` : 'inherit',
+                                    fontWeight: 400,
+                                    // 浣跨敤瀛椾綋澶у皬鎴栭鑹叉潵鍖哄垎灞傜骇
+                                    fontSize: depth === 0 ? '0.95rem' : '0.9rem',
+                                    // 鎴栬�呬娇鐢ㄤ笉鍚岀殑棰滆壊
+                                    color: depth === 0 ? 'text.primary' : `rgba(0, 0, 0, ${opacity})`,
+                                }}
                             >
                                 {column.format ? column.format(value) : value}
                             </StyledTableCell>
@@ -176,18 +214,30 @@
                 })}
                 <StyledTableCell>
                     <Tooltip title="Edit">
-                        <IconButton onClick={() => onEdit(row)}>
+                        <IconButton 
+                            onClick={() => onEdit(row)}
+                            sx={{
+                                opacity: depth > 0 ? opacity : 1,
+                            }}
+                            size="small"
+                        >
                             <Edit />
                         </IconButton>
                     </Tooltip>
                     <Tooltip title="Delete">
-                        <IconButton onClick={() => onDelete(row)}>
+                        <IconButton 
+                            onClick={() => onDelete(row)}
+                            sx={{
+                                opacity: depth > 0 ? opacity : 1,
+                            }}
+                            size="small"
+                        >
                             <Delete />
                         </IconButton>
                     </Tooltip>
                 </StyledTableCell>
             </StyledTableRow>
-            {row.children && isOpen && (
+            {row.children && row.children.length > 0 && isOpen && (
                 row.children.map((child) => (
                     <TreeTableRow
                         key={child.id}
diff --git a/rsf-admin/src/page/system/role/AssignPermissions.jsx b/rsf-admin/src/page/system/role/AssignPermissions.jsx
index 7be80ae..d65fddf 100644
--- a/rsf-admin/src/page/system/role/AssignPermissions.jsx
+++ b/rsf-admin/src/page/system/role/AssignPermissions.jsx
@@ -12,15 +12,17 @@
 const DEFAULT_EXPAND_ALL = true;
 
 const AssignPermissions = (props) => {
-    const { role, originMenuIds, setDrawerVal, closeCallback } = props;
+    const { role, originMenuIds, setDrawerVal, closeCallback, authType } = props;
     const translate = useTranslate();
     const notify = useNotify();
+
+    console.log("authType"+authType)
 
     const [loading, setLoading] = useState(false);
     const [treeData, setTreeData] = useState([]);
     const [selectedItems, setSelectedItems] = useState([]);
     const [expandedItems, setExpandedItems] = useState([]);
-    const [parmas, setParmas] = useState({ condition: '' });
+    const [parmas, setParmas] = useState({ condition: '', authType: authType });
     const toggledItemRef = useRef({});
     const apiRef = useTreeViewApiRef();
 
diff --git a/rsf-admin/src/page/system/role/RoleList.jsx b/rsf-admin/src/page/system/role/RoleList.jsx
index a5432bd..1973c7d 100644
--- a/rsf-admin/src/page/system/role/RoleList.jsx
+++ b/rsf-admin/src/page/system/role/RoleList.jsx
@@ -55,7 +55,7 @@
     '& .column-name': {
     },
     '& .opt': {
-        width: 260
+        width: 450
     },
 }));
 
@@ -63,7 +63,6 @@
     <SearchInput source="condition" alwaysOn />,
     <TextInput source="name" label="table.field.role.name" />,
     <TextInput source="code" label="table.field.role.code" />,
-
     <TextInput label="common.field.memo" source="memo" />,
     <SelectInput
         label="common.field.status"
@@ -83,6 +82,8 @@
     const [drawerVal, setDrawerVal] = useState(false);
 
     const [menuIds, setMenuIds] = useState([]);
+
+    const [authType,setAuthType] = useState(0)
 
     const assign = (record) => {
         request('/role/scope/list', {
@@ -146,7 +147,9 @@
                     <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">
-                        <ScopeButton sx={{ padding: '1px', fontSize: '.75rem' }} assign={assign} />
+                        <ScopeButton sx={{ padding: '1px', fontSize: '.75rem' }} assign={assign} auType={0} setAuthType={setAuthType} label="缃戦〉鏉冮檺&nbsp;&nbsp;&nbsp;" />
+                        <ScopeButton sx={{ padding: '1px', fontSize: '.75rem' }} assign={assign} auType={1} setAuthType={setAuthType} label="PDA鏉冮檺&nbsp;&nbsp;&nbsp;" />
+                        <ScopeButton sx={{ padding: '1px', fontSize: '.75rem' }} assign={assign} auType={2} setAuthType={setAuthType} label="浠撳簱鏉冮檺&nbsp;" />
                         <EditButton sx={{ padding: '1px', fontSize: '.75rem' }} />
                         <DeleteButton sx={{ padding: '1px', fontSize: '.75rem' }} mutationMode={OPERATE_MODE} />
                     </WrapperField>
@@ -171,6 +174,7 @@
                     closeCallback={() => {
                         setMenuIds([]);
                     }}
+                    authType = {authType}
                 />
             </PageDrawer>
         </Box>
@@ -179,14 +183,15 @@
 
 const ScopeButton = (props) => {
     const record = useRecordContext();
-    const { assign, ...rest } = props;
+    const { assign, auType, setAuthType, label, ...rest } = props;    
     return (
         <Button
             variant="text"
             color="primary"
             startIcon={<AssignmentIndIcon />}
-            label="common.action.scope"
+            label={label}
             onClick={(event) => {
+                setAuthType(auType);
                 event.stopPropagation();
                 assign(record);
             }}
diff --git a/rsf-admin/src/themes/ThemeSwapper.jsx b/rsf-admin/src/themes/ThemeSwapper.jsx
index c726222..1d0707b 100644
--- a/rsf-admin/src/themes/ThemeSwapper.jsx
+++ b/rsf-admin/src/themes/ThemeSwapper.jsx
@@ -41,7 +41,7 @@
                 </IconButton>
             </Tooltip>
             {currentTheme?.dark ? <ToggleThemeButton /> : null}
-            <Menu open={open} onClose={handleClose} anchorEl={anchorEl}>
+            {/* <Menu open={open} onClose={handleClose} anchorEl={anchorEl}>
                 {themes.map((theme, index) => (
                     <MenuItem
                         onClick={event => handleChange(event, index)}
@@ -52,7 +52,7 @@
                         {ucFirst(theme.name)}
                     </MenuItem>
                 ))}
-            </Menu>
+            </Menu> */}
         </>
     );
 };
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatPreparationController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatPreparationController.java
new file mode 100644
index 0000000..09194cd
--- /dev/null
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/MatPreparationController.java
@@ -0,0 +1,96 @@
+package com.vincent.rsf.server.manager.controller;
+
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.vincent.rsf.framework.common.R;
+import com.vincent.rsf.server.common.domain.BaseParam;
+import com.vincent.rsf.server.common.domain.PageParam;
+import com.vincent.rsf.server.common.utils.FieldsUtils;
+import com.vincent.rsf.server.manager.entity.Task;
+import com.vincent.rsf.server.manager.entity.TaskItem;
+import com.vincent.rsf.server.manager.entity.WkOrder;
+import com.vincent.rsf.server.manager.enums.OrderType;
+import com.vincent.rsf.server.manager.service.OutStockService;
+import com.vincent.rsf.server.manager.service.TaskService;
+import com.vincent.rsf.server.system.controller.BaseController;
+import io.swagger.annotations.Api;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RestController;
+
+import javax.annotation.Resource;
+import java.util.*;
+
+@RestController
+@Api(tags = "澶囨枡鍗�")
+public class MatPreparationController extends BaseController {
+
+    Logger logger = LoggerFactory.getLogger(OutStockController.class);
+
+    @Resource
+    private TaskService taskService;
+
+    @PostMapping("/preparation/page")
+    public R page(@RequestBody Map<String, Object> map) {
+
+//        JSONObject jsonObject = new JSONObject(map);
+//        jsonObject.put("orderCode", "BL25090927787678");
+//        jsonObject.put("orderStatus", 1);
+//        jsonObject.put("orderTime", new Date());
+//        jsonObject.put("anfme", 100);
+//        List<JSONObject> list = new ArrayList<>();
+//        list.add(jsonObject);
+//
+//        return R.ok().add(list);
+
+        BaseParam baseParam = buildParam(map, BaseParam.class);
+        PageParam<Task, BaseParam> pageParam = new PageParam<>(baseParam, Task.class);
+        QueryWrapper<Task> queryWrapper = pageParam.buildWrapper(true);
+        return R.ok().add(taskService.page(pageParam, queryWrapper));
+    }
+
+//    @PreAuthorize("hasAuthority('manager:outStock:list')")
+    @PostMapping("/preparation/list")
+    public R list(@RequestBody Map<String, Object> map) {
+
+        return R.ok().add(taskService.list());
+    }
+
+
+//    @PreAuthorize("hasAuthority('manager:taskItem:list')")
+    @PostMapping("/preparationItem/page")
+    public R itemPage(@RequestBody Map<String, Object> map) {
+//        BaseParam baseParam = buildParam(map, BaseParam.class);
+//        PageParam<TaskItem, BaseParam> pageParam = new PageParam<>(baseParam, TaskItem.class);
+//        /**鎷兼帴鎵╁睍瀛楁*/
+//        PageParam<TaskItem, BaseParam> page = taskItemService.page(pageParam, pageParam.buildWrapper(true));
+//        List<TaskItem> records = page.getRecords();
+//        for (TaskItem record : records) {
+//            if (!Objects.isNull(record.getFieldsIndex())) {
+//                Map<String, String> fields = FieldsUtils.getFields(record.getFieldsIndex());
+//                record.setExtendFields(fields);
+//            }
+//        }
+//        page.setRecords(records);
+
+
+        JSONObject jsonObject = new JSONObject(map);
+        jsonObject.put("matnrCode", "BL25090927787678");
+        jsonObject.put("maktx", "鎷夋潌");
+        jsonObject.put("unit", "涓�");
+        jsonObject.put("spec", "閾濆悎閲� 閾惰壊");
+        jsonObject.put("model", "澶�");
+        jsonObject.put("anfme", 100);
+        jsonObject.put("workQty", 60);
+        jsonObject.put("status", 11);
+        List<JSONObject> list = new ArrayList<>();
+        list.add(jsonObject);
+        return R.ok().add(list);
+    }
+
+}

--
Gitblit v1.9.1