@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.
Files changed (36) hide show
  1. package/dist/index.esm.js +508 -217
  2. package/dist/index.js +507 -216
  3. package/dist/src/context/common.d.ts +2 -0
  4. package/dist/src/context/common.d.ts.map +1 -1
  5. package/dist/src/context/mapEdit.d.ts +1 -1
  6. package/dist/src/context/mapEdit.d.ts.map +1 -1
  7. package/dist/src/processor/unified/BaseData.d.ts +3 -4
  8. package/dist/src/processor/unified/BaseData.d.ts.map +1 -1
  9. package/dist/src/processor/unified/UnifiedMapDataProcessor.d.ts.map +1 -1
  10. package/dist/src/render/BoundarySvgRender.d.ts +1 -1
  11. package/dist/src/render/MowerMapRenderer.d.ts.map +1 -1
  12. package/dist/src/render/layers/ObstacleLayer.d.ts +16 -0
  13. package/dist/src/render/layers/ObstacleLayer.d.ts.map +1 -1
  14. package/dist/src/render/svgEditMap/components/AddEntry/components/DoodleModal/index.d.ts.map +1 -1
  15. package/dist/src/render/svgEditMap/components/AddEntry/index.d.ts.map +1 -1
  16. package/dist/src/render/svgEditMap/components/HandleElementInfo/boundary.d.ts.map +1 -1
  17. package/dist/src/render/svgEditMap/components/HandleElementInfo/components/DirectionModal/component/MowDirection/index.d.ts.map +1 -1
  18. package/dist/src/render/svgEditMap/components/HandleElementInfo/components/DirectionModal/index.d.ts.map +1 -1
  19. package/dist/src/render/svgEditMap/components/HandleElementInfo/components/TimePeriod/index.d.ts +4 -4
  20. package/dist/src/render/svgEditMap/components/HandleElementInfo/components/TimePeriod/index.d.ts.map +1 -1
  21. package/dist/src/render/svgEditMap/components/HandleElementInfo/doodle.d.ts.map +1 -1
  22. package/dist/src/render/svgEditMap/components/HandleElementInfo/index.d.ts.map +1 -1
  23. package/dist/src/render/svgEditMap/components/HandleElementInfo/obstacle.d.ts.map +1 -1
  24. package/dist/src/render/svgEditMap/components/HandleElementInfo/visionOff.d.ts.map +1 -1
  25. package/dist/src/render/svgEditMap/index.d.ts +8 -1
  26. package/dist/src/render/svgEditMap/index.d.ts.map +1 -1
  27. package/dist/src/render/svgElement/ChannelElement/index.d.ts.map +1 -1
  28. package/dist/src/render/svgElement/DoodleElement/index.d.ts.map +1 -1
  29. package/dist/src/render/svgElement/Mobile/CreateObstacleElement/index.d.ts +4 -1
  30. package/dist/src/render/svgElement/Mobile/CreateObstacleElement/index.d.ts.map +1 -1
  31. package/dist/src/render/svgElement/PolygonELement/index.d.ts.map +1 -1
  32. package/dist/src/render/svgElement/TransformWrapper/DoodleTransformWrapper/DoodleTransformWrapper.d.ts.map +1 -1
  33. package/dist/src/render/svgElement/TransformWrapper/VisionOffTransformWrapper/VisionOffTransformWrapper.d.ts.map +1 -1
  34. package/dist/src/types/renderer.d.ts +10 -2
  35. package/dist/src/types/renderer.d.ts.map +1 -1
  36. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -210,14 +210,13 @@ class ChannelData extends BaseData {
210
210
  * 障碍物数据类
211
211
  */
212
212
  class ObstacleData extends BaseData {
213
- constructor(originalData, level, isTimeLimit, style) {
213
+ constructor(originalData, level, style) {
214
214
  const convertedPoints = convertPointsFormat(originalData?.points) || [];
215
215
  super(originalData?.id, DataType.OBSTACLE, level, RenderType.POLYGON, convertedPoints, originalData);
216
216
  this.area = originalData?.area;
217
217
  this.status = originalData?.status || 1;
218
- this.startTimestamp = originalData?.start_timestamp;
219
- this.endTimestamp = originalData?.end_timestamp;
220
- this.isTimeLimit = isTimeLimit;
218
+ this.start_timestamp = originalData?.start_timestamp;
219
+ this.end_timestamp = originalData?.end_timestamp;
221
220
  this.name = originalData?.name || 'Obstacle';
222
221
  this.style = style;
223
222
  }
@@ -349,8 +348,8 @@ function initDoodle() {
349
348
  svg: '',
350
349
  scale: 1,
351
350
  direction: 0,
352
- create_ts: Date.now(),
353
- expiration_ts: Date.now() + 3600000 * 24 * 7, // 1小时后过期
351
+ create_ts: Math.floor(Date.now() / 1000),
352
+ expiration_ts: Math.floor(Date.now() / 1000) + 3600 * 24 * 7, // 1小时后过期
354
353
  type: 'TIME_LIMIT_OBSTACLE',
355
354
  };
356
355
  return new DoodleData(doodle, 100);
@@ -636,7 +635,7 @@ class UnifiedMapDataProcessor {
636
635
  continue;
637
636
  }
638
637
  const obstacleData = new ObstacleData(element, 150, // 高层级
639
- false, this.mapConfig.obstacle || {});
638
+ this.mapConfig.obstacle || {});
640
639
  obstacleDataList.push(obstacleData);
641
640
  }
642
641
  catch (error) {
@@ -766,7 +765,7 @@ class UnifiedMapDataProcessor {
766
765
  continue;
767
766
  }
768
767
  const obstacleData = new ObstacleData(element, 150, // 高层级
769
- true, this.mapConfig.obstacle || {});
768
+ this.mapConfig.obstacle || {});
770
769
  obstacleDataList.push(obstacleData);
771
770
  }
772
771
  }
@@ -8713,7 +8712,7 @@ function styleInject(css, ref) {
8713
8712
  }
8714
8713
  }
8715
8714
 
8716
- 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 display: none;\n}";
8715
+ 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}";
8717
8716
  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"};
8718
8717
  styleInject(css_248z$i);
8719
8718
 
@@ -8795,8 +8794,10 @@ const DragHandle = ({ onDragStart, isDragging }) => {
8795
8794
  onDragStart(e);
8796
8795
  }, onTouchStart: (e) => onDragStart(e), onMouseUp: (e) => {
8797
8796
  console.log('drag up');
8798
- onDragEnd(e);
8799
- }, onTouchEnd: (e) => onDragEnd(e), style: { cursor: isDragging ? 'grabbing' : 'move' }, dangerouslySetInnerHTML: { __html: DEFAULT_DRAG_ICON } }));
8797
+ // onDragEnd(e);
8798
+ },
8799
+ // onTouchEnd={(e) => onDragEnd(e)}
8800
+ style: { cursor: isDragging ? 'grabbing' : 'move' }, dangerouslySetInnerHTML: { __html: DEFAULT_DRAG_ICON } }));
8800
8801
  };
8801
8802
 
8802
8803
  const MapDrag = ({ map: _map, dragCallbacks, onBoundaryLabelsCollapse, onTransformChange, isDragMap = false, }) => {
@@ -12533,11 +12534,74 @@ class ObstacleLayer extends BaseLayer {
12533
12534
  }
12534
12535
  }
12535
12536
  }
12537
+ /**
12538
+ * 将坐标点按type分组
12539
+ */
12540
+ groupCoordinatesByType(coordinates) {
12541
+ const segments = [];
12542
+ let currentSegment = null;
12543
+ for (let i = 0; i < coordinates.length; i++) {
12544
+ const coord = coordinates[i];
12545
+ const type = coord[2] || 2; // 默认type为2
12546
+ if (!currentSegment || currentSegment.type !== type) {
12547
+ // 开始新的段
12548
+ if (currentSegment && currentSegment.points.length > 0) {
12549
+ // 为了连接线段,将当前点也加入上一段的结尾
12550
+ currentSegment.points.push(coord);
12551
+ }
12552
+ currentSegment = {
12553
+ type: type,
12554
+ points: [coord],
12555
+ };
12556
+ segments.push(currentSegment);
12557
+ }
12558
+ else {
12559
+ // 继续当前段
12560
+ currentSegment.points.push(coord);
12561
+ }
12562
+ }
12563
+ // 处理封闭边界:如果第一段和最后一段type相同,需要连接起来
12564
+ if (segments.length > 1 && segments[0].type === segments[segments.length - 1].type) {
12565
+ const firstSegment = segments[0];
12566
+ const lastSegment = segments[segments.length - 1];
12567
+ // 将第一个点添加到最后一段,形成封闭
12568
+ lastSegment.points.push(firstSegment.points[0]);
12569
+ }
12570
+ else if (segments.length === 1) {
12571
+ // 只有一段的情况,添加第一个点到末尾形成封闭
12572
+ segments[0].points.push(coordinates[0]);
12573
+ }
12574
+ return segments;
12575
+ }
12536
12576
  /**
12537
12577
  * 渲染障碍物元素
12538
12578
  */
