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:
Dunqing 2023-04-17 21:31:24 +08:00 committed by GitHub
parent f5df009465
commit 42152568ee
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 76 additions and 43 deletions

View File

@ -14,14 +14,13 @@ const defaultImage =
'';
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 field = getField(fieldNames?.field);
const [isMapInitialization, setIsMapInitialization] = useState(false);
const mapRef = useRef<AMapForwardedRefProps>();
const geometryUtils: AMap.IGeometryUtil = mapRef.current?.aMap?.GeometryUtil;
const [record, setRecord] = useState();
const [visible, setVisible] = useState(false);
const [selectingMode, setSelecting] = useState('');
const { t } = useMapTranslation();
const compile = useCompile();
@ -166,7 +165,6 @@ export const MapBlock = (props) => {
}
if (data) {
setVisible(true);
setRecord(data);
}
};
@ -241,9 +239,7 @@ export const MapBlock = (props) => {
) : null}
</Space>
</div>
<RecordProvider record={record}>
<MapBlockDrawer visible={visible} setVisible={setVisible} record={null} />
</RecordProvider>
<MapBlockDrawer record={record} setVisible={setRecord} />
<AMap
{...field?.uiSchema?.['x-component-props']}
ref={mapRefCallback}
@ -261,7 +257,7 @@ export const MapBlock = (props) => {
};
const MapBlockDrawer = (props) => {
const { visible, setVisible } = props;
const { setVisible, record } = props;
const fieldSchema = useFieldSchema();
const schema: Schema = useMemo(
() =>
@ -276,8 +272,10 @@ const MapBlockDrawer = (props) => {
return (
schema && (
<ActionContext.Provider value={{ visible, setVisible }}>
<RecursionField schema={schema} name={schema.name} />
<ActionContext.Provider value={{ visible: !!record, setVisible }}>
<RecordProvider record={record}>
<RecursionField schema={schema} name={schema.name} />
</RecordProvider>
</ActionContext.Provider>
)
);

View File

@ -19,6 +19,10 @@ export interface AMapComponentProps {
onChange?: (value: number[]) => void;
disabled?: boolean;
mapType: string;
/**
* only ReadPretty
*/
readonly: string;
zoom: number;
type: MapEditorType;
style?: React.CSSProperties;
@ -80,7 +84,7 @@ export interface AMapForwardedRefProps {
const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps>((props, ref) => {
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 fieldSchema = useFieldSchema();
const aMap = useRef<any>();
@ -252,7 +256,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
// 编辑时
useEffect(() => {
if (!aMap.current) return;
if (!value || overlay.current) {
if (!value || (!readonly && overlay.current)) {
return;
}
@ -260,10 +264,11 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
// 聚焦在编辑的位置
map.current.setFitView([nextOverlay]);
overlay.current = nextOverlay;
createEditor();
setTarget();
}, [value, needUpdateFlag, type, commonOptions]);
if (!disabled) {
createEditor();
setTarget();
}
}, [value, needUpdateFlag, type, commonOptions, disabled, readonly]);
// 当在编辑时,关闭 mouseTool
useEffect(() => {
@ -285,6 +290,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
createEditor();
}, [disabled, needUpdateFlag, type]);
// 当值变更时toggle mouseTool
useEffect(() => {
if (!mouseTool.current || !editor.current) return;
const target = editor.current.getTarget();
@ -310,7 +316,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
plugins: ['AMap.MouseTool', 'AMap.PolygonEditor', 'AMap.PolylineEditor', 'AMap.CircleEditor'],
})
.then((amap) => {
setTimeout(() => {
requestIdleCallback(() => {
map.current = new amap.Map(id.current, {
resizeEnable: true,
zoom,
@ -318,7 +324,7 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
aMap.current = amap;
setErrMessage('');
forceUpdate([]);
}, Math.random() * 300);
});
})
.catch((err) => {
if (err.includes('多个不一致的 key')) {
@ -393,17 +399,23 @@ const AMapComponent = React.forwardRef<AMapForwardedRefProps, AMapComponentProps
icon={<SyncOutlined />}
></Button>
</div>
<div
className={css`
position: absolute;
bottom: 20px;
left: 10px;
z-index: 2;
pointer-events: none;
`}
>
<Alert message={t('Click to select the starting point and double-click to end the drawing')} type="info" />
</div>
{type !== 'point' ? (
<div
className={css`
position: absolute;
bottom: 20px;
left: 10px;
z-index: 2;
pointer-events: none;
`}
>
<Alert
message={t('Click to select the starting point and double-click to end the drawing')}
type="info"
/>
</div>
) : null}
<div
className={css`
position: absolute;

View File

@ -3,7 +3,7 @@ import { useBoolean } from 'ahooks';
import { Button, Card, Form, Input, message, Tabs } from 'antd';
import React, { useEffect, useMemo } from 'react';
import { MapTypes } from '../constants';
import { MapConfigurationResourceKey, useMapConfiguration } from '../hooks';
import { MapConfigurationResourceKey, getSSKey, useMapConfiguration } from '../hooks';
import { useMapTranslation } from '../locale';
const AMapConfiguration = ({ type }) => {
@ -30,6 +30,7 @@ const AMapConfiguration = ({ type }) => {
type,
})
.then((res) => {
sessionStorage.removeItem(getSSKey(type));
message.success(t('Saved successfully'));
})
.catch((err) => {

View File

@ -1,5 +1,5 @@
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 AMapComponent from './AMap';
@ -10,8 +10,7 @@ const ReadPretty = (props) => {
const collectionField = getField(fieldSchema.name);
const mapType = props.mapType || collectionField?.uiSchema['x-component-props']?.mapType;
const field = useField();
const form = useForm()
const form = useForm();
useEffect(() => {
if (!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;

View File

@ -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 getSSKey = (type) => {
return `NOCOBASE_PLUGIN_MAP_CONFIGURATION_${type}`;
};
export const useMapConfiguration = (type: string) => {
return useRequest({
resource: MapConfigurationResourceKey,
action: 'get',
params: {
type,
// 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,
action: 'get',
params: {
type,
},
},
}).data?.data;
}
{
onSuccess(data) {
sessionStorage.setItem(getSSKey(type), JSON.stringify(data?.data));
},
refreshOnWindowFocus: false,
refreshDeps: [],
manual: config ? true : false,
},
).data?.data;
};