From ee5046d151a858339aa137790bc830efe7f55980 Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期三, 18 六月 2025 15:13:14 +0800 Subject: [PATCH] 1 --- zy-acs-flow/src/map/insight/index.jsx | 70 ++++++++++++++++++++++++----------- 1 files changed, 48 insertions(+), 22 deletions(-) diff --git a/zy-acs-flow/src/map/insight/index.jsx b/zy-acs-flow/src/map/insight/index.jsx index 48c10db..3bc802c 100644 --- a/zy-acs-flow/src/map/insight/index.jsx +++ b/zy-acs-flow/src/map/insight/index.jsx @@ -6,14 +6,17 @@ import { DEVICE_TYPE, } from '../constants'; +import JsonShow from '../JsonShow'; import ShelfInsight from './shelf'; import AgvInsight from './agv'; +import PointInsight from './point'; const Insight = (props) => { - const { open, onCancel, sprite, width = PAGE_DRAWER_WIDTH, title } = props; + const { open, onCancel, sprite, width = PAGE_DRAWER_WIDTH } = props; const theme = useTheme(); const themeMode = theme.palette.mode; const translate = useTranslate(); + const [title, setTitle] = useState(null); const deviceType = sprite?.data?.type; @@ -22,7 +25,7 @@ } useEffect(() => { - }, []) + }, [sprite]) return ( <> @@ -34,18 +37,19 @@ sx={{ zIndex: 100, opacity: 1 }} > {open && ( - <Box pt={12} width={{ xs: '100vW', sm: width }} height={'calc(100vh - 200px);'} mt={{ xs: 2, sm: 1 }} sx={{ + <Box pt={12} width={{ xs: '100vW', sm: width }} height={'calc(100vh - 100px);'} mt={{ xs: 2, sm: 1 }} sx={{ }}> - <Stack direction="row" p={2}> + <Stack direction="row" p={2} pt={3}> <Typography variant="h6" flex="1"> - {title || translate('page.map.insight.title')} + {title || ''} </Typography> <IconButton onClick={handleClose} size="small"> <CloseIcon /> </IconButton> </Stack> - <Box p={2} pt={1}> + <Box p={2} pt={0} height='100%'> <Card sx={{ + height: '100%', transition: '0.3s', boxShadow: themeMode === 'light' ? '0px 2px 8px rgba(0, 0, 0, 0.1)' @@ -57,22 +61,12 @@ }, borderRadius: '8px', }}> - <CardContent> - {deviceType === DEVICE_TYPE.SHELF && ( - <> - <ShelfInsight - sprite={sprite} - /> - </> - )} - - {deviceType === DEVICE_TYPE.AGV && ( - <> - <AgvInsight - - /> - </> - )} + <CardContent sx={{ height: '100%' }}> + <DeviceContent + deviceType={deviceType} + sprite={sprite} + setTitle={setTitle} + /> </CardContent> </Card> </Box> @@ -83,5 +77,37 @@ ) } +const DeviceContent = ({ deviceType, sprite, setTitle }) => { + switch (deviceType) { + case DEVICE_TYPE.SHELF: + return ( + <ShelfInsight + sprite={sprite} + setTitle={setTitle} + /> + ) + case DEVICE_TYPE.AGV: + return ( + <AgvInsight + sprite={sprite} + setTitle={setTitle} + /> + ) + case DEVICE_TYPE.POINT: + return ( + <PointInsight + sprite={sprite} + setTitle={setTitle} + /> + ) + default: + return ( + <JsonShow + data={sprite?.data} + height={550} + /> + ) + } +} export default Insight; \ No newline at end of file -- Gitblit v1.9.1