| | |
| | | import React, { useState, useRef, useEffect, useMemo, useCallback } from "react"; |
| | | import { Drawer, Box, Typography, Card, IconButton, Stack } from '@mui/material'; |
| | | import CloseIcon from '@mui/icons-material/Close'; |
| | | import * as Common from '@/utils/common'; |
| | | import { PAGE_DRAWER_WIDTH } from '@/config/setting'; |
| | | |
| | | const Device = (props) => { |
| | | const { |
| | | title = 'Drawer', |
| | | open, |
| | | onCancel, |
| | | closeCallback, |
| | | width = PAGE_DRAWER_WIDTH, |
| | | children |
| | | } = props; |
| | | |
| | | const Device = () => { |
| | | const handleClose = () => { |
| | | onCancel(); |
| | | if (closeCallback) { |
| | | closeCallback(); |
| | | } |
| | | } |
| | | |
| | | return ( |
| | | <> |
| | | |
| | | </> |
| | | <Drawer |
| | | variant="persistent" |
| | | open={open} |
| | | anchor="right" |
| | | onClose={handleClose} |
| | | sx={{ zIndex: 100 }} |
| | | > |
| | | {open && ( |
| | | <Box pt={12} width={{ xs: '100vW', sm: width }} height={'calc(100vh - 200px);'} mt={{ xs: 2, sm: 1 }} sx={{ |
| | | }}> |
| | | <Stack direction="row" p={2}> |
| | | <Typography variant="h6" flex="1"> |
| | | {title} |
| | | </Typography> |
| | | <IconButton onClick={handleClose} size="small"> |
| | | <CloseIcon /> |
| | | </IconButton> |
| | | </Stack> |
| | | {children} |
| | | </Box> |
| | | )} |
| | | </Drawer> |
| | | ) |
| | | } |
| | | |
| | |
| | | const switchMode = (mode) => { |
| | | switch (mode) { |
| | | case MapMode.OBSERVER_MODE: |
| | | console.log('a'); |
| | | setDeviceVisible(false); |
| | | break |
| | | case MapMode.MOVABLE_MODE: |
| | | console.log('b'); |
| | | setDeviceVisible(true); |
| | | break |
| | | case MapMode.SETTINGS_MODE: |
| | | console.log('c'); |
| | | setDeviceVisible(false); |
| | | break |
| | | default: |
| | | break |
| | |
| | | flexDirection: 'column', |
| | | }} |
| | | > |
| | | {/* header */} |
| | | <Box |
| | | sx={{ |
| | | display: 'flex', |
| | |
| | | padding: '0 16px', |
| | | height: '64px', |
| | | flexShrink: 0, // keep height |
| | | zIndex: 200 |
| | | }} |
| | | > |
| | | <TextField |
| | |
| | | variant="contained" |
| | | color="primary" |
| | | sx={{ mr: 1 }} |
| | | onClick={() => setDeviceVisible(!deviceVisible)} |
| | | > |
| | | 添加模型 |
| | | </Button> |
| | |
| | | <MenuItem value={MapMode.SETTINGS_MODE}>配置模式</MenuItem> |
| | | </Select> |
| | | </Box> |
| | | {/* content */} |
| | | <Box |
| | | sx={{ |
| | | flexGrow: 1, // fill remaining of map space |
| | |
| | | ))} |
| | | </SpeedDial> |
| | | </Box> |
| | | |
| | | <Device |
| | | open={deviceVisible} |
| | | onCancel={() => { |
| | |
| | | }} |
| | | onDrop={onDrop} |
| | | /> |
| | | |
| | | </Box> |
| | | ); |
| | | } |