@fleet-frontend/mower-maps 0.2.0-beta.3 → 0.2.0-beta.5
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.
- package/dist/index.esm.js +508 -217
- package/dist/index.js +507 -216
- package/dist/src/context/common.d.ts +2 -0
- package/dist/src/context/common.d.ts.map +1 -1
- package/dist/src/context/mapEdit.d.ts +1 -1
- package/dist/src/context/mapEdit.d.ts.map +1 -1
- package/dist/src/processor/unified/BaseData.d.ts +3 -4
- package/dist/src/processor/unified/BaseData.d.ts.map +1 -1
- package/dist/src/processor/unified/UnifiedMapDataProcessor.d.ts.map +1 -1
- package/dist/src/render/BoundarySvgRender.d.ts +1 -1
- package/dist/src/render/MowerMapRenderer.d.ts.map +1 -1
- package/dist/src/render/layers/ObstacleLayer.d.ts +16 -0
- package/dist/src/render/layers/ObstacleLayer.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/AddEntry/components/DoodleModal/index.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/AddEntry/index.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/boundary.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/components/DirectionModal/component/MowDirection/index.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/components/DirectionModal/index.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/components/TimePeriod/index.d.ts +4 -4
- package/dist/src/render/svgEditMap/components/HandleElementInfo/components/TimePeriod/index.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/doodle.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/index.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/obstacle.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/components/HandleElementInfo/visionOff.d.ts.map +1 -1
- package/dist/src/render/svgEditMap/index.d.ts +8 -1
- package/dist/src/render/svgEditMap/index.d.ts.map +1 -1
- package/dist/src/render/svgElement/ChannelElement/index.d.ts.map +1 -1
- package/dist/src/render/svgElement/DoodleElement/index.d.ts.map +1 -1
- package/dist/src/render/svgElement/Mobile/CreateObstacleElement/index.d.ts +4 -1
- package/dist/src/render/svgElement/Mobile/CreateObstacleElement/index.d.ts.map +1 -1
- package/dist/src/render/svgElement/PolygonELement/index.d.ts.map +1 -1
- package/dist/src/render/svgElement/TransformWrapper/DoodleTransformWrapper/DoodleTransformWrapper.d.ts.map +1 -1
- package/dist/src/render/svgElement/TransformWrapper/VisionOffTransformWrapper/VisionOffTransformWrapper.d.ts.map +1 -1
- package/dist/src/types/renderer.d.ts +10 -2
- package/dist/src/types/renderer.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/index.esm.js
CHANGED
|
@@ -2,7 +2,7 @@ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
|
2
2
|
import * as React from 'react';
|
|
3
3
|
import React__default, { memo, useMemo, useEffect, useState, useRef, useCallback, createContext, useContext, forwardRef, useImperativeHandle, useLayoutEffect } from 'react';
|
|
4
4
|
import ReactDOM from 'react-dom';
|
|
5
|
-
import { Modal, message, Popover, Input, Switch, Slider, Radio, Button, DatePicker, Select } from 'antd';
|
|
5
|
+
import { Modal, message, Popover, Input, Switch, Slider, Radio, Button, DatePicker, Select, Space } from 'antd';
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* 常量和枚举类型定义
|
|
@@ -190,14 +190,13 @@ class ChannelData extends BaseData {
|
|
|
190
190
|
* 障碍物数据类
|
|
191
191
|
*/
|
|
192
192
|
class ObstacleData extends BaseData {
|
|
193
|
-
constructor(originalData, level,
|
|
193
|
+
constructor(originalData, level, style) {
|
|
194
194
|
const convertedPoints = convertPointsFormat(originalData?.points) || [];
|
|
195
195
|
super(originalData?.id, DataType.OBSTACLE, level, RenderType.POLYGON, convertedPoints, originalData);
|
|
196
196
|
this.area = originalData?.area;
|
|
197
197
|
this.status = originalData?.status || 1;
|
|
198
|
-
this.
|
|
199
|
-
this.
|
|
200
|
-
this.isTimeLimit = isTimeLimit;
|
|
198
|
+
this.start_timestamp = originalData?.start_timestamp;
|
|
199
|
+
this.end_timestamp = originalData?.end_timestamp;
|
|
201
200
|
this.name = originalData?.name || 'Obstacle';
|
|
202
201
|
this.style = style;
|
|
203
202
|
}
|
|
@@ -329,8 +328,8 @@ function initDoodle() {
|
|
|
329
328
|
svg: '',
|
|
330
329
|
scale: 1,
|
|
331
330
|
direction: 0,
|
|
332
|
-
create_ts: Date.now(),
|
|
333
|
-
expiration_ts: Date.now() +
|
|
331
|
+
create_ts: Math.floor(Date.now() / 1000),
|
|
332
|
+
expiration_ts: Math.floor(Date.now() / 1000) + 3600 * 24 * 7, // 1小时后过期
|
|
334
333
|
type: 'TIME_LIMIT_OBSTACLE',
|
|
335
334
|
};
|
|
336
335
|
return new DoodleData(doodle, 100);
|
|
@@ -616,7 +615,7 @@ class UnifiedMapDataProcessor {
|
|
|
616
615
|
continue;
|
|
617
616
|
}
|
|
618
617
|
const obstacleData = new ObstacleData(element, 150, // 高层级
|
|
619
|
-
|
|
618
|
+
this.mapConfig.obstacle || {});
|
|
620
619
|
obstacleDataList.push(obstacleData);
|
|
621
620
|
}
|
|
622
621
|
catch (error) {
|
|
@@ -746,7 +745,7 @@ class UnifiedMapDataProcessor {
|
|
|
746
745
|
continue;
|
|
747
746
|
}
|
|
748
747
|
const obstacleData = new ObstacleData(element, 150, // 高层级
|
|
749
|
-
|
|
748
|
+
this.mapConfig.obstacle || {});
|
|
750
749
|
obstacleDataList.push(obstacleData);
|
|
751
750
|
}
|
|
752
751
|
}
|
|
@@ -8693,7 +8692,7 @@ function styleInject(css, ref) {
|
|
|
8693
8692
|
}
|
|
8694
8693
|
}
|
|
8695
8694
|
|
|
8696
|
-
var css_248z$i = ".index-module_edit__-5VvX {\n position: absolute;\n top: 0px;\n left: 0px;\n width: 100%;\n height: 100%;\n pointer-events: auto;\n z-index: 1000;\n cursor: move;\n touch-action: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n.index-module_edit__-5VvX .index-module_border__JdNLM {\n position: absolute;\n inset: -10px;\n border: 2px dashed rgb(241, 102, 41);\n border-radius: 2px;\n pointer-events: none;\n}\n.index-module_edit__-5VvX .index-module_drag__uvdPG {\n position: absolute;\n inset: -10px;\n border-radius: 2px;\n}\n.index-module_edit__-5VvX .index-module_rotate__H-KIZ {\n position: absolute;\n top: -20px;\n right: -20px;\n width: 20px;\n height: 20px;\n cursor: grab;\n z-index: 1001;\n pointer-events: auto;\n}\n.index-module_edit__-5VvX .index-module_move__mZF8s {\n position: absolute;\n bottom: -20px;\n left: -20px;\n width: 20px;\n height: 20px;\n cursor: move;\n z-index: 1001;\n pointer-events: auto;\n
|
|
8695
|
+
var css_248z$i = ".index-module_edit__-5VvX {\n position: absolute;\n top: 0px;\n left: 0px;\n width: 100%;\n height: 100%;\n pointer-events: auto;\n z-index: 1000;\n cursor: move;\n touch-action: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n.index-module_edit__-5VvX .index-module_border__JdNLM {\n position: absolute;\n inset: -10px;\n border: 2px dashed rgb(241, 102, 41);\n border-radius: 2px;\n pointer-events: none;\n}\n.index-module_edit__-5VvX .index-module_drag__uvdPG {\n position: absolute;\n inset: -10px;\n border-radius: 2px;\n}\n.index-module_edit__-5VvX .index-module_rotate__H-KIZ {\n position: absolute;\n top: -20px;\n right: -20px;\n width: 20px;\n height: 20px;\n cursor: grab;\n z-index: 1001;\n pointer-events: auto;\n}\n.index-module_edit__-5VvX .index-module_move__mZF8s {\n position: absolute;\n bottom: -20px;\n left: -20px;\n width: 20px;\n height: 20px;\n cursor: move;\n z-index: 1001;\n pointer-events: auto;\n}";
|
|
8697
8696
|
var styles$i = {"edit":"index-module_edit__-5VvX","border":"index-module_border__JdNLM","drag":"index-module_drag__uvdPG","rotate":"index-module_rotate__H-KIZ","move":"index-module_move__mZF8s"};
|
|
8698
8697
|
styleInject(css_248z$i);
|
|
8699
8698
|
|
|
@@ -8775,8 +8774,10 @@ const DragHandle = ({ onDragStart, isDragging }) => {
|
|
|
8775
8774
|
onDragStart(e);
|
|
8776
8775
|
}, onTouchStart: (e) => onDragStart(e), onMouseUp: (e) => {
|
|
8777
8776
|
console.log('drag up');
|
|
8778
|
-
onDragEnd(e);
|
|
8779
|
-
},
|
|
8777
|
+
// onDragEnd(e);
|
|
8778
|
+
},
|
|
8779
|
+
// onTouchEnd={(e) => onDragEnd(e)}
|
|
8780
|
+
style: { cursor: isDragging ? 'grabbing' : 'move' }, dangerouslySetInnerHTML: { __html: DEFAULT_DRAG_ICON } }));
|
|
8780
8781
|
};
|
|
8781
8782
|
|
|
8782
8783
|
const MapDrag = ({ map: _map, dragCallbacks, onBoundaryLabelsCollapse, onTransformChange, isDragMap = false, }) => {
|
|
@@ -12513,11 +12514,74 @@ class ObstacleLayer extends BaseLayer {
|
|
|
12513
12514
|
}
|
|
12514
12515
|
}
|
|
12515
12516
|
}
|
|
12517
|
+
/**
|
|
12518
|
+
* 将坐标点按type分组
|
|
12519
|
+
*/
|
|
12520
|
+
groupCoordinatesByType(coordinates) {
|
|
12521
|
+
const segments = [];
|
|
12522
|
+
let currentSegment = null;
|
|
12523
|
+
for (let i = 0; i < coordinates.length; i++) {
|
|
12524
|
+
const coord = coordinates[i];
|
|
12525
|
+
const type = coord[2] || 2; // 默认type为2
|
|
12526
|
+
if (!currentSegment || currentSegment.type !== type) {
|
|
12527
|
+
// 开始新的段
|
|
12528
|
+
if (currentSegment && currentSegment.points.length > 0) {
|
|
12529
|
+
// 为了连接线段,将当前点也加入上一段的结尾
|
|
12530
|
+
currentSegment.points.push(coord);
|
|
12531
|
+
}
|
|
12532
|
+
currentSegment = {
|
|
12533
|
+
type: type,
|
|
12534
|
+
points: [coord],
|
|
12535
|
+
};
|
|
12536
|
+
segments.push(currentSegment);
|
|
12537
|
+
}
|
|
12538
|
+
else {
|
|
12539
|
+
// 继续当前段
|
|
12540
|
+
currentSegment.points.push(coord);
|
|
12541
|
+
}
|
|
12542
|
+
}
|
|
12543
|
+
// 处理封闭边界:如果第一段和最后一段type相同,需要连接起来
|
|
12544
|
+
if (segments.length > 1 && segments[0].type === segments[segments.length - 1].type) {
|
|
12545
|
+
const firstSegment = segments[0];
|
|
12546
|
+
const lastSegment = segments[segments.length - 1];
|
|
12547
|
+
// 将第一个点添加到最后一段,形成封闭
|
|
12548
|
+
lastSegment.points.push(firstSegment.points[0]);
|
|
12549
|
+
}
|
|
12550
|
+
else if (segments.length === 1) {
|
|
12551
|
+
// 只有一段的情况,添加第一个点到末尾形成封闭
|
|
12552
|
+
segments[0].points.push(coordinates[0]);
|
|
12553
|
+
}
|
|
12554
|
+
return segments;
|
|
12555
|
+
}
|
|
12516
12556
|
/**
|
|
12517
12557
|
* 渲染障碍物元素
|
|
12518
12558
|
*/
|
|
12519
12559
|
renderObstacle(svgGroup, element) {
|
|
12520
|
-
const { coordinates, style } = element;
|
|
12560
|
+
const { coordinates, style, originalData } = element;
|
|
12561
|
+
const { status, start_timestamp, end_timestamp } = originalData || {};
|
|
12562
|
+
if (coordinates.length < 2 || status === 0) {
|
|
12563
|
+
return;
|
|
12564
|
+
}
|
|
12565
|
+
if (status === 1 &&
|
|
12566
|
+
(start_timestamp > Date.now() / 1000 || end_timestamp < Date.now() / 1000)) {
|
|
12567
|
+
return;
|
|
12568
|
+
}
|
|
12569
|
+
// 1. 先遍历所有的coordinates,把所有点分为若干段的path
|
|
12570
|
+
const pathSegments = this.groupCoordinatesByType(coordinates);
|
|
12571
|
+
// 2&3. 根据type处理每个path段
|
|
12572
|
+
pathSegments.forEach((segment) => {
|
|
12573
|
+
if (segment.points.length < 2)
|
|
12574
|
+
return;
|
|
12575
|
+
if (segment.type === 2) {
|
|
12576
|
+
// type=2: 直接添加到svgGroup中
|
|
12577
|
+
this.createDirectPath(svgGroup, segment.points, style);
|
|
12578
|
+
}
|
|
12579
|
+
else if (segment.type === 1) {
|
|
12580
|
+
// type=1: 使用PathMeasure逻辑生成平行路径
|
|
12581
|
+
// this.createDirectPath(svgGroup, segment.points, style);
|
|
12582
|
+
this.createParallelPathsWithMeasure(svgGroup, segment.points, style);
|
|
12583
|
+
}
|
|
12584
|
+
});
|
|
12521
12585
|
if (coordinates.length < 3)
|
|
12522
12586
|
return;
|
|
12523
12587
|
const polygon = document.createElementNS('http://www.w3.org/2000/svg', 'polygon');
|
|
@@ -12525,7 +12589,7 @@ class ObstacleLayer extends BaseLayer {
|
|
|
12525
12589
|
const points = coordinates.map((coord) => `${coord[0]},${coord[1]}`).join(' ');
|
|
12526
12590
|
polygon.setAttribute('points', points);
|
|
12527
12591
|
polygon.setAttribute('fill', style.fillColor || 'rgba(220, 53, 69, 0.2)');
|
|
12528
|
-
polygon.setAttribute('stroke',
|
|
12592
|
+
polygon.setAttribute('stroke', 'transparent');
|
|
12529
12593
|
// 确保最小线条宽度
|
|
12530
12594
|
const lineWidth = Math.max(style.lineWidth || 2, 0.5);
|
|
12531
12595
|
polygon.setAttribute('stroke-width', lineWidth.toString());
|
|
@@ -12536,6 +12600,113 @@ class ObstacleLayer extends BaseLayer {
|
|
|
12536
12600
|
polygon.classList.add('vector-obstacle');
|
|
12537
12601
|
svgGroup.appendChild(polygon);
|
|
12538
12602
|
}
|
|
12603
|
+
/**
|
|
12604
|
+
* 创建直接路径(type=2)
|
|
12605
|
+
*/
|
|
12606
|
+
createDirectPath(svgGroup, points, style) {
|
|
12607
|
+
const path = document.createElementNS('http://www.w3.org/2000/svg', 'path');
|
|
12608
|
+
const strokeColor = style.lineColor;
|
|
12609
|
+
// 构建路径数据
|
|
12610
|
+
let pathData = '';
|
|
12611
|
+
for (let i = 0; i < points.length; i++) {
|
|
12612
|
+
const [x, y] = points[i];
|
|
12613
|
+
if (i === 0) {
|
|
12614
|
+
pathData += `M ${x} ${y}`;
|
|
12615
|
+
}
|
|
12616
|
+
else {
|
|
12617
|
+
pathData += ` L ${x} ${y}`;
|
|
12618
|
+
}
|
|
12619
|
+
}
|
|
12620
|
+
path.setAttribute('d', pathData);
|
|
12621
|
+
path.setAttribute('stroke', strokeColor);
|
|
12622
|
+
path.setAttribute('fill', 'none');
|
|
12623
|
+
// 确保最小线条宽度
|
|
12624
|
+
const lineWidth = dp2px(style.lineWidth || 3);
|
|
12625
|
+
path.setAttribute('stroke-width', lineWidth.toString());
|
|
12626
|
+
path.setAttribute('stroke-linecap', 'round');
|
|
12627
|
+
path.setAttribute('stroke-linejoin', 'round');
|
|
12628
|
+
path.setAttribute('opacity', (style.opacity || 1).toString());
|
|
12629
|
+
path.setAttribute('vector-effect', 'non-scaling-stroke');
|
|
12630
|
+
path.classList.add('vector-obstacle');
|
|
12631
|
+
svgGroup.appendChild(path);
|
|
12632
|
+
}
|
|
12633
|
+
/**
|
|
12634
|
+
* 使用PathMeasure逻辑创建平行路径(type=1)
|
|
12635
|
+
*/
|
|
12636
|
+
createParallelPathsWithMeasure(svgGroup, points, style) {
|
|
12637
|
+
const strokeColor = style.lineColor;
|
|
12638
|
+
const lineWidth = dp2px(style.lineWidth || 3);
|
|
12639
|
+
// 获取当前SVG的缩放级别,计算固定屏幕像素间距
|
|
12640
|
+
const fixedScreenDistance = lineWidth; // 固定的屏幕像素距离
|
|
12641
|
+
const offsetDistance = fixedScreenDistance; // 转换为SVG坐标系距离
|
|
12642
|
+
// 直接对每个线段生成平行直线段
|
|
12643
|
+
const parallelPaths = this.generateStraightParallelPaths(points, offsetDistance);
|
|
12644
|
+
// 渲染两条平行虚线
|
|
12645
|
+
parallelPaths.forEach((pathData, index) => {
|
|
12646
|
+
if (!pathData)
|
|
12647
|
+
return;
|
|
12648
|
+
const path = document.createElementNS('http://www.w3.org/2000/svg', 'path');
|
|
12649
|
+
path.setAttribute('d', pathData);
|
|
12650
|
+
path.setAttribute('fill', 'none');
|
|
12651
|
+
path.setAttribute('stroke', strokeColor);
|
|
12652
|
+
path.setAttribute('stroke-width', lineWidth.toString());
|
|
12653
|
+
path.setAttribute('stroke-linecap', 'round');
|
|
12654
|
+
path.setAttribute('stroke-linejoin', 'round');
|
|
12655
|
+
path.setAttribute('opacity', (style.opacity || 1).toString());
|
|
12656
|
+
// 使用CSS样式设置虚线,避免随SVG缩放变化
|
|
12657
|
+
// 或者可以根据当前缩放级别动态计算dash array
|
|
12658
|
+
path.style.strokeDasharray = `${lineWidth}px ${lineWidth * 2}px`;
|
|
12659
|
+
path.classList.add(`vector-boundary-parallel-${index + 1}`);
|
|
12660
|
+
svgGroup.appendChild(path);
|
|
12661
|
+
});
|
|
12662
|
+
}
|
|
12663
|
+
/**
|
|
12664
|
+
* 生成直线平行路径(每个线段分别处理)
|
|
12665
|
+
*/
|
|
12666
|
+
generateStraightParallelPaths(points, offsetDistance) {
|
|
12667
|
+
if (points.length < 2)
|
|
12668
|
+
return ['', ''];
|
|
12669
|
+
let parallelPath1Data = '';
|
|
12670
|
+
let parallelPath2Data = '';
|
|
12671
|
+
// 对每个线段分别计算平行线
|
|
12672
|
+
for (let i = 0; i < points.length - 1; i++) {
|
|
12673
|
+
const startPoint = points[i];
|
|
12674
|
+
const endPoint = points[i + 1];
|
|
12675
|
+
// 计算线段的方向向量
|
|
12676
|
+
const dx = endPoint[0] - startPoint[0];
|
|
12677
|
+
const dy = endPoint[1] - startPoint[1];
|
|
12678
|
+
const length = Math.sqrt(dx * dx + dy * dy);
|
|
12679
|
+
if (length === 0)
|
|
12680
|
+
continue; // 跳过零长度线段
|
|
12681
|
+
// 标准化方向向量
|
|
12682
|
+
const unitX = dx / length;
|
|
12683
|
+
const unitY = dy / length;
|
|
12684
|
+
// 计算垂直向量
|
|
12685
|
+
const perpendicularX = -unitY;
|
|
12686
|
+
const perpendicularY = unitX;
|
|
12687
|
+
// 计算平行线的起点和终点
|
|
12688
|
+
const start1X = startPoint[0] + perpendicularX * offsetDistance;
|
|
12689
|
+
const start1Y = startPoint[1] + perpendicularY * offsetDistance;
|
|
12690
|
+
const end1X = endPoint[0] + perpendicularX * offsetDistance;
|
|
12691
|
+
const end1Y = endPoint[1] + perpendicularY * offsetDistance;
|
|
12692
|
+
const start2X = startPoint[0] - perpendicularX * offsetDistance;
|
|
12693
|
+
const start2Y = startPoint[1] - perpendicularY * offsetDistance;
|
|
12694
|
+
const end2X = endPoint[0] - perpendicularX * offsetDistance;
|
|
12695
|
+
const end2Y = endPoint[1] - perpendicularY * offsetDistance;
|
|
12696
|
+
// 构建路径数据
|
|
12697
|
+
if (i === 0) {
|
|
12698
|
+
parallelPath1Data = `M ${start1X} ${start1Y}`;
|
|
12699
|
+
parallelPath2Data = `M ${start2X} ${start2Y}`;
|
|
12700
|
+
}
|
|
12701
|
+
else {
|
|
12702
|
+
parallelPath1Data += ` M ${start1X} ${start1Y}`;
|
|
12703
|
+
parallelPath2Data += ` M ${start2X} ${start2Y}`;
|
|
12704
|
+
}
|
|
12705
|
+
parallelPath1Data += ` L ${end1X} ${end1Y}`;
|
|
12706
|
+
parallelPath2Data += ` L ${end2X} ${end2Y}`;
|
|
12707
|
+
}
|
|
12708
|
+
return [parallelPath2Data, parallelPath1Data];
|
|
12709
|
+
}
|
|
12539
12710
|
}
|
|
12540
12711
|
|
|
12541
12712
|
var chargingPileImage = "";
|
|
@@ -15018,15 +15189,15 @@ const VertexElement = React__default.memo(({ r, stroke, ...props }) => {
|
|
|
15018
15189
|
return (jsx("circle", { r: radius * overlayScale, stroke: stroke || '#fff', fill: '#fff', strokeWidth: 2 * overlayScale, ...props }));
|
|
15019
15190
|
});
|
|
15020
15191
|
|
|
15021
|
-
var _path$
|
|
15022
|
-
function _extends$
|
|
15192
|
+
var _path$b;
|
|
15193
|
+
function _extends$j() { return _extends$j = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$j.apply(null, arguments); }
|
|
15023
15194
|
var SvgDelete$1 = function SvgDelete(props) {
|
|
15024
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
15195
|
+
return /*#__PURE__*/React.createElement("svg", _extends$j({
|
|
15025
15196
|
xmlns: "http://www.w3.org/2000/svg",
|
|
15026
15197
|
width: 16,
|
|
15027
15198
|
height: 16,
|
|
15028
15199
|
fill: "none"
|
|
15029
|
-
}, props), _path$
|
|
15200
|
+
}, props), _path$b || (_path$b = /*#__PURE__*/React.createElement("path", {
|
|
15030
15201
|
fill: "#FD494D",
|
|
15031
15202
|
d: "M6.667 12a.667.667 0 0 0 .666-.667v-4a.667.667 0 1 0-1.333 0v4a.667.667 0 0 0 .667.667m6.666-8h-2.666v-.667a2 2 0 0 0-2-2H7.333a2 2 0 0 0-2 2V4H2.667a.667.667 0 0 0 0 1.333h.666v7.334a2 2 0 0 0 2 2h5.334a2 2 0 0 0 2-2V5.333h.666a.667.667 0 1 0 0-1.333m-6.666-.667a.667.667 0 0 1 .666-.666h1.334a.667.667 0 0 1 .666.666V4H6.667zm4.666 9.334a.667.667 0 0 1-.666.666H5.333a.667.667 0 0 1-.666-.666V5.333h6.666zm-2-.667a.667.667 0 0 0 .667-.667v-4a.667.667 0 0 0-1.333 0v4a.667.667 0 0 0 .666.667"
|
|
15032
15203
|
})));
|
|
@@ -15199,6 +15370,7 @@ var MobileEditMode;
|
|
|
15199
15370
|
})(MobileEditMode || (MobileEditMode = {}));
|
|
15200
15371
|
var ClickEventType;
|
|
15201
15372
|
(function (ClickEventType) {
|
|
15373
|
+
// 点击doodle的active time的时候触发
|
|
15202
15374
|
ClickEventType["DOODLE_ACTIVE_TIME"] = "doodleActiveTime";
|
|
15203
15375
|
})(ClickEventType || (ClickEventType = {}));
|
|
15204
15376
|
const INIT_EDIT_MAP_INFO = {
|
|
@@ -15561,7 +15733,7 @@ const useCheckElement = () => {
|
|
|
15561
15733
|
return { isValid: true };
|
|
15562
15734
|
}, [editMapInfo, svgElementDatas, minDistance]);
|
|
15563
15735
|
const checkCanNotCreateAtPosition = useCallback((checkPoint) => {
|
|
15564
|
-
|
|
15736
|
+
console.log('editMapInfo.elementType--->', editMapInfo.elementType);
|
|
15565
15737
|
if (!editMapInfo.elementType)
|
|
15566
15738
|
return false;
|
|
15567
15739
|
const points = editMapInfo?.selectElement?.points || [];
|
|
@@ -15951,17 +16123,13 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
|
|
|
15951
16123
|
console.log('handleMouseUp', JSON.stringify(dragState));
|
|
15952
16124
|
if (dragState.isDragging && dragState.currentPosition) {
|
|
15953
16125
|
// 构建新的坐标数组
|
|
15954
|
-
const newCoordinates =
|
|
15955
|
-
? [...coordinates]
|
|
15956
|
-
: [...coordinates].reverse();
|
|
16126
|
+
const newCoordinates = [...coordinates];
|
|
15957
16127
|
// 如果是新创建的顶点,需要确保它已经被插入
|
|
15958
16128
|
if (dragState.dragType === 'new' && dragState.newVertexIndex !== -1) {
|
|
15959
16129
|
if (showNotCreateCursor) ;
|
|
15960
16130
|
else {
|
|
15961
16131
|
// mouseUp 时才真正插入新顶点
|
|
15962
16132
|
newCoordinates.splice(dragState.newVertexIndex, 0, dragState.currentPosition);
|
|
15963
|
-
// 通知外部坐标变化
|
|
15964
|
-
onCoordinatesChange?.(newCoordinates);
|
|
15965
16133
|
}
|
|
15966
16134
|
}
|
|
15967
16135
|
else {
|
|
@@ -15972,9 +16140,11 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
|
|
|
15972
16140
|
else {
|
|
15973
16141
|
newCoordinates[dragState.dragIndex] = dragState.currentPosition;
|
|
15974
16142
|
}
|
|
15975
|
-
// 通知外部坐标变化
|
|
15976
|
-
onCoordinatesChange?.(newCoordinates);
|
|
15977
16143
|
}
|
|
16144
|
+
const result = editMapInfo?.createMode === CreateStatus.CREATING
|
|
16145
|
+
? newCoordinates
|
|
16146
|
+
: newCoordinates.reverse();
|
|
16147
|
+
onCoordinatesChange?.(result);
|
|
15978
16148
|
}
|
|
15979
16149
|
setDragState({
|
|
15980
16150
|
isDragging: false,
|
|
@@ -16067,7 +16237,6 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
|
|
|
16067
16237
|
const ghostFirstMidpoint = createMode && mousePos && !completed && renderCoordinates.length >= 1
|
|
16068
16238
|
? calculateMidpoint(renderCoordinates[0], [mousePos.x, mousePos.y])
|
|
16069
16239
|
: null;
|
|
16070
|
-
console.log('ghostFirstMidpoint', ghostFirstMidpoint, ghostFirstDistance);
|
|
16071
16240
|
return (jsxs(Fragment, { children: [(editMode || (createMode && completed)) &&
|
|
16072
16241
|
dragState.isDragging &&
|
|
16073
16242
|
dragState.dragType !== 'new' &&
|
|
@@ -16191,7 +16360,8 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
|
|
|
16191
16360
|
if (onVertexDelete &&
|
|
16192
16361
|
(editMode || (createMode && completed)) &&
|
|
16193
16362
|
coordinates.length > 3) {
|
|
16194
|
-
|
|
16363
|
+
// 当前是逆时针展示的,但是外部数据是顺时针的,所以idx需要转换一下
|
|
16364
|
+
onVertexDelete(renderCoordinates?.length - 1 - idx);
|
|
16195
16365
|
}
|
|
16196
16366
|
setTooltipIndex(null);
|
|
16197
16367
|
}, style: { cursor: 'pointer' }, children: [jsx("rect", { x: 0, y: -24, width: 20, height: 20, rx: 2, ry: 2, fill: "#fff", strokeWidth: 1, filter: "url(#vertex-tooltip-shadow)" }), jsx("g", { transform: `translate(2, -22)`, children: jsx(SvgDelete$1, {}) })] })), canComplete && (jsx("g", { style: { pointerEvents: 'none' }, transform: `translate(${coord[0] - 5 * overlayScale * 3}, ${coord[1] - 2.5 * overlayScale * 3}) scale(${overlayScale * 3})`, children: jsx("svg", { width: "10", height: "5", viewBox: "0 0 6 5", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: jsx("path", { d: "M0.5 2.5L1.3452 3.3452C1.71469 3.71469 2.30636 3.73741 2.7031 3.39735L5.5 1", stroke: "#FF7A33", "stroke-linecap": "round" }) }) })
|
|
@@ -16883,9 +17053,9 @@ const useVisionOffTransform = (data, scaleConstraints
|
|
|
16883
17053
|
};
|
|
16884
17054
|
|
|
16885
17055
|
var _g$7, _defs$7;
|
|
16886
|
-
function _extends$
|
|
17056
|
+
function _extends$i() { return _extends$i = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$i.apply(null, arguments); }
|
|
16887
17057
|
var SvgTransformDelete = function SvgTransformDelete(props) {
|
|
16888
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
17058
|
+
return /*#__PURE__*/React.createElement("svg", _extends$i({
|
|
16889
17059
|
xmlns: "http://www.w3.org/2000/svg",
|
|
16890
17060
|
width: 20,
|
|
16891
17061
|
height: 20,
|
|
@@ -16934,9 +17104,9 @@ var SvgTransformDelete = function SvgTransformDelete(props) {
|
|
|
16934
17104
|
};
|
|
16935
17105
|
|
|
16936
17106
|
var _g$6, _defs$6;
|
|
16937
|
-
function _extends$
|
|
17107
|
+
function _extends$h() { return _extends$h = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$h.apply(null, arguments); }
|
|
16938
17108
|
var SvgTransformRotate = function SvgTransformRotate(props) {
|
|
16939
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
17109
|
+
return /*#__PURE__*/React.createElement("svg", _extends$h({
|
|
16940
17110
|
xmlns: "http://www.w3.org/2000/svg",
|
|
16941
17111
|
width: 21,
|
|
16942
17112
|
height: 20,
|
|
@@ -16970,9 +17140,9 @@ var SvgTransformRotate = function SvgTransformRotate(props) {
|
|
|
16970
17140
|
};
|
|
16971
17141
|
|
|
16972
17142
|
var _g$5, _defs$5;
|
|
16973
|
-
function _extends$
|
|
17143
|
+
function _extends$g() { return _extends$g = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$g.apply(null, arguments); }
|
|
16974
17144
|
var SvgTransformScale = function SvgTransformScale(props) {
|
|
16975
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
17145
|
+
return /*#__PURE__*/React.createElement("svg", _extends$g({
|
|
16976
17146
|
xmlns: "http://www.w3.org/2000/svg",
|
|
16977
17147
|
width: 21,
|
|
16978
17148
|
height: 20,
|
|
@@ -17006,9 +17176,9 @@ var SvgTransformScale = function SvgTransformScale(props) {
|
|
|
17006
17176
|
};
|
|
17007
17177
|
|
|
17008
17178
|
var _g$4, _defs$4;
|
|
17009
|
-
function _extends$
|
|
17179
|
+
function _extends$f() { return _extends$f = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$f.apply(null, arguments); }
|
|
17010
17180
|
var SvgTransformTranslate = function SvgTransformTranslate(props) {
|
|
17011
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
17181
|
+
return /*#__PURE__*/React.createElement("svg", _extends$f({
|
|
17012
17182
|
xmlns: "http://www.w3.org/2000/svg",
|
|
17013
17183
|
width: 20,
|
|
17014
17184
|
height: 20,
|
|
@@ -17186,8 +17356,8 @@ const VisionOffTransformWrapper = ({ data, isSelected = false, onSelect, onCance
|
|
|
17186
17356
|
const centerX = (minX + maxX) / 2;
|
|
17187
17357
|
// 计算尺寸显示框的位置(选择框下方)
|
|
17188
17358
|
const infoBoxY = maxY + 20; // 选择框下方20像素
|
|
17189
|
-
const infoBoxWidth = 140; // 信息框宽度
|
|
17190
|
-
const infoBoxHeight = 30; // 信息框高度
|
|
17359
|
+
const infoBoxWidth = 140 * overlayScale; // 信息框宽度
|
|
17360
|
+
const infoBoxHeight = 30 * overlayScale; // 信息框高度
|
|
17191
17361
|
const infoBoxX = centerX - infoBoxWidth / 2; // 居中对齐
|
|
17192
17362
|
const scale = (isWeb ? 2 : 1) * overlayScale;
|
|
17193
17363
|
const offsetLeft = 10 * scale;
|
|
@@ -17241,6 +17411,7 @@ const VisionOffTransformWrapper = ({ data, isSelected = false, onSelect, onCance
|
|
|
17241
17411
|
fontSize: '12px',
|
|
17242
17412
|
color: 'white',
|
|
17243
17413
|
fontWeight: '400',
|
|
17414
|
+
// transform: `translate(0, ${50 * overlayScale}px) scale(${overlayScale})`,
|
|
17244
17415
|
}, children: [dimensions.height, "m \u00D7 ", dimensions.width, "m"] }) }))] }));
|
|
17245
17416
|
})()] }));
|
|
17246
17417
|
};
|
|
@@ -17664,8 +17835,8 @@ const useDoodleTransform = (data, onTransformChange, options) => {
|
|
|
17664
17835
|
const scaledHeight = height * currentScale;
|
|
17665
17836
|
// 转换为米单位(假设SVG坐标单位是米)
|
|
17666
17837
|
// 这里可以根据实际的地图比例尺进行调整
|
|
17667
|
-
const widthInMeters = scaledWidth;
|
|
17668
|
-
const heightInMeters = scaledHeight;
|
|
17838
|
+
const widthInMeters = scaledWidth / SCALE_FACTOR;
|
|
17839
|
+
const heightInMeters = scaledHeight / SCALE_FACTOR;
|
|
17669
17840
|
return {
|
|
17670
17841
|
width: Math.round(widthInMeters * 100) / 100, // 保留2位小数
|
|
17671
17842
|
height: Math.round(heightInMeters * 100) / 100, // 保留2位小数
|
|
@@ -17697,15 +17868,15 @@ const useDoodleTransform = (data, onTransformChange, options) => {
|
|
|
17697
17868
|
};
|
|
17698
17869
|
};
|
|
17699
17870
|
|
|
17700
|
-
var _path$
|
|
17701
|
-
function _extends$
|
|
17871
|
+
var _path$a;
|
|
17872
|
+
function _extends$e() { return _extends$e = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$e.apply(null, arguments); }
|
|
17702
17873
|
var SvgTransformArrow = function SvgTransformArrow(props) {
|
|
17703
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
17874
|
+
return /*#__PURE__*/React.createElement("svg", _extends$e({
|
|
17704
17875
|
xmlns: "http://www.w3.org/2000/svg",
|
|
17705
17876
|
width: 7,
|
|
17706
17877
|
height: 11,
|
|
17707
17878
|
fill: "none"
|
|
17708
|
-
}, props), _path$
|
|
17879
|
+
}, props), _path$a || (_path$a = /*#__PURE__*/React.createElement("path", {
|
|
17709
17880
|
fill: "#fff",
|
|
17710
17881
|
d: "M2.156 1.032a.777.777 0 0 0-1.061 0 .69.69 0 0 0-.062.943l.062.068 3.97 3.78-3.97 3.78a.69.69 0 0 0-.062.944l.062.067c.27.257.696.277.99.06l.07-.06 4.5-4.286a.69.69 0 0 0 .063-.943l-.062-.067z",
|
|
17711
17882
|
opacity: 0.5
|
|
@@ -17767,7 +17938,7 @@ const DoodleTransform = ({ data, isSelected: _isSelected, onSelect }) => {
|
|
|
17767
17938
|
};
|
|
17768
17939
|
|
|
17769
17940
|
const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOperation = false, onSelect, onCancel, onTransformChange, disabled = false, className = '', minScale, onMinScaleReached, onDragMove, onDragEnd, showInfo = true, onClickInfo, }) => {
|
|
17770
|
-
const { platform } = useCommonContext();
|
|
17941
|
+
const { platform, overlayScale } = useCommonContext();
|
|
17771
17942
|
// 使用自定义hook管理所有变换逻辑
|
|
17772
17943
|
const { currentCenter, currentScale, currentDirection, isDragging, isRotating, isScaling, initializeTransform, calculateSelectionBoxPoints, handleMouseDown, handleRotateStart, handleScaleStart, handleMouseMove, handleMouseUp, containerRef, dimensions, } = useDoodleTransform(data, onTransformChange, {
|
|
17773
17944
|
minScale,
|
|
@@ -17789,16 +17960,20 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
|
|
|
17789
17960
|
}, [data?.svg, currentCenter, currentScale, currentDirection]);
|
|
17790
17961
|
const isWeb = useMemo(() => platform === 'web', [platform]);
|
|
17791
17962
|
const activeTime = useMemo(() => {
|
|
17792
|
-
|
|
17793
|
-
|
|
17794
|
-
console.log('now------->', now);
|
|
17795
|
-
console.log('data.create_ts------->', data.create_ts);
|
|
17796
|
-
console.log('data.expiration_ts------->', data.expiration_ts);
|
|
17797
|
-
if (data.create_ts <= now && data.expiration_ts >= now) {
|
|
17798
|
-
return Math.floor((data.expiration_ts - now) / (60 * 60 * 24 * 1000));
|
|
17963
|
+
if (data.create_ts && data.expiration_ts) {
|
|
17964
|
+
return Math.floor((data.expiration_ts - data.create_ts) / (60 * 60 * 24));
|
|
17799
17965
|
}
|
|
17800
17966
|
return 0;
|
|
17801
17967
|
}, [data]);
|
|
17968
|
+
const remainingTime = useMemo(() => {
|
|
17969
|
+
const currentTime = Math.floor(Date.now() / 1000);
|
|
17970
|
+
console.log('data.expiration_ts--', data.expiration_ts);
|
|
17971
|
+
if (data.expiration_ts <= currentTime) {
|
|
17972
|
+
return 0;
|
|
17973
|
+
}
|
|
17974
|
+
// 保留一位小数
|
|
17975
|
+
return ((currentTime - data.expiration_ts) / (24 * 60 * 60)).toFixed(1);
|
|
17976
|
+
}, [data]);
|
|
17802
17977
|
// 初始化变换状态
|
|
17803
17978
|
useEffect(() => {
|
|
17804
17979
|
initializeTransform();
|
|
@@ -17879,7 +18054,18 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
|
|
|
17879
18054
|
};
|
|
17880
18055
|
const selectionBoxWithoutOperation = () => {
|
|
17881
18056
|
const selectionBoxPoints = calculateSelectionBoxPoints();
|
|
17882
|
-
|
|
18057
|
+
// 计算选择框的边界
|
|
18058
|
+
const minX = Math.min(...selectionBoxPoints.map((p) => p.x));
|
|
18059
|
+
const maxX = Math.max(...selectionBoxPoints.map((p) => p.x));
|
|
18060
|
+
const maxY = Math.max(...selectionBoxPoints.map((p) => p.y));
|
|
18061
|
+
// 计算选择框的中心
|
|
18062
|
+
const centerX = (minX + maxX) / 2;
|
|
18063
|
+
// 计算尺寸显示框的位置(选择框下方)
|
|
18064
|
+
const infoBoxY = maxY + 20; // 选择框下方20像素
|
|
18065
|
+
const infoBoxWidth = 140 * overlayScale; // 信息框宽度
|
|
18066
|
+
const infoBoxHeight = 100 * overlayScale; // 信息框高度
|
|
18067
|
+
const infoBoxX = centerX - infoBoxWidth / 2; // 居中对齐
|
|
18068
|
+
return (jsxs(Fragment, { children: [jsx("polygon", { points: selectionBoxPoints.map((point) => `${point.x},${point.y}`).join(' '), fill: "none", stroke: "#B2B4B9", strokeWidth: "2", strokeDasharray: "5,5", vectorEffect: "non-scaling-stroke", style: { cursor: 'move' }, ...(platform === PlatformType.H5
|
|
17883
18069
|
? {
|
|
17884
18070
|
onTouchStart: createReactEventHandler((e) => {
|
|
17885
18071
|
handleMouseDownWithDisabled(e);
|
|
@@ -17887,7 +18073,26 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
|
|
|
17887
18073
|
}
|
|
17888
18074
|
: {
|
|
17889
18075
|
onMouseDown: handleMouseDownWithDisabled,
|
|
17890
|
-
}) }), jsx("circle", { cx: selectionBoxPoints[0].x, cy: selectionBoxPoints[0].y, r:
|
|
18076
|
+
}) }), jsx("circle", { cx: selectionBoxPoints[0].x, cy: selectionBoxPoints[0].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsx("circle", { cx: selectionBoxPoints[3].x, cy: selectionBoxPoints[3].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsx("circle", { cx: selectionBoxPoints[1].x, cy: selectionBoxPoints[1].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsx("circle", { cx: selectionBoxPoints[2].x, cy: selectionBoxPoints[2].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsx("foreignObject", { x: infoBoxX, y: infoBoxY, width: infoBoxWidth, height: infoBoxHeight, style: { textAlign: 'center' }, onClick: () => {
|
|
18077
|
+
onClickInfo?.();
|
|
18078
|
+
}, children: jsx("div", { style: {
|
|
18079
|
+
padding: '5px 6px',
|
|
18080
|
+
background: 'rgba(201, 209, 218, 1)',
|
|
18081
|
+
borderRadius: '10px',
|
|
18082
|
+
display: 'inline-flex',
|
|
18083
|
+
flexDirection: 'column',
|
|
18084
|
+
alignItems: 'flex-start',
|
|
18085
|
+
justifyContent: 'center',
|
|
18086
|
+
fontSize: '12px',
|
|
18087
|
+
color: 'white',
|
|
18088
|
+
fontWeight: '400',
|
|
18089
|
+
// transform: `translate(0, ${50 * overlayScale}px) scale(${overlayScale})`,
|
|
18090
|
+
}, children: jsx("div", { style: {
|
|
18091
|
+
display: 'flex',
|
|
18092
|
+
alignItems: 'center',
|
|
18093
|
+
justifyContent: 'center',
|
|
18094
|
+
gap: '10px',
|
|
18095
|
+
}, children: jsxs("div", { children: ["Remaining Time: ", remainingTime] }) }) }) })] }));
|
|
17891
18096
|
};
|
|
17892
18097
|
useEffect(() => {
|
|
17893
18098
|
const isMove = isDragging || isRotating || isScaling;
|
|
@@ -17935,10 +18140,10 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
|
|
|
17935
18140
|
const centerX = (minX + maxX) / 2;
|
|
17936
18141
|
// 计算尺寸显示框的位置(选择框下方)
|
|
17937
18142
|
const infoBoxY = maxY + 20; // 选择框下方20像素
|
|
17938
|
-
const infoBoxWidth = 140; // 信息框宽度
|
|
17939
|
-
const infoBoxHeight =
|
|
18143
|
+
const infoBoxWidth = 140 * overlayScale; // 信息框宽度
|
|
18144
|
+
const infoBoxHeight = 100 * overlayScale; // 信息框高度
|
|
17940
18145
|
const infoBoxX = centerX - infoBoxWidth / 2; // 居中对齐
|
|
17941
|
-
const scale = isWeb ? 2 : 1;
|
|
18146
|
+
const scale = (isWeb ? 2 : 1) * overlayScale;
|
|
17942
18147
|
const offsetLeft = 10 * scale;
|
|
17943
18148
|
return (jsxs(Fragment, { children: [jsx("polygon", { points: selectionBoxPoints.map((point) => `${point.x},${point.y}`).join(' '), fill: "none", stroke: "#9EA6BA", strokeWidth: "2", strokeDasharray: "5,5", vectorEffect: "non-scaling-stroke", style: { cursor: 'move' }, ...(platform === PlatformType.H5
|
|
17944
18149
|
? {
|
|
@@ -17993,6 +18198,7 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
|
|
|
17993
18198
|
fontSize: '12px',
|
|
17994
18199
|
color: 'white',
|
|
17995
18200
|
fontWeight: '400',
|
|
18201
|
+
// transform: `translate(0, ${50 * overlayScale}px) scale(${overlayScale})`,
|
|
17996
18202
|
}, children: [jsxs("div", { children: [dimensions.height, "m \u00D7 ", dimensions.width, "m"] }), jsxs("div", { style: {
|
|
17997
18203
|
display: 'flex',
|
|
17998
18204
|
alignItems: 'center',
|
|
@@ -18003,9 +18209,9 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
|
|
|
18003
18209
|
};
|
|
18004
18210
|
|
|
18005
18211
|
const DoodleElement = ({ data }) => {
|
|
18006
|
-
const { editMapInfo, setEditMapInfo, onHandleEnterRecord,
|
|
18212
|
+
const { editMapInfo, setEditMapInfo, onHandleEnterRecord, onHandleEvent } = useMapEditContext();
|
|
18007
18213
|
const { addHistory } = useHistoryHandle();
|
|
18008
|
-
const { platform } = useCommonContext();
|
|
18214
|
+
const { platform, doodleList } = useCommonContext();
|
|
18009
18215
|
const isSelected = useMemo(() => {
|
|
18010
18216
|
if (platform === PlatformType.H5) {
|
|
18011
18217
|
if (editMapInfo.mobileMode !== MobileEditMode.START &&
|
|
@@ -18022,6 +18228,23 @@ const DoodleElement = ({ data }) => {
|
|
|
18022
18228
|
}
|
|
18023
18229
|
return data;
|
|
18024
18230
|
}, [data, editMapInfo?.selectElement]);
|
|
18231
|
+
const minScale = useMemo(() => {
|
|
18232
|
+
const doodleInfo = doodleList?.find((item) => {
|
|
18233
|
+
// 移除所有空白字符(包括\n、\r、\t等)进行比较
|
|
18234
|
+
const normalizedItemSvg = item.svgStr?.replace(/[\s\n\r\t]+/g, '').replace(/\\n/g, '');
|
|
18235
|
+
const normalizedOriginSvg = originData.svg?.replace(/[\s\n\r\t]+/g, '').replace(/\\n/g, '');
|
|
18236
|
+
// console.log('normalizedItemSvg--->', normalizedItemSvg, normalizedOriginSvg);
|
|
18237
|
+
return normalizedItemSvg === normalizedOriginSvg;
|
|
18238
|
+
});
|
|
18239
|
+
console.log('doodleList--->', doodleList, originData, doodleInfo);
|
|
18240
|
+
if (!doodleInfo) {
|
|
18241
|
+
return 1;
|
|
18242
|
+
}
|
|
18243
|
+
const minLength = doodleInfo?.minLength;
|
|
18244
|
+
const parseSvg = SvgParserNative.parseSvg(originData.svg);
|
|
18245
|
+
const svgMinLength = parseSvg.height / SCALE_FACTOR;
|
|
18246
|
+
return minLength / svgMinLength;
|
|
18247
|
+
}, [doodleList, originData]);
|
|
18025
18248
|
const isSelectedWithoutOperation = useMemo(() => {
|
|
18026
18249
|
if (platform === PlatformType.H5) {
|
|
18027
18250
|
if (editMapInfo.mobileMode === MobileEditMode.START &&
|
|
@@ -18100,8 +18323,8 @@ const DoodleElement = ({ data }) => {
|
|
|
18100
18323
|
}));
|
|
18101
18324
|
}, []);
|
|
18102
18325
|
const handleClickInfo = useCallback(() => {
|
|
18103
|
-
|
|
18104
|
-
}, [
|
|
18326
|
+
onHandleEvent?.(ClickEventType.DOODLE_ACTIVE_TIME);
|
|
18327
|
+
}, [onHandleEvent]);
|
|
18105
18328
|
// const handleDragMove = useCallback(
|
|
18106
18329
|
// (data: DoodleData) => {
|
|
18107
18330
|
// setEditMapInfo((prev: EditMapInfo) => ({
|
|
@@ -18129,7 +18352,8 @@ const DoodleElement = ({ data }) => {
|
|
|
18129
18352
|
},
|
|
18130
18353
|
});
|
|
18131
18354
|
}, [transformedElements]);
|
|
18132
|
-
|
|
18355
|
+
console.log('originData--->', originData, minScale);
|
|
18356
|
+
return (jsx(DoodleTransformWrapper, { data: originData, onTransformChange: handleTransformChange, isSelected: isSelected, isSelectedWithoutOperation: isSelectedWithoutOperation, onSelect: handleSelect, onCancel: handleCancel, onDragEnd: handleDragEnd, showInfo: platform === PlatformType.H5, onClickInfo: handleClickInfo, minScale: minScale }));
|
|
18133
18357
|
};
|
|
18134
18358
|
|
|
18135
18359
|
const SvgElement = React__default.memo(({ type, data, interactive = false }) => {
|
|
@@ -19363,27 +19587,37 @@ const getScreenCenterSvgPoint = (svgElement, mapInstance) => {
|
|
|
19363
19587
|
*/
|
|
19364
19588
|
const CreateObstacleElement = forwardRef(({ enabled = false, svgElement, onPointsChange, styles, points }, ref) => {
|
|
19365
19589
|
const { mapRef } = useCommonContext();
|
|
19590
|
+
const { checkCanNotCreateAtPosition } = useCheckElement();
|
|
19366
19591
|
// 使用固定的样式,确保能正常渲染
|
|
19367
19592
|
// 在十字准心位置添加点
|
|
19368
19593
|
const addPoint = useCallback(() => {
|
|
19369
19594
|
if (!enabled || !svgElement) {
|
|
19370
19595
|
console.warn('未启用创建模式或SVG元素不存在');
|
|
19371
|
-
return false;
|
|
19596
|
+
return { isValid: false, reason: '未启用创建模式或SVG元素不存在' };
|
|
19372
19597
|
}
|
|
19373
19598
|
if (!mapRef) {
|
|
19374
19599
|
console.warn('地图实例不存在');
|
|
19375
|
-
return false;
|
|
19600
|
+
return { isValid: false, reason: '地图实例不存在' };
|
|
19376
19601
|
}
|
|
19377
19602
|
const centerPoint = getScreenCenterSvgPoint(svgElement, mapRef);
|
|
19378
19603
|
if (!centerPoint) {
|
|
19379
19604
|
console.warn('无法获取屏幕中心点的SVG坐标或点不在SVG可见区域内');
|
|
19380
|
-
|
|
19381
|
-
|
|
19382
|
-
|
|
19605
|
+
return { isValid: false, reason: '无法获取屏幕中心点的SVG坐标或点不在SVG可见区域内' };
|
|
19606
|
+
}
|
|
19607
|
+
console.error('centerPoint--->', centerPoint);
|
|
19608
|
+
console.error('checkCanNotCreateAtPosition--->', checkCanNotCreateAtPosition(centerPoint));
|
|
19609
|
+
// 校验是否能打点
|
|
19610
|
+
if (checkCanNotCreateAtPosition(centerPoint)) {
|
|
19611
|
+
return {
|
|
19612
|
+
isValid: false,
|
|
19613
|
+
reason: '无法获取屏幕中心点的SVG坐标或点不在SVG可见区域内',
|
|
19614
|
+
};
|
|
19383
19615
|
}
|
|
19384
19616
|
const newPoints = [...points, centerPoint];
|
|
19385
19617
|
onPointsChange?.(newPoints);
|
|
19386
|
-
return
|
|
19618
|
+
return {
|
|
19619
|
+
isValid: true,
|
|
19620
|
+
};
|
|
19387
19621
|
}, [enabled, svgElement, mapRef, points, onPointsChange]);
|
|
19388
19622
|
// 撤销最后一个点
|
|
19389
19623
|
const undoLastPoint = useCallback(() => {
|
|
@@ -19473,7 +19707,7 @@ const SvgEditMap = forwardRef(({ mapJson, mapConfig, editMap, onEditInfoMapChang
|
|
|
19473
19707
|
const { editMapInfo, setEditMapInfo } = useMapEditContext();
|
|
19474
19708
|
const { getVisionOffPoints, centerPoint } = useCreateVisionOffElement();
|
|
19475
19709
|
const { svgElementDatas } = useSvgEditContext();
|
|
19476
|
-
const { checkCanNotCreateAtPosition } = useCheckElement();
|
|
19710
|
+
const { checkCanNotCreateAtPosition, checkDoodle } = useCheckElement();
|
|
19477
19711
|
const svgRef = useRef(null);
|
|
19478
19712
|
const containerRef = useRef(null);
|
|
19479
19713
|
const { platform } = useCommonContext();
|
|
@@ -19607,7 +19841,7 @@ const SvgEditMap = forwardRef(({ mapJson, mapConfig, editMap, onEditInfoMapChang
|
|
|
19607
19841
|
getEditMapInfo,
|
|
19608
19842
|
// 十字准心点管理器方法
|
|
19609
19843
|
addCreateObstaclePoint: () => {
|
|
19610
|
-
return pointManagerRef.current?.addPoint();
|
|
19844
|
+
return pointManagerRef.current?.addPoint?.();
|
|
19611
19845
|
},
|
|
19612
19846
|
undoCreateObstaclePoint: () => {
|
|
19613
19847
|
pointManagerRef.current?.undoLastPoint();
|
|
@@ -19629,6 +19863,7 @@ const SvgEditMap = forwardRef(({ mapJson, mapConfig, editMap, onEditInfoMapChang
|
|
|
19629
19863
|
clearHistory,
|
|
19630
19864
|
addHistory,
|
|
19631
19865
|
addDoodle,
|
|
19866
|
+
checkDoodle: () => checkDoodle?.(),
|
|
19632
19867
|
}));
|
|
19633
19868
|
// 初始化多边形绘制 Hook
|
|
19634
19869
|
const { onSvgClick, onSvgMouseMove, onPointClick, points, completed, mousePos, updatePoints } = usePolygonDrawing({ createMode: isCreating });
|
|
@@ -19748,10 +19983,10 @@ var css_248z$c = ".index-module_addEntry__QsQHD {\n position: absolute;\n righ
|
|
|
19748
19983
|
var styles$c = {"addEntry":"index-module_addEntry__QsQHD","icon":"index-module_icon__qIgA4","addItem":"index-module_addItem__mglwZ","label":"index-module_label__QqZ-9"};
|
|
19749
19984
|
styleInject(css_248z$c);
|
|
19750
19985
|
|
|
19751
|
-
var _rect$2, _path$
|
|
19752
|
-
function _extends$
|
|
19986
|
+
var _rect$2, _path$9, _defs$3;
|
|
19987
|
+
function _extends$d() { return _extends$d = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$d.apply(null, arguments); }
|
|
19753
19988
|
var SvgAddEntry = function SvgAddEntry(props) {
|
|
19754
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
19989
|
+
return /*#__PURE__*/React.createElement("svg", _extends$d({
|
|
19755
19990
|
xmlns: "http://www.w3.org/2000/svg",
|
|
19756
19991
|
width: 24,
|
|
19757
19992
|
height: 24,
|
|
@@ -19779,7 +20014,7 @@ var SvgAddEntry = function SvgAddEntry(props) {
|
|
|
19779
20014
|
height: "100%",
|
|
19780
20015
|
width: "100%"
|
|
19781
20016
|
}
|
|
19782
|
-
})), _path$
|
|
20017
|
+
})), _path$9 || (_path$9 = /*#__PURE__*/React.createElement("path", {
|
|
19783
20018
|
fill: "#1F1F1F",
|
|
19784
20019
|
stroke: "url(#add-entry_svg__c)",
|
|
19785
20020
|
strokeWidth: 0.3,
|
|
@@ -19819,15 +20054,15 @@ var SvgAddEntry = function SvgAddEntry(props) {
|
|
|
19819
20054
|
})))));
|
|
19820
20055
|
};
|
|
19821
20056
|
|
|
19822
|
-
var _path$
|
|
19823
|
-
function _extends$
|
|
20057
|
+
var _path$8, _path2$3, _path3;
|
|
20058
|
+
function _extends$c() { return _extends$c = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$c.apply(null, arguments); }
|
|
19824
20059
|
var SvgBoundary = function SvgBoundary(props) {
|
|
19825
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
20060
|
+
return /*#__PURE__*/React.createElement("svg", _extends$c({
|
|
19826
20061
|
xmlns: "http://www.w3.org/2000/svg",
|
|
19827
20062
|
width: 16,
|
|
19828
20063
|
height: 16,
|
|
19829
20064
|
fill: "none"
|
|
19830
|
-
}, props), _path$
|
|
20065
|
+
}, props), _path$8 || (_path$8 = /*#__PURE__*/React.createElement("path", {
|
|
19831
20066
|
fill: "#1DBEAC",
|
|
19832
20067
|
fillRule: "evenodd",
|
|
19833
20068
|
d: "M3.385 2h9.23C13.38 2 14 2.62 14 3.385v9.23C14 13.38 13.38 14 12.615 14h-9.23C2.62 14 2 13.38 2 12.615v-9.23C2 2.62 2.62 2 3.385 2m9.692 1.385a.46.46 0 0 0-.462-.462h-9.23a.46.46 0 0 0-.462.462v9.23c0 .255.207.462.462.462h9.23a.46.46 0 0 0 .462-.462z",
|
|
@@ -19845,15 +20080,15 @@ var SvgBoundary = function SvgBoundary(props) {
|
|
|
19845
20080
|
})));
|
|
19846
20081
|
};
|
|
19847
20082
|
|
|
19848
|
-
var _path$
|
|
19849
|
-
function _extends$
|
|
20083
|
+
var _path$7, _path2$2, _rect$1, _rect2$1;
|
|
20084
|
+
function _extends$b() { return _extends$b = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$b.apply(null, arguments); }
|
|
19850
20085
|
var SvgLimitIsland = function SvgLimitIsland(props) {
|
|
19851
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
20086
|
+
return /*#__PURE__*/React.createElement("svg", _extends$b({
|
|
19852
20087
|
xmlns: "http://www.w3.org/2000/svg",
|
|
19853
20088
|
width: 16,
|
|
19854
20089
|
height: 16,
|
|
19855
20090
|
fill: "none"
|
|
19856
|
-
}, props), _path$
|
|
20091
|
+
}, props), _path$7 || (_path$7 = /*#__PURE__*/React.createElement("path", {
|
|
19857
20092
|
fill: "#FFA077",
|
|
19858
20093
|
d: "M11.725 6.714c-1.019-.137-2.516-1.488-1.9-2.14.588-.621 1.91.344 1.9 2.14"
|
|
19859
20094
|
})), _path2$2 || (_path2$2 = /*#__PURE__*/React.createElement("path", {
|
|
@@ -19879,9 +20114,9 @@ var SvgLimitIsland = function SvgLimitIsland(props) {
|
|
|
19879
20114
|
};
|
|
19880
20115
|
|
|
19881
20116
|
var _rect, _rect2, _rect3, _rect4, _g$3;
|
|
19882
|
-
function _extends$
|
|
20117
|
+
function _extends$a() { return _extends$a = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$a.apply(null, arguments); }
|
|
19883
20118
|
var SvgVisionFence = function SvgVisionFence(props) {
|
|
19884
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
20119
|
+
return /*#__PURE__*/React.createElement("svg", _extends$a({
|
|
19885
20120
|
xmlns: "http://www.w3.org/2000/svg",
|
|
19886
20121
|
width: 16,
|
|
19887
20122
|
height: 16,
|
|
@@ -19934,9 +20169,9 @@ var SvgVisionFence = function SvgVisionFence(props) {
|
|
|
19934
20169
|
};
|
|
19935
20170
|
|
|
19936
20171
|
var _g$2, _defs$2;
|
|
19937
|
-
function _extends$
|
|
20172
|
+
function _extends$9() { return _extends$9 = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$9.apply(null, arguments); }
|
|
19938
20173
|
var SvgDoodle = function SvgDoodle(props) {
|
|
19939
|
-
return /*#__PURE__*/React.createElement("svg", _extends$
|
|
20174
|
+
return /*#__PURE__*/React.createElement("svg", _extends$9({
|
|
19940
20175
|
xmlns: "http://www.w3.org/2000/svg",
|
|
19941
20176
|
width: 16,
|
|
19942
20177
|
height: 16,
|
|
@@ -20045,25 +20280,10 @@ const CustomModal = ({ children, titleCenter, hasMinHeight, height, ...props })
|
|
|
20045
20280
|
}), cancelButtonProps: { color: 'primary', variant: 'outlined' }, cancelText: 'Cancel', ...props, children: children }));
|
|
20046
20281
|
};
|
|
20047
20282
|
|
|
20048
|
-
var css_248z$a = ".index-module_doodleModal__EGNPW .index-module_title__ViZuB {\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: rgb(29, 29, 29);\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T {\n display: flex;\n flex-wrap: wrap;\n gap: 10px;\n max-height: 230px;\n overflow-y: auto;\n width: 470px;\n margin: 20px auto 0;\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7 {\n width: 70px;\n height: 70px;\n padding: 10px;\n border-radius: 8px;\n cursor: pointer;\n border: 2px solid transparent;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n transition: all 0.2s ease;\n position: relative;\n background: rgb(233, 242, 241);\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7:hover {\n background-color: rgba(0, 0, 0, 0.05);\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7.index-module_active__1OHfd {\n border: 2px solid
|
|
20049
|
-
var styles$a = {"doodleModal":"index-module_doodleModal__EGNPW","title":"index-module_title__ViZuB","content":"index-module_content__h-60T","item":"index-module_item__dvoq7","active":"index-module_active__1OHfd","
|
|
20283
|
+
var css_248z$a = ".index-module_doodleModal__EGNPW .index-module_title__ViZuB {\n font-weight: 400;\n font-size: 14px;\n line-height: 20px;\n color: rgb(29, 29, 29);\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T {\n display: flex;\n flex-wrap: wrap;\n gap: 10px;\n max-height: 230px;\n overflow-y: auto;\n width: 470px;\n margin: 20px auto 0;\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7 {\n width: 70px;\n height: 70px;\n padding: 10px;\n border-radius: 8px;\n cursor: pointer;\n border: 2px solid transparent;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n transition: all 0.2s ease;\n position: relative;\n background: rgb(233, 242, 241);\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7:hover {\n background-color: rgba(0, 0, 0, 0.05);\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7.index-module_active__1OHfd {\n border: 2px solid #ff5a00;\n background-color: rgba(110, 220, 207, 0.1);\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7.index-module_active__1OHfd .index-module_selectIcon__EFQF- {\n display: block;\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7 .index-module_svgImage__2OT8- {\n width: 100%;\n height: 100%;\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7 .index-module_svgImage__2OT8- svg {\n width: 100%;\n height: 100%;\n}\n.index-module_doodleModal__EGNPW .index-module_content__h-60T .index-module_item__dvoq7 .index-module_selectIcon__EFQF- {\n position: absolute;\n bottom: 4px;\n right: 4px;\n display: none;\n}";
|
|
20284
|
+
var styles$a = {"doodleModal":"index-module_doodleModal__EGNPW","title":"index-module_title__ViZuB","content":"index-module_content__h-60T","item":"index-module_item__dvoq7","active":"index-module_active__1OHfd","svgImage":"index-module_svgImage__2OT8-"};
|
|
20050
20285
|
styleInject(css_248z$a);
|
|
20051
20286
|
|
|
20052
|
-
var _path$7;
|
|
20053
|
-
function _extends$9() { return _extends$9 = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends$9.apply(null, arguments); }
|
|
20054
|
-
var SvgSelect = function SvgSelect(props) {
|
|
20055
|
-
return /*#__PURE__*/React.createElement("svg", _extends$9({
|
|
20056
|
-
xmlns: "http://www.w3.org/2000/svg",
|
|
20057
|
-
width: 14,
|
|
20058
|
-
height: 12,
|
|
20059
|
-
fill: "none"
|
|
20060
|
-
}, props), _path$7 || (_path$7 = /*#__PURE__*/React.createElement("path", {
|
|
20061
|
-
stroke: "#6EDCCF",
|
|
20062
|
-
strokeWidth: 2,
|
|
20063
|
-
d: "m1 7.5 4 3L12.5 1"
|
|
20064
|
-
})));
|
|
20065
|
-
};
|
|
20066
|
-
|
|
20067
20287
|
const DoodleModal = ({ open, onSelect, setOpen, doodleList, centerPoint }) => {
|
|
20068
20288
|
const { editMapInfo, setEditMapInfo, onHandleEnterRecord } = useMapEditContext();
|
|
20069
20289
|
const [selectedDoodle, setSelectedDoodle] = useState(null);
|
|
@@ -20081,7 +20301,7 @@ const DoodleModal = ({ open, onSelect, setOpen, doodleList, centerPoint }) => {
|
|
|
20081
20301
|
const svg = selectedDoodle?.svgStr;
|
|
20082
20302
|
const minLength = selectedDoodle.minLength;
|
|
20083
20303
|
const parseSvg = SvgParserNative.parseSvg(svg);
|
|
20084
|
-
const svgMinLength =
|
|
20304
|
+
const svgMinLength = parseSvg.height / SCALE_FACTOR;
|
|
20085
20305
|
// 使用获取到的 SVG 内容,如果没有获取到则使用 URL
|
|
20086
20306
|
newDoodle.svg = svg;
|
|
20087
20307
|
newDoodle.scale = minLength / svgMinLength;
|
|
@@ -20111,12 +20331,12 @@ const DoodleModal = ({ open, onSelect, setOpen, doodleList, centerPoint }) => {
|
|
|
20111
20331
|
});
|
|
20112
20332
|
}
|
|
20113
20333
|
}, [selectedDoodle, setEditMapInfo, editMapInfo, setOpen, onSelect, centerPoint]);
|
|
20114
|
-
return (jsx(CustomModal, { width: 560, title: "
|
|
20334
|
+
return (jsx(CustomModal, { width: 560, title: "Create doodle", titleCenter: true, open: open, onOk: handleConfirm, onCancel: () => setOpen(false), okButtonProps: { disabled: !selectedDoodle }, afterClose: () => setSelectedDoodle(null), okText: "Create", cancelText: "Cancel", children: jsxs("div", { className: styles$a.doodleModal, children: [jsx("div", { className: styles$a.title, children: "Select the doodle that you want to create" }), jsx("div", { className: styles$a.content, children: doodleList
|
|
20115
20335
|
?.filter((item) => !noNeed.includes(item.name))
|
|
20116
20336
|
.map((item) => {
|
|
20117
|
-
return (
|
|
20337
|
+
return (jsx("div", { className: classNames(styles$a.item, {
|
|
20118
20338
|
[styles$a.active]: selectedDoodle?.svg === item.svg,
|
|
20119
|
-
}), onClick: () => handleSelectDoodle(item), children:
|
|
20339
|
+
}), onClick: () => handleSelectDoodle(item), children: jsx("div", { className: styles$a.svgImage, dangerouslySetInnerHTML: { __html: item?.svgStr } }) }, item.id));
|
|
20120
20340
|
}) })] }) }));
|
|
20121
20341
|
};
|
|
20122
20342
|
|
|
@@ -20212,11 +20432,11 @@ const AddEntry = ({ doodleList, disabledObstacles, editMap }) => {
|
|
|
20212
20432
|
}), children: jsx("div", { className: styles$c.icon, children: jsx(SvgAddEntry, {}) }) }), jsx(DoodleModal, { centerPoint: centerPoint, doodleList: doodleList, open: doodleOpen, onOk: () => setDoodleOpen(false), setOpen: setDoodleOpen })] }));
|
|
20213
20433
|
};
|
|
20214
20434
|
|
|
20215
|
-
var css_248z$9 = ".index-module_handleElementInfo__vWIaf {\n position: absolute;\n right: 0;\n top: 0;\n border-radius: 8px;\n padding:
|
|
20216
|
-
var styles$9 = {"handleElementInfo":"index-module_handleElementInfo__vWIaf","undoAndRedo":"index-module_undoAndRedo__EKeA8","undo":"index-module_undo__lPY1X","redo":"index-module_redo__EU5u-","disabled":"index-module_disabled__w6gCJ","nameEdit":"index-module_nameEdit__eVzQ-","handle":"index-module_handle__4mIxr","doodleInfo":"index-module_doodleInfo__bd2ua","time":"index-module_time__1bUFf","exist":"index-module_exist__gWtNo","tip":"index-module_tip__1HNmj","
|
|
20435
|
+
var css_248z$9 = ".index-module_handleElementInfo__vWIaf {\n position: absolute;\n right: 0;\n top: 0;\n border-radius: 8px;\n padding: 8px;\n background: #fff;\n width: 265px;\n user-select: none;\n}\n.index-module_handleElementInfo__vWIaf .index-module_border__iPL-- {\n margin: 8px 0;\n border-top: 1px solid #c5c5c5;\n}\n.index-module_handleElementInfo__vWIaf .index-module_undoAndRedo__EKeA8 {\n position: absolute;\n left: -96px;\n top: 0;\n display: flex;\n gap: 12px;\n}\n.index-module_handleElementInfo__vWIaf .index-module_undoAndRedo__EKeA8 .index-module_undo__lPY1X,\n.index-module_handleElementInfo__vWIaf .index-module_undoAndRedo__EKeA8 .index-module_redo__EU5u- {\n background: #fff;\n border-radius: 8px;\n padding: 6px;\n}\n.index-module_handleElementInfo__vWIaf .index-module_undoAndRedo__EKeA8 .index-module_undo__lPY1X:not(.index-module_disabled__w6gCJ):hover,\n.index-module_handleElementInfo__vWIaf .index-module_undoAndRedo__EKeA8 .index-module_redo__EU5u-:not(.index-module_disabled__w6gCJ):hover {\n opacity: 0.8;\n cursor: pointer;\n}\n.index-module_handleElementInfo__vWIaf .index-module_undoAndRedo__EKeA8 .index-module_undo__lPY1X.index-module_disabled__w6gCJ,\n.index-module_handleElementInfo__vWIaf .index-module_undoAndRedo__EKeA8 .index-module_redo__EU5u-.index-module_disabled__w6gCJ {\n color: #d8d8d8;\n}\n.index-module_handleElementInfo__vWIaf .index-module_nameEdit__eVzQ- {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n}\n.index-module_handleElementInfo__vWIaf .index-module_nameEdit__eVzQ- input {\n padding: 2px 0;\n}\n.index-module_handleElementInfo__vWIaf .index-module_nameEdit__eVzQ- .index-module_edit__b0r9I {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 16px;\n height: 16px;\n cursor: pointer;\n}\n.index-module_handleElementInfo__vWIaf .index-module_boundaryOther__FyJvt {\n padding-top: 4px;\n border-top: 1px solid rgb(197, 197, 197);\n}\n.index-module_handleElementInfo__vWIaf .index-module_handle__4mIxr {\n display: flex;\n align-items: center;\n justify-content: flex-end;\n padding: 0px 0 4px 0;\n}\n\n.index-module_doodleInfo__bd2ua .index-module_time__1bUFf {\n width: 100%;\n}\n.index-module_doodleInfo__bd2ua .index-module_exist__gWtNo {\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n}\n.index-module_doodleInfo__bd2ua .index-module_tip__1HNmj {\n color: #ff3f33;\n margin-top: 10px;\n font-size: 14px;\n font-weight: 400;\n line-height: 16px;\n}\n\n.index-module_areaInfo__-WJPL {\n color: #9e9e9e;\n width: 100%;\n font-size: 14px;\n font-weight: 400;\n line-height: 16px; /* 114.286% */\n}\n.index-module_areaInfo__-WJPL .index-module_areaItem__fk-i2 {\n display: flex;\n justify-content: space-between;\n padding: 6px 0;\n}\n.index-module_areaInfo__-WJPL .index-module_areaItem__fk-i2:not(:last-child) {\n margin-bottom: 4px;\n}\n\n.index-module_boundaryInfo__VfR-N .index-module_otherEdit__17SuM {\n color: #1f1f1f;\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 16px;\n}\n.index-module_boundaryInfo__VfR-N .index-module_otherEdit__17SuM .index-module_otherItem__ATLFZ {\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n}\n.index-module_boundaryInfo__VfR-N .index-module_otherEdit__17SuM .index-module_otherItem__ATLFZ .index-module_value__x3-se {\n margin-left: auto;\n}\n.index-module_boundaryInfo__VfR-N .index-module_otherEdit__17SuM .index-module_otherItem__ATLFZ .index-module_icon__167WB {\n width: 16px;\n height: 16px;\n cursor: pointer;\n}";
|
|
20436
|
+
var styles$9 = {"handleElementInfo":"index-module_handleElementInfo__vWIaf","border":"index-module_border__iPL--","undoAndRedo":"index-module_undoAndRedo__EKeA8","undo":"index-module_undo__lPY1X","redo":"index-module_redo__EU5u-","disabled":"index-module_disabled__w6gCJ","nameEdit":"index-module_nameEdit__eVzQ-","handle":"index-module_handle__4mIxr","doodleInfo":"index-module_doodleInfo__bd2ua","time":"index-module_time__1bUFf","exist":"index-module_exist__gWtNo","tip":"index-module_tip__1HNmj","areaInfo":"index-module_areaInfo__-WJPL","areaItem":"index-module_areaItem__fk-i2","boundaryInfo":"index-module_boundaryInfo__VfR-N","otherEdit":"index-module_otherEdit__17SuM","otherItem":"index-module_otherItem__ATLFZ","value":"index-module_value__x3-se","icon":"index-module_icon__167WB"};
|
|
20217
20437
|
styleInject(css_248z$9);
|
|
20218
20438
|
|
|
20219
|
-
var css_248z$8 = ".index-module_infoHeader__l9F6q {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n padding:
|
|
20439
|
+
var css_248z$8 = ".index-module_infoHeader__l9F6q {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n padding: 6px 0;\n}\n.index-module_infoHeader__l9F6q .index-module_headerIcon__sK1hg {\n width: 16px;\n height: 16px;\n}\n.index-module_infoHeader__l9F6q .index-module_headerName__UGnrH {\n margin-left: 4px;\n color: rgb(158, 158, 158);\n font-weight: 500;\n font-size: 14px;\n line-height: 16px;\n pointer-events: none;\n}\n.index-module_infoHeader__l9F6q .index-module_headerHandle__ymh7f {\n margin-left: auto;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n}\n.index-module_infoHeader__l9F6q .index-module_headerHandle__ymh7f .index-module_focus__llcox {\n width: 16px;\n height: 16px;\n cursor: pointer;\n}\n.index-module_infoHeader__l9F6q .index-module_headerHandle__ymh7f .index-module_delete__hD4-Q {\n width: 16px;\n height: 16px;\n margin-left: 8px;\n cursor: pointer;\n}";
|
|
20220
20440
|
var styles$8 = {"infoHeader":"index-module_infoHeader__l9F6q","headerIcon":"index-module_headerIcon__sK1hg","headerName":"index-module_headerName__UGnrH","headerHandle":"index-module_headerHandle__ymh7f","focus":"index-module_focus__llcox","delete":"index-module_delete__hD4-Q"};
|
|
20221
20441
|
styleInject(css_248z$8);
|
|
20222
20442
|
|
|
@@ -20285,7 +20505,7 @@ const NameModal = ({ title, name, open, setOpen, onOk }) => {
|
|
|
20285
20505
|
setOpen(false);
|
|
20286
20506
|
}, onCancel: () => setOpen(false), okText: "Confirm", afterClose: () => {
|
|
20287
20507
|
setNameValue('');
|
|
20288
|
-
}, children: jsx(Input, { maxLength:
|
|
20508
|
+
}, children: jsx(Input, { maxLength: 12, showCount: true, placeholder: "Please enter boundary name", value: nameValue, onChange: (e) => setNameValue(e.target.value) }) }));
|
|
20289
20509
|
};
|
|
20290
20510
|
|
|
20291
20511
|
const NameEdit = ({ title, name, onChange }) => {
|
|
@@ -20302,12 +20522,12 @@ var SvgArrow = function SvgArrow(props) {
|
|
|
20302
20522
|
height: 16,
|
|
20303
20523
|
fill: "none"
|
|
20304
20524
|
}, props), _path$3 || (_path$3 = /*#__PURE__*/React.createElement("path", {
|
|
20305
|
-
fill: "#
|
|
20525
|
+
fill: "#1F1F1F",
|
|
20306
20526
|
d: "M11.523 7.704c.005.014.015.026.02.04.049.125.065.268.046.406a.73.73 0 0 1-.152.363l-3.88 4.638a.47.47 0 0 1-.377.182.49.49 0 0 1-.369-.208.77.77 0 0 1-.144-.477.76.76 0 0 1 .164-.466l3.483-4.162-3.468-4.224a.77.77 0 0 1-.15-.462c0-.172.053-.338.148-.463a.49.49 0 0 1 .36-.204.47.47 0 0 1 .371.17l3.845 4.682q.007.017.017.032.008.01.018.019c.032.04.046.09.067.134"
|
|
20307
20527
|
})));
|
|
20308
20528
|
};
|
|
20309
20529
|
|
|
20310
|
-
var css_248z$6 = ".index-module_item__wwHEt {\n font-weight: 400;\n font-size: 14px;\n line-height: 16px;\n display: flex;\n align-items: center;\n padding:
|
|
20530
|
+
var css_248z$6 = ".index-module_item__wwHEt {\n font-weight: 400;\n font-size: 14px;\n line-height: 16px;\n display: flex;\n align-items: center;\n padding: 6px 0;\n}\n.index-module_item__wwHEt:not(:last-child) {\n margin-bottom: 4px;\n}";
|
|
20311
20531
|
var styles$6 = {"item":"index-module_item__wwHEt"};
|
|
20312
20532
|
styleInject(css_248z$6);
|
|
20313
20533
|
|
|
@@ -20651,43 +20871,81 @@ function convertDirectionToParams(value) {
|
|
|
20651
20871
|
return directions;
|
|
20652
20872
|
}
|
|
20653
20873
|
|
|
20874
|
+
const DEFAULT_LIST = [
|
|
20875
|
+
{
|
|
20876
|
+
value: 1 << 0,
|
|
20877
|
+
text: 'A',
|
|
20878
|
+
selected: false,
|
|
20879
|
+
},
|
|
20880
|
+
{
|
|
20881
|
+
value: 1 << 1,
|
|
20882
|
+
text: 'B',
|
|
20883
|
+
selected: false,
|
|
20884
|
+
},
|
|
20885
|
+
{
|
|
20886
|
+
value: 1 << 2,
|
|
20887
|
+
text: 'C',
|
|
20888
|
+
selected: false,
|
|
20889
|
+
},
|
|
20890
|
+
{
|
|
20891
|
+
value: 1 << 3,
|
|
20892
|
+
text: 'D',
|
|
20893
|
+
selected: false,
|
|
20894
|
+
},
|
|
20895
|
+
{
|
|
20896
|
+
value: 1 << 4,
|
|
20897
|
+
text: 'E',
|
|
20898
|
+
selected: false,
|
|
20899
|
+
},
|
|
20900
|
+
{
|
|
20901
|
+
value: 1 << 5,
|
|
20902
|
+
text: 'F',
|
|
20903
|
+
selected: false,
|
|
20904
|
+
},
|
|
20905
|
+
];
|
|
20654
20906
|
const MowDirection_L = (props) => {
|
|
20655
20907
|
const { value, angleValue, optionAngle = 45, zIndex = 10000, onChange,
|
|
20656
20908
|
// children,
|
|
20657
20909
|
} = props;
|
|
20658
20910
|
const [angle, setAngle] = useState(0);
|
|
20659
|
-
const
|
|
20660
|
-
{
|
|
20661
|
-
|
|
20662
|
-
|
|
20663
|
-
|
|
20664
|
-
|
|
20665
|
-
|
|
20666
|
-
|
|
20667
|
-
|
|
20668
|
-
|
|
20669
|
-
|
|
20670
|
-
|
|
20671
|
-
|
|
20672
|
-
|
|
20673
|
-
|
|
20674
|
-
|
|
20675
|
-
|
|
20676
|
-
|
|
20677
|
-
|
|
20678
|
-
|
|
20679
|
-
|
|
20680
|
-
|
|
20681
|
-
|
|
20682
|
-
|
|
20683
|
-
|
|
20684
|
-
|
|
20685
|
-
|
|
20686
|
-
|
|
20687
|
-
|
|
20688
|
-
|
|
20689
|
-
|
|
20690
|
-
|
|
20911
|
+
const lineList = useMemo(() => {
|
|
20912
|
+
return DEFAULT_LIST.map((item) => ({
|
|
20913
|
+
...item,
|
|
20914
|
+
selected: convertDirectionToParams(value).includes(item.value),
|
|
20915
|
+
}));
|
|
20916
|
+
}, [value]);
|
|
20917
|
+
// const [lineList, setLineList] = useState<LineItem[]>([
|
|
20918
|
+
// {
|
|
20919
|
+
// value: 1 << 0,
|
|
20920
|
+
// text: 'A',
|
|
20921
|
+
// selected: false,
|
|
20922
|
+
// },
|
|
20923
|
+
// {
|
|
20924
|
+
// value: 1 << 1,
|
|
20925
|
+
// text: 'B',
|
|
20926
|
+
// selected: false,
|
|
20927
|
+
// },
|
|
20928
|
+
// {
|
|
20929
|
+
// value: 1 << 2,
|
|
20930
|
+
// text: 'C',
|
|
20931
|
+
// selected: false,
|
|
20932
|
+
// },
|
|
20933
|
+
// {
|
|
20934
|
+
// value: 1 << 3,
|
|
20935
|
+
// text: 'D',
|
|
20936
|
+
// selected: false,
|
|
20937
|
+
// },
|
|
20938
|
+
// {
|
|
20939
|
+
// value: 1 << 4,
|
|
20940
|
+
// text: 'E',
|
|
20941
|
+
// selected: false,
|
|
20942
|
+
// },
|
|
20943
|
+
// {
|
|
20944
|
+
// value: 1 << 5,
|
|
20945
|
+
// text: 'F',
|
|
20946
|
+
// selected: false,
|
|
20947
|
+
// },
|
|
20948
|
+
// ]);
|
|
20691
20949
|
const hitRectAngle = useMemo(() => {
|
|
20692
20950
|
const direction = lineList
|
|
20693
20951
|
?.filter((item) => item?.selected)
|
|
@@ -20700,12 +20958,6 @@ const MowDirection_L = (props) => {
|
|
|
20700
20958
|
const allSelect = useMemo(() => {
|
|
20701
20959
|
return lineList?.every((item) => item?.selected);
|
|
20702
20960
|
}, [lineList]);
|
|
20703
|
-
useEffect(() => {
|
|
20704
|
-
setLineList(lineList.map((line) => ({
|
|
20705
|
-
...line,
|
|
20706
|
-
selected: convertDirectionToParams(value).includes(line.value),
|
|
20707
|
-
})));
|
|
20708
|
-
}, [value]);
|
|
20709
20961
|
useEffect(() => {
|
|
20710
20962
|
setAngle(angleValue);
|
|
20711
20963
|
}, [angleValue]);
|
|
@@ -20720,7 +20972,6 @@ const MowDirection_L = (props) => {
|
|
|
20720
20972
|
}
|
|
20721
20973
|
return { ...line };
|
|
20722
20974
|
});
|
|
20723
|
-
setLineList(newLine);
|
|
20724
20975
|
onChange?.(newLine
|
|
20725
20976
|
?.filter((item) => item?.selected)
|
|
20726
20977
|
.reduce((pre, line) => {
|
|
@@ -20833,10 +21084,25 @@ const DirectionModal = ({ directionInfo, open, setOpen, zoneName, optionAngle, o
|
|
|
20833
21084
|
setAngle(defaultAngle);
|
|
20834
21085
|
}
|
|
20835
21086
|
};
|
|
20836
|
-
|
|
20837
|
-
|
|
21087
|
+
const handleCancel = useCallback(() => {
|
|
21088
|
+
if (!canSave) {
|
|
20838
21089
|
setOpen(false);
|
|
20839
|
-
|
|
21090
|
+
return;
|
|
21091
|
+
}
|
|
21092
|
+
Modal.confirm({
|
|
21093
|
+
icon: null,
|
|
21094
|
+
centered: true,
|
|
21095
|
+
title: 'Exit editing',
|
|
21096
|
+
content: 'Changes you made will not be saved. Are you sure you want to exit editing the mowing direction?',
|
|
21097
|
+
onOk: () => {
|
|
21098
|
+
setOpen(false);
|
|
21099
|
+
},
|
|
21100
|
+
okText: 'Exit',
|
|
21101
|
+
cancelText: 'Continue editing',
|
|
21102
|
+
});
|
|
21103
|
+
}, [canSave, setOpen]);
|
|
21104
|
+
console.log('directionInfo=>', directionInfo, mapJson);
|
|
21105
|
+
return (jsx(CustomModal, { maskClosable: false, titleCenter: true, title: `${zoneName} mowing direction`, open: open, width: 600, onCancel: handleCancel, onOk: () => {
|
|
20840
21106
|
onChange?.(directions, angle);
|
|
20841
21107
|
setOpen(false);
|
|
20842
21108
|
}, okText: "Confirm", cancelText: "Cancel", okButtonProps: { disabled: !canSave }, afterClose: () => {
|
|
@@ -20844,6 +21110,8 @@ const DirectionModal = ({ directionInfo, open, setOpen, zoneName, optionAngle, o
|
|
|
20844
21110
|
setAngle(MIN_DIRECTION_ANGLE);
|
|
20845
21111
|
}, children: jsxs("div", { className: styles$3.directions, children: [jsx("div", { className: styles$3.default, children: jsx(Button, { disabled: !canSetDefault, variant: "link", color: "primary", onClick: resetDirection, children: "Default" }) }), jsx("div", { className: styles$3.tips, children: "\u4E00\u4E2A\u7B80\u77ED\u7684\u8BF4\u660E\uFF0C\u5E0C\u671B\u80FD\u5145\u5F53\u7B80\u5355\u7684\u6559\u7A0B\uFF0C\u9700\u8981\u53EF\u5FC3\u6839\u636EC\u7AEF\u5DF2\u6709\u7684\u6574\u5408\u4E00\u4E0B" }), jsxs("div", { className: styles$3.optimal, children: [jsx("div", { children: "*" }), jsx(SvgOption, {}), jsx("div", { className: styles$3.text, children: "Optimal direction" })] }), jsxs("div", { className: styles$3.content, children: [jsx("div", { className: styles$3.background, children: jsx(BoundarySvgRender, { mapJson: mapJson, id: editMapInfo.selectElement.id }) }), jsx("div", { className: styles$3.luppan, children: jsx(MowDirection_L, { value: directions, angleValue: angle, optionAngle: optionAngle, onChange: (value) => {
|
|
20846
21112
|
console.log('valie=>', value);
|
|
21113
|
+
if (!value)
|
|
21114
|
+
return message.warning('Choose at least one mowing direction');
|
|
20847
21115
|
setDirections(value);
|
|
20848
21116
|
} }) })] }), jsx("div", { className: styles$3.slideTip, children: "\u7528\u6237\u8FD8\u53EF\u4EE5\u901A\u8FC7\u6ED1\u8F68\u5FAE\u8C03\u5272\u8349\u65B9\u5411\uFF08\u975E\u5FC5\u987B\uFF09" }), jsx("div", { className: styles$3.slider, children: jsx(Slider, { tooltip: {
|
|
20849
21117
|
formatter: (value) => `${value}°`,
|
|
@@ -20902,13 +21170,13 @@ const BoundaryInfo = ({ onHandleDelete }) => {
|
|
|
20902
21170
|
name: name,
|
|
20903
21171
|
},
|
|
20904
21172
|
});
|
|
20905
|
-
} }) }), jsxs("div", { className: styles$9.otherEdit, children: [jsx(Item, { children: jsxs("div", { className: styles$9.otherItem, children: [jsx("div", { className: styles$9.label, children: "
|
|
21173
|
+
} }) }), jsx("div", { className: styles$9.border }), jsxs("div", { className: styles$9.otherEdit, children: [jsx(Item, { children: jsxs("div", { className: styles$9.otherItem, children: [jsx("div", { className: styles$9.label, children: "Cutting height" }), jsx("div", { className: styles$9.value, children: generateHeightStr(heightValue?.cuttingHeight, unitType, true) }), jsx("div", { className: styles$9.icon, onClick: () => {
|
|
20906
21174
|
setHeightOpen(true);
|
|
20907
|
-
}, children: jsx(SvgArrow, {}) })] }) }), jsx(Item, { children: jsxs("div", { className: styles$9.otherItem, children: [jsx("div", { className: styles$9.label, children: "
|
|
21175
|
+
}, children: jsx(SvgArrow, {}) })] }) }), jsx(Item, { children: jsxs("div", { className: styles$9.otherItem, children: [jsx("div", { className: styles$9.label, children: "Mowing direction" }), jsx("div", { className: styles$9.value }), jsx("div", { className: styles$9.icon, onClick: () => {
|
|
20908
21176
|
setDirectionOpen(true);
|
|
20909
|
-
}, children: jsx(SvgArrow, {}) })] }) }), jsx(Item, { children: jsxs("div", { className: styles$9.otherItem, children: [jsx("div", { className: styles$9.label, children: "
|
|
21177
|
+
}, children: jsx(SvgArrow, {}) })] }) }), jsx(Item, { children: jsxs("div", { className: styles$9.otherItem, children: [jsx("div", { className: styles$9.label, children: "Edge mowing" }), jsx("div", { className: styles$9.value }), jsx("div", { className: styles$9.icon, onClick: () => {
|
|
20910
21178
|
setOpen(true);
|
|
20911
|
-
}, children: jsx(SvgArrow, {}) })] }) })] }), jsxs("div", { className: styles$9.areaInfo, children: [jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Area:" }), jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] }), jsx(MowingEdgeModal, { value: edgeMowingValue, onChange: (value) => {
|
|
21179
|
+
}, children: jsx(SvgArrow, {}) })] }) })] }), jsx("div", { className: styles$9.border }), jsxs("div", { className: styles$9.areaInfo, children: [jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Area:" }), jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] }), jsx(MowingEdgeModal, { value: edgeMowingValue, onChange: (value) => {
|
|
20912
21180
|
setEditMapInfo({
|
|
20913
21181
|
...editMapInfo,
|
|
20914
21182
|
selectElement: {
|
|
@@ -20938,7 +21206,7 @@ const BoundaryInfo = ({ onHandleDelete }) => {
|
|
|
20938
21206
|
} })] }));
|
|
20939
21207
|
};
|
|
20940
21208
|
|
|
20941
|
-
var css_248z$1 = ".index-module_timePeriod__EkVZl {\n display: flex;\n flex-direction: column;\n
|
|
21209
|
+
var css_248z$1 = ".index-module_timePeriod__EkVZl {\n display: flex;\n flex-direction: column;\n}\n.index-module_timePeriod__EkVZl .index-module_timePeriodHeader__CgJGW {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n padding: 4px 0;\n}\n.index-module_timePeriod__EkVZl .index-module_timePeriodHeader__CgJGW .index-module_timePeriodTitle__lnYno {\n font-weight: 400;\n font-size: 14px;\n line-height: 16px;\n color: rgb(0, 0, 0);\n}\n.index-module_timePeriod__EkVZl .index-module_timePeriodHeader__CgJGW .index-module_timePeriodHandle__pjDTA {\n margin-left: auto;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n}\n.index-module_timePeriod__EkVZl .index-module_timePeriodContent__pTqdW {\n margin-top: 4px;\n}\n.index-module_timePeriod__EkVZl .index-module_timePeriodContent__pTqdW .index-module_timePeriodRadioItem__3rd-r {\n line-height: 28px;\n}";
|
|
20942
21210
|
var styles$1 = {"timePeriod":"index-module_timePeriod__EkVZl","timePeriodHeader":"index-module_timePeriodHeader__CgJGW","timePeriodTitle":"index-module_timePeriodTitle__lnYno","timePeriodHandle":"index-module_timePeriodHandle__pjDTA","timePeriodContent":"index-module_timePeriodContent__pTqdW","timePeriodRadioItem":"index-module_timePeriodRadioItem__3rd-r"};
|
|
20943
21211
|
styleInject(css_248z$1);
|
|
20944
21212
|
|
|
@@ -20962,6 +21230,8 @@ const TimePeriod = ({ value, onChange }) => {
|
|
|
20962
21230
|
onChange({
|
|
20963
21231
|
...value,
|
|
20964
21232
|
status: checked ? 1 : 0,
|
|
21233
|
+
start_timestamp: checked ? value.start_timestamp : 0,
|
|
21234
|
+
end_timestamp: checked ? value.end_timestamp : 0,
|
|
20965
21235
|
});
|
|
20966
21236
|
} }) })] }), jsx("div", { className: styles$1.timePeriodContent, children: jsxs(Radio.Group, { value: radioValue, onChange: (e) => {
|
|
20967
21237
|
setRadioValue(e.target.value);
|
|
@@ -20969,8 +21239,8 @@ const TimePeriod = ({ value, onChange }) => {
|
|
|
20969
21239
|
setDate(null);
|
|
20970
21240
|
onChange({
|
|
20971
21241
|
...value,
|
|
20972
|
-
|
|
20973
|
-
|
|
21242
|
+
start_timestamp: 0,
|
|
21243
|
+
end_timestamp: 0,
|
|
20974
21244
|
});
|
|
20975
21245
|
}
|
|
20976
21246
|
else if (e.target.value === RadioValue.SHORT_TIME) {
|
|
@@ -20981,15 +21251,15 @@ const TimePeriod = ({ value, onChange }) => {
|
|
|
20981
21251
|
// endTimestamp: dayjs().add(1, 'hour').unix(),
|
|
20982
21252
|
// });
|
|
20983
21253
|
}
|
|
20984
|
-
}, style: { display: 'flex', flexDirection: 'column', gap: '4px' }, children: [jsx(Radio, { value: RadioValue.LONG_TIME, children: jsx("div", { className: styles$1.timePeriodRadioItem, children: "
|
|
21254
|
+
}, style: { display: 'flex', flexDirection: 'column', gap: '4px' }, children: [jsx(Radio, { value: RadioValue.LONG_TIME, children: jsx("div", { className: styles$1.timePeriodRadioItem, children: "Always" }) }), jsx(Radio, { value: RadioValue.SHORT_TIME, children: jsx("div", { className: styles$1.timePeriodRadioItem, children: jsx(DatePicker.RangePicker, { open: open, value: date ? date : undefined, disabled: radioValue === RadioValue.LONG_TIME, showTime: { format: 'HH:mm' }, format: "MM/DD/YYYY HH:mm", preserveInvalidOnBlur: true, onOpenChange: (open) => {
|
|
20985
21255
|
setOpen(open);
|
|
20986
21256
|
}, onChange: (dateValue, dateString) => {
|
|
20987
21257
|
setDate(dateValue);
|
|
20988
21258
|
if (dateValue?.length === 2) {
|
|
20989
21259
|
onChange({
|
|
20990
21260
|
status: RadioValue.SHORT_TIME,
|
|
20991
|
-
|
|
20992
|
-
|
|
21261
|
+
start_timestamp: dateValue[0].unix(),
|
|
21262
|
+
end_timestamp: dateValue[1].unix(),
|
|
20993
21263
|
});
|
|
20994
21264
|
}
|
|
20995
21265
|
} }) }) })] }) })] }));
|
|
@@ -21003,12 +21273,12 @@ const ObstacleInfo = ({ onHandleDelete }) => {
|
|
|
21003
21273
|
if (!editMapInfo.selectElement)
|
|
21004
21274
|
return null;
|
|
21005
21275
|
const status = editMapInfo.selectElement?.status;
|
|
21006
|
-
const
|
|
21007
|
-
const
|
|
21276
|
+
const start_timestamp = editMapInfo.selectElement?.start_timestamp;
|
|
21277
|
+
const end_timestamp = editMapInfo.selectElement?.end_timestamp;
|
|
21008
21278
|
return {
|
|
21009
21279
|
status,
|
|
21010
|
-
|
|
21011
|
-
|
|
21280
|
+
start_timestamp,
|
|
21281
|
+
end_timestamp,
|
|
21012
21282
|
};
|
|
21013
21283
|
}, [editMapInfo.selectElement]);
|
|
21014
21284
|
const sizeValue = useMemo(() => {
|
|
@@ -21035,18 +21305,18 @@ const ObstacleInfo = ({ onHandleDelete }) => {
|
|
|
21035
21305
|
name: name,
|
|
21036
21306
|
},
|
|
21037
21307
|
});
|
|
21038
|
-
} }) }), jsx("div", { className: styles$9.timePeriod, children: jsx(TimePeriod, { value: timePeriodValue, onChange: (value) => {
|
|
21308
|
+
} }) }), jsx("div", { className: styles$9.border }), jsx("div", { className: styles$9.timePeriod, children: jsx(TimePeriod, { value: timePeriodValue, onChange: (value) => {
|
|
21039
21309
|
setEditMapInfo({
|
|
21040
21310
|
...editMapInfo,
|
|
21041
21311
|
isShowDrag: editMapInfo?.isShowDrag || false,
|
|
21042
21312
|
selectElement: {
|
|
21043
21313
|
...editMapInfo.selectElement,
|
|
21044
21314
|
status: value.status,
|
|
21045
|
-
start_timestamp: value.
|
|
21046
|
-
end_timestamp: value.
|
|
21315
|
+
start_timestamp: value.start_timestamp,
|
|
21316
|
+
end_timestamp: value.end_timestamp,
|
|
21047
21317
|
},
|
|
21048
21318
|
});
|
|
21049
|
-
} }) }), jsxs("div", { className: styles$9.areaInfo, children: [jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Area:" }), jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] })] }));
|
|
21319
|
+
} }) }), jsx("div", { className: styles$9.border }), jsxs("div", { className: styles$9.areaInfo, children: [jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Area:" }), jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] })] }));
|
|
21050
21320
|
};
|
|
21051
21321
|
|
|
21052
21322
|
const DoodleInfo = ({ onHandleDelete }) => {
|
|
@@ -21068,31 +21338,37 @@ const DoodleInfo = ({ onHandleDelete }) => {
|
|
|
21068
21338
|
const create_ts = editMapInfo?.selectElement?.create_ts;
|
|
21069
21339
|
const expiration_ts = editMapInfo.selectElement.expiration_ts;
|
|
21070
21340
|
const diff = expiration_ts - create_ts;
|
|
21071
|
-
const day = Math.floor(diff / (60 * 60 * 24
|
|
21072
|
-
console.log('create_ts->', create_ts, expiration_ts, day);
|
|
21341
|
+
const day = Math.floor(diff / (60 * 60 * 24));
|
|
21073
21342
|
return {
|
|
21074
21343
|
day: day,
|
|
21075
21344
|
};
|
|
21076
21345
|
}, [editMapInfo?.selectElement]);
|
|
21346
|
+
const remainDay = useMemo(() => {
|
|
21347
|
+
if (!editMapInfo.selectElement)
|
|
21348
|
+
return null;
|
|
21349
|
+
const expiration_ts = editMapInfo.selectElement.expiration_ts;
|
|
21350
|
+
const diff = expiration_ts - Date.now() / 1000;
|
|
21351
|
+
return Math.floor(diff / (60 * 60 * 24));
|
|
21352
|
+
}, [editMapInfo?.selectElement]);
|
|
21077
21353
|
const sizeValue = useMemo(() => {
|
|
21078
21354
|
if (!editMapInfo.selectElement || !editMapInfo.selectElement.svg)
|
|
21079
21355
|
return '';
|
|
21080
21356
|
const svg = editMapInfo.selectElement?.svg;
|
|
21357
|
+
const scale = editMapInfo.selectElement.scale;
|
|
21081
21358
|
const parseSvg = SvgParserNative.parseSvg(svg);
|
|
21082
|
-
const width = parseSvg.width / SCALE_FACTOR;
|
|
21083
|
-
const height = parseSvg.height / SCALE_FACTOR;
|
|
21084
|
-
console.log('parseSvg->', parseSvg);
|
|
21085
|
-
return `${width} m x ${height} m`;
|
|
21359
|
+
const width = (parseSvg.width * scale) / SCALE_FACTOR;
|
|
21360
|
+
const height = (parseSvg.height * scale) / SCALE_FACTOR;
|
|
21361
|
+
console.log('parseSvg->', editMapInfo, parseSvg);
|
|
21362
|
+
return `${width.toFixed(1)} m x ${height.toFixed(1)} m`;
|
|
21086
21363
|
}, [editMapInfo.selectElement]);
|
|
21087
21364
|
const handleChange = useCallback((day) => {
|
|
21088
|
-
const lastTime = Date.now() - editMapInfo.selectElement.create_ts;
|
|
21089
21365
|
setEditMapInfo((pre) => {
|
|
21090
|
-
console.log('expiration_ts->', lastTime, day, lastTime + day * 24 * 60 * 60 * 1000);
|
|
21091
21366
|
return {
|
|
21092
21367
|
...pre,
|
|
21093
21368
|
selectElement: {
|
|
21094
21369
|
...pre.selectElement,
|
|
21095
|
-
|
|
21370
|
+
create_ts: Date.now() / 1000,
|
|
21371
|
+
expiration_ts: Date.now() / 1000 + day * 24 * 60 * 60,
|
|
21096
21372
|
},
|
|
21097
21373
|
};
|
|
21098
21374
|
});
|
|
@@ -21100,7 +21376,7 @@ const DoodleInfo = ({ onHandleDelete }) => {
|
|
|
21100
21376
|
console.log('doodleInfo->', doodleInfo);
|
|
21101
21377
|
return (jsxs("div", { className: styles$9.doodleInfo, children: [jsx(Header, { handleDelete: () => {
|
|
21102
21378
|
onHandleDelete();
|
|
21103
|
-
}, handleFocus: () => { }, type: editMapInfo.elementType }), isCreate ? (jsx(Item, { children: jsxs("div", { className: styles$9.time, children: [jsxs("div", { className: styles$9.exist, children: [jsx("div", { className: styles$9.label, children: "
|
|
21379
|
+
}, handleFocus: () => { }, type: editMapInfo.elementType }), jsx("div", { className: styles$9.border }), isCreate ? (jsxs(Fragment, { children: [jsx(Item, { children: jsxs("div", { className: styles$9.time, children: [jsxs("div", { className: styles$9.exist, children: [jsx("div", { className: styles$9.label, children: "Preserve doodle for" }), jsx("div", { className: styles$9.value, children: jsx(Select, { defaultValue: doodleInfo?.day, style: { width: 80 }, onChange: (value) => handleChange(value), options: options }) })] }), doodleInfo?.day >= 14 && (jsx("div", { className: styles$9.tip, children: "* If the doodle lasts over 14 days, the grass may grow too tall for the mower to mow later." }))] }) }), jsx("div", { className: styles$9.border }), jsx("div", { className: styles$9.areaInfo, children: jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Size:" }), jsx("div", { className: styles$9.value, children: sizeValue })] }) })] })) : (jsxs("div", { className: styles$9.areaInfo, children: [jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Remaining time:" }), jsxs("div", { className: styles$9.value, children: [remainDay, " day"] })] }), jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Size:" }), jsx("div", { className: styles$9.value, children: sizeValue })] })] }))] }));
|
|
21104
21380
|
};
|
|
21105
21381
|
|
|
21106
21382
|
const VisionOffInfo = ({ onHandleDelete }) => {
|
|
@@ -21116,7 +21392,7 @@ const VisionOffInfo = ({ onHandleDelete }) => {
|
|
|
21116
21392
|
}, [editMapInfo.selectElement]);
|
|
21117
21393
|
return (jsxs("div", { className: "visionOffInfo", children: [jsx(Header, { handleDelete: () => {
|
|
21118
21394
|
onHandleDelete?.();
|
|
21119
|
-
}, handleFocus: () => { }, type: DataType.VISION_OFF }), jsx("div", { className: styles$9.areaInfo, children: jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Size:" }), jsx("div", { className: styles$9.value, children: sizeValue })] }) })] }));
|
|
21395
|
+
}, handleFocus: () => { }, type: DataType.VISION_OFF }), jsx("div", { className: styles$9.border }), jsx("div", { className: styles$9.areaInfo, children: jsxs("div", { className: styles$9.areaItem, children: [jsx("div", { className: styles$9.label, children: "Size:" }), jsx("div", { className: styles$9.value, children: sizeValue })] }) })] }));
|
|
21120
21396
|
};
|
|
21121
21397
|
|
|
21122
21398
|
var _path$2, _path2$1;
|
|
@@ -21257,9 +21533,9 @@ const HandleElementInfo = () => {
|
|
|
21257
21533
|
if (element?.type === DataType.OBSTACLE) {
|
|
21258
21534
|
data.obstacle = {
|
|
21259
21535
|
name: element?.name,
|
|
21260
|
-
status: element?.status
|
|
21261
|
-
end_timestamp: element?.end_timestamp
|
|
21262
|
-
start_timestamp: element?.start_timestamp
|
|
21536
|
+
status: element?.status ?? 1,
|
|
21537
|
+
end_timestamp: element?.end_timestamp,
|
|
21538
|
+
start_timestamp: element?.start_timestamp,
|
|
21263
21539
|
points: restorePointsFormat(element.points),
|
|
21264
21540
|
};
|
|
21265
21541
|
if (element?.id) {
|
|
@@ -21287,6 +21563,12 @@ const HandleElementInfo = () => {
|
|
|
21287
21563
|
const params = renderElementData(editMapInfo?.selectElement);
|
|
21288
21564
|
const isObstacle = editMapInfo?.selectElement?.type === DataType.OBSTACLE;
|
|
21289
21565
|
const hasNotEnoughPoints = params?.obstacle?.points?.length < 3;
|
|
21566
|
+
const isDoodle = editMapInfo?.selectElement?.type === DataType.DOODLE;
|
|
21567
|
+
const doodleResult = checkDoodle();
|
|
21568
|
+
if (isDoodle && !doodleResult?.isValid) {
|
|
21569
|
+
message.error('Keep more distance from boundaries, off-limit island and other doodles');
|
|
21570
|
+
return;
|
|
21571
|
+
}
|
|
21290
21572
|
if (isObstacle && hasNotEnoughPoints) {
|
|
21291
21573
|
message.error('Save failed, please draw a closed shape');
|
|
21292
21574
|
return;
|
|
@@ -21318,16 +21600,27 @@ const HandleElementInfo = () => {
|
|
|
21318
21600
|
message.error('Save failed, please try again');
|
|
21319
21601
|
});
|
|
21320
21602
|
}
|
|
21321
|
-
}, [editMapInfo.selectElement]);
|
|
21603
|
+
}, [editMapInfo.selectElement, onUpdateBoundary, onHandleCompleteRecord]);
|
|
21322
21604
|
const handleCancel = useCallback(() => {
|
|
21323
|
-
|
|
21324
|
-
|
|
21325
|
-
|
|
21326
|
-
|
|
21327
|
-
|
|
21328
|
-
|
|
21329
|
-
|
|
21330
|
-
|
|
21605
|
+
const name = DATE_TYPE_MAP.find((item) => item.type === editMapInfo.elementType)?.label;
|
|
21606
|
+
Modal.confirm({
|
|
21607
|
+
icon: null,
|
|
21608
|
+
centered: true,
|
|
21609
|
+
title: 'Quit editing',
|
|
21610
|
+
content: `Changes you made will not be saved. Are you sure you want to quit editing the ${name}?`,
|
|
21611
|
+
okText: 'Quit',
|
|
21612
|
+
cancelText: 'Keep editing',
|
|
21613
|
+
onOk: () => {
|
|
21614
|
+
onHandleStopRecord?.()?.then(() => {
|
|
21615
|
+
setEditMapInfo({
|
|
21616
|
+
...editMapInfo,
|
|
21617
|
+
createMode: null,
|
|
21618
|
+
elementType: null,
|
|
21619
|
+
selectElement: null,
|
|
21620
|
+
isShowDrag: false,
|
|
21621
|
+
});
|
|
21622
|
+
});
|
|
21623
|
+
},
|
|
21331
21624
|
});
|
|
21332
21625
|
}, [editMapInfo]);
|
|
21333
21626
|
const handleDelete = useCallback(() => {
|
|
@@ -21372,26 +21665,12 @@ const HandleElementInfo = () => {
|
|
|
21372
21665
|
},
|
|
21373
21666
|
});
|
|
21374
21667
|
}, [editMapInfo?.selectElement, onHandleDeleteElement, onHandleStopRecord]);
|
|
21375
|
-
const checkDisabled = useCallback(() => {
|
|
21376
|
-
if (editMapInfo.elementType === DataType.DOODLE) {
|
|
21377
|
-
const result = checkDoodle();
|
|
21378
|
-
return !result?.isValid;
|
|
21379
|
-
}
|
|
21380
|
-
return false;
|
|
21381
|
-
}, [checkDoodle, editMapInfo]);
|
|
21382
21668
|
if (!editMapInfo.selectElement)
|
|
21383
21669
|
return null;
|
|
21384
21670
|
console.log('handleElementInfo->', editMapInfo, currentType);
|
|
21385
|
-
return (jsxs("div", { className: styles$9.handleElementInfo, children: [editMapInfo?.elementType !== DataType.BOUNDARY ? (jsxs("div", { className: styles$9.undoAndRedo, children: [jsx("div", { className: classNames(styles$9.undo, { [styles$9.disabled]: isUndoDisabled }), onClick: handleUndo, children: jsx(SvgUndo, {}) }), jsx("div", { className: classNames(styles$9.redo, { [styles$9.disabled]: idRedoDisabled }), onClick: handleRedo, children: jsx(SvgRedo, {}) })] })) : null, editMapInfo?.elementType === DataType.BOUNDARY && (jsx(BoundaryInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.OBSTACLE && (jsx(ObstacleInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.DOODLE && jsx(DoodleInfo, { onHandleDelete: handleDelete }), editMapInfo?.elementType === DataType.VISION_OFF && (jsx(VisionOffInfo, { onHandleDelete: handleDelete })),
|
|
21386
|
-
|
|
21387
|
-
|
|
21388
|
-
createMode: null,
|
|
21389
|
-
editMap: false,
|
|
21390
|
-
elementType: undefined,
|
|
21391
|
-
selectElement: null,
|
|
21392
|
-
isShowDrag: false,
|
|
21393
|
-
});
|
|
21394
|
-
}, children: "Cancel" })] })] }));
|
|
21671
|
+
return (jsxs("div", { className: styles$9.handleElementInfo, children: [editMapInfo?.elementType !== DataType.BOUNDARY ? (jsxs("div", { className: styles$9.undoAndRedo, children: [jsx("div", { className: classNames(styles$9.undo, { [styles$9.disabled]: isUndoDisabled }), onClick: handleUndo, children: jsx(SvgUndo, {}) }), jsx("div", { className: classNames(styles$9.redo, { [styles$9.disabled]: idRedoDisabled }), onClick: handleRedo, children: jsx(SvgRedo, {}) })] })) : null, editMapInfo?.elementType === DataType.BOUNDARY && (jsx(BoundaryInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.OBSTACLE && (jsx(ObstacleInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.DOODLE && jsx(DoodleInfo, { onHandleDelete: handleDelete }), editMapInfo?.elementType === DataType.VISION_OFF && (jsx(VisionOffInfo, { onHandleDelete: handleDelete })), jsx("div", { className: styles$9.border }), jsx("div", { className: styles$9.handle, children: jsxs(Space, { size: 12, children: [jsx(Button, { variant: "outlined", color: "default", onClick: () => {
|
|
21672
|
+
handleCancel();
|
|
21673
|
+
}, children: "Cancel" }), jsx(Button, { variant: "solid", color: "primary", onClick: handleSave, children: "Save" })] }) })] }));
|
|
21395
21674
|
};
|
|
21396
21675
|
|
|
21397
21676
|
var _path;
|
|
@@ -21517,7 +21796,7 @@ const defaultMapConfig = DEFAULT_STYLES;
|
|
|
21517
21796
|
// 地图渲染器组件
|
|
21518
21797
|
const MowerMapRenderer = forwardRef(({ sn, platform = PlatformType.WEB, edger = false, unitType = UnitsType.Imperial, language = 'en', onlyRead = false, mapConfig,
|
|
21519
21798
|
// pathConfig,
|
|
21520
|
-
modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, onPathLoad, onError, className, style, googleMapInstance: _googleMapInstance, dragMap = false, dragCallbacks, defaultTransform, debug: _debug = false, doodleList = [], editMap = false, unStructMapData, disabledObstacles = false, onHandleEnterRecord, onHandleCompleteRecord, onHandleStopRecord, onHandleDeleteElement, onSaveBoundaryData, onSaveMap, onEditInfoMapChange, onUpdateBoundary, heightOptions, globalHeight,
|
|
21799
|
+
modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, onPathLoad, onError, className, style, googleMapInstance: _googleMapInstance, dragMap = false, dragCallbacks, defaultTransform, debug: _debug = false, doodleList = [], editMap = false, unStructMapData, disabledObstacles = false, onHandleEnterRecord, onHandleCompleteRecord, onHandleStopRecord, onHandleDeleteElement, onSaveBoundaryData, onSaveMap, onEditInfoMapChange, onUpdateBoundary, heightOptions, globalHeight, onHandleEvent, }, ref) => {
|
|
21521
21800
|
const [currentError, setCurrentError] = useState(null);
|
|
21522
21801
|
const overlayRef = useRef(null);
|
|
21523
21802
|
// const mapRef = useMap();
|
|
@@ -21573,7 +21852,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
|
|
|
21573
21852
|
onSaveMap,
|
|
21574
21853
|
onHandleDeleteElement,
|
|
21575
21854
|
onUpdateBoundary,
|
|
21576
|
-
|
|
21855
|
+
onHandleEvent,
|
|
21577
21856
|
};
|
|
21578
21857
|
}, [
|
|
21579
21858
|
minDistance,
|
|
@@ -21585,7 +21864,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
|
|
|
21585
21864
|
onSaveBoundaryData,
|
|
21586
21865
|
onSaveMap,
|
|
21587
21866
|
onUpdateBoundary,
|
|
21588
|
-
|
|
21867
|
+
onHandleEvent,
|
|
21589
21868
|
]);
|
|
21590
21869
|
// 合并配置
|
|
21591
21870
|
const mergedMapConfig = useMemo(() => {
|
|
@@ -21619,6 +21898,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
|
|
|
21619
21898
|
drag: defaultTransform,
|
|
21620
21899
|
mapRef,
|
|
21621
21900
|
overlayScale,
|
|
21901
|
+
doodleList,
|
|
21622
21902
|
};
|
|
21623
21903
|
}, [
|
|
21624
21904
|
sn,
|
|
@@ -21633,6 +21913,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
|
|
|
21633
21913
|
defaultTransform,
|
|
21634
21914
|
mapRef,
|
|
21635
21915
|
overlayScale,
|
|
21916
|
+
doodleList,
|
|
21636
21917
|
]);
|
|
21637
21918
|
// console.log('svgElementDatas->', svgElementDatas, unStructMapData, commonValue);
|
|
21638
21919
|
// 处理地图分区边界
|
|
@@ -21874,7 +22155,15 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
|
|
|
21874
22155
|
// 基于固定的参考zoom级别计算overlayScale
|
|
21875
22156
|
const zoomDiff = currentZoom - REFERENCE_ZOOM;
|
|
21876
22157
|
const scale = Math.pow(2, -zoomDiff); // 负数实现反向缩放
|
|
21877
|
-
|
|
22158
|
+
if (scale < 1) {
|
|
22159
|
+
setOverlayScale(1);
|
|
22160
|
+
}
|
|
22161
|
+
else if (scale > 4) {
|
|
22162
|
+
setOverlayScale(4);
|
|
22163
|
+
}
|
|
22164
|
+
else {
|
|
22165
|
+
setOverlayScale(scale);
|
|
22166
|
+
}
|
|
21878
22167
|
};
|
|
21879
22168
|
// 使用lodash throttle进行节流处理: 100ms内只执行一次
|
|
21880
22169
|
const handleZoomChanged = throttle$2(updateScale, 50);
|
|
@@ -21967,6 +22256,8 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
|
|
|
21967
22256
|
addHistory: (history) => svgEditMapRef.current?.addHistory(history),
|
|
21968
22257
|
// 添加doodle
|
|
21969
22258
|
addDoodle: (doodle) => svgEditMapRef.current?.addDoodle(doodle),
|
|
22259
|
+
// 检查doodle
|
|
22260
|
+
checkDoodle: () => svgEditMapRef.current?.checkDoodle?.(),
|
|
21970
22261
|
}));
|
|
21971
22262
|
/**
|
|
21972
22263
|
* 根据割草机的位置更新路径
|