1
zhang
2025-06-17 2d133dbde15886b20e22f0766880d23cb9bb10a8
zy-acs-flow/src/map/insight/index.jsx
@@ -6,8 +6,10 @@
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 } = props;
@@ -39,7 +41,7 @@
                    }}>
                        <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 />
@@ -60,23 +62,11 @@
                                borderRadius: '8px',
                            }}>
                                <CardContent sx={{ height: '100%' }}>
                                    {deviceType === DEVICE_TYPE.SHELF && (
                                        <>
                                            <ShelfInsight
                                                sprite={sprite}
                                                setTitle={setTitle}
                                            />
                                        </>
                                    )}
                                    {deviceType === DEVICE_TYPE.AGV && (
                                        <>
                                            <AgvInsight
                                                sprite={sprite}
                                                setTitle={setTitle}
                                            />
                                        </>
                                    )}
                                    <DeviceContent
                                        deviceType={deviceType}
                                        sprite={sprite}
                                        setTitle={setTitle}
                                    />
                                </CardContent>
                            </Card>
                        </Box>
@@ -87,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;