@libs-ui/components-draw-line 0.2.70 → 0.2.72
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/draw-line.directive.d.ts +2 -0
- package/esm2022/draw-line.directive.mjs +65 -10
- package/esm2022/util/calculator-branch.util.mjs +1 -1
- package/esm2022/util/calculator-diretion-element.until.mjs +34 -23
- package/esm2022/util/connect-navigation-new-element.util.mjs +7 -10
- package/esm2022/util/line-connect-bottom-left.until.mjs +23 -31
- package/fesm2022/libs-ui-components-draw-line.mjs +124 -70
- package/fesm2022/libs-ui-components-draw-line.mjs.map +1 -1
- package/package.json +1 -1
- package/util/calculator-diretion-element.until.d.ts +8 -4
|
@@ -34,7 +34,6 @@ export class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
|
34
34
|
const listLine = separatedPoints.filter(item => item.id === 'checkAndAvoidBlocksYLeft');
|
|
35
35
|
const elements = listLine.filter(item => item.start.x === straightLine.endPath.x || item.end.x === straightLine.endPath.x);
|
|
36
36
|
elements.forEach(item => {
|
|
37
|
-
console.log('directionStartX', directionStartX);
|
|
38
37
|
if (item.start.x === straightLine.endPath.x) {
|
|
39
38
|
item.start.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartX, item.start.x, (lineCurve));
|
|
40
39
|
}
|
|
@@ -44,34 +43,31 @@ export class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
|
44
43
|
});
|
|
45
44
|
}
|
|
46
45
|
// // kiểm tra ngay khi cua có vướng ai không rồi hẵng vẽ Q1
|
|
47
|
-
const elementBlockRoad = MoCanvasCalculatorDirectionElementUtil.checkLinePassBlockHorizontal(straightLine.endPath.x ?? 0,
|
|
46
|
+
const elementBlockRoad = MoCanvasCalculatorDirectionElementUtil.checkLinePassBlockHorizontal(straightLine.endPath.x ?? 0, endPositionOrigin.x, straightLine.endPath.y ?? 0, 'x', obstacleRect);
|
|
48
47
|
const directionNextX = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(straightLine.endPath.x ?? 0, endPositionOrigin.x, 'x');
|
|
49
48
|
const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: straightLine.endPath.x ?? 0, y: straightLine.endPath.y ?? 0 }, `${directionStartY}-${directionNextX}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
50
|
-
|
|
49
|
+
const elementBlockRoadX = (elementBlockRoad?.x ?? 0) + (elementBlockRoad?.width ?? 0);
|
|
50
|
+
if (elementBlockRoad && Math.abs((elementBlockRoadX) - (straightLine.endPath.x ?? 0)) <= lineCurve * 2) {
|
|
51
51
|
coordQ1.x1 = straightLine.endPath.x ?? 0;
|
|
52
52
|
coordQ1.y1 = straightLine.endPath.y ?? 0;
|
|
53
53
|
coordQ1.x = straightLine.endPath.x ?? 0;
|
|
54
54
|
coordQ1.y = straightLine.endPath.y ?? 0;
|
|
55
55
|
}
|
|
56
56
|
// kiểm tra và vẽ hướng ngang
|
|
57
|
-
const directionXToEnd = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(coordQ1.x ?? 0,
|
|
58
|
-
endPosition.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionXToEnd, endPosition.x, lineCurve);
|
|
59
|
-
if (Math.abs((coordQ1.y ?? 0) - endPosition.y) <= lineCurve) {
|
|
60
|
-
endPosition.y -= lineCurve;
|
|
61
|
-
}
|
|
57
|
+
const directionXToEnd = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(coordQ1.x ?? 0, endPosition.x, 'x');
|
|
62
58
|
const pathHorizontal = [];
|
|
63
|
-
const
|
|
59
|
+
const endPath = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPosition, obstacleRect, pathHorizontal);
|
|
64
60
|
if (directionXToEnd === 'left' && endPath.x > (coordQ1.x ?? 0)) {
|
|
65
|
-
separatedPoints.push({ start: straightLine.endPath, end:
|
|
61
|
+
separatedPoints.push({ start: straightLine.endPath, end: endPosition, mode: 'vertical', id: '6a ' + directionStartY });
|
|
66
62
|
return;
|
|
67
63
|
}
|
|
68
64
|
const end = { x: (coordQ1.x ?? 0), y: coordQ1.y ?? 0 };
|
|
69
|
-
separatedPoints.push({ start: straightLine.endPath, end: end, mode: 'vertical-single-curve', id: '6a ' + directionStartY }); // góc cong từ đường thẳng sang ngang
|
|
70
65
|
separatedPoints.push(...pathHorizontal);
|
|
71
|
-
|
|
66
|
+
separatedPoints.push({ start: straightLine.endPath, end: end, mode: 'vertical-single-curve', id: '6a ' + directionStartY }); // góc cong từ đường thẳng sang ngang
|
|
67
|
+
if (endPath.x === endPosition.x && endPath.y < endPosition.y) {
|
|
72
68
|
const itemLast = pathHorizontal.find(item => item.end.x === endPath.x);
|
|
73
69
|
if (itemLast) {
|
|
74
|
-
itemLast.end.x =
|
|
70
|
+
itemLast.end.x = endPosition.x + 50;
|
|
75
71
|
endPath.x = itemLast.end.x;
|
|
76
72
|
}
|
|
77
73
|
}
|
|
@@ -97,34 +93,30 @@ export class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
|
97
93
|
separatedPointsCheckAndAvoidBlocks = [];
|
|
98
94
|
}
|
|
99
95
|
if (Math.abs((endPath.y ?? 0) - endPosition.y) < 15) {
|
|
100
|
-
const
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
}
|
|
96
|
+
const element = separatedPointsCheckAndAvoidBlocks.find(item => (item.end.y === endPath.y && item.end.x === endPath.x));
|
|
97
|
+
const elementQR = separatedPointsCheckAndAvoidBlocks.find(item => (item.end.y === element?.start.y && item.end.x === element.start.x));
|
|
98
|
+
if (element) {
|
|
99
|
+
element.start.y = endPosition.y;
|
|
100
|
+
element.end.y = endPosition.y;
|
|
101
|
+
}
|
|
102
|
+
if (elementQR) {
|
|
103
|
+
elementQR.end.y = endPosition.y;
|
|
104
|
+
}
|
|
109
105
|
}
|
|
110
106
|
separatedPoints.splice(separatedPoints.length, 0, ...separatedPointsCheckAndAvoidBlocks);
|
|
111
107
|
if (endPath.y === endPosition.y) {
|
|
112
108
|
separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: endPosition, mode: 'horizontal' });
|
|
113
109
|
return;
|
|
114
110
|
}
|
|
111
|
+
if (Math.abs((endPath.y ?? 0) - endPosition.y) < 15) {
|
|
112
|
+
separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: endPosition, mode: 'vertical' });
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
115
|
// // sau khi đã đi ngang và tránh các khối, tiếp theo là đi tiếp hướng lên xuống để về khối cần nối tới, cần check xem điểm end X nó đang ở hướng nào
|
|
116
116
|
const directionY = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(endPath.y, endPosition.y, 'y');
|
|
117
117
|
const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: endPath.x ?? 0, y: endPath.y ?? 0 }, `right-${directionY === 'above' ? 'above' : 'under'}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
118
118
|
const endPositionY = cloneDeep(endPosition);
|
|
119
119
|
endPositionY.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionY, endPositionY.y, lineCurve);
|
|
120
|
-
// // cần check khi đi thẳng lên có vướng khối nào không để tiến lên, nhưng cần phải xem x của nó có quá gần endX không, gần quá thì
|
|
121
|
-
const elementBlockRoadStraightLineY = MoCanvasCalculatorDirectionElementUtil.checkBlocksElementStraightY((endPath.x ?? 0) + 10, endPath.y ?? 0, endPositionY, obstacleRect);
|
|
122
|
-
if (elementBlockRoadStraightLineY) {
|
|
123
|
-
coordQ1.x = (elementBlockRoadStraightLineY.x ?? 0) + (elementBlockRoadStraightLineY.width ?? 0) + lineCurve;
|
|
124
|
-
}
|
|
125
|
-
if (Math.abs((coordQ1.x ?? 0) - endPosition.x) < 20 && directionY === 'under') {
|
|
126
|
-
coordQ1.x = endPosition.x + 20; // trường hợp right quay xuống dưới điểm end khá gần điểm start => không đủ khoảng cách quay mũi tên vào
|
|
127
|
-
}
|
|
128
120
|
separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: { x: coordQ1.x ?? 0, y: (coordQ1.y ?? 0) }, mode: 'horizontal-single-curve', id: 'g' });
|
|
129
121
|
let avoidBlocksYLine = [];
|
|
130
122
|
const straightLine = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksY(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPositionY, directionY, obstacleRect, avoidBlocksYLine);
|
|
@@ -152,4 +144,4 @@ export class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
|
152
144
|
return;
|
|
153
145
|
}
|
|
154
146
|
}
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-connect-bottom-left.until.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/draw-line/src/util/line-connect-bottom-left.until.ts"],"names":[],"mappings":"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","sourcesContent":["import { cloneDeep } from \"@libs-ui/utils\";\nimport { IPoint, IPoints, IRect } from \"../draw-line.interface\";\nimport { MoCanvasCalculatorBranchUtil } from \"./calculator-branch.util\";\nimport { MoCanvasCalculatorDirectionElementUtil } from \"./calculator-diretion-element.until\";\n\nexport class MoCanvasConnectNavigationBottomLeftElementUtil {\n  static lineLeft(pointNext: IRect, pointStart: IRect, start: IPoint, lineCurve: number, obstacleRect: IRect[], separatedPoints: Array<IPoints>) {\n    const endPositionOrigin = {\n      x: pointNext.x,\n      y: pointNext.y\n    };\n    const endPosition = cloneDeep(endPositionOrigin);\n    const directionStartY = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(start.y, endPositionOrigin.y, 'y');\n\n    let newPosition = start;\n\n    if (directionStartY === 'above') {\n      const startQL = { lx: start.x - lineCurve, ly: (start.y ?? 0) + lineCurve }\n      const line = {\n        start: { x: (start.x ?? 0), y: start.y ?? 0 },\n        end: { x: startQL.lx ?? 0, y: startQL.ly ?? 0 }\n      }\n      newPosition = {\n        x: pointStart.x - (lineCurve + 10),\n        y: MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartY, line.end.y, lineCurve, true)\n      }\n\n      separatedPoints.push({ start: line.start, end: line.end, mode: 'vertical-single-curve', id: '1' }); // line vẽ đi khỏi khối đầu tiên\n      separatedPoints.push({ start: line.end, end: newPosition, mode: 'horizontal-single-curve', id: '1' }); // line vẽ đi khỏi khối đầu tiên\n    }\n\n    // kiểm tra hướng thẳng đến end, nếu có khối thì tránh\n    endPositionOrigin.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartY, endPositionOrigin.y, lineCurve);\n    const straightLine = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksYLeft(newPosition.x ?? 0, newPosition.y ?? 0, lineCurve, endPositionOrigin, directionStartY, obstacleRect, separatedPoints);\n\n    const directionStartX = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(straightLine.endPath.x, endPositionOrigin.x, 'x');\n    if (directionStartX === 'center' && directionStartY === 'under') {\n      return;\n    }\n\n    if (Math.abs((straightLine.endPath.x ?? 0) - endPositionOrigin.x) < lineCurve) {\n      const listLine = separatedPoints.filter(item => item.id === 'checkAndAvoidBlocksYLeft');\n      const elements = listLine.filter(item => item.start.x === straightLine.endPath.x || item.end.x === straightLine.endPath.x);\n      elements.forEach(item => {\n        console.log('directionStartX', directionStartX);\n        if (item.start.x === straightLine.endPath.x) {\n          item.start.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartX, item.start.x, (lineCurve));\n        }\n        if (item.end.x === straightLine.endPath.x) {\n          item.end.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartX, item.end.x, (lineCurve));\n        }\n      })\n    }\n\n    // // kiểm tra ngay khi cua có vướng ai không rồi hẵng vẽ Q1\n    const elementBlockRoad = MoCanvasCalculatorDirectionElementUtil.checkLinePassBlockHorizontal(straightLine.endPath.x ?? 0, endPosition.x, straightLine.endPath.y ?? 0, 'x', obstacleRect) as IRect;\n    const directionNextX = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(straightLine.endPath.x ?? 0, endPositionOrigin.x, 'x');\n    const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: straightLine.endPath.x ?? 0, y: straightLine.endPath.y ?? 0 },\n      `${directionStartY}-${directionNextX}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng\n\n    if (elementBlockRoad) {\n      coordQ1.x1 = straightLine.endPath.x ?? 0;\n      coordQ1.y1 = straightLine.endPath.y ?? 0;\n      coordQ1.x = straightLine.endPath.x ?? 0;\n      coordQ1.y = straightLine.endPath.y ?? 0;\n    }\n\n    // kiểm tra và vẽ hướng ngang\n    const directionXToEnd = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(coordQ1.x ?? 0, endPositionOrigin.x, 'x');\n\n    endPosition.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionXToEnd, endPosition.x, lineCurve);\n    if (Math.abs((coordQ1.y ?? 0) - endPosition.y) <= lineCurve) {\n      endPosition.y -= lineCurve;\n    }\n    const pathHorizontal: IPoints[] = [];\n    const { endPath } = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPositionOrigin, obstacleRect, pathHorizontal);\n\n    if (directionXToEnd === 'left' && endPath.x > (coordQ1.x ?? 0)) {\n      separatedPoints.push({ start: straightLine.endPath, end: endPositionOrigin, mode: 'vertical', id: '6a ' + directionStartY });\n      return;\n    }\n    const end = { x: (coordQ1.x ?? 0), y: coordQ1.y ?? 0 };\n    separatedPoints.push({ start: straightLine.endPath, end: end, mode: 'vertical-single-curve', id: '6a ' + directionStartY }); // góc cong từ đường thẳng sang ngang\n    separatedPoints.push(...pathHorizontal)\n    if (endPath.x === endPositionOrigin.x && endPath.y < endPositionOrigin.y) {\n      const itemLast = pathHorizontal.find(item => item.end.x === endPath.x);\n      if (itemLast) {\n        itemLast.end.x = endPositionOrigin.x + 50;\n        endPath.x = itemLast.end.x;\n      }\n    }\n    separatedPoints.push({ start: endPath, end: { x: pointNext.x, y: pointNext.y }, mode: 'horizontal', id: 'lineEnd' });\n  }\n\n  static rightLeft(elementNext: IRect, start: IPoint, lineCurve: number, obstacleRect: IRect[], separatedPoints: Array<IPoints>) {\n    const endPosition = {\n      x: elementNext.x,\n      y: elementNext.y\n    };\n\n    // vẽ 1 đường thẳng từ điểm start ra ngoài đã\n    const end = { x: (start.x ?? 0) + 10, y: (start.y ?? 0) + 10 };\n    separatedPoints.push({ start: { x: (start.x ?? 0), y: start.y ?? 0 }, end: end, mode: 'vertical-single-curve', id: '1' });\n\n    const endPositionX = cloneDeep(endPosition);\n    endPositionX.x -= 50;\n\n    let separatedPointsCheckAndAvoidBlocks: Array<IPoints> = [];\n    let { endPath } = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocks(end.x ?? 0, (end.y ?? 0), lineCurve, endPositionX, obstacleRect, separatedPointsCheckAndAvoidBlocks);\n\n    if (Math.abs((start.x ?? 0) - endPosition.x) < 10 || end.x > endPath.x) {\n      endPath = {\n        x: end.x,\n        y: end.y\n      };\n\n      separatedPointsCheckAndAvoidBlocks = [];\n    }\n\n    if (Math.abs((endPath.y ?? 0) - endPosition.y) < 15) {\n      const elements = separatedPointsCheckAndAvoidBlocks.filter(item => item.start.y === endPath.y || item.end.y === endPath.y);\n      elements.forEach(item => {\n        if (item.start.y === endPath.y) {\n          item.start.y -= 10;\n        }\n        if (item.end.y === endPath.y) {\n          item.end.y -= 10;\n        }\n      })\n    }\n\n    separatedPoints.splice(separatedPoints.length, 0, ...separatedPointsCheckAndAvoidBlocks);\n\n    if (endPath.y === endPosition.y) {\n      separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: endPosition, mode: 'horizontal' });\n      return;\n    }\n\n    // // sau khi đã đi ngang và tránh các khối, tiếp theo là đi tiếp hướng lên xuống để về khối cần nối tới, cần check xem điểm end X nó đang ở hướng nào\n    const directionY = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(endPath.y, endPosition.y, 'y');\n\n    const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: endPath.x ?? 0, y: endPath.y ?? 0 }, `right-${directionY === 'above' ? 'above' : 'under'}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng\n    const endPositionY = cloneDeep(endPosition);\n    endPositionY.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionY, endPositionY.y, lineCurve);\n\n    // // cần check khi đi thẳng lên có vướng khối nào không để tiến lên, nhưng cần phải xem x của nó có quá gần endX không, gần quá thì \n    const elementBlockRoadStraightLineY = MoCanvasCalculatorDirectionElementUtil.checkBlocksElementStraightY((endPath.x ?? 0) + 10, endPath.y ?? 0, endPositionY, obstacleRect);\n    if (elementBlockRoadStraightLineY) {\n      coordQ1.x = (elementBlockRoadStraightLineY.x ?? 0) + (elementBlockRoadStraightLineY.width ?? 0) + lineCurve;\n    }\n    if (Math.abs((coordQ1.x ?? 0) - endPosition.x) < 20 && directionY === 'under') {\n      coordQ1.x = endPosition.x + 20;  // trường hợp right quay xuống dưới điểm end khá gần điểm start => không đủ khoảng cách quay mũi tên vào\n    }\n    separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: { x: coordQ1.x ?? 0, y: (coordQ1.y ?? 0) }, mode: 'horizontal-single-curve', id: 'g' });\n\n    let avoidBlocksYLine: IPoints[] = [];\n    const straightLine = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksY(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPositionY, directionY, obstacleRect, avoidBlocksYLine);\n    if (directionY === 'under' && (coordQ1.y ?? 0) > endPositionY.y) {\n      avoidBlocksYLine = [];\n      straightLine.endPath = { x: coordQ1.x ?? 0, y: coordQ1.y ?? 0 };\n    }\n    if (directionY === 'above' && straightLine.endPath.y <= endPosition.y) {\n      avoidBlocksYLine = [];\n      straightLine.endPath = { x: coordQ1.x ?? 0, y: coordQ1.y ?? 0 };\n    }\n    if (Math.abs((straightLine.endPath.x ?? 0) - endPosition.x) < 15) {\n      const elements = avoidBlocksYLine.filter(item => item.start.x === straightLine.endPath.x || item.end.x === straightLine.endPath.x);\n      elements.forEach(item => {\n        if (item.start.x === straightLine.endPath.x) {\n          item.start.x += 30;\n        }\n        if (item.end.x === straightLine.endPath.x) {\n          item.end.x += 30;\n        }\n      })\n    }\n\n    separatedPoints.push(...avoidBlocksYLine);\n    separatedPoints.push({ start: { x: straightLine.endPath.x ?? 0, y: straightLine.endPath.y ?? 0 }, end: endPosition, mode: 'vertical-single-curve', id: '4' });\n\n    return;\n  }\n}"]}
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-connect-bottom-left.until.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/draw-line/src/util/line-connect-bottom-left.until.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,4BAA4B,EAAE,MAAM,0BAA0B,CAAC;AACxE,OAAO,EAAE,sCAAsC,EAAE,MAAM,qCAAqC,CAAC;AAE7F,MAAM,OAAO,8CAA8C;IACzD,MAAM,CAAC,QAAQ,CAAC,SAAgB,EAAE,UAAiB,EAAE,KAAa,EAAE,SAAiB,EAAE,YAAqB,EAAE,eAA+B;QAC3I,MAAM,iBAAiB,GAAG;YACxB,CAAC,EAAE,SAAS,CAAC,CAAC;YACd,CAAC,EAAE,SAAS,CAAC,CAAC;SACf,CAAC;QACF,MAAM,WAAW,GAAG,SAAS,CAAC,iBAAiB,CAAC,CAAC;QACjD,MAAM,eAAe,GAAG,sCAAsC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAEvH,IAAI,WAAW,GAAG,KAAK,CAAC;QAExB,IAAI,eAAe,KAAK,OAAO,EAAE,CAAC;YAChC,MAAM,OAAO,GAAG,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC,GAAG,SAAS,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC;YAC5E,MAAM,IAAI,GAAG;gBACX,KAAK,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE;gBAC7C,GAAG,EAAE,EAAE,CAAC,EAAE,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE;aAChD,CAAC;YAEF,WAAW,GAAG;gBACZ,CAAC,EAAE,UAAU,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,EAAE,CAAC;gBAClC,CAAC,EAAE,4BAA4B,CAAC,wBAAwB,CAAC,eAAe,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC;aACvG,CAAC;YAEF,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,uBAAuB,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,gCAAgC;YACpI,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,yBAAyB,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,gCAAgC;QACzI,CAAC;QAED,sDAAsD;QACtD,iBAAiB,CAAC,CAAC,GAAG,4BAA4B,CAAC,wBAAwB,CAAC,eAAe,EAAE,iBAAiB,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QAC7H,MAAM,YAAY,GAAG,sCAAsC,CAAC,wBAAwB,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,iBAAiB,EAAE,eAAe,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;QAC3M,MAAM,eAAe,GAAG,sCAAsC,CAAC,oBAAoB,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,iBAAiB,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAEtI,IAAI,eAAe,KAAK,QAAQ,IAAI,eAAe,KAAK,OAAO,EAAE,CAAC;YAChE,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,iBAAiB,CAAC,CAAC,CAAC,GAAG,SAAS,EAAE,CAAC;YAC9E,MAAM,QAAQ,GAAG,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,0BAA0B,CAAC,CAAC;YACxF,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAE3H,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACtB,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;oBAC5C,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,4BAA4B,CAAC,wBAAwB,CAAC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;gBACnH,CAAC;gBACD,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;oBAC1C,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,4BAA4B,CAAC,wBAAwB,CAAC,eAAe,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;gBAC/G,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,4DAA4D;QAC5D,MAAM,gBAAgB,GAAG,sCAAsC,CAAC,4BAA4B,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,iBAAiB,CAAC,CAAC,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,YAAY,CAAU,CAAC;QACxM,MAAM,cAAc,GAAG,sCAAsC,CAAC,oBAAoB,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,iBAAiB,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAC1I,MAAM,OAAO,GAAG,sCAAsC,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,EACjI,GAAG,eAAe,IAAI,cAAc,EAAE,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,iDAAiD;QAClH,MAAM,iBAAiB,GAAG,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,KAAK,IAAI,CAAC,CAAC,CAAC;QAEtF,IAAI,gBAAgB,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;YACvG,OAAO,CAAC,EAAE,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;YACzC,OAAO,CAAC,EAAE,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;YACzC,OAAO,CAAC,CAAC,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;YACxC,OAAO,CAAC,CAAC,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;QAC1C,CAAC;QAED,6BAA6B;QAC7B,MAAM,eAAe,GAAG,sCAAsC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACxH,MAAM,cAAc,GAAc,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,sCAAsC,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,cAAc,CAAC,CAAC;QAErK,IAAI,eAAe,KAAK,MAAM,IAAI,OAAO,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;YAC/D,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,YAAY,CAAC,OAAO,EAAE,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE,KAAK,GAAG,eAAe,EAAE,CAAC,CAAC;YAEvH,OAAO;QACT,CAAC;QACD,MAAM,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;QAEvD,eAAe,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,CAAC;QACxC,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,YAAY,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,uBAAuB,EAAE,EAAE,EAAE,KAAK,GAAG,eAAe,EAAE,CAAC,CAAC,CAAC,qCAAqC;QAClK,IAAI,OAAO,CAAC,CAAC,KAAK,WAAW,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,EAAE,CAAC;YAC7D,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;YAEvE,IAAI,QAAQ,EAAE,CAAC;gBACb,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,GAAG,EAAE,CAAC;gBACpC,OAAO,CAAC,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;QACD,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;IACvH,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,WAAkB,EAAE,KAAa,EAAE,SAAiB,EAAE,YAAqB,EAAE,eAA+B;QAC3H,MAAM,WAAW,GAAG;YAClB,CAAC,EAAE,WAAW,CAAC,CAAC;YAChB,CAAC,EAAE,WAAW,CAAC,CAAC;SACjB,CAAC;QAEF,6CAA6C;QAC7C,MAAM,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC;QAE/D,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,uBAAuB,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;QAE1H,MAAM,YAAY,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;QAE5C,YAAY,CAAC,CAAC,IAAI,EAAE,CAAC;QAErB,IAAI,kCAAkC,GAAmB,EAAE,CAAC;QAE5D,IAAI,EAAE,OAAO,EAAE,GAAG,sCAAsC,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,kCAAkC,CAAC,CAAC;QAElL,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,IAAI,GAAG,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;YACvE,OAAO,GAAG;gBACR,CAAC,EAAE,GAAG,CAAC,CAAC;gBACR,CAAC,EAAE,GAAG,CAAC,CAAC;aACT,CAAC;YAEF,kCAAkC,GAAG,EAAE,CAAC;QAC1C,CAAC;QAED,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC;YACpD,MAAM,OAAO,GAAG,kCAAkC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;YACxH,MAAM,SAAS,GAAG,kCAAkC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,OAAO,EAAE,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAEvI,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;gBAChC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;YAChC,CAAC;YACD,IAAI,SAAS,EAAE,CAAC;gBACd,SAAS,CAAC,GAAG,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC;YAClC,CAAC;QACH,CAAC;QAED,eAAe,CAAC,MAAM,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC,EAAE,GAAG,kCAAkC,CAAC,CAAC;QAEzF,IAAI,OAAO,CAAC,CAAC,KAAK,WAAW,CAAC,CAAC,EAAE,CAAC;YAChC,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC;YAE3G,OAAO;QACT,CAAC;QACD,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC;YACpD,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;YAEzG,OAAO;QACT,CAAC;QAED,sJAAsJ;QACtJ,MAAM,UAAU,GAAG,sCAAsC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAE9G,MAAM,OAAO,GAAG,sCAAsC,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,UAAU,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,iDAAiD;QAC1O,MAAM,YAAY,GAAG,SAAS,CAAC,WAAW,CAAC,CAAC;QAE5C,YAAY,CAAC,CAAC,GAAG,4BAA4B,CAAC,wBAAwB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QAC9G,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,yBAAyB,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;QAEhK,IAAI,gBAAgB,GAAc,EAAE,CAAC;QACrC,MAAM,YAAY,GAAG,sCAAsC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,YAAY,EAAE,gBAAgB,CAAC,CAAC;QAEtL,IAAI,UAAU,KAAK,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,EAAE,CAAC;YAChE,gBAAgB,GAAG,EAAE,CAAC;YACtB,YAAY,CAAC,OAAO,GAAG,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;QAClE,CAAC;QACD,IAAI,UAAU,KAAK,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,WAAW,CAAC,CAAC,EAAE,CAAC;YACtE,gBAAgB,GAAG,EAAE,CAAC;YACtB,YAAY,CAAC,OAAO,GAAG,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;QAClE,CAAC;QACD,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC;YACjE,MAAM,QAAQ,GAAG,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAEnI,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACtB,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;oBAC5C,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;gBACrB,CAAC;gBACD,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;oBAC1C,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;gBACnB,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,eAAe,CAAC,IAAI,CAAC,GAAG,gBAAgB,CAAC,CAAC;QAC1C,eAAe,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,EAAE,WAAW,EAAE,IAAI,EAAE,uBAAuB,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;QAE9J,OAAO;IACT,CAAC;CACF","sourcesContent":["import { cloneDeep } from \"@libs-ui/utils\";\nimport { IPoint, IPoints, IRect } from \"../draw-line.interface\";\nimport { MoCanvasCalculatorBranchUtil } from \"./calculator-branch.util\";\nimport { MoCanvasCalculatorDirectionElementUtil } from \"./calculator-diretion-element.until\";\n\nexport class MoCanvasConnectNavigationBottomLeftElementUtil {\n  static lineLeft(pointNext: IRect, pointStart: IRect, start: IPoint, lineCurve: number, obstacleRect: IRect[], separatedPoints: Array<IPoints>) {\n    const endPositionOrigin = {\n      x: pointNext.x,\n      y: pointNext.y\n    };\n    const endPosition = cloneDeep(endPositionOrigin);\n    const directionStartY = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(start.y, endPositionOrigin.y, 'y');\n\n    let newPosition = start;\n\n    if (directionStartY === 'above') {\n      const startQL = { lx: start.x - lineCurve, ly: (start.y ?? 0) + lineCurve };\n      const line = {\n        start: { x: (start.x ?? 0), y: start.y ?? 0 },\n        end: { x: startQL.lx ?? 0, y: startQL.ly ?? 0 }\n      };\n\n      newPosition = {\n        x: pointStart.x - (lineCurve + 10),\n        y: MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartY, line.end.y, lineCurve, true)\n      };\n\n      separatedPoints.push({ start: line.start, end: line.end, mode: 'vertical-single-curve', id: '1' }); // line vẽ đi khỏi khối đầu tiên\n      separatedPoints.push({ start: line.end, end: newPosition, mode: 'horizontal-single-curve', id: '1' }); // line vẽ đi khỏi khối đầu tiên\n    }\n\n    // kiểm tra hướng thẳng đến end, nếu có khối thì tránh\n    endPositionOrigin.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartY, endPositionOrigin.y, lineCurve);\n    const straightLine = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksYLeft(newPosition.x ?? 0, newPosition.y ?? 0, lineCurve, endPositionOrigin, directionStartY, obstacleRect, separatedPoints);\n    const directionStartX = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(straightLine.endPath.x, endPositionOrigin.x, 'x');\n\n    if (directionStartX === 'center' && directionStartY === 'under') {\n      return;\n    }\n\n    if (Math.abs((straightLine.endPath.x ?? 0) - endPositionOrigin.x) < lineCurve) {\n      const listLine = separatedPoints.filter(item => item.id === 'checkAndAvoidBlocksYLeft');\n      const elements = listLine.filter(item => item.start.x === straightLine.endPath.x || item.end.x === straightLine.endPath.x);\n\n      elements.forEach(item => {\n        if (item.start.x === straightLine.endPath.x) {\n          item.start.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartX, item.start.x, (lineCurve));\n        }\n        if (item.end.x === straightLine.endPath.x) {\n          item.end.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartX, item.end.x, (lineCurve));\n        }\n      });\n    }\n\n    // // kiểm tra ngay khi cua có vướng ai không rồi hẵng vẽ Q1\n    const elementBlockRoad = MoCanvasCalculatorDirectionElementUtil.checkLinePassBlockHorizontal(straightLine.endPath.x ?? 0, endPositionOrigin.x, straightLine.endPath.y ?? 0, 'x', obstacleRect) as IRect;\n    const directionNextX = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(straightLine.endPath.x ?? 0, endPositionOrigin.x, 'x');\n    const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: straightLine.endPath.x ?? 0, y: straightLine.endPath.y ?? 0 },\n      `${directionStartY}-${directionNextX}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng\n    const elementBlockRoadX = (elementBlockRoad?.x ?? 0) + (elementBlockRoad?.width ?? 0);\n\n    if (elementBlockRoad && Math.abs((elementBlockRoadX) - (straightLine.endPath.x ?? 0)) <= lineCurve * 2) {\n      coordQ1.x1 = straightLine.endPath.x ?? 0;\n      coordQ1.y1 = straightLine.endPath.y ?? 0;\n      coordQ1.x = straightLine.endPath.x ?? 0;\n      coordQ1.y = straightLine.endPath.y ?? 0;\n    }\n\n    // kiểm tra và vẽ hướng ngang\n    const directionXToEnd = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(coordQ1.x ?? 0, endPosition.x, 'x');\n    const pathHorizontal: IPoints[] = [];\n    const endPath = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPosition, obstacleRect, pathHorizontal);\n\n    if (directionXToEnd === 'left' && endPath.x > (coordQ1.x ?? 0)) {\n      separatedPoints.push({ start: straightLine.endPath, end: endPosition, mode: 'vertical', id: '6a ' + directionStartY });\n\n      return;\n    }\n    const end = { x: (coordQ1.x ?? 0), y: coordQ1.y ?? 0 };\n\n    separatedPoints.push(...pathHorizontal);\n    separatedPoints.push({ start: straightLine.endPath, end: end, mode: 'vertical-single-curve', id: '6a ' + directionStartY }); // góc cong từ đường thẳng sang ngang\n    if (endPath.x === endPosition.x && endPath.y < endPosition.y) {\n      const itemLast = pathHorizontal.find(item => item.end.x === endPath.x);\n\n      if (itemLast) {\n        itemLast.end.x = endPosition.x + 50;\n        endPath.x = itemLast.end.x;\n      }\n    }\n    separatedPoints.push({ start: endPath, end: { x: pointNext.x, y: pointNext.y }, mode: 'horizontal', id: 'lineEnd' });\n  }\n\n  static rightLeft(elementNext: IRect, start: IPoint, lineCurve: number, obstacleRect: IRect[], separatedPoints: Array<IPoints>) {\n    const endPosition = {\n      x: elementNext.x,\n      y: elementNext.y\n    };\n\n    // vẽ 1 đường thẳng từ điểm start ra ngoài đã\n    const end = { x: (start.x ?? 0) + 10, y: (start.y ?? 0) + 10 };\n\n    separatedPoints.push({ start: { x: (start.x ?? 0), y: start.y ?? 0 }, end: end, mode: 'vertical-single-curve', id: '1' });\n\n    const endPositionX = cloneDeep(endPosition);\n\n    endPositionX.x -= 50;\n\n    let separatedPointsCheckAndAvoidBlocks: Array<IPoints> = [];\n\n    let { endPath } = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocks(end.x ?? 0, (end.y ?? 0), lineCurve, endPositionX, obstacleRect, separatedPointsCheckAndAvoidBlocks);\n\n    if (Math.abs((start.x ?? 0) - endPosition.x) < 10 || end.x > endPath.x) {\n      endPath = {\n        x: end.x,\n        y: end.y\n      };\n\n      separatedPointsCheckAndAvoidBlocks = [];\n    }\n\n    if (Math.abs((endPath.y ?? 0) - endPosition.y) < 15) {\n      const element = separatedPointsCheckAndAvoidBlocks.find(item => (item.end.y === endPath.y && item.end.x === endPath.x));\n      const elementQR = separatedPointsCheckAndAvoidBlocks.find(item => (item.end.y === element?.start.y && item.end.x === element.start.x));\n\n      if (element) {\n        element.start.y = endPosition.y;\n        element.end.y = endPosition.y;\n      }\n      if (elementQR) {\n        elementQR.end.y = endPosition.y;\n      }\n    }\n\n    separatedPoints.splice(separatedPoints.length, 0, ...separatedPointsCheckAndAvoidBlocks);\n\n    if (endPath.y === endPosition.y) {\n      separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: endPosition, mode: 'horizontal' });\n\n      return;\n    }\n    if (Math.abs((endPath.y ?? 0) - endPosition.y) < 15) {\n      separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: endPosition, mode: 'vertical' });\n\n      return;\n    }\n\n    // // sau khi đã đi ngang và tránh các khối, tiếp theo là đi tiếp hướng lên xuống để về khối cần nối tới, cần check xem điểm end X nó đang ở hướng nào\n    const directionY = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(endPath.y, endPosition.y, 'y');\n\n    const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: endPath.x ?? 0, y: endPath.y ?? 0 }, `right-${directionY === 'above' ? 'above' : 'under'}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng\n    const endPositionY = cloneDeep(endPosition);\n\n    endPositionY.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionY, endPositionY.y, lineCurve);\n    separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: { x: coordQ1.x ?? 0, y: (coordQ1.y ?? 0) }, mode: 'horizontal-single-curve', id: 'g' });\n\n    let avoidBlocksYLine: IPoints[] = [];\n    const straightLine = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksY(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPositionY, directionY, obstacleRect, avoidBlocksYLine);\n\n    if (directionY === 'under' && (coordQ1.y ?? 0) > endPositionY.y) {\n      avoidBlocksYLine = [];\n      straightLine.endPath = { x: coordQ1.x ?? 0, y: coordQ1.y ?? 0 };\n    }\n    if (directionY === 'above' && straightLine.endPath.y <= endPosition.y) {\n      avoidBlocksYLine = [];\n      straightLine.endPath = { x: coordQ1.x ?? 0, y: coordQ1.y ?? 0 };\n    }\n    if (Math.abs((straightLine.endPath.x ?? 0) - endPosition.x) < 15) {\n      const elements = avoidBlocksYLine.filter(item => item.start.x === straightLine.endPath.x || item.end.x === straightLine.endPath.x);\n\n      elements.forEach(item => {\n        if (item.start.x === straightLine.endPath.x) {\n          item.start.x += 30;\n        }\n        if (item.end.x === straightLine.endPath.x) {\n          item.end.x += 30;\n        }\n      });\n    }\n\n    separatedPoints.push(...avoidBlocksYLine);\n    separatedPoints.push({ start: { x: straightLine.endPath.x ?? 0, y: straightLine.endPath.y ?? 0 }, end: endPosition, mode: 'vertical-single-curve', id: '4' });\n\n    return;\n  }\n}"]}
|
|
@@ -107,19 +107,21 @@ class MoCanvasCalculatorDirectionElementUtil {
|
|
|
107
107
|
x: Q1.x ?? 0,
|
|
108
108
|
y: (directionY === 'under' ? bottomElementBlockRoad : topElementBlockRoad)
|
|
109
109
|
};
|
|
110
|
-
if (
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
110
|
+
if (MoCanvasConnectNavigationNewElementUtil.START_MODE !== 'bottom-left') {
|
|
111
|
+
if ((directionY === 'under' && bottomElementBlockRoad - (Q1.y ?? 0) <= 0)
|
|
112
|
+
|| (directionY === 'above' && topElementBlockRoad - (Q1.y ?? 0) >= 0)) {
|
|
113
|
+
L1.y = Q1.y ?? 0;
|
|
114
|
+
}
|
|
115
|
+
if (Math.abs((L1.y ?? 0) - endY) <= 10) {
|
|
116
|
+
L1.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionX, L1.y, lineCurve);
|
|
117
|
+
}
|
|
116
118
|
}
|
|
117
119
|
const Q2 = this.drawLineQ({ x: L1.x, y: L1.y ?? 0 }, `${directionY === 'under' ? 'under' : 'above'}-${directionX}`, lineCurve, lineCurve);
|
|
118
120
|
const pathQ1 = `Q ${Q1.x1},${Q1.y1} ${Q1.x},${Q1.y} L ${L1.x} ${L1.y}`;
|
|
119
121
|
const pathQ2 = `Q ${Q2.x1},${Q2.y1} ${Q2.x},${Q2.y}`;
|
|
120
122
|
separatedPoints.push({ start: { x: coordLX ?? startX, y: startY }, end: { x: Q1.x ?? 0, y: Q1.y ?? 0 }, mode: 'horizontal-single-curve', id: key, name: 'qr' });
|
|
121
|
-
separatedPoints.push({ start: { x: Q1.x ?? 0, y: Q1.y ?? 0 }, end: { x: L1.x ?? 0, y: L1.y
|
|
122
|
-
separatedPoints.push({ start: { x: L1.x ?? 0, y: L1.y
|
|
123
|
+
separatedPoints.push({ start: { x: Q1.x ?? 0, y: Q1.y ?? 0 }, end: { x: L1.x ?? 0, y: L1.y }, mode: 'horizontal', id: key, name: 'lr' });
|
|
124
|
+
separatedPoints.push({ start: { x: L1.x ?? 0, y: L1.y }, end: { x: Q2.x ?? 0, y: Q2.y ?? 0 }, mode: 'vertical-single-curve', id: key, name: 'q2r' });
|
|
123
125
|
return {
|
|
124
126
|
pathByPassQ: `${pathQ1} ${pathQ2}`,
|
|
125
127
|
endPath: {
|
|
@@ -204,15 +206,12 @@ class MoCanvasCalculatorDirectionElementUtil {
|
|
|
204
206
|
return elementBlockRoad.reduce((a, b) => (Math.abs(((a.y ?? 0) - startY))) < (Math.abs(((b.y ?? 0) - startY))) ? a : b);
|
|
205
207
|
}
|
|
206
208
|
// kiểm tra hướng sang phải là tránh khối
|
|
207
|
-
static checkAndAvoidBlocksLeft(startX, startY, lineCurve, endPosition, obstacleRect, separatedPoints
|
|
209
|
+
static checkAndAvoidBlocksLeft(startX, startY, lineCurve, endPosition, obstacleRect, separatedPoints) {
|
|
208
210
|
const coordLX = { x: endPosition.x, y: startY };
|
|
209
211
|
const elementBlockRoad = this.checkLinePassBlockHorizontal(startX, endPosition.x, startY, 'x', obstacleRect);
|
|
210
212
|
if (!elementBlockRoad) {
|
|
211
213
|
separatedPoints.push({ start: { x: startX, y: startY }, end: coordLX, mode: 'horizontal', id: '14' });
|
|
212
|
-
return
|
|
213
|
-
path: pathPre ? `${pathPre} L ${coordLX.x} ${coordLX.y}` : `L ${coordLX.x} ${coordLX.y}`,
|
|
214
|
-
endPath: coordLX
|
|
215
|
-
};
|
|
214
|
+
return coordLX;
|
|
216
215
|
}
|
|
217
216
|
const directionX = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(startX, endPosition.x, 'x');
|
|
218
217
|
const specificXElement = directionX === 'right' ? (elementBlockRoad.x ?? 0) : ((elementBlockRoad.x ?? 0) + (elementBlockRoad.width ?? 0));
|
|
@@ -225,14 +224,17 @@ class MoCanvasCalculatorDirectionElementUtil {
|
|
|
225
224
|
coordLX.x = startX;
|
|
226
225
|
startXBypassElement = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionX, coordLX.x, lineCurve);
|
|
227
226
|
}
|
|
228
|
-
|
|
229
|
-
|
|
227
|
+
let lineByPassBlock = [];
|
|
228
|
+
let { endPath } = MoCanvasCalculatorDirectionElementUtil.byPassElementOnRightSide(startXBypassElement ?? 0, coordLX.y ?? 0, endPosition.y, lineCurve, elementBlockRoad, directionX, lineByPassBlock, undefined, coordLX.x);
|
|
229
|
+
if (MoCanvasConnectNavigationNewElementUtil.START_MODE === 'bottom-left' && elementBlockRoad.x + (elementBlockRoad.width) / 2 === endPosition.x && Math.abs(endPosition.y - elementBlockRoad.y) <= 20) { // check xem khối chắn có phải là khối đích hay không?
|
|
230
|
+
lineByPassBlock = [];
|
|
231
|
+
const data = MoCanvasCalculatorDirectionElementUtil.byPassElementOnRightSideNewMode(startXBypassElement ?? 0, coordLX.y ?? 0, endPosition.y, lineByPassBlock, undefined, coordLX.x);
|
|
232
|
+
endPath = data.endPath;
|
|
233
|
+
}
|
|
234
|
+
separatedPoints.push(...lineByPassBlock);
|
|
230
235
|
separatedPoints.push({ start: { x: startX, y: startY }, end: coordLX, mode: 'horizontal', id: '15' });
|
|
231
|
-
const
|
|
232
|
-
return
|
|
233
|
-
path: data.path,
|
|
234
|
-
endPath: data.endPath
|
|
235
|
-
};
|
|
236
|
+
const dataEndPath = this.checkAndAvoidBlocksLeft(endPath.x ?? 0, endPath.y ?? 0, lineCurve, endPosition, obstacleRect, separatedPoints);
|
|
237
|
+
return dataEndPath;
|
|
236
238
|
}
|
|
237
239
|
// kiểm tra hướng sang phải là tránh khối
|
|
238
240
|
static checkAndAvoidBlocks(startX, startY, lineCurve, endPosition, obstacleRect, separatedPoints, pathPre) {
|
|
@@ -247,7 +249,7 @@ class MoCanvasCalculatorDirectionElementUtil {
|
|
|
247
249
|
}
|
|
248
250
|
coordLX.x = toX;
|
|
249
251
|
}
|
|
250
|
-
separatedPoints.push({ start: { x: startX, y: startY }, end: coordLX, mode: 'horizontal', id: 'checkAndAvoidBlocks', name: '
|
|
252
|
+
separatedPoints.push({ start: { x: startX, y: startY }, end: coordLX, mode: 'horizontal', id: 'checkAndAvoidBlocks', name: 'end' });
|
|
251
253
|
return {
|
|
252
254
|
path: pathPre ? `${pathPre} L ${coordLX.x} ${coordLX.y}` : `L ${coordLX.x} ${coordLX.y}`,
|
|
253
255
|
endPath: coordLX
|
|
@@ -325,7 +327,7 @@ class MoCanvasCalculatorDirectionElementUtil {
|
|
|
325
327
|
const bottomElementBlockRoad = (elementBlockRoadStraightLineX.y ?? 0) + (elementBlockRoadStraightLineX.height ?? 0);
|
|
326
328
|
let toY = (directionY === 'under' ? topElementBlockRoad : bottomElementBlockRoad);
|
|
327
329
|
toY = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionY, toY, lineCurve * 2);
|
|
328
|
-
if (toY > startY) {
|
|
330
|
+
if (toY > startY && MoCanvasConnectNavigationNewElementUtil.START_MODE !== 'bottom-left') {
|
|
329
331
|
coordLX.y = toY;
|
|
330
332
|
}
|
|
331
333
|
}
|
|
@@ -364,6 +366,15 @@ class MoCanvasCalculatorDirectionElementUtil {
|
|
|
364
366
|
endPath: data.endPath
|
|
365
367
|
};
|
|
366
368
|
}
|
|
369
|
+
static byPassElementOnRightSideNewMode(startX, startY, endY, separatedPoints, key, coordLX) {
|
|
370
|
+
const start = { x: coordLX ?? startX, y: startY };
|
|
371
|
+
const end = { x: (start.x ?? 0) - 20, y: endY };
|
|
372
|
+
separatedPoints.push({ start: start, end: end, mode: 'horizontal', id: key, name: 'q2r' });
|
|
373
|
+
return {
|
|
374
|
+
pathByPassQ: ``,
|
|
375
|
+
endPath: end
|
|
376
|
+
};
|
|
377
|
+
}
|
|
367
378
|
}
|
|
368
379
|
|
|
369
380
|
class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
@@ -399,7 +410,6 @@ class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
|
399
410
|
const listLine = separatedPoints.filter(item => item.id === 'checkAndAvoidBlocksYLeft');
|
|
400
411
|
const elements = listLine.filter(item => item.start.x === straightLine.endPath.x || item.end.x === straightLine.endPath.x);
|
|
401
412
|
elements.forEach(item => {
|
|
402
|
-
console.log('directionStartX', directionStartX);
|
|
403
413
|
if (item.start.x === straightLine.endPath.x) {
|
|
404
414
|
item.start.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartX, item.start.x, (lineCurve));
|
|
405
415
|
}
|
|
@@ -409,34 +419,31 @@ class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
|
409
419
|
});
|
|
410
420
|
}
|
|
411
421
|
// // kiểm tra ngay khi cua có vướng ai không rồi hẵng vẽ Q1
|
|
412
|
-
const elementBlockRoad = MoCanvasCalculatorDirectionElementUtil.checkLinePassBlockHorizontal(straightLine.endPath.x ?? 0,
|
|
422
|
+
const elementBlockRoad = MoCanvasCalculatorDirectionElementUtil.checkLinePassBlockHorizontal(straightLine.endPath.x ?? 0, endPositionOrigin.x, straightLine.endPath.y ?? 0, 'x', obstacleRect);
|
|
413
423
|
const directionNextX = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(straightLine.endPath.x ?? 0, endPositionOrigin.x, 'x');
|
|
414
424
|
const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: straightLine.endPath.x ?? 0, y: straightLine.endPath.y ?? 0 }, `${directionStartY}-${directionNextX}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
415
|
-
|
|
425
|
+
const elementBlockRoadX = (elementBlockRoad?.x ?? 0) + (elementBlockRoad?.width ?? 0);
|
|
426
|
+
if (elementBlockRoad && Math.abs((elementBlockRoadX) - (straightLine.endPath.x ?? 0)) <= lineCurve * 2) {
|
|
416
427
|
coordQ1.x1 = straightLine.endPath.x ?? 0;
|
|
417
428
|
coordQ1.y1 = straightLine.endPath.y ?? 0;
|
|
418
429
|
coordQ1.x = straightLine.endPath.x ?? 0;
|
|
419
430
|
coordQ1.y = straightLine.endPath.y ?? 0;
|
|
420
431
|
}
|
|
421
432
|
// kiểm tra và vẽ hướng ngang
|
|
422
|
-
const directionXToEnd = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(coordQ1.x ?? 0,
|
|
423
|
-
endPosition.x = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionXToEnd, endPosition.x, lineCurve);
|
|
424
|
-
if (Math.abs((coordQ1.y ?? 0) - endPosition.y) <= lineCurve) {
|
|
425
|
-
endPosition.y -= lineCurve;
|
|
426
|
-
}
|
|
433
|
+
const directionXToEnd = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(coordQ1.x ?? 0, endPosition.x, 'x');
|
|
427
434
|
const pathHorizontal = [];
|
|
428
|
-
const
|
|
435
|
+
const endPath = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPosition, obstacleRect, pathHorizontal);
|
|
429
436
|
if (directionXToEnd === 'left' && endPath.x > (coordQ1.x ?? 0)) {
|
|
430
|
-
separatedPoints.push({ start: straightLine.endPath, end:
|
|
437
|
+
separatedPoints.push({ start: straightLine.endPath, end: endPosition, mode: 'vertical', id: '6a ' + directionStartY });
|
|
431
438
|
return;
|
|
432
439
|
}
|
|
433
440
|
const end = { x: (coordQ1.x ?? 0), y: coordQ1.y ?? 0 };
|
|
434
|
-
separatedPoints.push({ start: straightLine.endPath, end: end, mode: 'vertical-single-curve', id: '6a ' + directionStartY }); // góc cong từ đường thẳng sang ngang
|
|
435
441
|
separatedPoints.push(...pathHorizontal);
|
|
436
|
-
|
|
442
|
+
separatedPoints.push({ start: straightLine.endPath, end: end, mode: 'vertical-single-curve', id: '6a ' + directionStartY }); // góc cong từ đường thẳng sang ngang
|
|
443
|
+
if (endPath.x === endPosition.x && endPath.y < endPosition.y) {
|
|
437
444
|
const itemLast = pathHorizontal.find(item => item.end.x === endPath.x);
|
|
438
445
|
if (itemLast) {
|
|
439
|
-
itemLast.end.x =
|
|
446
|
+
itemLast.end.x = endPosition.x + 50;
|
|
440
447
|
endPath.x = itemLast.end.x;
|
|
441
448
|
}
|
|
442
449
|
}
|
|
@@ -462,34 +469,30 @@ class MoCanvasConnectNavigationBottomLeftElementUtil {
|
|
|
462
469
|
separatedPointsCheckAndAvoidBlocks = [];
|
|
463
470
|
}
|
|
464
471
|
if (Math.abs((endPath.y ?? 0) - endPosition.y) < 15) {
|
|
465
|
-
const
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
}
|
|
472
|
+
const element = separatedPointsCheckAndAvoidBlocks.find(item => (item.end.y === endPath.y && item.end.x === endPath.x));
|
|
473
|
+
const elementQR = separatedPointsCheckAndAvoidBlocks.find(item => (item.end.y === element?.start.y && item.end.x === element.start.x));
|
|
474
|
+
if (element) {
|
|
475
|
+
element.start.y = endPosition.y;
|
|
476
|
+
element.end.y = endPosition.y;
|
|
477
|
+
}
|
|
478
|
+
if (elementQR) {
|
|
479
|
+
elementQR.end.y = endPosition.y;
|
|
480
|
+
}
|
|
474
481
|
}
|
|
475
482
|
separatedPoints.splice(separatedPoints.length, 0, ...separatedPointsCheckAndAvoidBlocks);
|
|
476
483
|
if (endPath.y === endPosition.y) {
|
|
477
484
|
separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: endPosition, mode: 'horizontal' });
|
|
478
485
|
return;
|
|
479
486
|
}
|
|
487
|
+
if (Math.abs((endPath.y ?? 0) - endPosition.y) < 15) {
|
|
488
|
+
separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: endPosition, mode: 'vertical' });
|
|
489
|
+
return;
|
|
490
|
+
}
|
|
480
491
|
// // sau khi đã đi ngang và tránh các khối, tiếp theo là đi tiếp hướng lên xuống để về khối cần nối tới, cần check xem điểm end X nó đang ở hướng nào
|
|
481
492
|
const directionY = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(endPath.y, endPosition.y, 'y');
|
|
482
493
|
const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: endPath.x ?? 0, y: endPath.y ?? 0 }, `right-${directionY === 'above' ? 'above' : 'under'}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
483
494
|
const endPositionY = cloneDeep(endPosition);
|
|
484
495
|
endPositionY.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionY, endPositionY.y, lineCurve);
|
|
485
|
-
// // cần check khi đi thẳng lên có vướng khối nào không để tiến lên, nhưng cần phải xem x của nó có quá gần endX không, gần quá thì
|
|
486
|
-
const elementBlockRoadStraightLineY = MoCanvasCalculatorDirectionElementUtil.checkBlocksElementStraightY((endPath.x ?? 0) + 10, endPath.y ?? 0, endPositionY, obstacleRect);
|
|
487
|
-
if (elementBlockRoadStraightLineY) {
|
|
488
|
-
coordQ1.x = (elementBlockRoadStraightLineY.x ?? 0) + (elementBlockRoadStraightLineY.width ?? 0) + lineCurve;
|
|
489
|
-
}
|
|
490
|
-
if (Math.abs((coordQ1.x ?? 0) - endPosition.x) < 20 && directionY === 'under') {
|
|
491
|
-
coordQ1.x = endPosition.x + 20; // trường hợp right quay xuống dưới điểm end khá gần điểm start => không đủ khoảng cách quay mũi tên vào
|
|
492
|
-
}
|
|
493
496
|
separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y }, end: { x: coordQ1.x ?? 0, y: (coordQ1.y ?? 0) }, mode: 'horizontal-single-curve', id: 'g' });
|
|
494
497
|
let avoidBlocksYLine = [];
|
|
495
498
|
const straightLine = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksY(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPositionY, directionY, obstacleRect, avoidBlocksYLine);
|
|
@@ -629,21 +632,18 @@ class MoCanvasConnectNavigationNewElementUtil {
|
|
|
629
632
|
endPosition.y = MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartY, endY, (lineCurve * 2));
|
|
630
633
|
const pathQ = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: (start.x ?? 0) + 10, y: start.y ?? 0 }, `right-${directionStartY === 'under' ? 'under' : 'above'}`, lineCurve, lineCurve);
|
|
631
634
|
const startQL = { lx: pathQ.x, ly: MoCanvasCalculatorBranchUtil.mathOperatorsCalculation(directionStartY, (pathQ.y ?? 0), ((elementFrom.height ?? 0) / 2), true) };
|
|
632
|
-
const dPathStart = `Q ${pathQ.x1} ${pathQ.y1} ${pathQ.x} ${pathQ.y} L ${startQL.lx} ${startQL.ly}`;
|
|
633
635
|
separatedPoints.push({ start: { x: (start.x ?? 0), y: start.y ?? 0 }, end: { x: pathQ.x ?? 0, y: pathQ.y ?? 0 }, mode: 'horizontal-single-curve', id: '1' });
|
|
634
636
|
separatedPoints.push({ start: { x: pathQ.x ?? 0, y: pathQ.y ?? 0 }, end: { x: startQL.lx ?? 0, y: startQL.ly }, mode: 'horizontal', id: '2' });
|
|
635
637
|
if (directionStartY === 'center') {
|
|
636
638
|
const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: startQL.lx ?? 0, y: startQL.ly ?? 0 }, `above-left`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
637
|
-
const pathQ1 = `Q ${coordQ1.x1},${coordQ1.y1} ${coordQ1.x},${coordQ1.y}`; // từ ngang sang thẳng phải có đường cong
|
|
638
639
|
separatedPoints.push({ start: { x: startQL.lx ?? 0, y: startQL.ly }, end: { x: coordQ1.x ?? 0, y: coordQ1.y ?? 0 }, mode: 'vertical-single-curve', id: '3' });
|
|
639
|
-
const
|
|
640
|
+
const endPath = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPosition, obstacleRect, separatedPoints);
|
|
640
641
|
const directionStartY2 = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(endPath.y, endPositionOrigin.y, 'y');
|
|
641
642
|
const coordQ2 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: endPath.x ?? 0, y: endPath.y ?? 0 }, `left-${directionStartY2 === 'above' ? 'above' : 'under'}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
642
|
-
const pathQ2 = `Q ${coordQ2.x1},${coordQ2.y1} ${coordQ2.x},${coordQ2.y}`; // từ ngang sang thẳng phải có đường cong
|
|
643
643
|
separatedPoints.push({ start: { x: endPath.x ?? 0, y: endPath.y ?? 0 }, end: { x: coordQ2.x ?? 0, y: coordQ2.y ?? 0 }, mode: 'horizontal-single-curve', id: '4' });
|
|
644
|
-
|
|
644
|
+
this.closeLine({ x: coordQ2.x ?? 0, y: coordQ2.y ?? 0 }, endPositionOrigin, lineCurve, elementNext, separatedPoints);
|
|
645
645
|
return {
|
|
646
|
-
dPath:
|
|
646
|
+
dPath: ``,
|
|
647
647
|
};
|
|
648
648
|
}
|
|
649
649
|
const straightLine = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksYLeft(startQL.lx ?? 0, startQL.ly ?? 0, lineCurve, endPosition, directionStartY, obstacleRect, separatedPoints);
|
|
@@ -684,7 +684,7 @@ class MoCanvasConnectNavigationNewElementUtil {
|
|
|
684
684
|
coordQ1.y = straightLine.endPath.y ?? 0;
|
|
685
685
|
}
|
|
686
686
|
separatedPoints.push({ start: straightLine.endPath, end: { x: coordQ1.x ?? 0, y: coordQ1.y ?? 0 }, mode: 'vertical-single-curve', id: '6a ' + directionStartY });
|
|
687
|
-
const
|
|
687
|
+
const endPath = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPosition, obstacleRect, separatedPoints);
|
|
688
688
|
const directionStartY2 = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(endPath.y, endPositionOrigin.y, 'y');
|
|
689
689
|
const directionNextY = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(coordQ1.x ?? 0, endPath.x, 'x');
|
|
690
690
|
const coordQ2 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: endPath.x ?? 0, y: endPath.y ?? 0 }, `${directionNextY}-${directionStartY2 === 'above' ? 'above' : 'under'}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
@@ -749,7 +749,7 @@ class MoCanvasConnectNavigationNewElementUtil {
|
|
|
749
749
|
const coordQ1 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: startQL.lx ?? 0, y: startQL.ly ?? 0 }, `above-left`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
750
750
|
// từ ngang sang thẳng phải có đường cong
|
|
751
751
|
separatedPoints.push({ start: { x: startQL.lx ?? 0, y: startQL.ly }, end: { x: coordQ1.x ?? 0, y: coordQ1.y ?? 0 }, mode: 'vertical-single-curve', id: '3' });
|
|
752
|
-
const
|
|
752
|
+
const endPath = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPosition, obstacleRect, separatedPoints);
|
|
753
753
|
const directionStartY2 = MoCanvasCalculatorDirectionElementUtil.checkUpDownLeftRight(endPath.y, endPositionOrigin.y, 'y');
|
|
754
754
|
const coordQ2 = MoCanvasCalculatorDirectionElementUtil.drawLineQ({ x: endPath.x ?? 0, y: endPath.y ?? 0 }, `left-${directionStartY2 === 'above' ? 'above' : 'under'}`, lineCurve, lineCurve); // tính đoạn cong từ đường ngang sang đường thẳng
|
|
755
755
|
// từ ngang sang thẳng phải có đường cong
|
|
@@ -803,7 +803,7 @@ class MoCanvasConnectNavigationNewElementUtil {
|
|
|
803
803
|
endPosition.y -= lineCurve;
|
|
804
804
|
}
|
|
805
805
|
const pathHorizontal = [];
|
|
806
|
-
const
|
|
806
|
+
const endPath = MoCanvasCalculatorDirectionElementUtil.checkAndAvoidBlocksLeft(coordQ1.x ?? 0, coordQ1.y ?? 0, lineCurve, endPosition, obstacleRect, pathHorizontal);
|
|
807
807
|
if (directionXToEnd === 'left' && endPath.x > (coordQ1.x ?? 0)) {
|
|
808
808
|
separatedPoints.push({ start: straightLine.endPath, end: endPositionOrigin, mode: 'vertical', id: '6a ' + directionStartY });
|
|
809
809
|
this.closeLineWithLineTopBottom(endPositionOrigin, endPositionOrigin, lineCurve, elementNext, separatedPoints);
|
|
@@ -1066,9 +1066,29 @@ class LibsUiComponentsDrawLineDirective {
|
|
|
1066
1066
|
this.buildPathAndDraw(data, points, mode);
|
|
1067
1067
|
return;
|
|
1068
1068
|
}
|
|
1069
|
+
let path = '';
|
|
1069
1070
|
points.separatedPoints.forEach(separatedPoints => {
|
|
1070
|
-
this.
|
|
1071
|
+
path += this.buildPathAndDrawSeparatedPoints(data, separatedPoints, separatedPoints.mode || mode);
|
|
1071
1072
|
});
|
|
1073
|
+
const pathElement = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
|
1074
|
+
this.svgElement.append(pathElement);
|
|
1075
|
+
points.pathElement = pathElement;
|
|
1076
|
+
const styleConfig = {
|
|
1077
|
+
stroke: data.lineStyle?.stroke ?? '#9CA2AD',
|
|
1078
|
+
strokeDasharray: data.lineStyle?.strokeDasharray,
|
|
1079
|
+
strokeWidth: data.lineStyle?.strokeWidth ?? '1px',
|
|
1080
|
+
fill: data.lineStyle?.fill ?? 'none',
|
|
1081
|
+
curve: data.lineStyle?.curve ?? 10,
|
|
1082
|
+
distancePoint: data.lineStyle?.distancePoint ?? 10
|
|
1083
|
+
};
|
|
1084
|
+
points.pathElement?.setAttribute('stroke', styleConfig.stroke);
|
|
1085
|
+
points.pathElement?.setAttribute('fill', styleConfig.fill);
|
|
1086
|
+
points.pathElement?.setAttribute('stroke-width', styleConfig.strokeWidth);
|
|
1087
|
+
if (styleConfig.strokeDasharray) {
|
|
1088
|
+
points.pathElement?.setAttribute('stroke-dasharray', styleConfig.strokeDasharray);
|
|
1089
|
+
}
|
|
1090
|
+
points.pathElement?.setAttribute('d', path);
|
|
1091
|
+
this.drawRectAndInitEvent(data, mode);
|
|
1072
1092
|
});
|
|
1073
1093
|
}
|
|
1074
1094
|
updateViewBox(viewBoxConfig) {
|
|
@@ -1118,9 +1138,6 @@ class LibsUiComponentsDrawLineDirective {
|
|
|
1118
1138
|
MoCanvasConnectNavigationNewElementUtil.ELEMENT_MARGIN_BETWEEN_BRANCH_DEFAULT = this.viewBoxConfig?.marginBetweenElement ?? 32;
|
|
1119
1139
|
}
|
|
1120
1140
|
MoCanvasConnectNavigationNewElementUtil.setXYConnectElements(elementStart ?? { ...points.start, width: 1, height: 1 }, elementEnd ?? { ...points.end, width: 1, height: 1 }, obstacleRects, separatedPoints, curve);
|
|
1121
|
-
separatedPoints?.forEach(item => {
|
|
1122
|
-
item.pathElement = this.createPathAndArrowElement(name).pathElement;
|
|
1123
|
-
});
|
|
1124
1141
|
}
|
|
1125
1142
|
buildPathAndDraw(data, points, mode) {
|
|
1126
1143
|
let dPath = {};
|
|
@@ -1283,7 +1300,7 @@ class LibsUiComponentsDrawLineDirective {
|
|
|
1283
1300
|
};
|
|
1284
1301
|
const pointEnd = cloneDeep(points.end);
|
|
1285
1302
|
const arrowElement = points.arrowElement;
|
|
1286
|
-
const direction = data.arrowDirection || this.getDirection(points,
|
|
1303
|
+
const direction = data.arrowDirection || this.getDirection(points, data.startEndMode);
|
|
1287
1304
|
switch (direction) {
|
|
1288
1305
|
case 'right':
|
|
1289
1306
|
if (mode.includes('horizontal') || mode.includes('vertical')) {
|
|
@@ -1324,7 +1341,7 @@ class LibsUiComponentsDrawLineDirective {
|
|
|
1324
1341
|
circleElement.setAttribute('stroke-width', `${circleStyle?.strokeWidth ?? '1px'}`);
|
|
1325
1342
|
return circleElement;
|
|
1326
1343
|
}
|
|
1327
|
-
getDirection(points,
|
|
1344
|
+
getDirection(points, startEndMode) {
|
|
1328
1345
|
let pointStart = { ...points.start };
|
|
1329
1346
|
if (points.separatedPoints) {
|
|
1330
1347
|
const lineToEnd = points.separatedPoints.find(item => item.end.x === points.end.x && item.end.y === points.end.y);
|
|
@@ -1334,10 +1351,20 @@ class LibsUiComponentsDrawLineDirective {
|
|
|
1334
1351
|
}
|
|
1335
1352
|
const modeHorizontal = pointStart.x < points.end.x ? 'right' : 'left';
|
|
1336
1353
|
const modeVertical = pointStart.y < points.end.y ? 'bottom' : 'top';
|
|
1337
|
-
if (
|
|
1338
|
-
|
|
1354
|
+
if (!startEndMode) {
|
|
1355
|
+
if (Math.abs(points.end.x - pointStart.x) > Math.abs(points.end.y - pointStart.y)) {
|
|
1356
|
+
return modeHorizontal;
|
|
1357
|
+
}
|
|
1358
|
+
return modeVertical;
|
|
1359
|
+
}
|
|
1360
|
+
switch (startEndMode) {
|
|
1361
|
+
case 'bottom-left':
|
|
1362
|
+
return modeHorizontal;
|
|
1363
|
+
case 'right-left':
|
|
1364
|
+
return modeHorizontal;
|
|
1365
|
+
case 'bottom-top':
|
|
1366
|
+
return modeVertical;
|
|
1339
1367
|
}
|
|
1340
|
-
return modeVertical;
|
|
1341
1368
|
}
|
|
1342
1369
|
initEvent(data) {
|
|
1343
1370
|
const points = data.points;
|
|
@@ -1459,6 +1486,33 @@ class LibsUiComponentsDrawLineDirective {
|
|
|
1459
1486
|
Array.from(this.svgElement.getElementsByTagName('rect'))?.forEach(item => item.remove());
|
|
1460
1487
|
Array.from(this.svgElement.getElementsByTagName('text'))?.forEach(item => item.remove());
|
|
1461
1488
|
}
|
|
1489
|
+
buildPathAndDrawSeparatedPoints(data, points, mode) {
|
|
1490
|
+
let dPath = {};
|
|
1491
|
+
const styleConfig = {
|
|
1492
|
+
curve: data.lineStyle?.curve ?? 10,
|
|
1493
|
+
distancePoint: data.lineStyle?.distancePoint ?? 10
|
|
1494
|
+
};
|
|
1495
|
+
let { curve, distancePoint } = styleConfig;
|
|
1496
|
+
mode = mode || "quart-in";
|
|
1497
|
+
if (mode !== 'quart-in') {
|
|
1498
|
+
curve = curve ?? 10;
|
|
1499
|
+
distancePoint = distancePoint ?? 10;
|
|
1500
|
+
}
|
|
1501
|
+
if (mode === 'quart-in' || points.start.x === points.end.x || points.start.y === points.end.y) {
|
|
1502
|
+
this.drawBalancedCurve(dPath, points);
|
|
1503
|
+
if (mode === 'quart-in') {
|
|
1504
|
+
dPath = {};
|
|
1505
|
+
this.drawBendBothEndsCurve(dPath, points);
|
|
1506
|
+
}
|
|
1507
|
+
return this.builDAttributeToString(dPath);
|
|
1508
|
+
}
|
|
1509
|
+
const result = this.calculatorDistancePointAndCurve(points, distancePoint, curve, mode);
|
|
1510
|
+
distancePoint = result.distancePoint;
|
|
1511
|
+
curve = result.curve;
|
|
1512
|
+
this.buildDAttributeByPointEndModeHorizontal(dPath, points, distancePoint || 0, curve || 0, mode);
|
|
1513
|
+
this.buildDAttributeByPointEndModeVertical(dPath, points, distancePoint || 0, curve || 0, mode);
|
|
1514
|
+
return this.builDAttributeToString(dPath);
|
|
1515
|
+
}
|
|
1462
1516
|
ngOnDestroy() {
|
|
1463
1517
|
this.onDestroy.next();
|
|
1464
1518
|
this.onDestroy.complete();
|