mirror of
https://github.com/nocobase/nocobase
synced 2024-11-15 08:55:33 +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) => {
|
||||
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>
|
||||
)
|
||||
);
|
||||
|
@ -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;
|
||||
|
@ -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) => {
|
||||
|
@ -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;
|
||||
|
@ -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;
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user