12539
12579
  renderObstacle(svgGroup, element) {
12540
- const { coordinates, style } = element;
12580
+ const { coordinates, style, originalData } = element;
12581
+ const { status, start_timestamp, end_timestamp } = originalData || {};
12582
+ if (coordinates.length < 2 || status === 0) {
12583
+ return;
12584
+ }
12585
+ if (status === 1 &&
12586
+ (start_timestamp > Date.now() / 1000 || end_timestamp < Date.now() / 1000)) {
12587
+ return;
12588
+ }
12589
+ // 1. 先遍历所有的coordinates,把所有点分为若干段的path
12590
+ const pathSegments = this.groupCoordinatesByType(coordinates);
12591
+ // 2&3. 根据type处理每个path段
12592
+ pathSegments.forEach((segment) => {
12593
+ if (segment.points.length < 2)
12594
+ return;
12595
+ if (segment.type === 2) {
12596
+ // type=2: 直接添加到svgGroup中
12597
+ this.createDirectPath(svgGroup, segment.points, style);
12598
+ }
12599
+ else if (segment.type === 1) {
12600
+ // type=1: 使用PathMeasure逻辑生成平行路径
12601
+ // this.createDirectPath(svgGroup, segment.points, style);
12602
+ this.createParallelPathsWithMeasure(svgGroup, segment.points, style);
12603
+ }
12604
+ });
12541
12605
  if (coordinates.length < 3)
12542
12606
  return;
12543
12607
  const polygon = document.createElementNS('http://www.w3.org/2000/svg', 'polygon');
@@ -12545,7 +12609,7 @@ class ObstacleLayer extends BaseLayer {
12545
12609
  const points = coordinates.map((coord) => `${coord[0]},${coord[1]}`).join(' ');
12546
12610
  polygon.setAttribute('points', points);
12547
12611
  polygon.setAttribute('fill', style.fillColor || 'rgba(220, 53, 69, 0.2)');
12548
- polygon.setAttribute('stroke', style.lineColor || '#dc3545');
12612
+ polygon.setAttribute('stroke', 'transparent');
12549
12613
  // 确保最小线条宽度
12550
12614
  const lineWidth = Math.max(style.lineWidth || 2, 0.5);
12551
12615
  polygon.setAttribute('stroke-width', lineWidth.toString());
@@ -12556,6 +12620,113 @@ class ObstacleLayer extends BaseLayer {
12556
12620
  polygon.classList.add('vector-obstacle');
12557
12621
  svgGroup.appendChild(polygon);
12558
12622
  }
12623
+ /**
12624
+ * 创建直接路径(type=2)
12625
+ */
12626
+ createDirectPath(svgGroup, points, style) {
12627
+ const path = document.createElementNS('http://www.w3.org/2000/svg', 'path');
12628
+ const strokeColor = style.lineColor;
12629
+ // 构建路径数据
12630
+ let pathData = '';
12631
+ for (let i = 0; i < points.length; i++) {
12632
+ const [x, y] = points[i];
12633
+ if (i === 0) {
12634
+ pathData += `M ${x} ${y}`;
12635
+ }
12636
+ else {
12637
+ pathData += ` L ${x} ${y}`;
12638
+ }
12639
+ }
12640
+ path.setAttribute('d', pathData);
12641
+ path.setAttribute('stroke', strokeColor);
12642
+ path.setAttribute('fill', 'none');
12643
+ // 确保最小线条宽度
12644
+ const lineWidth = dp2px(style.lineWidth || 3);
12645
+ path.setAttribute('stroke-width', lineWidth.toString());
12646
+ path.setAttribute('stroke-linecap', 'round');
12647
+ path.setAttribute('stroke-linejoin', 'round');
12648
+ path.setAttribute('opacity', (style.opacity || 1).toString());
12649
+ path.setAttribute('vector-effect', 'non-scaling-stroke');
12650
+ path.classList.add('vector-obstacle');
12651
+ svgGroup.appendChild(path);
12652
+ }
12653
+ /**
12654
+ * 使用PathMeasure逻辑创建平行路径(type=1)
12655
+ */
12656
+ createParallelPathsWithMeasure(svgGroup, points, style) {
12657
+ const strokeColor = style.lineColor;
12658
+ const lineWidth = dp2px(style.lineWidth || 3);
12659
+ // 获取当前SVG的缩放级别,计算固定屏幕像素间距
12660
+ const fixedScreenDistance = lineWidth; // 固定的屏幕像素距离
12661
+ const offsetDistance = fixedScreenDistance; // 转换为SVG坐标系距离
12662
+ // 直接对每个线段生成平行直线段
12663
+ const parallelPaths = this.generateStraightParallelPaths(points, offsetDistance);
12664
+ // 渲染两条平行虚线
12665
+ parallelPaths.forEach((pathData, index) => {
12666
+ if (!pathData)
12667
+ return;
12668
+ const path = document.createElementNS('http://www.w3.org/2000/svg', 'path');
12669
+ path.setAttribute('d', pathData);
12670
+ path.setAttribute('fill', 'none');
12671
+ path.setAttribute('stroke', strokeColor);
12672
+ path.setAttribute('stroke-width', lineWidth.toString());
12673
+ path.setAttribute('stroke-linecap', 'round');
12674
+ path.setAttribute('stroke-linejoin', 'round');
12675
+ path.setAttribute('opacity', (style.opacity || 1).toString());
12676
+ // 使用CSS样式设置虚线,避免随SVG缩放变化
12677
+ // 或者可以根据当前缩放级别动态计算dash array
12678
+ path.style.strokeDasharray = `${lineWidth}px ${lineWidth * 2}px`;
12679
+ path.classList.add(`vector-boundary-parallel-${index + 1}`);
12680
+ svgGroup.appendChild(path);
12681
+ });
12682
+ }
12683
+ /**
12684
+ * 生成直线平行路径(每个线段分别处理)
12685
+ */
12686
+ generateStraightParallelPaths(points, offsetDistance) {
12687
+ if (points.length < 2)
12688
+ return ['', ''];
12689
+ let parallelPath1Data = '';
12690
+ let parallelPath2Data = '';
12691
+ // 对每个线段分别计算平行线
12692
+ for (let i = 0; i < points.length - 1; i++) {
12693
+ const startPoint = points[i];
12694
+ const endPoint = points[i + 1];
12695
+ // 计算线段的方向向量
12696
+ const dx = endPoint[0] - startPoint[0];
12697
+ const dy = endPoint[1] - startPoint[1];
12698
+ const length = Math.sqrt(dx * dx + dy * dy);
12699
+ if (length === 0)
12700
+ continue; // 跳过零长度线段
12701
+ // 标准化方向向量
12702
+ const unitX = dx / length;
12703
+ const unitY = dy / length;
12704
+ // 计算垂直向量
12705
+ const perpendicularX = -unitY;
12706
+ const perpendicularY = unitX;
12707
+ // 计算平行线的起点和终点
12708
+ const start1X = startPoint[0] + perpendicularX * offsetDistance;
12709
+ const start1Y = startPoint[1] + perpendicularY * offsetDistance;
12710
+ const end1X = endPoint[0] + perpendicularX * offsetDistance;
12711
+ const end1Y = endPoint[1] + perpendicularY * offsetDistance;
12712
+ const start2X = startPoint[0] - perpendicularX * offsetDistance;
12713
+ const start2Y = startPoint[1] - perpendicularY * offsetDistance;
12714
+ const end2X = endPoint[0] - perpendicularX * offsetDistance;
12715
+ const end2Y = endPoint[1] - perpendicularY * offsetDistance;
12716
+ // 构建路径数据
12717
+ if (i === 0) {
12718
+ parallelPath1Data = `M ${start1X} ${start1Y}`;
12719
+ parallelPath2Data = `M ${start2X} ${start2Y}`;
12720
+ }
12721
+ else {
12722
+ parallelPath1Data += ` M ${start1X} ${start1Y}`;
12723
+ parallelPath2Data += ` M ${start2X} ${start2Y}`;
12724
+ }
12725
+ parallelPath1Data += ` L ${end1X} ${end1Y}`;
12726
+ parallelPath2Data += ` L ${end2X} ${end2Y}`;
12727
+ }
12728
+ return [parallelPath2Data, parallelPath1Data];
12729
+ }
12559
12730
  }
12560
12731
 
12561
12732
  var chargingPileImage = "";
@@ -15038,15 +15209,15 @@ const VertexElement = React.memo(({ r, stroke, ...props }) => {
15038
15209
  return (jsxRuntime.jsx("circle", { r: radius * overlayScale, stroke: stroke || '#fff', fill: '#fff', strokeWidth: 2 * overlayScale, ...props }));
15039
15210
  });
15040
15211
 
15041
- var _path$c;
15042
- function _extends$k() { return _extends$k = 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$k.apply(null, arguments); }
15212
+ var _path$b;
15213
+ 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); }
15043
15214
  var SvgDelete$1 = function SvgDelete(props) {
15044
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$k({
15215
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$j({
15045
15216
  xmlns: "http://www.w3.org/2000/svg",
15046
15217
  width: 16,
15047
15218
  height: 16,
15048
15219
  fill: "none"
15049
- }, props), _path$c || (_path$c = /*#__PURE__*/React__namespace.createElement("path", {
15220
+ }, props), _path$b || (_path$b = /*#__PURE__*/React__namespace.createElement("path", {
15050
15221
  fill: "#FD494D",
15051
15222
  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"
15052
15223
  })));
@@ -15219,6 +15390,7 @@ var MobileEditMode;
15219
15390
  })(MobileEditMode || (MobileEditMode = {}));
15220
15391
  var ClickEventType;
15221
15392
  (function (ClickEventType) {
15393
+ // 点击doodle的active time的时候触发
15222
15394
  ClickEventType["DOODLE_ACTIVE_TIME"] = "doodleActiveTime";
15223
15395
  })(ClickEventType || (ClickEventType = {}));
15224
15396
  const INIT_EDIT_MAP_INFO = {
@@ -15581,7 +15753,7 @@ const useCheckElement = () => {
15581
15753
  return { isValid: true };
15582
15754
  }, [editMapInfo, svgElementDatas, minDistance]);
15583
15755
  const checkCanNotCreateAtPosition = React.useCallback((checkPoint) => {
15584
- // console.log('editMapInfo.elementType--->', editMapInfo.elementType);
15756
+ console.log('editMapInfo.elementType--->', editMapInfo.elementType);
15585
15757
  if (!editMapInfo.elementType)
15586
15758
  return false;
15587
15759
  const points = editMapInfo?.selectElement?.points || [];
@@ -15971,17 +16143,13 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
15971
16143
  console.log('handleMouseUp', JSON.stringify(dragState));
15972
16144
  if (dragState.isDragging && dragState.currentPosition) {
15973
16145
  // 构建新的坐标数组
15974
- const newCoordinates = editMapInfo?.createMode === CreateStatus.CREATING
15975
- ? [...coordinates]
15976
- : [...coordinates].reverse();
16146
+ const newCoordinates = [...coordinates];
15977
16147
  // 如果是新创建的顶点,需要确保它已经被插入
15978
16148
  if (dragState.dragType === 'new' && dragState.newVertexIndex !== -1) {
15979
16149
  if (showNotCreateCursor) ;
15980
16150
  else {
15981
16151
  // mouseUp 时才真正插入新顶点
15982
16152
  newCoordinates.splice(dragState.newVertexIndex, 0, dragState.currentPosition);
15983
- // 通知外部坐标变化
15984
- onCoordinatesChange?.(newCoordinates);
15985
16153
  }
15986
16154
  }
15987
16155
  else {
@@ -15992,9 +16160,11 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
15992
16160
  else {
15993
16161
  newCoordinates[dragState.dragIndex] = dragState.currentPosition;
15994
16162
  }
15995
- // 通知外部坐标变化
15996
- onCoordinatesChange?.(newCoordinates);
15997
16163
  }
16164
+ const result = editMapInfo?.createMode === CreateStatus.CREATING
16165
+ ? newCoordinates
16166
+ : newCoordinates.reverse();
16167
+ onCoordinatesChange?.(result);
15998
16168
  }
15999
16169
  setDragState({
16000
16170
  isDragging: false,
@@ -16087,7 +16257,6 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
16087
16257
  const ghostFirstMidpoint = createMode && mousePos && !completed && renderCoordinates.length >= 1
16088
16258
  ? calculateMidpoint(renderCoordinates[0], [mousePos.x, mousePos.y])
16089
16259
  : null;
16090
- console.log('ghostFirstMidpoint', ghostFirstMidpoint, ghostFirstDistance);
16091
16260
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [(editMode || (createMode && completed)) &&
16092
16261
  dragState.isDragging &&
16093
16262
  dragState.dragType !== 'new' &&
@@ -16211,7 +16380,8 @@ const PolygonElement = ({ points, fillColor = 'rgba(0, 0, 0, 0.1)', fillOpacity
16211
16380
  if (onVertexDelete &&
16212
16381
  (editMode || (createMode && completed)) &&
16213
16382
  coordinates.length > 3) {
16214
- onVertexDelete(idx);
16383
+ // 当前是逆时针展示的,但是外部数据是顺时针的,所以idx需要转换一下
16384
+ onVertexDelete(renderCoordinates?.length - 1 - idx);
16215
16385
  }
16216
16386
  setTooltipIndex(null);
16217
16387
  }, style: { cursor: 'pointer' }, children: [jsxRuntime.jsx("rect", { x: 0, y: -24, width: 20, height: 20, rx: 2, ry: 2, fill: "#fff", strokeWidth: 1, filter: "url(#vertex-tooltip-shadow)" }), jsxRuntime.jsx("g", { transform: `translate(2, -22)`, children: jsxRuntime.jsx(SvgDelete$1, {}) })] })), canComplete && (jsxRuntime.jsx("g", { style: { pointerEvents: 'none' }, transform: `translate(${coord[0] - 5 * overlayScale * 3}, ${coord[1] - 2.5 * overlayScale * 3}) scale(${overlayScale * 3})`, children: jsxRuntime.jsx("svg", { width: "10", height: "5", viewBox: "0 0 6 5", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: jsxRuntime.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" }) }) })
@@ -16903,9 +17073,9 @@ const useVisionOffTransform = (data, scaleConstraints
16903
17073
  };
16904
17074
 
16905
17075
  var _g$7, _defs$7;
16906
- 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); }
17076
+ 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); }
16907
17077
  var SvgTransformDelete = function SvgTransformDelete(props) {
16908
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$j({
17078
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$i({
16909
17079
  xmlns: "http://www.w3.org/2000/svg",
16910
17080
  width: 20,
16911
17081
  height: 20,
@@ -16954,9 +17124,9 @@ var SvgTransformDelete = function SvgTransformDelete(props) {
16954
17124
  };
16955
17125
 
16956
17126
  var _g$6, _defs$6;
16957
- 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); }
17127
+ 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); }
16958
17128
  var SvgTransformRotate = function SvgTransformRotate(props) {
16959
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$i({
17129
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$h({
16960
17130
  xmlns: "http://www.w3.org/2000/svg",
16961
17131
  width: 21,
16962
17132
  height: 20,
@@ -16990,9 +17160,9 @@ var SvgTransformRotate = function SvgTransformRotate(props) {
16990
17160
  };
16991
17161
 
16992
17162
  var _g$5, _defs$5;
16993
- 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); }
17163
+ 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); }
16994
17164
  var SvgTransformScale = function SvgTransformScale(props) {
16995
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$h({
17165
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$g({
16996
17166
  xmlns: "http://www.w3.org/2000/svg",
16997
17167
  width: 21,
16998
17168
  height: 20,
@@ -17026,9 +17196,9 @@ var SvgTransformScale = function SvgTransformScale(props) {
17026
17196
  };
17027
17197
 
17028
17198
  var _g$4, _defs$4;
17029
- 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); }
17199
+ 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); }
17030
17200
  var SvgTransformTranslate = function SvgTransformTranslate(props) {
17031
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$g({
17201
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$f({
17032
17202
  xmlns: "http://www.w3.org/2000/svg",
17033
17203
  width: 20,
17034
17204
  height: 20,
@@ -17206,8 +17376,8 @@ const VisionOffTransformWrapper = ({ data, isSelected = false, onSelect, onCance
17206
17376
  const centerX = (minX + maxX) / 2;
17207
17377
  // 计算尺寸显示框的位置(选择框下方)
17208
17378
  const infoBoxY = maxY + 20; // 选择框下方20像素
17209
- const infoBoxWidth = 140; // 信息框宽度
17210
- const infoBoxHeight = 30; // 信息框高度
17379
+ const infoBoxWidth = 140 * overlayScale; // 信息框宽度
17380
+ const infoBoxHeight = 30 * overlayScale; // 信息框高度
17211
17381
  const infoBoxX = centerX - infoBoxWidth / 2; // 居中对齐
17212
17382
  const scale = (isWeb ? 2 : 1) * overlayScale;
17213
17383
  const offsetLeft = 10 * scale;
@@ -17261,6 +17431,7 @@ const VisionOffTransformWrapper = ({ data, isSelected = false, onSelect, onCance
17261
17431
  fontSize: '12px',
17262
17432
  color: 'white',
17263
17433
  fontWeight: '400',
17434
+ // transform: `translate(0, ${50 * overlayScale}px) scale(${overlayScale})`,
17264
17435
  }, children: [dimensions.height, "m \u00D7 ", dimensions.width, "m"] }) }))] }));
17265
17436
  })()] }));
17266
17437
  };
