From fbc75a189b3f99527f4130e944829ee9f7b13056 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@gmail.com>
Date: 星期六, 22 三月 2025 10:24:22 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/map/insight/shelf/index.jsx |   84 ++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 80 insertions(+), 4 deletions(-)

diff --git a/zy-acs-flow/src/map/insight/shelf/index.jsx b/zy-acs-flow/src/map/insight/shelf/index.jsx
index 49465ba..c5d6076 100644
--- a/zy-acs-flow/src/map/insight/shelf/index.jsx
+++ b/zy-acs-flow/src/map/insight/shelf/index.jsx
@@ -1,11 +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 { sprite, setTitle } = props;
+    const theme = useTheme();
+    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 (
-        <>
-            <h1>SHleft</h1>
-        </>
+        <Box sx={{ height: '100%', display: 'flex', flexDirection: 'column' }}>
+            <Tabs
+                value={activeTab}
+                onChange={handleTabChange}
+                centered
+                sx={{ mb: 0 }}
+            >
+                <Tab label={translate('page.map.insight.title')} />
+                <Tab label={'JSON'} />
+            </Tabs>
+
+            <Divider />
+
+            <Box flex={1} pt={2}>
+                {activeTab === 0 && (
+                    <ShelfMain
+                        row={sprite?.data?.row}
+                        bay={sprite?.data?.bay}
+                        curLocNo={curLocNo}
+                        curShelfInfo={curShelfInfo}
+                        setCurLocNo={setCurLocNo}
+                    />
+                )}
+                {activeTab === 1 && (
+                    <JsonShow
+                        data={curShelfInfo || sprite?.data}
+                        height={550}
+                    />
+                )}
+            </Box>
+        </Box>
     )
 }
 

--
Gitblit v1.9.1