From 25f276990df41cc8bc03a9427874f70776b04bea Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期三, 08 一月 2025 16:18:48 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/map/insight/shelf/index.jsx |   69 +++++++++++++++++++++++++++-------
 1 files changed, 54 insertions(+), 15 deletions(-)

diff --git a/zy-acs-flow/src/map/insight/shelf/index.jsx b/zy-acs-flow/src/map/insight/shelf/index.jsx
index 75f55fd..c5d6076 100644
--- a/zy-acs-flow/src/map/insight/shelf/index.jsx
+++ b/zy-acs-flow/src/map/insight/shelf/index.jsx
@@ -1,48 +1,87 @@
 import React, { useState, useRef, useEffect } from 'react';
 import { useTranslate } from "react-admin";
 import { Box, Typography, Tabs, Tab, Stack, useTheme, Divider } from '@mui/material';
+import ShelfMain from './ShelfMain';
+import JsonShow from '../../JsonShow';
+import { getLocGroup } from '../../http';
 
 const ShelfInsight = (props) => {
-    const { } = props;
+    const { sprite, setTitle } = props;
     const theme = useTheme();
-    const themeMode = theme.palette.mode;
     const translate = useTranslate();
 
     const [activeTab, setActiveTab] = useState(0);
+    const [curShelfInfo, setCurShelfInfo] = useState(null);
+    const [curLocNo, setCurLocNo] = useState(null);
+
+    const fetchShelfInfo = (row, bay) => {
+        getLocGroup(row, bay, (response) => {
+            setCurShelfInfo(response);
+            const defaultLocNo = response[0]?.locNo;
+            setCurLocNo(defaultLocNo);
+        });
+    }
+
+    useEffect(() => {
+        if (sprite) {
+            const { row, bay } = sprite.data;
+            if (row && bay) {
+                fetchShelfInfo(row, bay);
+            }
+        }
+
+        return () => {
+            setCurLocNo(null);
+            setCurShelfInfo(null);
+        }
+    }, [sprite]);
+
+    useEffect(() => {
+        if (curLocNo) {
+            setTitle(translate('page.map.devices.shelf') + ' - ' + curLocNo);
+        }
+
+        return () => {
+            setTitle(null);
+        }
+    }, [curLocNo])
 
     const handleTabChange = (event, newValue) => {
         setActiveTab(newValue);
     };
 
     return (
-        <>
+        <Box sx={{ height: '100%', display: 'flex', flexDirection: 'column' }}>
             <Tabs
                 value={activeTab}
                 onChange={handleTabChange}
-                indicatorColor="primary"
-                textColor="primary"
                 centered
                 sx={{ mb: 0 }}
             >
-                <Tab label={translate('page.map.settings.map.title')} />
-                <Tab label={translate('page.map.settings.config.title')} />
+                <Tab label={translate('page.map.insight.title')} />
+                <Tab label={'JSON'} />
             </Tabs>
 
             <Divider />
 
-            <Box p={3}>
+            <Box flex={1} pt={2}>
                 {activeTab === 0 && (
-                    <Box>
-                        <h1>1</h1>
-                    </Box>
+                    <ShelfMain
+                        row={sprite?.data?.row}
+                        bay={sprite?.data?.bay}
+                        curLocNo={curLocNo}
+                        curShelfInfo={curShelfInfo}
+                        setCurLocNo={setCurLocNo}
+                    />
                 )}
                 {activeTab === 1 && (
-                    <Box>
-                        <h1>2</h1>
-                    </Box>
+                    <JsonShow
+                        data={curShelfInfo || sprite?.data}
+                        height={550}
+                    />
                 )}
             </Box>
-        </>
+        </Box>
     )
 }
 

--
Gitblit v1.9.1