@@ -17684,8 +17855,8 @@ const useDoodleTransform = (data, onTransformChange, options) => {
17684
17855
  const scaledHeight = height * currentScale;
17685
17856
  // 转换为米单位(假设SVG坐标单位是米)
17686
17857
  // 这里可以根据实际的地图比例尺进行调整
17687
- const widthInMeters = scaledWidth;
17688
- const heightInMeters = scaledHeight;
17858
+ const widthInMeters = scaledWidth / SCALE_FACTOR;
17859
+ const heightInMeters = scaledHeight / SCALE_FACTOR;
17689
17860
  return {
17690
17861
  width: Math.round(widthInMeters * 100) / 100, // 保留2位小数
17691
17862
  height: Math.round(heightInMeters * 100) / 100, // 保留2位小数
@@ -17717,15 +17888,15 @@ const useDoodleTransform = (data, onTransformChange, options) => {
17717
17888
  };
17718
17889
  };
17719
17890
 
17720
- var _path$b;
17721
- 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); }
17891
+ var _path$a;
17892
+ 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); }
17722
17893
  var SvgTransformArrow = function SvgTransformArrow(props) {
17723
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$f({
17894
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$e({
17724
17895
  xmlns: "http://www.w3.org/2000/svg",
17725
17896
  width: 7,
17726
17897
  height: 11,
17727
17898
  fill: "none"
17728
- }, props), _path$b || (_path$b = /*#__PURE__*/React__namespace.createElement("path", {
17899
+ }, props), _path$a || (_path$a = /*#__PURE__*/React__namespace.createElement("path", {
17729
17900
  fill: "#fff",
17730
17901
  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",
17731
17902
  opacity: 0.5
@@ -17787,7 +17958,7 @@ const DoodleTransform = ({ data, isSelected: _isSelected, onSelect }) => {
17787
17958
  };
17788
17959
 
17789
17960
  const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOperation = false, onSelect, onCancel, onTransformChange, disabled = false, className = '', minScale, onMinScaleReached, onDragMove, onDragEnd, showInfo = true, onClickInfo, }) => {
17790
- const { platform } = useCommonContext();
17961
+ const { platform, overlayScale } = useCommonContext();
17791
17962
  // 使用自定义hook管理所有变换逻辑
17792
17963
  const { currentCenter, currentScale, currentDirection, isDragging, isRotating, isScaling, initializeTransform, calculateSelectionBoxPoints, handleMouseDown, handleRotateStart, handleScaleStart, handleMouseMove, handleMouseUp, containerRef, dimensions, } = useDoodleTransform(data, onTransformChange, {
17793
17964
  minScale,
@@ -17809,16 +17980,20 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
17809
17980
  }, [data?.svg, currentCenter, currentScale, currentDirection]);
17810
17981
  const isWeb = React.useMemo(() => platform === 'web', [platform]);
17811
17982
  const activeTime = React.useMemo(() => {
17812
- // 如果当前时间在有效期范围,则显示有效期,否则显示0
17813
- const now = Date.now();
17814
- console.log('now------->', now);
17815
- console.log('data.create_ts------->', data.create_ts);
17816
- console.log('data.expiration_ts------->', data.expiration_ts);
17817
- if (data.create_ts <= now && data.expiration_ts >= now) {
17818
- return Math.floor((data.expiration_ts - now) / (60 * 60 * 24 * 1000));
17983
+ if (data.create_ts && data.expiration_ts) {
17984
+ return Math.floor((data.expiration_ts - data.create_ts) / (60 * 60 * 24));
17819
17985
  }
17820
17986
  return 0;
17821
17987
  }, [data]);
17988
+ const remainingTime = React.useMemo(() => {
17989
+ const currentTime = Math.floor(Date.now() / 1000);
17990
+ console.log('data.expiration_ts--', data.expiration_ts);
17991
+ if (data.expiration_ts <= currentTime) {
17992
+ return 0;
17993
+ }
17994
+ // 保留一位小数
17995
+ return ((currentTime - data.expiration_ts) / (24 * 60 * 60)).toFixed(1);
17996
+ }, [data]);
17822
17997
  // 初始化变换状态
17823
17998
  React.useEffect(() => {
17824
17999
  initializeTransform();
@@ -17899,7 +18074,18 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
17899
18074
  };
17900
18075
  const selectionBoxWithoutOperation = () => {
17901
18076
  const selectionBoxPoints = calculateSelectionBoxPoints();
17902
- return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.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
18077
+ // 计算选择框的边界
18078
+ const minX = Math.min(...selectionBoxPoints.map((p) => p.x));
18079
+ const maxX = Math.max(...selectionBoxPoints.map((p) => p.x));
18080
+ const maxY = Math.max(...selectionBoxPoints.map((p) => p.y));
18081
+ // 计算选择框的中心
18082
+ const centerX = (minX + maxX) / 2;
18083
+ // 计算尺寸显示框的位置(选择框下方)
18084
+ const infoBoxY = maxY + 20; // 选择框下方20像素
18085
+ const infoBoxWidth = 140 * overlayScale; // 信息框宽度
18086
+ const infoBoxHeight = 100 * overlayScale; // 信息框高度
18087
+ const infoBoxX = centerX - infoBoxWidth / 2; // 居中对齐
18088
+ return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.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
17903
18089
  ? {
17904
18090
  onTouchStart: createReactEventHandler((e) => {
17905
18091
  handleMouseDownWithDisabled(e);
@@ -17907,7 +18093,26 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
17907
18093
  }
17908
18094
  : {
17909
18095
  onMouseDown: handleMouseDownWithDisabled,
17910
- }) }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[0].x, cy: selectionBoxPoints[0].y, r: "6", fill: "#9EA6BA", stroke: "none" }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[3].x, cy: selectionBoxPoints[3].y, r: "6", fill: "#9EA6BA", stroke: "none" }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[1].x, cy: selectionBoxPoints[1].y, r: "6", fill: "#9EA6BA", stroke: "none" }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[2].x, cy: selectionBoxPoints[2].y, r: "6", fill: "#9EA6BA", stroke: "none" })] }));
18096
+ }) }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[0].x, cy: selectionBoxPoints[0].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[3].x, cy: selectionBoxPoints[3].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[1].x, cy: selectionBoxPoints[1].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsxRuntime.jsx("circle", { cx: selectionBoxPoints[2].x, cy: selectionBoxPoints[2].y, r: 10 * overlayScale, fill: "#B2B4B9", stroke: "none" }), jsxRuntime.jsx("foreignObject", { x: infoBoxX, y: infoBoxY, width: infoBoxWidth, height: infoBoxHeight, style: { textAlign: 'center' }, onClick: () => {
18097
+ onClickInfo?.();
18098
+ }, children: jsxRuntime.jsx("div", { style: {
18099
+ padding: '5px 6px',
18100
+ background: 'rgba(201, 209, 218, 1)',
18101
+ borderRadius: '10px',
18102
+ display: 'inline-flex',
18103
+ flexDirection: 'column',
18104
+ alignItems: 'flex-start',
18105
+ justifyContent: 'center',
18106
+ fontSize: '12px',
18107
+ color: 'white',
18108
+ fontWeight: '400',
18109
+ // transform: `translate(0, ${50 * overlayScale}px) scale(${overlayScale})`,
18110
+ }, children: jsxRuntime.jsx("div", { style: {
18111
+ display: 'flex',
18112
+ alignItems: 'center',
18113
+ justifyContent: 'center',
18114
+ gap: '10px',
18115
+ }, children: jsxRuntime.jsxs("div", { children: ["Remaining Time: ", remainingTime] }) }) }) })] }));
17911
18116
  };
