From 686e9cb12978d559130f816e5c2d2854a13c2f48 Mon Sep 17 00:00:00 2001
From: wente <329538422@qq.com>
Date: 星期三, 22 五月 2024 08:43:31 +0800
Subject: [PATCH] svgEditor

---
 web/src/views/modules/taskReliability/RBD-edit-img.vue |  150 +++++++++++++++++++++++++++++++++++--------------
 1 files changed, 106 insertions(+), 44 deletions(-)

diff --git a/web/src/views/modules/taskReliability/RBD-edit-img.vue b/web/src/views/modules/taskReliability/RBD-edit-img.vue
index 8566355..07ec2d5 100644
--- a/web/src/views/modules/taskReliability/RBD-edit-img.vue
+++ b/web/src/views/modules/taskReliability/RBD-edit-img.vue
@@ -348,11 +348,7 @@
         if (res.data !== null && (res.data.content != null)) {
           this.dataForm = res.data
           this.diagramJson = JSON.parse(this.dataForm.content)
-          if (this.diagramJson.cells.length !== 0) {
             this.graph.fromJSON(this.diagramJson)
-          } else {
-            this.graph.fromJSON(RBDDefault)
-          }
           this.isFirstLoad = false;
           console.log(this.diagramJson.cells.length, 'this.diagramJson.cells.length')
 
@@ -360,13 +356,16 @@
           // this.graph.centerContent()
           // this.graph.zoomToFit()
         } else {
-          await this.clearDiagram()
+          this.graph.fromJSON(RBDDefault)
+          this.isFirstLoad = false
         }
       },
       async clearDiagram() {
         this.dataForm.id = null
         // this.graph.fromJSON(this.emptyJson)
-        this.graph.fromJSON('')
+        this.graph.fromJSON(RBDDefault)
+        this.graph.positionContent('left')
+        this.isFirstLoad = false;
         // this.graph.centerContent()
         // this.graph.zoomToFit()
         // this.graph.freeze()
@@ -586,10 +585,12 @@
         let res = await this.$http.get(`/basicInfo/XhProductModel/getProduct`, {params: params})
         this.imagesList2 = res.data
         console.log(this.imagesList2, 'getProduct(productId)234567890')
+        let urlObject = window.URL || window.webkitURL || window;
+
         const imageNodes2 = this.imagesList2.map((item) =>
           this.graph.createNode({
             shape: 'image',
-            imageUrl: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getProductImg?token=${Cookies.get('token')}&id=${item.imgPath}`,
+            //imageUrl: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getProductImg?token=${Cookies.get('token')}&id=${item.imgPath}`,
             width: 60,
             height: 60,
             id: item.dataId, // 鎵嬪姩璁剧疆鑺傜偣鐨� ID
@@ -612,6 +613,10 @@
               voteNum: '',
             },
             attrs: {
+              image: {
+                'xlink:href': `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getSvgImage?token=${Cookies.get('token')}&id=${item.imgPath}`,
+                //'xlink:href': urlObject.createObjectURL(new Blob([item.svgContent])),
+              },
               text: {
                 text: item.imgName,
                 fontSize: 14,
@@ -689,7 +694,22 @@
           if (cells.length === 1) {
             let node = cells[0]
             if (!node.isNode()) {
-              this.$message({message: '璇烽�変腑鑺傜偣', type: 'warning'})
+              this.$confirm('鏄惁鍒犻櫎璇ヨ繛鎺ョ嚎鐐�?', '鎻愮ず', {
+                confirmButtonText: '纭畾',
+                cancelButtonText: '鍙栨秷',
+                type: 'warning'
+              }).then(() => {
+                this.$message({
+                  type: 'success',
+                  message: '鍒犻櫎鎴愬姛!'
+                })
+              }).catch(() => {
+                this.$message({
+                  type: 'info',
+                  message: '宸插彇娑堝垹闄�'
+                })
+              })
+              // this.$message({message: '璇烽�変腑鑺傜偣', type: 'warning'})
               return false; // 鍙栨秷鎿嶄綔
             }
             let nodeType = node.getData().nodeType
@@ -720,17 +740,17 @@
                 let outNode = isSeriesNode.outNode
                 console.log(inLine, outLine, 'inLine,outLine')
                 console.log(inNode, outNode, 'inNode,outNode')
-                if (inLineIsToLine) {
-                  inLine[0].target = {cell: outNode.id, port: 'left1'}
-                } else {
-                  outLine[0].source = {cell: inNode.id, port: 'right1'}
-                }
                 //鎻愮ず鏄惁瑕佸垹闄�
                 this.$confirm('鏄惁鍒犻櫎璇ヨ妭鐐�?', '鎻愮ず', {
                   confirmButtonText: '纭畾',
                   cancelButtonText: '鍙栨秷',
                   type: 'warning'
                 }).then(() => {
+                  if (inLineIsToLine) {
+                    inLine[0].target = {cell: outNode.id, port: 'left1'}
+                  } else {
+                    outLine[0].source = {cell: inNode.id, port: 'right1'}
+                  }
                   if (deleteType === 1){
                     node.remove()
                   }
@@ -746,15 +766,37 @@
                     type: 'info',
                     message: '宸插彇娑堝垹闄�'
                   })
+                  return false
                 })
               }
               if (this.isMultipleBrach(node)) {
                 //鎻愮ず鏄惁瑕佸垹闄�
-                if (deleteType === 1)
-                  node.remove()
-                else
-                  this.deleteCombination(node)
-                return
+                this.$confirm('鏄惁鍒犻櫎璇ヨ妭鐐�?', '鎻愮ず', {
+                  confirmButtonText: '纭畾',
+                  cancelButtonText: '鍙栨秷',
+                  type: 'warning'
+                }).then(() => {
+                  if (inLineIsToLine) {
+                    inLine[0].target = {cell: outNode.id, port: 'left1'}
+                  } else {
+                    outLine[0].source = {cell: inNode.id, port: 'right1'}
+                  }
+                  if (deleteType === 1)
+                    node.remove()
+                  else
+                    this.deleteCombination(node)
+                  this.$message({
+                    type: 'success',
+                    message: '鍒犻櫎鎴愬姛!'
+                  })
+
+                }).catch(() => {
+                  this.$message({
+                    type: 'info',
+                    message: '宸插彇娑堝垹闄�'
+                  })
+                  return false
+                })
               }
             }
             //鎻愮ず涓嶈兘鍒犻櫎
@@ -1119,12 +1161,14 @@
         let dragNodeType = dragNode.getData().nodeType
         let offHeight = 50
         if (dragNodeType === 'node') {
-          offHeight = 50
+          offHeight = 60
         } else if (dragNodeType === 'bridgeConnection') {
-          offHeight = 230
+          offHeight = 175
         } else {
           offHeight = 70
         }
+        let centerX = 0,  centerY = 0;
+
         if (graphNodeType === 'dashedBox') { //铏氭
           const edges = this.graph.getConnectedEdges(graphNode); // 鑾峰彇鐢诲竷涓婂師鏈夌殑鑺傜偣鎵�鏈夎繘鏉ョ殑绾�
           let inEdges = edges.filter(edge => edge.target.cell === graphNode.id)
@@ -1140,10 +1184,12 @@
             endNode = this.graph.getCellById(endNodeId)
           }
           if (startNode && endNode) {
-            let centerY = graphNode.position().y
-            let result = this.addNodeAndConnect(graphNode, dragNode, dragNode.position().x, centerY)
+            centerX = graphNode.position().x+graphNode.getBBox().width/2
+            centerY = graphNode.position().y+graphNode.getBBox().height/2
+            let result = this.addNodeAndConnect(graphNode, dragNode, centerX, centerY)
             if (!result){
               dragNode.remove()
+              this.$message({message: '娌℃湁瓒冲鐨勭┖闂存斁缃鑺傜偣锛岃鎵╁ぇ鍓╀綑绌洪棿', type: 'warning'})
               return
             }
             inEdges[0].target = {cell: result.newStartNode.id, port: 'left1'}
@@ -1158,22 +1204,24 @@
           let maxY = graphNode.position().y + graphNode.getBBox().height
 
           const edges = this.graph.getConnectedEdges(graphNode); // 鑾峰彇鐢诲竷涓婂師鏈夌殑鑺傜偣鎵�鏈夎繘鏉ョ殑绾�
+          // 鑾峰彇杩炴帴绾跨殑璺緞鏁版嵁
           let inEdges = edges.filter(edge => edge.target.cell === graphNode.id)
           //閬嶅巻杩欎釜缁勫悎閲岄潰鎵�鏈夎妭鐐癸紝 淇敼minY锛宮axY
-
           let pointXY = {minY: minY, maxY: maxY}
           console.log(pointXY, 'old')
           this.getYRange(inEdges, graphNodeStartNode, pointXY)
           console.log(pointXY, 'new')
 
-          let minX = graphNodeStartNode.position().x + graphNodeStartNode.getBBox().width
+          let minX = graphNodeStartNode.position().x + graphNode.getBBox().width+15
           let maxX = graphNode.position().x
           let centerX = minX + (maxX - minX) / 2
-          let centerY = graphNodeY - pointXY.minY > pointXY.maxY - graphNodeY ? pointXY.maxY + 30 : pointXY.minY - offHeight - 30
+          let centerY = graphNodeY+ graphNode.getBBox().height/2 - pointXY.minY > pointXY.maxY - (graphNodeY+ graphNode.getBBox().height/2) ?
+            pointXY.maxY + offHeight/2 + 30 : pointXY.minY - offHeight/2 - 30
 
           let result = this.addNodeAndConnect(null, dragNode, minX, centerY)
           if (!result){
             dragNode.remove()
+            this.$message({message: '娌℃湁瓒冲鐨勭┖闂存斁缃鑺傜偣锛岃鎵╁ぇ鍓╀綑绌洪棿', type: 'warning'})
             return
           }
           this.graph.addEdge({
@@ -1190,8 +1238,11 @@
           })
         }
       },
-      addNodeAndConnect(targetNode, dragNode, leftX, centerY) { // graphCell鏄敾甯冧笂鍘熸湁鐨勮妭鐐广�俤ragNode鏄綋鍓嶆嫋鎷界殑鑺傜偣
-        let width =100, height = 80, leftTopX = leftX , leftTopY = centerY
+      addNodeAndConnect(targetNode, dragNode, centerX, centerY) { // graphCell鏄敾甯冧笂鍘熸湁鐨勮妭鐐广�俤ragNode鏄綋鍓嶆嫋鎷界殑鑺傜偣
+        let width =100,
+          height = 80,
+          leftTopX = centerX ,
+          leftTopY = centerY
         let dragNodeType = dragNode.getData().nodeType
         if (dragNodeType === 'node') {
           width =60
@@ -1200,35 +1251,46 @@
           width =100
           height = 60
         } else if (dragNodeType === 'bridgeConnection') {
-          width =450
-          height = 160
-          // leftTopY = 240/2
+          width =550
+          height = 175
         } else {
           width =270
           height = 60
         }
-
+        leftTopX = centerX - width/2
+        leftTopY = centerY - height/2
         if (!this.canPlace(targetNode,dragNode,{leftTopX, leftTopY, width, height})){
           return false
         }
 
         if (dragNodeType === 'node' || dragNodeType === 'dashedBox') {
-          dragNode.position(leftX, centerY)
+          dragNode.position(leftTopX, leftTopY)
           return {newStartNode: dragNode, newEndNode: dragNode}
         } else if (dragNodeType === 'bridgeConnection') {
-          return this.createBridgeConnection(leftX, centerY, dragNode)
+          return this.createBridgeConnection(leftTopX, leftTopY, dragNode)
         } else {
-          return this.createParallelBrach(leftX, centerY, dragNode)
+          return this.createParallelBrach(leftTopX, centerY, dragNode)
         }
       },
       // 鐩镐氦鐨勮竟
       addNodeAndInsertEdge(graphEdge, dragNode) {
+        const Source = graphEdge.getSourceCell()
+        const Target = graphEdge.getTargetCell()
+
+        let centerY = Source.position().y + Source.getBBox().height/2
+        if (Target.getData().nodeType === 'node'){
+          centerY = Target.position().y  + Target.getBBox().height/2
+        }
+
+        console.log(Source,'Source 璧峰鐐逛俊鎭�')
+        console.log(Target,'Target 缁堟鐐逛俊鎭�')
+        console.log(Source.position().y,'璧峰鐐圭殑Y鍧愭爣')
+        console.log(Target.position().y,'缁堟鐐圭殑Y鍧愭爣')
         let startNodeId = graphEdge.source.cell
         let startNode = this.graph.getCellById(startNodeId)
         let endNodeId = graphEdge.target.cell
         let endNode = this.graph.getCellById(endNodeId)
         if (startNode && endNode) {
-          let centerY = dragNode.position().y
           let isRight = true;
           let startPort = 'right1'
           let endPort = 'left1'
@@ -1247,6 +1309,7 @@
           let result = this.addNodeAndConnect(null, dragNode, dragNode.position().x, centerY)
           if (!result){
             dragNode.remove()
+            this.$message({message: '娌℃湁瓒冲鐨勭┖闂存斁缃鑺傜偣锛岃鎵╁ぇ鍓╀綑绌洪棿', type: 'warning'})
             return
           }
           if (isRight) {
@@ -1257,7 +1320,6 @@
               router: {name: 'manhattan'},
               connector: {name: 'rounded'}
             })
-
           } else {
             this.graph.addEdge({
               source: {cell: startNode, port: startPort},
@@ -1327,15 +1389,16 @@
                 })*/
       },
       createBridgeConnection(x, y, dragNode) {
-        const leftTopDashedBox = this.createDashedBox(x + 120, y)
-        const rightTopDashedBox = this.createDashedBox(x + 400, y)
+        console.log(x,y,'leftX centerY')
+        const leftTopDashedBox = this.createDashedBox(x + 40, y)
+        const rightTopDashedBox = this.createDashedBox(x + 380, y)
 
-        const leftConnectNode = this.createConnectNode(x + 50, y + 80)
-        const alignCenterDashedBox = this.createDashedBox(x + 260, y + 80)
-        const rightConnectNode = this.createBridgeNode(x + 550, y + 80)
+        const leftConnectNode = this.createConnectNode(x, y + 87)
+        const alignCenterDashedBox = this.createDashedBox(x+ 210, y + 87)
+        const rightConnectNode = this.createBridgeNode(x + 530, y + 87)
 
-        const leftBottomDashedBox = this.createDashedBox(x + 120, y + 160)
-        const rightBottomDashedBox = this.createDashedBox(x + 400, y + 160)
+        const leftBottomDashedBox = this.createDashedBox(x+ 50, y + 160)
+        const rightBottomDashedBox = this.createDashedBox(x + 370 , y + 160)
 
         rightConnectNode.setData({startNodeId: leftConnectNode.id})
         leftConnectNode.setData({endNodeId: rightConnectNode.id})
@@ -1445,7 +1508,6 @@
         const dragNodeId = getUUID().toString()
         let connectNode = this.graph.addNode({
           shape: 'image',
-          // imageUrl: require('/public/modelImg/' + item.imgPath + '.png'),
           width: 10,
           height: 10,
           id: connectId,

--
Gitblit v1.9.1