#
vincentlu
2025-12-09 0ffd2aa6ffc171ce9efbe4b0bf5232347c4fb200
zy-acs-flow/src/map/MapPage.jsx
@@ -19,11 +19,13 @@
import * as Http from './http';
import WebSocketClient from './websocket'
import ConfirmButton from "../page/components/ConfirmButton";
import { FitScreen, AltRoute, RotateRight } from '@mui/icons-material';
import { FitScreen, RotateRight, Flip } from '@mui/icons-material';
import MapSearch from "./header/MapSearch";
import { startupOrShutdown } from "./http";
import PulseSignal from "../page/components/PulseSignal";
import FakeFab from "./header/FakeFab";
import RouteFab from "./header/RouteFab";
import MoreOperate from "./header/MoreOperate";
let player;
let websocket;
@@ -166,6 +168,9 @@
                    Tool.beSettings(child, setCurSprite);
                })
                break
            case MAP_MODE.ZONING_MODE:
                Tool.removeAgvGraphics();
                break
            default:
                break
        }
@@ -284,6 +289,7 @@
                        <Button variant="contained" color="primary">
                            {translate('page.map.action.monitor')}
                        </Button>
                        <MoreOperate />
                    </>
                )}
@@ -337,6 +343,28 @@
                    </>
                )}
                {mode === MAP_MODE.ZONING_MODE && (
                    <>
                        <Button
                            variant="contained"
                            color="primary"
                            sx={{ mr: 2 }}
                            onClick={() => {
                                Tool.startZoneDrawing({
                                    promptText: translate('page.map.prompt.zoneName'),
                                    onComplete: ({ name }) => {
                                        if (name) {
                                            notify.success(translate('page.map.msg.zoneCreated', { name }));
                                        }
                                    }
                                });
                            }}
                        >
                            {translate('page.map.action.addZone')}
                        </Button>
                    </>
                )}
                <Select
                    value={mode ?? ''}
                    onChange={(event) => {
@@ -354,6 +382,7 @@
                    <MenuItem value={MAP_MODE.OBSERVER_MODE}>{translate('page.map.mode.observer')}</MenuItem>
                    <MenuItem value={MAP_MODE.MOVABLE_MODE}>{translate('page.map.mode.movable')}</MenuItem>
                    <MenuItem value={MAP_MODE.SETTINGS_MODE}>{translate('page.map.mode.settings')}</MenuItem>
                    <MenuItem value={MAP_MODE.ZONING_MODE}>{translate('page.map.mode.zoning')}</MenuItem>
                </Select>
            </Box>
            {/* content */}
@@ -409,16 +438,12 @@
                >
                    {mode !== MAP_MODE.MOVABLE_MODE && (
                        <>
                            <Fab
                                variant="extended"
                                color={showRoutes ? 'primary' : 'default'}
                                size="small"
                                onClick={() => {
                                    showRoutes ? Tool.hideRoutes(curZone, setShowRoutes) : Tool.showRoutes(curZone, setShowRoutes)
                                }}
                            >
                                <AltRoute />
                            </Fab>
                            <RouteFab
                                curZone={curZone}
                                showRoutes={showRoutes}
                                setShowRoutes={setShowRoutes}
                                notify={notify}
                            />
                            <FakeFab />
                        </>
                    )}
@@ -431,7 +456,7 @@
                        }}
                    >
                        <RotateRight />
                        {/* &nbsp;{translate('page.map.action.adapt')} */}
                        &nbsp;{translate('page.map.action.rotate')}&nbsp;
                    </Fab>
                    <Fab
                        variant="extended"
@@ -442,7 +467,7 @@
                        }}
                    >
                        <FitScreen />
                        {/* &nbsp;{translate('page.map.action.adapt')} */}
                        &nbsp;{translate('page.map.action.adapt')}&nbsp;
                    </Fab>
                </Box>
            </Box>