17912
18117
  React.useEffect(() => {
17913
18118
  const isMove = isDragging || isRotating || isScaling;
@@ -17955,10 +18160,10 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
17955
18160
  const centerX = (minX + maxX) / 2;
17956
18161
  // 计算尺寸显示框的位置(选择框下方)
17957
18162
  const infoBoxY = maxY + 20; // 选择框下方20像素
17958
- const infoBoxWidth = 140; // 信息框宽度
17959
- const infoBoxHeight = 50; // 信息框高度
18163
+ const infoBoxWidth = 140 * overlayScale; // 信息框宽度
18164
+ const infoBoxHeight = 100 * overlayScale; // 信息框高度
17960
18165
  const infoBoxX = centerX - infoBoxWidth / 2; // 居中对齐
17961
- const scale = isWeb ? 2 : 1;
18166
+ const scale = (isWeb ? 2 : 1) * overlayScale;
17962
18167
  const offsetLeft = 10 * scale;
17963
18168
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.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
17964
18169
  ? {
@@ -18013,6 +18218,7 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
18013
18218
  fontSize: '12px',
18014
18219
  color: 'white',
18015
18220
  fontWeight: '400',
18221
+ // transform: `translate(0, ${50 * overlayScale}px) scale(${overlayScale})`,
18016
18222
  }, children: [jsxRuntime.jsxs("div", { children: [dimensions.height, "m \u00D7 ", dimensions.width, "m"] }), jsxRuntime.jsxs("div", { style: {
18017
18223
  display: 'flex',
18018
18224
  alignItems: 'center',
@@ -18023,9 +18229,9 @@ const DoodleTransformWrapper = ({ data, isSelected = false, isSelectedWithoutOpe
18023
18229
  };
18024
18230
 
18025
18231
  const DoodleElement = ({ data }) => {
18026
- const { editMapInfo, setEditMapInfo, onHandleEnterRecord, onClickEvent } = useMapEditContext();
18232
+ const { editMapInfo, setEditMapInfo, onHandleEnterRecord, onHandleEvent } = useMapEditContext();
18027
18233
  const { addHistory } = useHistoryHandle();
18028
- const { platform } = useCommonContext();
18234
+ const { platform, doodleList } = useCommonContext();
18029
18235
  const isSelected = React.useMemo(() => {
18030
18236
  if (platform === PlatformType.H5) {
18031
18237
  if (editMapInfo.mobileMode !== MobileEditMode.START &&
@@ -18042,6 +18248,23 @@ const DoodleElement = ({ data }) => {
18042
18248
  }
18043
18249
  return data;
18044
18250
  }, [data, editMapInfo?.selectElement]);
18251
+ const minScale = React.useMemo(() => {
18252
+ const doodleInfo = doodleList?.find((item) => {
18253
+ // 移除所有空白字符(包括\n、\r、\t等)进行比较
18254
+ const normalizedItemSvg = item.svgStr?.replace(/[\s\n\r\t]+/g, '').replace(/\\n/g, '');
18255
+ const normalizedOriginSvg = originData.svg?.replace(/[\s\n\r\t]+/g, '').replace(/\\n/g, '');
18256
+ // console.log('normalizedItemSvg--->', normalizedItemSvg, normalizedOriginSvg);
18257
+ return normalizedItemSvg === normalizedOriginSvg;
18258
+ });
18259
+ console.log('doodleList--->', doodleList, originData, doodleInfo);
18260
+ if (!doodleInfo) {
18261
+ return 1;
18262
+ }
18263
+ const minLength = doodleInfo?.minLength;
18264
+ const parseSvg = SvgParserNative.parseSvg(originData.svg);
18265
+ const svgMinLength = parseSvg.height / SCALE_FACTOR;
18266
+ return minLength / svgMinLength;
18267
+ }, [doodleList, originData]);
18045
18268
  const isSelectedWithoutOperation = React.useMemo(() => {
18046
18269
  if (platform === PlatformType.H5) {
18047
18270
  if (editMapInfo.mobileMode === MobileEditMode.START &&
@@ -18120,8 +18343,8 @@ const DoodleElement = ({ data }) => {
18120
18343
  }));
18121
18344
  }, []);
18122
18345
  const handleClickInfo = React.useCallback(() => {
18123
- onClickEvent?.(ClickEventType.DOODLE_ACTIVE_TIME);
18124
- }, [onClickEvent]);
18346
+ onHandleEvent?.(ClickEventType.DOODLE_ACTIVE_TIME);
18347
+ }, [onHandleEvent]);
18125
18348
  // const handleDragMove = useCallback(
18126
18349
  // (data: DoodleData) => {
18127
18350
  // setEditMapInfo((prev: EditMapInfo) => ({
@@ -18149,7 +18372,8 @@ const DoodleElement = ({ data }) => {
18149
18372
  },
18150
18373
  });
18151
18374
  }, [transformedElements]);
18152
- return (jsxRuntime.jsx(DoodleTransformWrapper, { data: originData, onTransformChange: handleTransformChange, isSelected: isSelected, isSelectedWithoutOperation: isSelectedWithoutOperation, onSelect: handleSelect, onCancel: handleCancel, onDragEnd: handleDragEnd, showInfo: platform === PlatformType.H5, onClickInfo: handleClickInfo }));
18375
+ console.log('originData--->', originData, minScale);
18376
+ return (jsxRuntime.jsx(DoodleTransformWrapper, { data: originData, onTransformChange: handleTransformChange, isSelected: isSelected, isSelectedWithoutOperation: isSelectedWithoutOperation, onSelect: handleSelect, onCancel: handleCancel, onDragEnd: handleDragEnd, showInfo: platform === PlatformType.H5, onClickInfo: handleClickInfo, minScale: minScale }));
18153
18377
  };
18154
18378
 
18155
18379
  const SvgElement = React.memo(({ type, data, interactive = false }) => {
@@ -19383,27 +19607,37 @@ const getScreenCenterSvgPoint = (svgElement, mapInstance) => {
19383
19607
  */
19384
19608
  const CreateObstacleElement = React.forwardRef(({ enabled = false, svgElement, onPointsChange, styles, points }, ref) => {
19385
19609
  const { mapRef } = useCommonContext();
19610
+ const { checkCanNotCreateAtPosition } = useCheckElement();
19386
19611
  // 使用固定的样式,确保能正常渲染
19387
19612
  // 在十字准心位置添加点
19388
19613
  const addPoint = React.useCallback(() => {
19389
19614
  if (!enabled || !svgElement) {
19390
19615
  console.warn('未启用创建模式或SVG元素不存在');
19391
- return false;
19616
+ return { isValid: false, reason: '未启用创建模式或SVG元素不存在' };
19392
19617
  }
19393
19618
  if (!mapRef) {
19394
19619
  console.warn('地图实例不存在');
19395
- return false;
19620
+ return { isValid: false, reason: '地图实例不存在' };
19396
19621
  }
19397
19622
  const centerPoint = getScreenCenterSvgPoint(svgElement, mapRef);
19398
19623
  if (!centerPoint) {
19399
19624
  console.warn('无法获取屏幕中心点的SVG坐标或点不在SVG可见区域内');
19400
- // 可以在这里添加用户友好的提示,比如显示toast消息
19401
- // window.alert('十字准心位置不在地图可见区域内,请调整地图位置后再试');
19402
- return false;
19625
+ return { isValid: false, reason: '无法获取屏幕中心点的SVG坐标或点不在SVG可见区域内' };
19626
+ }
19627
+ console.error('centerPoint--->', centerPoint);
19628
+ console.error('checkCanNotCreateAtPosition--->', checkCanNotCreateAtPosition(centerPoint));
19629
+ // 校验是否能打点
19630
+ if (checkCanNotCreateAtPosition(centerPoint)) {
19631
+ return {
19632
+ isValid: false,
19633
+ reason: '无法获取屏幕中心点的SVG坐标或点不在SVG可见区域内',
19634
+ };
19403
19635
  }
19404
19636
  const newPoints = [...points, centerPoint];
19405
19637
  onPointsChange?.(newPoints);
19406
- return true;
19638
+ return {
19639
+ isValid: true,
19640
+ };
19407
19641
  }, [enabled, svgElement, mapRef, points, onPointsChange]);
19408
19642
  // 撤销最后一个点
19409
19643
  const undoLastPoint = React.useCallback(() => {
@@ -19493,7 +19727,7 @@ const SvgEditMap = React.forwardRef(({ mapJson, mapConfig, editMap, onEditInfoMa
19493
19727
  const { editMapInfo, setEditMapInfo } = useMapEditContext();
19494
19728
  const { getVisionOffPoints, centerPoint } = useCreateVisionOffElement();
19495
19729
  const { svgElementDatas } = useSvgEditContext();
19496
- const { checkCanNotCreateAtPosition } = useCheckElement();
19730
+ const { checkCanNotCreateAtPosition, checkDoodle } = useCheckElement();
19497
19731
  const svgRef = React.useRef(null);
19498
19732
  const containerRef = React.useRef(null);
19499
19733
  const { platform } = useCommonContext();
@@ -19627,7 +19861,7 @@ const SvgEditMap = React.forwardRef(({ mapJson, mapConfig, editMap, onEditInfoMa
19627
19861
  getEditMapInfo,
19628
19862
  // 十字准心点管理器方法
19629
19863
  addCreateObstaclePoint: () => {
19630
- return pointManagerRef.current?.addPoint();
19864
+ return pointManagerRef.current?.addPoint?.();
19631
19865
  },
19632
19866
  undoCreateObstaclePoint: () => {
19633
19867
  pointManagerRef.current?.undoLastPoint();
@@ -19649,6 +19883,7 @@ const SvgEditMap = React.forwardRef(({ mapJson, mapConfig, editMap, onEditInfoMa
19649
19883
  clearHistory,
19650
19884
  addHistory,
19651
19885
  addDoodle,
19886
+ checkDoodle: () => checkDoodle?.(),
19652
19887
  }));
19653
19888
  // 初始化多边形绘制 Hook
19654
19889
  const { onSvgClick, onSvgMouseMove, onPointClick, points, completed, mousePos, updatePoints } = usePolygonDrawing({ createMode: isCreating });
@@ -19768,10 +20003,10 @@ var css_248z$c = ".index-module_addEntry__QsQHD {\n position: absolute;\n righ
19768
20003
  var styles$c = {"addEntry":"index-module_addEntry__QsQHD","icon":"index-module_icon__qIgA4","addItem":"index-module_addItem__mglwZ","label":"index-module_label__QqZ-9"};
19769
20004
  styleInject(css_248z$c);
19770
20005
 
19771
- var _rect$2, _path$a, _defs$3;
19772
- 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); }
20006
+ var _rect$2, _path$9, _defs$3;
20007
+ 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); }
19773
20008
  var SvgAddEntry = function SvgAddEntry(props) {
19774
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$e({
20009
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$d({
19775
20010
  xmlns: "http://www.w3.org/2000/svg",
19776
20011
  width: 24,
19777
20012
  height: 24,
@@ -19799,7 +20034,7 @@ var SvgAddEntry = function SvgAddEntry(props) {
19799
20034
  height: "100%",
19800
20035
  width: "100%"
19801
20036
  }
19802
- })), _path$a || (_path$a = /*#__PURE__*/React__namespace.createElement("path", {
20037
+ })), _path$9 || (_path$9 = /*#__PURE__*/React__namespace.createElement("path", {
19803
20038
  fill: "#1F1F1F",
19804
20039
  stroke: "url(#add-entry_svg__c)",
19805
20040
  strokeWidth: 0.3,
@@ -19839,15 +20074,15 @@ var SvgAddEntry = function SvgAddEntry(props) {
19839
20074
  })))));
19840
20075
  };
19841
20076
 
19842
- var _path$9, _path2$3, _path3;
19843
- 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); }
20077
+ var _path$8, _path2$3, _path3;
20078
+ 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); }
19844
20079
  var SvgBoundary = function SvgBoundary(props) {
19845
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$d({
20080
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$c({
19846
20081
  xmlns: "http://www.w3.org/2000/svg",
19847
20082
  width: 16,
19848
20083
  height: 16,
19849
20084
  fill: "none"
19850
- }, props), _path$9 || (_path$9 = /*#__PURE__*/React__namespace.createElement("path", {
20085
+ }, props), _path$8 || (_path$8 = /*#__PURE__*/React__namespace.createElement("path", {
19851
20086
  fill: "#1DBEAC",
19852
20087
  fillRule: "evenodd",
19853
20088
  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",
@@ -19865,15 +20100,15 @@ var SvgBoundary = function SvgBoundary(props) {
19865
20100
  })));
19866
20101
  };
19867
20102
 
19868
- var _path$8, _path2$2, _rect$1, _rect2$1;
19869
- 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); }
20103
+ var _path$7, _path2$2, _rect$1, _rect2$1;
20104
+ 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); }
19870
20105
  var SvgLimitIsland = function SvgLimitIsland(props) {
19871
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$c({
20106
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$b({
19872
20107
  xmlns: "http://www.w3.org/2000/svg",
19873
20108
  width: 16,
19874
20109
  height: 16,
19875
20110
  fill: "none"
19876
- }, props), _path$8 || (_path$8 = /*#__PURE__*/React__namespace.createElement("path", {
20111
+ }, props), _path$7 || (_path$7 = /*#__PURE__*/React__namespace.createElement("path", {
19877
20112
  fill: "#FFA077",
19878
20113
  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"
19879
20114
  })), _path2$2 || (_path2$2 = /*#__PURE__*/React__namespace.createElement("path", {
@@ -19899,9 +20134,9 @@ var SvgLimitIsland = function SvgLimitIsland(props) {
19899
20134
  };
19900
20135
 
19901
20136
  var _rect, _rect2, _rect3, _rect4, _g$3;
19902
- 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); }
20137
+ 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); }
19903
20138
  var SvgVisionFence = function SvgVisionFence(props) {
19904
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$b({
20139
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$a({
19905
20140
  xmlns: "http://www.w3.org/2000/svg",
19906
20141
  width: 16,
19907
20142
  height: 16,
@@ -19954,9 +20189,9 @@ var SvgVisionFence = function SvgVisionFence(props) {
19954
20189
  };
19955
20190
 
19956
20191
  var _g$2, _defs$2;
19957
- 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); }
20192
+ 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); }
19958
20193
  var SvgDoodle = function SvgDoodle(props) {
19959
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$a({
20194
+ return /*#__PURE__*/React__namespace.createElement("svg", _extends$9({
19960
20195
  xmlns: "http://www.w3.org/2000/svg",
19961
20196
  width: 16,
19962
20197
  height: 16,
@@ -20065,25 +20300,10 @@ const CustomModal = ({ children, titleCenter, hasMinHeight, height, ...props })
20065
20300
  }), cancelButtonProps: { color: 'primary', variant: 'outlined' }, cancelText: 'Cancel', ...props, children: children }));
20066
20301
  };
20067
20302
 
20068
- 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 rgb(110, 220, 207);\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}";
20069
- 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","selectIcon":"index-module_selectIcon__EFQF-","svgImage":"index-module_svgImage__2OT8-"};
20303
+ 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}";
20304
+ 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-"};
20070
20305
  styleInject(css_248z$a);
20071
20306
 
20072
- var _path$7;
20073
- 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); }
20074
- var SvgSelect = function SvgSelect(props) {
20075
- return /*#__PURE__*/React__namespace.createElement("svg", _extends$9({
20076
- xmlns: "http://www.w3.org/2000/svg",
20077
- width: 14,
20078
- height: 12,
20079
- fill: "none"
20080
- }, props), _path$7 || (_path$7 = /*#__PURE__*/React__namespace.createElement("path", {
20081
- stroke: "#6EDCCF",
20082
- strokeWidth: 2,
20083
- d: "m1 7.5 4 3L12.5 1"
20084
- })));
20085
- };
20086
-
20087
20307
  const DoodleModal = ({ open, onSelect, setOpen, doodleList, centerPoint }) => {
20088
20308
  const { editMapInfo, setEditMapInfo, onHandleEnterRecord } = useMapEditContext();
20089
20309
  const [selectedDoodle, setSelectedDoodle] = React.useState(null);
@@ -20101,7 +20321,7 @@ const DoodleModal = ({ open, onSelect, setOpen, doodleList, centerPoint }) => {
20101
20321
  const svg = selectedDoodle?.svgStr;
20102
20322
  const minLength = selectedDoodle.minLength;
20103
20323
  const parseSvg = SvgParserNative.parseSvg(svg);
20104
- const svgMinLength = Math.min(parseSvg.width, parseSvg.height) / SCALE_FACTOR;
20324
+ const svgMinLength = parseSvg.height / SCALE_FACTOR;
20105
20325
  // 使用获取到的 SVG 内容,如果没有获取到则使用 URL
20106
20326
  newDoodle.svg = svg;
20107
20327
  newDoodle.scale = minLength / svgMinLength;
@@ -20131,12 +20351,12 @@ const DoodleModal = ({ open, onSelect, setOpen, doodleList, centerPoint }) => {
20131
20351
  });
20132
20352
  }
20133
20353
  }, [selectedDoodle, setEditMapInfo, editMapInfo, setOpen, onSelect, centerPoint]);
20134
- return (jsxRuntime.jsx(CustomModal, { width: 560, title: "Creative logos", titleCenter: true, open: open, onOk: handleConfirm, onCancel: () => setOpen(false), okButtonProps: { disabled: !selectedDoodle }, afterClose: () => setSelectedDoodle(null), okText: "Confirm", cancelText: "Cancel", children: jsxRuntime.jsxs("div", { className: styles$a.doodleModal, children: [jsxRuntime.jsx("div", { className: styles$a.title, children: "Please select a doodle" }), jsxRuntime.jsx("div", { className: styles$a.content, children: doodleList
20354
+ return (jsxRuntime.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: jsxRuntime.jsxs("div", { className: styles$a.doodleModal, children: [jsxRuntime.jsx("div", { className: styles$a.title, children: "Select the doodle that you want to create" }), jsxRuntime.jsx("div", { className: styles$a.content, children: doodleList
20135
20355
  ?.filter((item) => !noNeed.includes(item.name))
20136
20356
  .map((item) => {
20137
- return (jsxRuntime.jsxs("div", { className: classNames(styles$a.item, {
20357
+ return (jsxRuntime.jsx("div", { className: classNames(styles$a.item, {
20138
20358
  [styles$a.active]: selectedDoodle?.svg === item.svg,
20139
- }), onClick: () => handleSelectDoodle(item), children: [jsxRuntime.jsx("div", { className: styles$a.svgImage, dangerouslySetInnerHTML: { __html: item?.svgStr } }), jsxRuntime.jsx("div", { className: styles$a.selectIcon, children: jsxRuntime.jsx(SvgSelect, {}) })] }, item.id));
20359
+ }), onClick: () => handleSelectDoodle(item), children: jsxRuntime.jsx("div", { className: styles$a.svgImage, dangerouslySetInnerHTML: { __html: item?.svgStr } }) }, item.id));
20140
20360
  }) })] }) }));
20141
20361
  };
20142
20362
 
@@ -20232,11 +20452,11 @@ const AddEntry = ({ doodleList, disabledObstacles, editMap }) => {
20232
20452
  }), children: jsxRuntime.jsx("div", { className: styles$c.icon, children: jsxRuntime.jsx(SvgAddEntry, {}) }) }), jsxRuntime.jsx(DoodleModal, { centerPoint: centerPoint, doodleList: doodleList, open: doodleOpen, onOk: () => setDoodleOpen(false), setOpen: setDoodleOpen })] }));
20233
20453
  };
20234
20454
 
20235
- var css_248z$9 = ".index-module_handleElementInfo__vWIaf {\n position: absolute;\n right: 0;\n top: 0;\n border-radius: 8px;\n padding: 4px 8px;\n background: #fff;\n width: 265px;\n user-select: none;\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 padding: 0 0 4px 0;\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 border-top: 1px solid rgb(197, 197, 197);\n display: flex;\n align-items: center;\n justify-content: space-between;\n padding: 8px 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_obstacleInfo__w6Sod .index-module_areaInfo__-WJPL {\n border-top: 1px solid rgb(197, 197, 197);\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\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}\n.index-module_boundaryInfo__VfR-N .index-module_areaInfo__-WJPL {\n border-top: 1px solid rgb(197, 197, 197);\n}";
20236
- 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","obstacleInfo":"index-module_obstacleInfo__w6Sod","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"};
20455
+ 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}";
20456
+ 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"};
20237
20457
  styleInject(css_248z$9);
20238
20458
 
20239
- var css_248z$8 = ".index-module_infoHeader__l9F6q {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n padding: 8px 0;\n border-bottom: 1px solid rgb(197, 197, 197);\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}";
20459
+ 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}";
20240
20460
  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"};
