优化MapSelector

master
LiuJiaNan 2025-11-14 15:26:23 +08:00
parent d3e64e0004
commit a2843dc788
2 changed files with 41 additions and 23 deletions

View File

@ -22,6 +22,8 @@ export interface MapSelectorProps {
area?: string; area?: string;
/** 是否显示所属区域 */ /** 是否显示所属区域 */
showArea?: boolean; showArea?: boolean;
/** 是否只查看 */
disable?: boolean;
/** 确认选择回调 */ /** 确认选择回调 */
onConfirm?: (longitude: number | string, latitude: number | string, extra: { area: string }) => void; onConfirm?: (longitude: number | string, latitude: number | string, extra: { area: string }) => void;
} }

View File

@ -13,6 +13,7 @@ const MapSelector = (props) => {
onConfirm, onConfirm,
area = "", area = "",
showArea = false, showArea = false,
disable = false,
} = props; } = props;
const mapContainerRef = useRef(null); const mapContainerRef = useRef(null);
@ -66,6 +67,7 @@ const MapSelector = (props) => {
} }
// 添加点击事件 // 添加点击事件
if (!disable) {
map.addEventListener("click", (event) => { map.addEventListener("click", (event) => {
map.clearOverlays(); map.clearOverlays();
const point = new window.BMapGL.Point(event.latlng.lng, event.latlng.lat); const point = new window.BMapGL.Point(event.latlng.lng, event.latlng.lat);
@ -75,6 +77,7 @@ const MapSelector = (props) => {
setCurrentLongitude(event.latlng.lng); setCurrentLongitude(event.latlng.lng);
}); });
} }
}
setLoading(false); setLoading(false);
} }
@ -149,10 +152,19 @@ const MapSelector = (props) => {
open={visible} open={visible}
title="坐标" title="坐标"
onCancel={handleClose} onCancel={handleClose}
onOk={handleConfirm}
width={1000} width={1000}
destroyOnHidden={false} destroyOnHidden={false}
afterClose={handleAfterClose} afterClose={handleAfterClose}
footer={[
<Button key="back" onClick={handleClose}>
取消
</Button>,
!disable && (
<Button key="submit" type="primary" onClick={handleConfirm}>
确定
</Button>
),
]}
> >
<Form labelAlign="right" labelCol={{ span: 6 }} wrapperCol={{ span: 18 }}> <Form labelAlign="right" labelCol={{ span: 6 }} wrapperCol={{ span: 18 }}>
{ {
@ -169,6 +181,8 @@ const MapSelector = (props) => {
</Row> </Row>
) )
} }
{
!disable && (
<Row gutter={24}> <Row gutter={24}>
<Col span={12}> <Col span={12}>
<Form.Item label="关键字搜索"> <Form.Item label="关键字搜索">
@ -183,6 +197,8 @@ const MapSelector = (props) => {
</Form.Item> </Form.Item>
</Col> </Col>
</Row> </Row>
)
}
<Row gutter={24}> <Row gutter={24}>
<Col span={12}> <Col span={12}>
<Form.Item label="经度"> <Form.Item label="经度">