mirror of
https://github.com/nocobase/nocobase
synced 2024-11-15 13:26:44 +00:00
fix(map-plugin): some data is incorrect (#1717)
* fix: data is incorrect * fix: the data is incorrect when switch page at details * feat: improve map configuration * fix: shouldn't display tip when type = point * fix: cache
This commit is contained in:
parent
f5df009465
commit
42152568ee
@ -14,14 +14,13 @@ const defaultImage =
|
|||||||
'';
|
'';
|
||||||
|
|
||||||
export const MapBlock = (props) => {
|
export const MapBlock = (props) => {
|
||||||
const { fieldNames, dataSource = [], fixedBlock, zoom, selectedRecordKeys, setSelectedRecordKeys } = useProps(props);
|
const { fieldNames, dataSource = [], fixedBlock, zoom, setSelectedRecordKeys } = useProps(props);
|
||||||
const { getField, getPrimaryKey } = useCollection();
|
const { getField, getPrimaryKey } = useCollection();
|
||||||
const field = getField(fieldNames?.field);
|
const field = getField(fieldNames?.field);
|
||||||
const [isMapInitialization, setIsMapInitialization] = useState(false);
|
const [isMapInitialization, setIsMapInitialization] = useState(false);
|
||||||
const mapRef = useRef<AMapForwardedRefProps>();
|
const mapRef = useRef<AMapForwardedRefProps>();
|
||||||
const geometryUtils: AMap.IGeometryUtil = mapRef.current?.aMap?.GeometryUtil;
|
const geometryUtils: AMap.IGeometryUtil = mapRef.current?.aMap?.GeometryUtil;
|
||||||
const [record, setRecord] = useState();
|
const [record, setRecord] = useState();
|
||||||
const [visible, setVisible] = useState(false);
|
|
||||||
const [selectingMode, setSelecting] = useState('');
|
const [selectingMode, setSelecting] = useState('');
|
||||||
const { t } = useMapTranslation();
|
const { t } = useMapTranslation();
|
||||||
const compile = useCompile();
|
const compile = useCompile();
|
||||||
@ -166,7 +165,6 @@ export const MapBlock = (props) => {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (data) {
|
if (data) {
|
||||||
setVisible(true);
|
|
||||||
setRecord(data);
|
setRecord(data);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -241,9 +239,7 @@ export const MapBlock = (props) => {
|
|||||||
) : null}
|
) : null}
|
||||||
</Space>
|
</Space>
|
||||||
</div>
|
</div>
|
||||||
<RecordProvider record={record}>
|
<MapBlockDrawer record={record} setVisible={setRecord} />
|
||||||
<MapBlockDrawer visible={visible} setVisible={setVisible} record={null} />
|
|
||||||
</RecordProvider>
|
|
||||||
<AMap
|
<AMap
|
||||||
{...field?.uiSchema?.['x-component-props']}
|
{...field?.uiSchema?.['x-component-props']}
|
||||||
ref={mapRefCallback}
|
ref={mapRefCallback}
|
||||||
@ -261,7 +257,7 @@ export const MapBlock = (props) => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const MapBlockDrawer = (props) => {
|
const MapBlockDrawer = (props) => {
|
||||||
const { visible, setVisible } = props;
|
const { setVisible, record } = props;
|
||||||
const fieldSchema = useFieldSchema();
|
const fieldSchema = useFieldSchema();
|
||||||
const schema: Schema = useMemo(
|
const schema: Schema = useMemo(
|
||||||
() =>
|
() =>
|
||||||
@ -276,8 +272,10 @@ const MapBlockDrawer = (props) => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
schema && (
|
schema && (
|
||||||
<ActionContext.Provider value={{ visible, setVisible }}>
|
<ActionContext.Provider value={{ visible: !!record, setVisible }}>
|
||||||
|
<RecordProvider record={record}>
|
||||||
<RecursionField schema={schema} name={schema.name} />
|
<RecursionField schema={schema} name={schema.name} />
|
||||||
|
</RecordProvider>
|
||||||
</ActionContext.Provider>
|
</ActionContext.Provider>
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
@ -19,6 +19,10 @@ export interface AMapComponentProps {
|
|||||||
onChange?: (value: number[]) => void;
|
onChange?: (value: number[]) => void;
|
||||||
disabled?: boolean;
|
disabled?: boolean;
|
||||||
mapType: string;
|
mapType: string;
|
||||||
|
/**
|
||||||
|
* only ReadPretty
|
||||||
|
*/
|
||||||
|
readonly: string;
|
||||||
zoom: number;
|
zoom: number;
|
||||||
type: MapEditorType;
|
type: MapEditorType;
|
||||||
style?: React.CSSProperties;
|
style?: React.CSSProperties;
|
||||||
@ -80,7 +84,7 @@ export interface AMapForwardedRefProps {
|
|||||||
|
|
||||||
const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps>((props, ref) => {
|
const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps>((props, ref) => {
|
||||||
const { accessKey, securityJsCode } = useMapConfiguration(props.mapType) || {};
|
const { accessKey, securityJsCode } = useMapConfiguration(props.mapType) || {};
|
||||||
const { value, onChange, block = false, disabled = block, zoom = 13, overlayCommonOptions } = props;
|
const { value, onChange, block = false, readonly, disabled = block, zoom = 13, overlayCommonOptions } = props;
|
||||||
const { t } = useMapTranslation();
|
const { t } = useMapTranslation();
|
||||||
const fieldSchema = useFieldSchema();
|
const fieldSchema = useFieldSchema();
|
||||||
const aMap = useRef<any>();
|
const aMap = useRef<any>();
|
||||||
@ -252,7 +256,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
|
|||||||
// 编辑时
|
// 编辑时
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!aMap.current) return;
|
if (!aMap.current) return;
|
||||||
if (!value || overlay.current) {
|
if (!value || (!readonly && overlay.current)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -260,10 +264,11 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
|
|||||||
// 聚焦在编辑的位置
|
// 聚焦在编辑的位置
|
||||||
map.current.setFitView([nextOverlay]);
|
map.current.setFitView([nextOverlay]);
|
||||||
overlay.current = nextOverlay;
|
overlay.current = nextOverlay;
|
||||||
|
if (!disabled) {
|
||||||
createEditor();
|
createEditor();
|
||||||
setTarget();
|
setTarget();
|
||||||
}, [value, needUpdateFlag, type, commonOptions]);
|
}
|
||||||
|
}, [value, needUpdateFlag, type, commonOptions, disabled, readonly]);
|
||||||
|
|
||||||
// 当在编辑时,关闭 mouseTool
|
// 当在编辑时,关闭 mouseTool
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@ -285,6 +290,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
|
|||||||
createEditor();
|
createEditor();
|
||||||
}, [disabled, needUpdateFlag, type]);
|
}, [disabled, needUpdateFlag, type]);
|
||||||
|
|
||||||
|
// 当值变更时,toggle mouseTool
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!mouseTool.current || !editor.current) return;
|
if (!mouseTool.current || !editor.current) return;
|
||||||
const target = editor.current.getTarget();
|
const target = editor.current.getTarget();
|
||||||
@ -310,7 +316,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
|
|||||||
plugins: ['AMap.MouseTool', 'AMap.PolygonEditor', 'AMap.PolylineEditor', 'AMap.CircleEditor'],
|
plugins: ['AMap.MouseTool', 'AMap.PolygonEditor', 'AMap.PolylineEditor', 'AMap.CircleEditor'],
|
||||||
})
|
})
|
||||||
.then((amap) => {
|
.then((amap) => {
|
||||||
setTimeout(() => {
|
requestIdleCallback(() => {
|
||||||
map.current = new amap.Map(id.current, {
|
map.current = new amap.Map(id.current, {
|
||||||
resizeEnable: true,
|
resizeEnable: true,
|
||||||
zoom,
|
zoom,
|
||||||
@ -318,7 +324,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
|
|||||||
aMap.current = amap;
|
aMap.current = amap;
|
||||||
setErrMessage('');
|
setErrMessage('');
|
||||||
forceUpdate([]);
|
forceUpdate([]);
|
||||||
}, Math.random() * 300);
|
});
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
if (err.includes('多个不一致的 key')) {
|
if (err.includes('多个不一致的 key')) {
|
||||||
@ -393,6 +399,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
|
|||||||
icon={<SyncOutlined />}
|
icon={<SyncOutlined />}
|
||||||
></Button>
|
></Button>
|
||||||
</div>
|
</div>
|
||||||
|
{type !== 'point' ? (
|
||||||
<div
|
<div
|
||||||
className={css`
|
className={css`
|
||||||
position: absolute;
|
position: absolute;
|
||||||
@ -402,8 +409,13 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
|
|||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
`}
|
`}
|
||||||
>
|
>
|
||||||
<Alert message={t('Click to select the starting point and double-click to end the drawing')} type="info" />
|
<Alert
|
||||||
|
message={t('Click to select the starting point and double-click to end the drawing')}
|
||||||
|
type="info"
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
|
) : null}
|
||||||
|
|
||||||
<div
|
<div
|
||||||
className={css`
|
className={css`
|
||||||
position: absolute;
|
position: absolute;
|
||||||
|
@ -3,7 +3,7 @@ import { useBoolean } from 'ahooks';
|
|||||||
import { Button, Card, Form, Input, message, Tabs } from 'antd';
|
import { Button, Card, Form, Input, message, Tabs } from 'antd';
|
||||||
import React, { useEffect, useMemo } from 'react';
|
import React, { useEffect, useMemo } from 'react';
|
||||||
import { MapTypes } from '../constants';
|
import { MapTypes } from '../constants';
|
||||||
import { MapConfigurationResourceKey, useMapConfiguration } from '../hooks';
|
import { MapConfigurationResourceKey, getSSKey, useMapConfiguration } from '../hooks';
|
||||||
import { useMapTranslation } from '../locale';
|
import { useMapTranslation } from '../locale';
|
||||||
|
|
||||||
const AMapConfiguration = ({ type }) => {
|
const AMapConfiguration = ({ type }) => {
|
||||||
@ -30,6 +30,7 @@ const AMapConfiguration = ({ type }) => {
|
|||||||
type,
|
type,
|
||||||
})
|
})
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
|
sessionStorage.removeItem(getSSKey(type));
|
||||||
message.success(t('Saved successfully'));
|
message.success(t('Saved successfully'));
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { useField, useFieldSchema, useForm } from '@formily/react';
|
import { useField, useFieldSchema, useForm } from '@formily/react';
|
||||||
import { EllipsisWithTooltip, useCollection, useTableBlockContext } from '@nocobase/client';
|
import { EllipsisWithTooltip, useCollection } from '@nocobase/client';
|
||||||
import React, { useEffect } from 'react';
|
import React, { useEffect } from 'react';
|
||||||
import AMapComponent from './AMap';
|
import AMapComponent from './AMap';
|
||||||
|
|
||||||
@ -10,8 +10,7 @@ const ReadPretty = (props) => {
|
|||||||
const collectionField = getField(fieldSchema.name);
|
const collectionField = getField(fieldSchema.name);
|
||||||
const mapType = props.mapType || collectionField?.uiSchema['x-component-props']?.mapType;
|
const mapType = props.mapType || collectionField?.uiSchema['x-component-props']?.mapType;
|
||||||
const field = useField();
|
const field = useField();
|
||||||
const form = useForm()
|
const form = useForm();
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!field.title && collectionField?.uiSchema?.title) {
|
if (!field.title && collectionField?.uiSchema?.title) {
|
||||||
field.title = collectionField.uiSchema.title;
|
field.title = collectionField.uiSchema.title;
|
||||||
@ -28,7 +27,7 @@ const ReadPretty = (props) => {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return mapType === 'amap' ? <AMapComponent mapType={mapType} {...props}></AMapComponent> : null;
|
return mapType === 'amap' ? <AMapComponent readonly mapType={mapType} {...props}></AMapComponent> : null;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default ReadPretty;
|
export default ReadPretty;
|
||||||
|
@ -1,15 +1,38 @@
|
|||||||
import { useRequest } from "@nocobase/client";
|
import { useRequest } from '@nocobase/client';
|
||||||
|
import { useMemo } from 'react';
|
||||||
|
|
||||||
export const MapConfigurationResourceKey = 'map-configuration';
|
export const MapConfigurationResourceKey = 'map-configuration';
|
||||||
|
export const getSSKey = (type) => {
|
||||||
|
return `NOCOBASE_PLUGIN_MAP_CONFIGURATION_${type}`;
|
||||||
|
};
|
||||||
|
|
||||||
export const useMapConfiguration = (type: string) => {
|
export const useMapConfiguration = (type: string) => {
|
||||||
return useRequest({
|
// cache
|
||||||
|
const config = useMemo(() => {
|
||||||
|
const d = sessionStorage.getItem(getSSKey(type));
|
||||||
|
if (d) {
|
||||||
|
return JSON.parse(d);
|
||||||
|
}
|
||||||
|
return d;
|
||||||
|
}, [type]);
|
||||||
|
|
||||||
|
if (config) return config;
|
||||||
|
|
||||||
|
return useRequest(
|
||||||
|
{
|
||||||
resource: MapConfigurationResourceKey,
|
resource: MapConfigurationResourceKey,
|
||||||
action: 'get',
|
action: 'get',
|
||||||
params: {
|
params: {
|
||||||
type,
|
type,
|
||||||
},
|
},
|
||||||
}).data?.data;
|
},
|
||||||
}
|
{
|
||||||
|
onSuccess(data) {
|
||||||
|
sessionStorage.setItem(getSSKey(type), JSON.stringify(data?.data));
|
||||||
|
},
|
||||||
|
refreshOnWindowFocus: false,
|
||||||
|
refreshDeps: [],
|
||||||
|
manual: config ? true : false,
|
||||||
|
},
|
||||||
|
).data?.data;
|
||||||
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user