20241
20461
  styleInject(css_248z$8);
20242
20462
 
@@ -20305,7 +20525,7 @@ const NameModal = ({ title, name, open, setOpen, onOk }) => {
20305
20525
  setOpen(false);
20306
20526
  }, onCancel: () => setOpen(false), okText: "Confirm", afterClose: () => {
20307
20527
  setNameValue('');
20308
- }, children: jsxRuntime.jsx(antd.Input, { maxLength: 120, showCount: true, placeholder: "Please enter boundary name", value: nameValue, onChange: (e) => setNameValue(e.target.value) }) }));
20528
+ }, children: jsxRuntime.jsx(antd.Input, { maxLength: 12, showCount: true, placeholder: "Please enter boundary name", value: nameValue, onChange: (e) => setNameValue(e.target.value) }) }));
20309
20529
  };
20310
20530
 
20311
20531
  const NameEdit = ({ title, name, onChange }) => {
@@ -20322,12 +20542,12 @@ var SvgArrow = function SvgArrow(props) {
20322
20542
  height: 16,
20323
20543
  fill: "none"
20324
20544
  }, props), _path$3 || (_path$3 = /*#__PURE__*/React__namespace.createElement("path", {
20325
- fill: "#FF5A00",
20545
+ fill: "#1F1F1F",
20326
20546
  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"
20327
20547
  })));
20328
20548
  };
20329
20549
 
20330
- 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: 8px 0;\n}";
20550
+ 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}";
20331
20551
  var styles$6 = {"item":"index-module_item__wwHEt"};
20332
20552
  styleInject(css_248z$6);
20333
20553
 
