@nocobase/plugin-map 0.10.0-alpha.5 → 0.10.1-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/lib/client/block/MapBlock.js +8 -328
  2. package/lib/client/block/MapBlockInitializer.js +7 -6
  3. package/lib/client/components/AMap/Block.d.ts +2 -0
  4. package/lib/client/components/AMap/Block.js +357 -0
  5. package/lib/client/components/{AMap.d.ts → AMap/Map.d.ts} +3 -3
  6. package/lib/client/components/{AMap.js → AMap/Map.js} +13 -13
  7. package/lib/client/components/{Search.d.ts → AMap/Search.d.ts} +2 -2
  8. package/lib/client/components/{Search.js → AMap/Search.js} +3 -4
  9. package/lib/client/components/AMap/index.d.ts +2 -0
  10. package/lib/client/components/AMap/index.js +27 -0
  11. package/lib/client/components/Configuration.d.ts +1 -2
  12. package/lib/client/components/Configuration.js +54 -28
  13. package/lib/client/components/GoogleMaps/Block.d.ts +2 -0
  14. package/lib/client/components/GoogleMaps/Block.js +377 -0
  15. package/lib/client/components/GoogleMaps/Map.d.ts +31 -0
  16. package/lib/client/components/GoogleMaps/Map.js +471 -0
  17. package/lib/client/components/GoogleMaps/Search.d.ts +8 -0
  18. package/lib/client/components/GoogleMaps/Search.js +128 -0
  19. package/lib/client/components/GoogleMaps/index.d.ts +2 -0
  20. package/lib/client/components/GoogleMaps/index.js +27 -0
  21. package/lib/client/components/GoogleMaps/utils.d.ts +5 -0
  22. package/lib/client/components/GoogleMaps/utils.js +44 -0
  23. package/lib/client/components/Map.d.ts +1 -1
  24. package/lib/client/components/Map.js +13 -14
  25. package/lib/client/components/MapBlock.d.ts +2 -0
  26. package/lib/client/components/MapBlock.js +40 -0
  27. package/lib/client/components/MapComponent.d.ts +2 -0
  28. package/lib/client/components/MapComponent.js +42 -0
  29. package/lib/client/components/ReadPretty.js +5 -13
  30. package/lib/client/components/index.d.ts +6 -0
  31. package/lib/client/components/index.js +71 -0
  32. package/lib/client/constants.d.ts +2 -0
  33. package/lib/client/constants.js +6 -2
  34. package/lib/client/index.js +3 -5
  35. package/lib/client/locale/zh-CN.d.ts +1 -0
  36. package/lib/client/locale/zh-CN.js +2 -1
  37. package/lib/client/types.d.ts +1 -0
  38. package/lib/client/types.js +5 -0
  39. package/lib/client/utils.d.ts +1 -0
  40. package/lib/client/utils.js +1 -0
  41. package/package.json +16 -5
  42. package/src/client/block/MapBlock.tsx +7 -311
  43. package/src/client/block/MapBlockInitializer.tsx +3 -2
  44. package/src/client/components/AMap/Block.tsx +314 -0
  45. package/src/client/components/{AMap.tsx → AMap/Map.tsx} +10 -11
  46. package/src/client/components/{Search.tsx → AMap/Search.tsx} +2 -4
  47. package/src/client/components/AMap/index.ts +2 -0
  48. package/src/client/components/Configuration.tsx +49 -25
  49. package/src/client/components/GoogleMaps/Block.tsx +341 -0
  50. package/src/client/components/GoogleMaps/Map.tsx +470 -0
  51. package/src/client/components/GoogleMaps/Search.tsx +107 -0
  52. package/src/client/components/GoogleMaps/index.ts +2 -0
  53. package/src/client/components/GoogleMaps/utils.ts +33 -0
  54. package/src/client/components/Map.tsx +6 -5
  55. package/src/client/components/MapBlock.tsx +24 -0
  56. package/src/client/components/MapComponent.tsx +23 -0
  57. package/src/client/components/ReadPretty.tsx +6 -11
  58. package/src/client/components/index.ts +6 -0
  59. package/src/client/constants.ts +5 -0
  60. package/src/client/index.tsx +2 -3
  61. package/src/client/locale/zh-CN.ts +2 -0
  62. package/src/client/types.ts +1 -0
  63. package/src/client/utils.ts +0 -0