@@ -20671,43 +20891,81 @@ function convertDirectionToParams(value) {
20671
20891
  return directions;
20672
20892
  }
20673
20893
 
20894
+ const DEFAULT_LIST = [
20895
+ {
20896
+ value: 1 << 0,
20897
+ text: 'A',
20898
+ selected: false,
20899
+ },
20900
+ {
20901
+ value: 1 << 1,
20902
+ text: 'B',
20903
+ selected: false,
20904
+ },
20905
+ {
20906
+ value: 1 << 2,
20907
+ text: 'C',
20908
+ selected: false,
20909
+ },
20910
+ {
20911
+ value: 1 << 3,
20912
+ text: 'D',
20913
+ selected: false,
20914
+ },
20915
+ {
20916
+ value: 1 << 4,
20917
+ text: 'E',
20918
+ selected: false,
20919
+ },
20920
+ {
20921
+ value: 1 << 5,
20922
+ text: 'F',
20923
+ selected: false,
20924
+ },
20925
+ ];
20674
20926
  const MowDirection_L = (props) => {
20675
20927
  const { value, angleValue, optionAngle = 45, zIndex = 10000, onChange,
20676
20928
  // children,
20677
20929
  } = props;
20678
20930
  const [angle, setAngle] = React.useState(0);
20679
- const [lineList, setLineList] = React.useState([
20680
- {
20681
- value: 1 << 0,
20682
- text: 'A',
20683
- selected: false,
20684
- },
20685
- {
20686
- value: 1 << 1,
20687
- text: 'B',
20688
- selected: false,
20689
- },
20690
- {
20691
- value: 1 << 2,
20692
- text: 'C',
20693
- selected: false,
20694
- },
20695
- {
20696
- value: 1 << 3,
20697
- text: 'D',
20698
- selected: false,
20699
- },
20700
- {
20701
- value: 1 << 4,
20702
- text: 'E',
20703
- selected: false,
20704
- },
20705
- {
20706
- value: 1 << 5,
20707
- text: 'F',
20708
- selected: false,
20709
- },
20710
- ]);
20931
+ const lineList = React.useMemo(() => {
20932
+ return DEFAULT_LIST.map((item) => ({
20933
+ ...item,
20934
+ selected: convertDirectionToParams(value).includes(item.value),
20935
+ }));
20936
+ }, [value]);
20937
+ // const [lineList, setLineList] = useState<LineItem[]>([
20938
+ // {
20939
+ // value: 1 << 0,
20940
+ // text: 'A',
20941
+ // selected: false,
20942
+ // },
20943
+ // {
20944
+ // value: 1 << 1,
20945
+ // text: 'B',
20946
+ // selected: false,
20947
+ // },
20948
+ // {
20949
+ // value: 1 << 2,
20950
+ // text: 'C',
20951
+ // selected: false,
20952
+ // },
20953
+ // {
20954
+ // value: 1 << 3,
20955
+ // text: 'D',
20956
+ // selected: false,
20957
+ // },
20958
+ // {
20959
+ // value: 1 << 4,
20960
+ // text: 'E',
20961
+ // selected: false,
20962
+ // },
20963
+ // {
20964
+ // value: 1 << 5,
20965
+ // text: 'F',
20966
+ // selected: false,
20967
+ // },
20968
+ // ]);
20711
20969
  const hitRectAngle = React.useMemo(() => {
20712
20970
  const direction = lineList
20713
20971
  ?.filter((item) => item?.selected)
@@ -20720,12 +20978,6 @@ const MowDirection_L = (props) => {
20720
20978
  const allSelect = React.useMemo(() => {
20721
20979
  return lineList?.every((item) => item?.selected);
20722
20980
  }, [lineList]);
20723
- React.useEffect(() => {
20724
- setLineList(lineList.map((line) => ({
20725
- ...line,
20726
- selected: convertDirectionToParams(value).includes(line.value),
20727
- })));
20728
- }, [value]);
20729
20981
  React.useEffect(() => {
20730
20982
  setAngle(angleValue);
20731
20983
  }, [angleValue]);
@@ -20740,7 +20992,6 @@ const MowDirection_L = (props) => {
20740
20992
  }
20741
20993
  return { ...line };
20742
20994
  });
20743
- setLineList(newLine);
20744
20995
  onChange?.(newLine
20745
20996
  ?.filter((item) => item?.selected)
20746
20997
  .reduce((pre, line) => {
@@ -20853,10 +21104,25 @@ const DirectionModal = ({ directionInfo, open, setOpen, zoneName, optionAngle, o
20853
21104
  setAngle(defaultAngle);
20854
21105
  }
20855
21106
  };
20856
- console.log('directionInfo=>', directionInfo, mapJson);
20857
- return (jsxRuntime.jsx(CustomModal, { maskClosable: false, titleCenter: true, title: `${zoneName} mowing direction`, open: open, width: 600, onCancel: () => {
21107
+ const handleCancel = React.useCallback(() => {
21108
+ if (!canSave) {
20858
21109
  setOpen(false);
20859
- }, onOk: () => {
21110
+ return;
21111
+ }
21112
+ antd.Modal.confirm({
21113
+ icon: null,
21114
+ centered: true,
21115
+ title: 'Exit editing',
21116
+ content: 'Changes you made will not be saved. Are you sure you want to exit editing the mowing direction?',
21117
+ onOk: () => {
21118
+ setOpen(false);
21119
+ },
21120
+ okText: 'Exit',
21121
+ cancelText: 'Continue editing',
21122
+ });
21123
+ }, [canSave, setOpen]);
21124
+ console.log('directionInfo=>', directionInfo, mapJson);
21125
+ return (jsxRuntime.jsx(CustomModal, { maskClosable: false, titleCenter: true, title: `${zoneName} mowing direction`, open: open, width: 600, onCancel: handleCancel, onOk: () => {
20860
21126
  onChange?.(directions, angle);
20861
21127
  setOpen(false);
20862
21128
  }, okText: "Confirm", cancelText: "Cancel", okButtonProps: { disabled: !canSave }, afterClose: () => {
@@ -20864,6 +21130,8 @@ const DirectionModal = ({ directionInfo, open, setOpen, zoneName, optionAngle, o
20864
21130
  setAngle(MIN_DIRECTION_ANGLE);
20865
21131
  }, children: jsxRuntime.jsxs("div", { className: styles$3.directions, children: [jsxRuntime.jsx("div", { className: styles$3.default, children: jsxRuntime.jsx(antd.Button, { disabled: !canSetDefault, variant: "link", color: "primary", onClick: resetDirection, children: "Default" }) }), jsxRuntime.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" }), jsxRuntime.jsxs("div", { className: styles$3.optimal, children: [jsxRuntime.jsx("div", { children: "*" }), jsxRuntime.jsx(SvgOption, {}), jsxRuntime.jsx("div", { className: styles$3.text, children: "Optimal direction" })] }), jsxRuntime.jsxs("div", { className: styles$3.content, children: [jsxRuntime.jsx("div", { className: styles$3.background, children: jsxRuntime.jsx(BoundarySvgRender, { mapJson: mapJson, id: editMapInfo.selectElement.id }) }), jsxRuntime.jsx("div", { className: styles$3.luppan, children: jsxRuntime.jsx(MowDirection_L, { value: directions, angleValue: angle, optionAngle: optionAngle, onChange: (value) => {
20866
21132
  console.log('valie=>', value);
21133
+ if (!value)
21134
+ return antd.message.warning('Choose at least one mowing direction');
20867
21135
  setDirections(value);
20868
21136
  } }) })] }), jsxRuntime.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" }), jsxRuntime.jsx("div", { className: styles$3.slider, children: jsxRuntime.jsx(antd.Slider, { tooltip: {
20869
21137
  formatter: (value) => `${value}°`,
@@ -20922,13 +21190,13 @@ const BoundaryInfo = ({ onHandleDelete }) => {
20922
21190
  name: name,
20923
21191
  },
20924
21192
  });
20925
- } }) }), jsxRuntime.jsxs("div", { className: styles$9.otherEdit, children: [jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.otherItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Height" }), jsxRuntime.jsx("div", { className: styles$9.value, children: generateHeightStr(heightValue?.cuttingHeight, unitType, true) }), jsxRuntime.jsx("div", { className: styles$9.icon, onClick: () => {
21193
+ } }) }), jsxRuntime.jsx("div", { className: styles$9.border }), jsxRuntime.jsxs("div", { className: styles$9.otherEdit, children: [jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.otherItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Cutting height" }), jsxRuntime.jsx("div", { className: styles$9.value, children: generateHeightStr(heightValue?.cuttingHeight, unitType, true) }), jsxRuntime.jsx("div", { className: styles$9.icon, onClick: () => {
20926
21194
  setHeightOpen(true);
20927
- }, children: jsxRuntime.jsx(SvgArrow, {}) })] }) }), jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.otherItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Direction" }), jsxRuntime.jsx("div", { className: styles$9.value }), jsxRuntime.jsx("div", { className: styles$9.icon, onClick: () => {
21195
+ }, children: jsxRuntime.jsx(SvgArrow, {}) })] }) }), jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.otherItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Mowing direction" }), jsxRuntime.jsx("div", { className: styles$9.value }), jsxRuntime.jsx("div", { className: styles$9.icon, onClick: () => {
20928
21196
  setDirectionOpen(true);
20929
- }, children: jsxRuntime.jsx(SvgArrow, {}) })] }) }), jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.otherItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Mowing Edge" }), jsxRuntime.jsx("div", { className: styles$9.value }), jsxRuntime.jsx("div", { className: styles$9.icon, onClick: () => {
21197
+ }, children: jsxRuntime.jsx(SvgArrow, {}) })] }) }), jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.otherItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Edge mowing" }), jsxRuntime.jsx("div", { className: styles$9.value }), jsxRuntime.jsx("div", { className: styles$9.icon, onClick: () => {
20930
21198
  setOpen(true);
20931
- }, children: jsxRuntime.jsx(SvgArrow, {}) })] }) })] }), jsxRuntime.jsxs("div", { className: styles$9.areaInfo, children: [jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Area:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] }), jsxRuntime.jsx(MowingEdgeModal, { value: edgeMowingValue, onChange: (value) => {
21199
+ }, children: jsxRuntime.jsx(SvgArrow, {}) })] }) })] }), jsxRuntime.jsx("div", { className: styles$9.border }), jsxRuntime.jsxs("div", { className: styles$9.areaInfo, children: [jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Area:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] }), jsxRuntime.jsx(MowingEdgeModal, { value: edgeMowingValue, onChange: (value) => {
20932
21200
  setEditMapInfo({
20933
21201
  ...editMapInfo,
20934
21202
  selectElement: {
@@ -20958,7 +21226,7 @@ const BoundaryInfo = ({ onHandleDelete }) => {
20958
21226
  } })] }));
20959
21227
  };
20960
21228
 
20961
- var css_248z$1 = ".index-module_timePeriod__EkVZl {\n display: flex;\n flex-direction: column;\n padding: 8px 0;\n border-top: 1px solid rgb(197, 197, 197);\n}\n.index-module_timePeriod__EkVZl .index-module_timePeriodHeader__CgJGW {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n padding: 0px 0 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 .index-module_timePeriodRadioItem__3rd-r {\n line-height: 28px;\n}";
21229
+ 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}";
20962
21230
  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"};
20963
21231
  styleInject(css_248z$1);
20964
21232
 
@@ -20982,6 +21250,8 @@ const TimePeriod = ({ value, onChange }) => {
20982
21250
  onChange({
20983
21251
  ...value,
20984
21252
  status: checked ? 1 : 0,
21253
+ start_timestamp: checked ? value.start_timestamp : 0,
21254
+ end_timestamp: checked ? value.end_timestamp : 0,
20985
21255
  });
20986
21256
  } }) })] }), jsxRuntime.jsx("div", { className: styles$1.timePeriodContent, children: jsxRuntime.jsxs(antd.Radio.Group, { value: radioValue, onChange: (e) => {
20987
21257
  setRadioValue(e.target.value);
@@ -20989,8 +21259,8 @@ const TimePeriod = ({ value, onChange }) => {
20989
21259
  setDate(null);
20990
21260
  onChange({
20991
21261
  ...value,
20992
- startTimestamp: 0,
20993
- endTimestamp: 0,
21262
+ start_timestamp: 0,
21263
+ end_timestamp: 0,
20994
21264
  });
20995
21265
  }
20996
21266
  else if (e.target.value === RadioValue.SHORT_TIME) {
@@ -21001,15 +21271,15 @@ const TimePeriod = ({ value, onChange }) => {
21001
21271
  // endTimestamp: dayjs().add(1, 'hour').unix(),
21002
21272
  // });
21003
21273
  }
21004
- }, style: { display: 'flex', flexDirection: 'column', gap: '4px' }, children: [jsxRuntime.jsx(antd.Radio, { value: RadioValue.LONG_TIME, children: jsxRuntime.jsx("div", { className: styles$1.timePeriodRadioItem, children: "\u957F\u65F6\u95F4\u5F00\u542F" }) }), jsxRuntime.jsx(antd.Radio, { value: RadioValue.SHORT_TIME, children: jsxRuntime.jsx("div", { className: styles$1.timePeriodRadioItem, children: jsxRuntime.jsx(antd.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) => {
21274
+ }, style: { display: 'flex', flexDirection: 'column', gap: '4px' }, children: [jsxRuntime.jsx(antd.Radio, { value: RadioValue.LONG_TIME, children: jsxRuntime.jsx("div", { className: styles$1.timePeriodRadioItem, children: "Always" }) }), jsxRuntime.jsx(antd.Radio, { value: RadioValue.SHORT_TIME, children: jsxRuntime.jsx("div", { className: styles$1.timePeriodRadioItem, children: jsxRuntime.jsx(antd.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) => {
21005
21275
  setOpen(open);
21006
21276
  }, onChange: (dateValue, dateString) => {
21007
21277
  setDate(dateValue);
21008
21278
  if (dateValue?.length === 2) {
21009
21279
  onChange({
21010
21280
  status: RadioValue.SHORT_TIME,
21011
- startTimestamp: dateValue[0].unix(),
21012
- endTimestamp: dateValue[1].unix(),
21281
+ start_timestamp: dateValue[0].unix(),
21282
+ end_timestamp: dateValue[1].unix(),
21013
21283
  });
21014
21284
  }
21015
21285
  } }) }) })] }) })] }));
@@ -21023,12 +21293,12 @@ const ObstacleInfo = ({ onHandleDelete }) => {
21023
21293
  if (!editMapInfo.selectElement)
21024
21294
  return null;
21025
21295
  const status = editMapInfo.selectElement?.status;
21026
- const startTimestamp = editMapInfo.selectElement?.start_timestamp;
21027
- const endTimestamp = editMapInfo.selectElement?.end_timestamp;
21296
+ const start_timestamp = editMapInfo.selectElement?.start_timestamp;
21297
+ const end_timestamp = editMapInfo.selectElement?.end_timestamp;
21028
21298
  return {
21029
21299
  status,
21030
- startTimestamp,
21031
- endTimestamp,
21300
+ start_timestamp,
21301
+ end_timestamp,
21032
21302
  };
21033
21303
  }, [editMapInfo.selectElement]);
21034
21304
  const sizeValue = React.useMemo(() => {
@@ -21055,18 +21325,18 @@ const ObstacleInfo = ({ onHandleDelete }) => {
21055
21325
  name: name,
21056
21326
  },
21057
21327
  });
21058
- } }) }), jsxRuntime.jsx("div", { className: styles$9.timePeriod, children: jsxRuntime.jsx(TimePeriod, { value: timePeriodValue, onChange: (value) => {
21328
+ } }) }), jsxRuntime.jsx("div", { className: styles$9.border }), jsxRuntime.jsx("div", { className: styles$9.timePeriod, children: jsxRuntime.jsx(TimePeriod, { value: timePeriodValue, onChange: (value) => {
21059
21329
  setEditMapInfo({
21060
21330
  ...editMapInfo,
21061
21331
  isShowDrag: editMapInfo?.isShowDrag || false,
21062
21332
  selectElement: {
21063
21333
  ...editMapInfo.selectElement,
21064
21334
  status: value.status,
21065
- start_timestamp: value.startTimestamp,
21066
- end_timestamp: value.endTimestamp,
21335
+ start_timestamp: value.start_timestamp,
21336
+ end_timestamp: value.end_timestamp,
21067
21337
  },
21068
21338
  });
21069
- } }) }), jsxRuntime.jsxs("div", { className: styles$9.areaInfo, children: [jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Area:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] })] }));
21339
+ } }) }), jsxRuntime.jsx("div", { className: styles$9.border }), jsxRuntime.jsxs("div", { className: styles$9.areaInfo, children: [jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Area:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.area })] }), jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Perimeter:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue?.perimeter })] })] })] }));
21070
21340
  };
21071
21341
 
21072
21342
  const DoodleInfo = ({ onHandleDelete }) => {
@@ -21088,31 +21358,37 @@ const DoodleInfo = ({ onHandleDelete }) => {
21088
21358
  const create_ts = editMapInfo?.selectElement?.create_ts;
21089
21359
  const expiration_ts = editMapInfo.selectElement.expiration_ts;
21090
21360
  const diff = expiration_ts - create_ts;
21091
- const day = Math.floor(diff / (60 * 60 * 24 * 1000));
21092
- console.log('create_ts->', create_ts, expiration_ts, day);
21361
+ const day = Math.floor(diff / (60 * 60 * 24));
21093
21362
  return {
21094
21363
  day: day,
21095
21364
  };
21096
21365
  }, [editMapInfo?.selectElement]);
21366
+ const remainDay = React.useMemo(() => {
21367
+ if (!editMapInfo.selectElement)
21368
+ return null;
21369
+ const expiration_ts = editMapInfo.selectElement.expiration_ts;
21370
+ const diff = expiration_ts - Date.now() / 1000;
21371
+ return Math.floor(diff / (60 * 60 * 24));
21372
+ }, [editMapInfo?.selectElement]);
21097
21373
  const sizeValue = React.useMemo(() => {
21098
21374
  if (!editMapInfo.selectElement || !editMapInfo.selectElement.svg)
21099
21375
  return '';
21100
21376
  const svg = editMapInfo.selectElement?.svg;
21377
+ const scale = editMapInfo.selectElement.scale;
21101
21378
  const parseSvg = SvgParserNative.parseSvg(svg);
21102
- const width = parseSvg.width / SCALE_FACTOR;
21103
- const height = parseSvg.height / SCALE_FACTOR;
21104
- console.log('parseSvg->', parseSvg);
21105
- return `${width} m x ${height} m`;
21379
+ const width = (parseSvg.width * scale) / SCALE_FACTOR;
21380
+ const height = (parseSvg.height * scale) / SCALE_FACTOR;
21381
+ console.log('parseSvg->', editMapInfo, parseSvg);
21382
+ return `${width.toFixed(1)} m x ${height.toFixed(1)} m`;
21106
21383
  }, [editMapInfo.selectElement]);
21107
21384
  const handleChange = React.useCallback((day) => {
21108
- const lastTime = Date.now() - editMapInfo.selectElement.create_ts;
21109
21385
  setEditMapInfo((pre) => {
21110
- console.log('expiration_ts->', lastTime, day, lastTime + day * 24 * 60 * 60 * 1000);
21111
21386
  return {
21112
21387
  ...pre,
21113
21388
  selectElement: {
21114
21389
  ...pre.selectElement,
21115
- expiration_ts: Date.now() + lastTime + day * 24 * 60 * 60 * 1000,
21390
+ create_ts: Date.now() / 1000,
21391
+ expiration_ts: Date.now() / 1000 + day * 24 * 60 * 60,
21116
21392
  },
21117
21393
  };
21118
21394
  });
@@ -21120,7 +21396,7 @@ const DoodleInfo = ({ onHandleDelete }) => {
21120
21396
  console.log('doodleInfo->', doodleInfo);
21121
21397
  return (jsxRuntime.jsxs("div", { className: styles$9.doodleInfo, children: [jsxRuntime.jsx(Header, { handleDelete: () => {
21122
21398
  onHandleDelete();
21123
- }, handleFocus: () => { }, type: editMapInfo.elementType }), isCreate ? (jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.time, children: [jsxRuntime.jsxs("div", { className: styles$9.exist, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Graph maintenance time" }), jsxRuntime.jsx("div", { className: styles$9.value, children: jsxRuntime.jsx(antd.Select, { defaultValue: doodleInfo?.day, style: { width: 80 }, onChange: (value) => handleChange(value), options: options }) })] }), doodleInfo?.day >= 14 && (jsxRuntime.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." }))] }) })) : (jsxRuntime.jsxs("div", { className: styles$9.areaInfo, children: [jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Graph maintenance time:" }), jsxRuntime.jsxs("div", { className: styles$9.value, children: [doodleInfo?.day, " day"] })] }), jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Size:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue })] })] }))] }));
21399
+ }, handleFocus: () => { }, type: editMapInfo.elementType }), jsxRuntime.jsx("div", { className: styles$9.border }), isCreate ? (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(Item, { children: jsxRuntime.jsxs("div", { className: styles$9.time, children: [jsxRuntime.jsxs("div", { className: styles$9.exist, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Preserve doodle for" }), jsxRuntime.jsx("div", { className: styles$9.value, children: jsxRuntime.jsx(antd.Select, { defaultValue: doodleInfo?.day, style: { width: 80 }, onChange: (value) => handleChange(value), options: options }) })] }), doodleInfo?.day >= 14 && (jsxRuntime.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." }))] }) }), jsxRuntime.jsx("div", { className: styles$9.border }), jsxRuntime.jsx("div", { className: styles$9.areaInfo, children: jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Size:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue })] }) })] })) : (jsxRuntime.jsxs("div", { className: styles$9.areaInfo, children: [jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Remaining time:" }), jsxRuntime.jsxs("div", { className: styles$9.value, children: [remainDay, " day"] })] }), jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Size:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue })] })] }))] }));
21124
21400
  };
21125
21401
 
21126
21402
  const VisionOffInfo = ({ onHandleDelete }) => {
@@ -21136,7 +21412,7 @@ const VisionOffInfo = ({ onHandleDelete }) => {
21136
21412
  }, [editMapInfo.selectElement]);
21137
21413
  return (jsxRuntime.jsxs("div", { className: "visionOffInfo", children: [jsxRuntime.jsx(Header, { handleDelete: () => {
21138
21414
  onHandleDelete?.();
21139
- }, handleFocus: () => { }, type: DataType.VISION_OFF }), jsxRuntime.jsx("div", { className: styles$9.areaInfo, children: jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Size:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue })] }) })] }));
21415
+ }, handleFocus: () => { }, type: DataType.VISION_OFF }), jsxRuntime.jsx("div", { className: styles$9.border }), jsxRuntime.jsx("div", { className: styles$9.areaInfo, children: jsxRuntime.jsxs("div", { className: styles$9.areaItem, children: [jsxRuntime.jsx("div", { className: styles$9.label, children: "Size:" }), jsxRuntime.jsx("div", { className: styles$9.value, children: sizeValue })] }) })] }));
21140
21416
  };