@@ -0,0 +1,377 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.GoogleMapsBlock = void 0;
7
+ function _icons() {
8
+ const data = require("@ant-design/icons");
9
+ _icons = function _icons() {
10
+ return data;
11
+ };
12
+ return data;
13
+ }
14
+ function _css() {
15
+ const data = require("@emotion/css");
16
+ _css = function _css() {
17
+ return data;
18
+ };
19
+ return data;
20
+ }
21
+ function _react() {
22
+ const data = require("@formily/react");
23
+ _react = function _react() {
24
+ return data;
25
+ };
26
+ return data;
27
+ }
28
+ function _client() {
29
+ const data = require("@nocobase/client");
30
+ _client = function _client() {
31
+ return data;
32
+ };
33
+ return data;
34
+ }
35
+ function _ahooks() {
36
+ const data = require("ahooks");
37
+ _ahooks = function _ahooks() {
38
+ return data;
39
+ };
40
+ return data;
41
+ }
42
+ function _antd() {
43
+ const data = require("antd");
44
+ _antd = function _antd() {
45
+ return data;
46
+ };
47
+ return data;
48
+ }
49
+ function _react2() {
50
+ const data = _interopRequireWildcard(require("react"));
51
+ _react2 = function _react2() {
52
+ return data;
53
+ };
54
+ return data;
55
+ }
56
+ var _constants = require("../../constants");
57
+ var _locale = require("../../locale");
58
+ var _Map = require("./Map");
59
+ var _utils = require("./utils");
60
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
61
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
62
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
63
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
64
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
65
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
66
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
67
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
68
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
69
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
70
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
71
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
72
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
73
+ const OVERLAY_KEY = 'google-maps-overlay-id';
74
+ const OVERLAY_SELECtED = 'google-maps-overlay-selected';
75
+ const labelClass = (0, _css().css)`
76
+ margin-top: 6px;
77
+ padding: 2px 4px;
78
+ background: #fff;
79
+ border: 1px solid #0000f5;
80
+ `;
81
+ const GoogleMapsBlock = props => {
82
+ const _useProps = (0, _client().useProps)(props),
83
+ fieldNames = _useProps.fieldNames,
84
+ _useProps$dataSource = _useProps.dataSource,
85
+ dataSource = _useProps$dataSource === void 0 ? [] : _useProps$dataSource,
86
+ fixedBlock = _useProps.fixedBlock,
87
+ zoom = _useProps.zoom,
88
+ setSelectedRecordKeys = _useProps.setSelectedRecordKeys;
89
+ const _useCollection = (0, _client().useCollection)(),
90
+ getField = _useCollection.getField,
91
+ getPrimaryKey = _useCollection.getPrimaryKey;
92
+ const _ref = fieldNames || {
93
+ marker: 'id',
94
+ field: 'id'
95
+ },
96
+ markerName = _ref.marker,
97
+ fieldName = _ref.field;
98
+ const field = getField(fieldName);
99
+ const _useState = (0, _react2().useState)(false),
100
+ _useState2 = _slicedToArray(_useState, 2),
101
+ isMapInitialization = _useState2[0],
102
+ setIsMapInitialization = _useState2[1];
103
+ const mapRef = (0, _react2().useRef)();
104
+ const _useState3 = (0, _react2().useState)(),
105
+ _useState4 = _slicedToArray(_useState3, 2),
106
+ record = _useState4[0],
107
+ setRecord = _useState4[1];
108
+ const _useState5 = (0, _react2().useState)(''),
109
+ _useState6 = _slicedToArray(_useState5, 2),
110
+ selectingMode = _useState6[0],
111
+ setSelecting = _useState6[1];
112
+ const _useMapTranslation = (0, _locale.useMapTranslation)(),
113
+ t = _useMapTranslation.t;
114
+ const compile = (0, _client().useCompile)();
115
+ const _useFilterAPI = (0, _client().useFilterAPI)(),
116
+ isConnected = _useFilterAPI.isConnected,
117
+ doFilter = _useFilterAPI.doFilter;
118
+ const _useState7 = (0, _react2().useState)(null),
119
+ _useState8 = _slicedToArray(_useState7, 2),
120
+ setPrevSelected = _useState8[1];
121
+ const selectingModeRef = (0, _react2().useRef)(selectingMode);
122
+ const selectionOverlayRef = (0, _react2().useRef)();
123
+ const overlaysRef = (0, _react2().useRef)([]);
124
+ selectingModeRef.current = selectingMode;
125
+ const setOverlayOptions = (overlay, state) => {
126
+ const selected = typeof state !== 'undefined' ? !state : overlay.get(OVERLAY_SELECtED);
127
+ overlay.set(OVERLAY_SELECtED, !selected);
128
+ overlay.setOptions(_objectSpread({}, selected ? {
129
+ icon: (0, _utils.getIcon)(_constants.defaultImage),
130
+ strokeColor: '#4e9bff',
131
+ fillColor: '#4e9bff'
132
+ } : {
133
+ icon: (0, _utils.getIcon)(_constants.selectedImage),
134
+ strokeColor: '#F18b62',
135
+ fillColor: '#F18b62'
136
+ }));
137
+ };
138
+ // selection
139
+ (0, _react2().useEffect)(() => {
140
+ if (selectingMode !== 'selection') {
141
+ return;
142
+ }
143
+ if (!mapRef.current.drawingManager) {
144
+ mapRef.current.drawingManager = mapRef.current.createDraw(true, {
145
+ editable: true,
146
+ draggable: true
147
+ });
148
+ }
149
+ const listenerSet = new Set();
150
+ mapRef.current.drawingManager.setDrawingMode(google.maps.drawing.OverlayType.POLYGON);
151
+ mapRef.current.drawingManager.addListener('overlaycomplete', event => {
152
+ const polygon = event.overlay;
153
+ mapRef.current.drawingManager.setDrawingMode(null);
154
+ selectionOverlayRef.current = polygon;
155
+ const path = polygon.getPath();
156
+ ['insert_at', 'remove_at', 'set_at'].forEach(key => {
157
+ listenerSet.add(path.addListener(key, () => {}).remove);
158
+ });
159
+ });
160
+ return () => {
161
+ var _selectionOverlayRef$, _selectionOverlayRef$2;
162
+ listenerSet.forEach(i => {
163
+ i();
164
+ });
165
+ if (!mapRef.current) return;
166
+ (_selectionOverlayRef$ = selectionOverlayRef.current) === null || _selectionOverlayRef$ === void 0 ? void 0 : _selectionOverlayRef$.unbindAll();
167
+ (_selectionOverlayRef$2 = selectionOverlayRef.current) === null || _selectionOverlayRef$2 === void 0 ? void 0 : _selectionOverlayRef$2.setMap(null);
168
+ selectionOverlayRef.current = null;
169
+ mapRef.current.drawingManager.setDrawingMode(null);
170
+ mapRef.current.drawingManager.unbindAll();
171
+ };
172
+ }, [selectingMode]);
173
+ (0, _react2().useEffect)(() => {
174
+ if (selectingMode) {
175
+ return () => {
176
+ if (!selectingModeRef.current) {
177
+ overlaysRef.current.forEach(o => {
178
+ setOverlayOptions(o, false);
179
+ });
180
+ }
181
+ };
182
+ }
183
+ }, [selectingMode]);
184
+ const onSelectingComplete = (0, _ahooks().useMemoizedFn)(() => {
185
+ const overlay = selectionOverlayRef.current;
186
+ const overlays = overlaysRef.current;
187
+ const poly = google.maps.geometry.poly;
188
+ const selectedOverlays = overlays.filter(o => {
189
+ if (o === overlay || o.get(OVERLAY_KEY) === undefined) return;
190
+ if (o instanceof google.maps.Marker) {
191
+ return poly.containsLocation(o.getPosition(), overlay);
192
+ } else if (o instanceof google.maps.Circle) {
193
+ return poly.containsLocation(o.getCenter(), overlay);
194
+ } else {
195
+ return o.getPath().getArray().some(position => {
196
+ return poly.containsLocation(position, overlay);
197
+ });
198
+ }
199
+ });
200
+ const ids = selectedOverlays.map(o => {
201
+ setOverlayOptions(o, true);
202
+ return o.get(OVERLAY_KEY);
203
+ });
204
+ setSelectedRecordKeys(lastIds => ids.concat(lastIds));
205
+ overlay.unbindAll();
206
+ overlay.setMap(null);
207
+ mapRef.current.drawingManager.setDrawingMode(google.maps.drawing.OverlayType.POLYGON);
208
+ });
209
+ (0, _react2().useEffect)(() => {
210
+ var _mapRef$current;
211
+ if (!field || !((_mapRef$current = mapRef.current) === null || _mapRef$current === void 0 ? void 0 : _mapRef$current.map)) return;
212
+ const overlays = dataSource.map(item => {
213
+ const data = item[fieldNames === null || fieldNames === void 0 ? void 0 : fieldNames.field];
214
+ if (!data) return;
215
+ const overlay = mapRef.current.setOverlay(field.type, data, {
216
+ strokeColor: '#4e9bff',
217
+ fillColor: '#4e9bff',
218
+ cursor: 'pointer',
219
+ label: {
220
+ className: labelClass,
221
+ fontFamily: 'inherit',
222
+ fontSize: '13px',
223
+ color: '#333',
224
+ text: (fieldNames === null || fieldNames === void 0 ? void 0 : fieldNames.marker) ? compile(item[markerName]) : undefined
225
+ }
226
+ });
227
+ overlay.set(OVERLAY_KEY, item[getPrimaryKey()]);
228
+ return overlay;
229
+ }).filter(Boolean);
230
+ overlaysRef.current = overlays;
231
+ mapRef.current.setFitView(overlays);
232
+ const events = overlays.map(o => {
233
+ const onClick = event => {
234
+ const overlay = o;
235
+ const id = overlay.get(OVERLAY_KEY);
236
+ if (!id) return;
237
+ const data = dataSource === null || dataSource === void 0 ? void 0 : dataSource.find(item => {
238
+ return id === item[getPrimaryKey()];
239
+ });
240
+ // 筛选区块模式
241
+ if (isConnected) {
242
+ setPrevSelected(prev => {
243
+ prev && clearSelected(overlay);
244
+ if (prev === o) {
245
+ clearSelected(overlay);
246
+ // 删除过滤参数
247
+ doFilter(null);
248
+ return null;
249
+ } else {
250
+ selectMarker(overlay);
251
+ doFilter(data[getPrimaryKey()], target => target.field || getPrimaryKey(), '$eq');
252
+ }
253
+ return overlay;
254
+ });
255
+ return;
256
+ }
257
+ if (data) {
258
+ setRecord(data);
259
+ }
260
+ };
261
+ o.addListener('click', onClick);
262
+ return () => o.unbindAll();
263
+ });
264
+ return () => {
265
+ overlays.forEach(ov => {
266
+ ov.setMap(null);
267
+ ov.unbindAll();
268
+ });
269
+ events.forEach(e => e());
270
+ };
271
+ }, [dataSource, isMapInitialization, markerName, field.type, isConnected]);
272
+ (0, _react2().useEffect)(() => {
273
+ setTimeout(() => {
274
+ setSelectedRecordKeys([]);
275
+ });
276
+ }, [dataSource]);
277
+ const mapRefCallback = instance => {
278
+ mapRef.current = instance;
279
+ setIsMapInitialization(!!(instance === null || instance === void 0 ? void 0 : instance.map) && !instance.errMessage);
280
+ };
281
+ return _react2().default.createElement("div", {
282
+ className: (0, _css().css)`
283
+ position: relative;
284
+ height: 100%;
285
+ `
286
+ }, isMapInitialization && _react2().default.createElement(_react2().default.Fragment, null, _react2().default.createElement("div", {
287
+ className: (0, _css().css)`
288
+ position: absolute;
289
+ left: 10px;
290
+ top: 10px;
291
+ z-index: 999;
292
+ `
293
+ }, _react2().default.createElement(_antd().Space, {
294
+ direction: "vertical"
295
+ }, _react2().default.createElement(_antd().Button, {
296
+ style: {
297
+ color: !selectingMode ? '#F18b62' : undefined,
298
+ borderColor: 'currentcolor'
299
+ },
300
+ onClick: e => {
301
+ e.stopPropagation();
302
+ setSelecting('');
303
+ },
304
+ icon: _react2().default.createElement(_icons().EnvironmentOutlined, null)
305
+ }), _react2().default.createElement(_antd().Button, {
306
+ style: {
307
+ color: selectingMode === 'selection' ? '#F18b62' : undefined,
308
+ borderColor: 'currentcolor'
309
+ },
310
+ onClick: e => {
311
+ e.stopPropagation();
312
+ setSelecting('selection');
313
+ },
314
+ icon: _react2().default.createElement(_icons().ExpandOutlined, null)
315
+ }), selectingMode === 'selection' ? _react2().default.createElement(_antd().Button, {
316
+ type: "primary",
317
+ icon: _react2().default.createElement(_icons().CheckOutlined, null),
318
+ title: t('Confirm selection'),
319
+ onClick: onSelectingComplete
320
+ }) : null)), _react2().default.createElement(MapBlockDrawer, {
321
+ record: record,
322
+ setVisible: setRecord
323
+ })), _react2().default.createElement(_Map.GoogleMapsComponent, _objectSpread(_objectSpread({}, props), {}, {
324
+ ref: mapRefCallback,
325
+ style: {
326
+ height: fixedBlock ? '100%' : null
327
+ },
328
+ zoom: zoom,
329
+ disabled: true,
330
+ block: true,
331
+ overlayCommonOptions: {
332
+ strokeColor: '#F18b62',
333
+ fillColor: '#F18b62'
334
+ }
335
+ })));
336
+ };
337
+ exports.GoogleMapsBlock = GoogleMapsBlock;
338
+ const MapBlockDrawer = props => {
339
+ const setVisible = props.setVisible,
340
+ record = props.record;
341
+ const fieldSchema = (0, _react().useFieldSchema)();
342
+ const schema = (0, _react2().useMemo)(() => fieldSchema.reduceProperties((buf, current) => {
343
+ if (current.name === 'drawer') {
344
+ return current;
345
+ }
346
+ return buf;
347
+ }, null), [fieldSchema]);
348
+ return schema && _react2().default.createElement(_client().ActionContextProvider, {
349
+ value: {
350
+ visible: !!record,
351
+ setVisible
352
+ }
353
+ }, _react2().default.createElement(_client().RecordProvider, {
354
+ record: record
355
+ }, _react2().default.createElement(_react().RecursionField, {
356
+ schema: schema,
357
+ name: schema.name
358
+ })));
359
+ };
360
+ function clearSelected(target) {
361
+ if (target instanceof google.maps.Marker) {
362
+ return target.setIcon((0, _utils.getIcon)(_constants.defaultImage));
363
+ }
364
+ target.setOptions({
365
+ strokeColor: '#4e9bff',
366
+ fillColor: '#4e9bff'
367
+ });
368
+ }
369
+ function selectMarker(target) {
370
+ if (target instanceof google.maps.Marker) {
371
+ return target.setIcon((0, _utils.getIcon)(_constants.selectedImage));
372
+ }
373
+ target.setOptions({
374
+ strokeColor: '#F18b62',
375
+ fillColor: '#F18b62'
376
+ });
377
+ }
@@ -0,0 +1,31 @@
1
+ /// <reference types="google.maps" />
2
+ import React from 'react';
3
+ import { MapEditorType } from '../../types';
4
+ export declare type OverlayOptions = google.maps.PolygonOptions & google.maps.MarkerOptions & google.maps.PolylineOptions;
5
+ export declare const getDrawingMode: (type: MapEditorType) => "polygon" | "circle" | "marker" | "polyline";
6
+ export interface GoogleMapsComponentProps {
7
+ value?: any;
8
+ onChange?: (value: number[]) => void;
9
+ disabled?: boolean;
10
+ mapType: string;
11
+ /**
12
+ * only ReadPretty
13
+ */
14
+ readonly: string;
15
+ zoom: number;
16
+ type: MapEditorType;
17
+ style?: React.CSSProperties;
18
+ overlayCommonOptions?: OverlayOptions;
19
+ block?: boolean;
20
+ }
21
+ export interface GoogleMapForwardedRefProps {
22
+ setOverlay: (t: MapEditorType, v: any, o?: OverlayOptions) => google.maps.MVCObject;
23
+ getOverlay: (t: MapEditorType, v: any, o?: OverlayOptions) => google.maps.MVCObject;
24
+ setFitView: (overlays: google.maps.MVCObject[]) => void;
25
+ createDraw: (onlyCreate?: boolean, additionalOptions?: OverlayOptions) => any;
26
+ map: google.maps.Map;
27
+ overlay: google.maps.MVCObject;
28
+ drawingManager: google.maps.drawing.DrawingManager;
29
+ errMessage?: string;
30
+ }
31
+ export declare const GoogleMapsComponent: React.ForwardRefExoticComponent<GoogleMapsComponentProps & React.RefAttributes<GoogleMapForwardedRefProps>>;