21141
21417
 
21142
21418
  var _path$2, _path2$1;
@@ -21277,9 +21553,9 @@ const HandleElementInfo = () => {
21277
21553
  if (element?.type === DataType.OBSTACLE) {
21278
21554
  data.obstacle = {
21279
21555
  name: element?.name,
21280
- status: element?.status || 1,
21281
- end_timestamp: element?.end_timestamp || 1758870283,
21282
- start_timestamp: element?.start_timestamp || 1768870283,
21556
+ status: element?.status ?? 1,
21557
+ end_timestamp: element?.end_timestamp,
21558
+ start_timestamp: element?.start_timestamp,
21283
21559
  points: restorePointsFormat(element.points),
21284
21560
  };
21285
21561
  if (element?.id) {
@@ -21307,6 +21583,12 @@ const HandleElementInfo = () => {
21307
21583
  const params = renderElementData(editMapInfo?.selectElement);
21308
21584
  const isObstacle = editMapInfo?.selectElement?.type === DataType.OBSTACLE;
21309
21585
  const hasNotEnoughPoints = params?.obstacle?.points?.length < 3;
21586
+ const isDoodle = editMapInfo?.selectElement?.type === DataType.DOODLE;
21587
+ const doodleResult = checkDoodle();
21588
+ if (isDoodle && !doodleResult?.isValid) {
21589
+ antd.message.error('Keep more distance from boundaries, off-limit island and other doodles');
21590
+ return;
21591
+ }
21310
21592
  if (isObstacle && hasNotEnoughPoints) {
21311
21593
  antd.message.error('Save failed, please draw a closed shape');
21312
21594
  return;
@@ -21338,16 +21620,27 @@ const HandleElementInfo = () => {
21338
21620
  antd.message.error('Save failed, please try again');
21339
21621
  });
21340
21622
  }
21341
- }, [editMapInfo.selectElement]);
21623
+ }, [editMapInfo.selectElement, onUpdateBoundary, onHandleCompleteRecord]);
21342
21624
  const handleCancel = React.useCallback(() => {
21343
- onHandleStopRecord?.()?.then(() => {
21344
- setEditMapInfo({
21345
- ...editMapInfo,
21346
- createMode: null,
21347
- elementType: null,
21348
- selectElement: null,
21349
- isShowDrag: false,
21350
- });
21625
+ const name = DATE_TYPE_MAP.find((item) => item.type === editMapInfo.elementType)?.label;
21626
+ antd.Modal.confirm({
21627
+ icon: null,
21628
+ centered: true,
21629
+ title: 'Quit editing',
21630
+ content: `Changes you made will not be saved. Are you sure you want to quit editing the ${name}?`,
21631
+ okText: 'Quit',
21632
+ cancelText: 'Keep editing',
21633
+ onOk: () => {
21634
+ onHandleStopRecord?.()?.then(() => {
21635
+ setEditMapInfo({
21636
+ ...editMapInfo,
21637
+ createMode: null,
21638
+ elementType: null,
21639
+ selectElement: null,
21640
+ isShowDrag: false,
21641
+ });
21642
+ });
21643
+ },
21351
21644
  });
21352
21645
  }, [editMapInfo]);
21353
21646
  const handleDelete = React.useCallback(() => {
@@ -21392,26 +21685,12 @@ const HandleElementInfo = () => {
21392
21685
  },
21393
21686
  });
21394
21687
  }, [editMapInfo?.selectElement, onHandleDeleteElement, onHandleStopRecord]);
21395
- const checkDisabled = React.useCallback(() => {
21396
- if (editMapInfo.elementType === DataType.DOODLE) {
21397
- const result = checkDoodle();
21398
- return !result?.isValid;
21399
- }
21400
- return false;
21401
- }, [checkDoodle, editMapInfo]);
21402
21688
  if (!editMapInfo.selectElement)
21403
21689
  return null;
21404
21690
  console.log('handleElementInfo->', editMapInfo, currentType);
21405
- return (jsxRuntime.jsxs("div", { className: styles$9.handleElementInfo, children: [editMapInfo?.elementType !== DataType.BOUNDARY ? (jsxRuntime.jsxs("div", { className: styles$9.undoAndRedo, children: [jsxRuntime.jsx("div", { className: classNames(styles$9.undo, { [styles$9.disabled]: isUndoDisabled }), onClick: handleUndo, children: jsxRuntime.jsx(SvgUndo, {}) }), jsxRuntime.jsx("div", { className: classNames(styles$9.redo, { [styles$9.disabled]: idRedoDisabled }), onClick: handleRedo, children: jsxRuntime.jsx(SvgRedo, {}) })] })) : null, editMapInfo?.elementType === DataType.BOUNDARY && (jsxRuntime.jsx(BoundaryInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.OBSTACLE && (jsxRuntime.jsx(ObstacleInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.DOODLE && jsxRuntime.jsx(DoodleInfo, { onHandleDelete: handleDelete }), editMapInfo?.elementType === DataType.VISION_OFF && (jsxRuntime.jsx(VisionOffInfo, { onHandleDelete: handleDelete })), jsxRuntime.jsxs("div", { className: styles$9.handle, children: [jsxRuntime.jsx(antd.Button, { disabled: checkDisabled(), variant: "solid", color: "primary", onClick: handleSave, children: "Save & Done" }), jsxRuntime.jsx(antd.Button, { variant: "outlined", color: "default", onClick: () => {
21406
- handleCancel();
21407
- setEditMapInfo({
21408
- createMode: null,
21409
- editMap: false,
21410
- elementType: undefined,
21411
- selectElement: null,
21412
- isShowDrag: false,
21413
- });
21414
- }, children: "Cancel" })] })] }));
21691
+ return (jsxRuntime.jsxs("div", { className: styles$9.handleElementInfo, children: [editMapInfo?.elementType !== DataType.BOUNDARY ? (jsxRuntime.jsxs("div", { className: styles$9.undoAndRedo, children: [jsxRuntime.jsx("div", { className: classNames(styles$9.undo, { [styles$9.disabled]: isUndoDisabled }), onClick: handleUndo, children: jsxRuntime.jsx(SvgUndo, {}) }), jsxRuntime.jsx("div", { className: classNames(styles$9.redo, { [styles$9.disabled]: idRedoDisabled }), onClick: handleRedo, children: jsxRuntime.jsx(SvgRedo, {}) })] })) : null, editMapInfo?.elementType === DataType.BOUNDARY && (jsxRuntime.jsx(BoundaryInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.OBSTACLE && (jsxRuntime.jsx(ObstacleInfo, { onHandleDelete: handleDelete })), editMapInfo?.elementType === DataType.DOODLE && jsxRuntime.jsx(DoodleInfo, { onHandleDelete: handleDelete }), editMapInfo?.elementType === DataType.VISION_OFF && (jsxRuntime.jsx(VisionOffInfo, { onHandleDelete: handleDelete })), jsxRuntime.jsx("div", { className: styles$9.border }), jsxRuntime.jsx("div", { className: styles$9.handle, children: jsxRuntime.jsxs(antd.Space, { size: 12, children: [jsxRuntime.jsx(antd.Button, { variant: "outlined", color: "default", onClick: () => {
21692
+ handleCancel();
21693
+ }, children: "Cancel" }), jsxRuntime.jsx(antd.Button, { variant: "solid", color: "primary", onClick: handleSave, children: "Save" })] }) })] }));
21415
21694
  };
21416
21695
 
21417
21696
  var _path;
@@ -21537,7 +21816,7 @@ const defaultMapConfig = DEFAULT_STYLES;
21537
21816
  // 地图渲染器组件
21538
21817
  const MowerMapRenderer = React.forwardRef(({ sn, platform = PlatformType.WEB, edger = false, unitType = UnitsType.Imperial, language = 'en', onlyRead = false, mapConfig,
21539
21818
  // pathConfig,
21540
- 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, onClickEvent, }, ref) => {
21819
+ 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) => {
21541
21820
  const [currentError, setCurrentError] = React.useState(null);
21542
21821
  const overlayRef = React.useRef(null);
21543
21822
  // const mapRef = useMap();
@@ -21593,7 +21872,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
21593
21872
  onSaveMap,
21594
21873
  onHandleDeleteElement,
21595
21874
  onUpdateBoundary,
21596
- onClickEvent,
21875
+ onHandleEvent,
21597
21876
  };
21598
21877
  }, [
21599
21878
  minDistance,
@@ -21605,7 +21884,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
21605
21884
  onSaveBoundaryData,
21606
21885
  onSaveMap,
21607
21886
  onUpdateBoundary,
21608
- onClickEvent,
21887
+ onHandleEvent,
21609
21888
  ]);
21610
21889
  // 合并配置
21611
21890
  const mergedMapConfig = React.useMemo(() => {
@@ -21639,6 +21918,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
21639
21918
  drag: defaultTransform,
21640
21919
  mapRef,
21641
21920
  overlayScale,
21921
+ doodleList,
21642
21922
  };
21643
21923
  }, [
21644
21924
  sn,
@@ -21653,6 +21933,7 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
21653
21933
  defaultTransform,
21654
21934
  mapRef,
21655
21935
  overlayScale,
21936
+ doodleList,
21656
21937
  ]);
21657
21938
  // console.log('svgElementDatas->', svgElementDatas, unStructMapData, commonValue);
21658
21939
  // 处理地图分区边界
@@ -21894,7 +22175,15 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
21894
22175
  // 基于固定的参考zoom级别计算overlayScale
21895
22176
  const zoomDiff = currentZoom - REFERENCE_ZOOM;
21896
22177
  const scale = Math.pow(2, -zoomDiff); // 负数实现反向缩放
21897
- setOverlayScale(scale);
22178
+ if (scale < 1) {
22179
+ setOverlayScale(1);
22180
+ }
22181
+ else if (scale > 4) {
22182
+ setOverlayScale(4);
22183
+ }
22184
+ else {
22185
+ setOverlayScale(scale);
22186
+ }
21898
22187
  };
21899
22188
  // 使用lodash throttle进行节流处理: 100ms内只执行一次
21900
22189
  const handleZoomChanged = throttle$2(updateScale, 50);
@@ -21987,6 +22276,8 @@ modelType, mapRef, mapJson, pathJson, realTimeData, antennaConfig, onMapLoad, on
21987
22276
  addHistory: (history) => svgEditMapRef.current?.addHistory(history),
21988
22277
  // 添加doodle
21989
22278
  addDoodle: (doodle) => svgEditMapRef.current?.addDoodle(doodle),
22279
+ // 检查doodle
22280
+ checkDoodle: () => svgEditMapRef.current?.checkDoodle?.(),
21990
22281
  }));
21991
22282
  /**
21992
22283
  * 根据割草机的位置更新路径