From 3ecb68c427a627ad8e90d8c555655e7724be2d96 Mon Sep 17 00:00:00 2001
From: jinlin <jinlin>
Date: 星期五, 06 九月 2024 11:06:12 +0800
Subject: [PATCH] 修改

---
 web/src/views/modules/taskReliability/RBD-edit-img.vue |  680 +++++++++++++++++++++++++++++++-------------------------
 1 files changed, 372 insertions(+), 308 deletions(-)

diff --git a/web/src/views/modules/taskReliability/RBD-edit-img.vue b/web/src/views/modules/taskReliability/RBD-edit-img.vue
index d483b9c..0deb426 100644
--- a/web/src/views/modules/taskReliability/RBD-edit-img.vue
+++ b/web/src/views/modules/taskReliability/RBD-edit-img.vue
@@ -16,7 +16,7 @@
             </el-form-item>
             <el-form-item>
               <el-button type="primary" @click="saveDiagram()">鏆傚瓨</el-button>
-              <el-button type="primary" @click="analyzeDiagram()">淇濆瓨</el-button>
+              <el-button type="primary" @click="analyzeDiagram()">鎻愪氦</el-button>
               <el-button type="primary" @click="clearDiagram()">娓呯┖鍥惧舰</el-button>
               <el-button @click="leftAlign()">
                 <i style="font-size: 1rem;" class="wt-iconfont icon-zuoduiqi"></i>
@@ -41,16 +41,15 @@
               <el-button @click="undo()">鎾ら攢</el-button>
               <el-button @click="redo()">閲嶅仛</el-button>
             </el-form-item>
+            <el-form-item>
+              <zt-button type="delete" @click="deleteCompment()" />
+            </el-form-item>
           </el-form>
           <div id="containerImg" style="border: 1px solid #EAEBEE;border-radius: 6px;
         box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%);height: 100%">
           </div>
-          <config-node v-show="type === 'node'" :id="id" :diagramId="diagramId" :globalGridAttr="globalGridAttr"
-                       :graph="graph"
-                       :nodeType="nodeType"
-                       :projectId="projectId"
-                       :shape="shape"/>
-          <config-edge v-show="type === 'edge'" :id="id" :globalGridAttr="globalGridAttr" :graph="graph"/>
+          <config-node ref="configNode" v-show="type === 'node'"/>
+          <config-edge ref="configEdge" v-show="type === 'edge'"/>
         </div>
       </el-col>
     </el-row>
@@ -59,19 +58,17 @@
 
 <script>
   import {Graph, Shape, Addon, Cell} from '@antv/x6'
-  import ConfigNode from './ConfigNode/index.vue'
-  import ConfigEdge from './ConfigEdge/index.vue'
-  import {removeCurrentTabHandle} from '@/commonJS/common'
+  import ConfigNode from './ConfigNode/configNode.vue'
+  import ConfigEdge from './ConfigEdge/configEdge.vue'
   import {setHartBeat} from '@/commonJS/common';
   import Cookies from 'js-cookie'
   import {getUUID} from '../../../../packages/utils'
-  import RBDDefault from './RBD-default.json'
+  // import Mousetrap from 'mousetrap'
+  // var Mousetrap = require('mousetrap');
+  // import RBDDefault from './RBD-default.json'
 
   export default {
     name: 'RBD-edit-img',
-    /*props: {
-
-    },*/
     props: {
       projectId: {
         type: String
@@ -91,230 +88,13 @@
       ConfigNode,
       ConfigEdge
     },
-    data() {
-      return {
-        isFirstLoad: true,
-        hasMoveNode: false,
-        hasMoveSingleNode: null,
-        nodeAdded: false,
-        connectNode: {},
-        modelId: '',
-        modelName: '',
-        modelType: '',
-        timer: null,
-        imagesList: [
-          // {imgPath: 'start', imgName: 'start', nodeType: 'start', imgWidth: 60, imgHeight: 60, imgId: '1', data: {}},
-          // {imgPath: 'end', imgName: 'end', nodeType: 'end', imgWidth: 60, imgHeight: 60, imgId: '2', data: {}},
-          // {
-          //   imgPath: 'connect',
-          //   imgName: 'connect',
-          //   nodeType: 'connect',
-          //   imgWidth: 30,
-          //   imgHeight: 30,
-          //   imgId: '3',
-          //   data: {}
-          // },
-          // {
-          //   imgPath: 'connect',
-          //   imgName: 'bridge',
-          //   nodeType: 'bridge',
-          //   imgWidth: 50,
-          //   imgHeight: 50,
-          //   imgId: '12',
-          //   data: {}
-          // },
-          {
-            imgPath: 'parallel',
-            imgName: 'parallel',
-            nodeType: 'parallel',
-            imgWidth: 50,
-            imgHeight: 50,
-            imgId: '9',
-            data: {}
-          },
-          {imgPath: 'vote', imgName: 'vote', nodeType: 'vote', imgWidth: 50, imgHeight: 50, imgId: '6', data: {}},
-          {
-            imgPath: 'switch',
-            imgName: 'switch',
-            nodeType: 'switch',
-            imgWidth: 50,
-            imgHeight: 50,
-            imgId: '5',
-            data: {}
-          },
-          {
-            imgPath: 'bridgeConnection',
-            imgName: 'bridgeConnection',
-            nodeType: 'bridgeConnection',
-            imgWidth: 50,
-            imgHeight: 50,
-            imgId: '10',
-            data: {}
-          },
-          // {
-          //   imgPath: 'dashedBox',
-          //   imgName: 'dashedBox',
-          //   nodeType: 'dashedBox',
-          //   imgWidth: 60,
-          //   imgHeight: 60,
-          //   imgId: '10000',
-          //   data: {}
-          // },
-        ],
-        imagesList2: [],
-        nodeType: '',
-        first: true,
-        shape: '',
-        projectList: [],
-        diagramList: [],
-        diagramId: '',
-        projectId: '',
-        diagramJson: '',
-        diagramIdDisabled: false,
-        dataForm: {
-          id: null,
-          content: null,
-          publishContent: null,
-          hasPublish: 0,
-          urlPref: '',
-        },
-        type: '',
-        id: '',
-        graph: null,
-        globalGridAttr: {
-          productType: '',
-          voteNum: '',
-          repairMttcr: '',
-          repairMttcrOther: '',
-          repairDistribType: '',
-          reliabDistribType: '',
-          taskMtbcfOther: '',
-          isRepair: 0,
-          taskMtbcf: '',
-          numberInputValue: '',
-          statusImg: '',
-          nodeTypeExt: '',
-          type: 'mesh',
-          size: 10,
-          color: '#e5e5e5',
-          thickness: 1,
-          colorSecond: '#d0d0d0',
-          thicknessSecond: 1,
-          factor: 4,
-          bgColor: '#e5e5e5',
-          showImage: true,
-          repeat: 'watermark',
-          position: 'center',
-          bgSize: JSON.stringify({width: 150, height: 150}),
-          opacity: 0.1,
-
-          stroke: '#5F95FF',
-          strokeWidth: 1,
-          connector: 'rounded',
-          router: 'manhattan',
-          label: '',
-          nodeStroke: '#5F95FF',
-          nodeStrokeWidth: 1,
-          nodeFill: '#ffffff',
-          nodeFontSize: 12,
-          nodeColor: '#080808',
-          nodeText: '',
-          nodeDate: '',
-          nodeUsers: '',
-          nodeDataDate: '',
-          nodeDataText: '',
-          dataId: '',
-          inspectName: '',
-          distance: 0.5,
-          angle: 0,
-        },
-        isReady: false,
-        curCel: Cell,
-        left_p: document.documentElement.clientHeight - 100,
-        ports: {
-          groups: {
-            top: {
-              position: {name: 'top'},
-              attrs: {
-                circle: {
-                  r: 4,
-                  magnet: true,
-                  stroke: '#5F95FF',
-                  strokeWidth: 1,
-                  fill: '#fff',
-                  style: {
-                    visibility: 'hidden',
-                  },
-                },
-              },
-            },
-            right: {
-              position: {name: 'right'},
-              attrs: {
-                circle: {
-                  r: 4,
-                  magnet: true,
-                  stroke: '#5F95FF',
-                  strokeWidth: 1,
-                  fill: '#fff',
-                  style: {
-                    visibility: 'hidden',
-                  },
-                },
-              },
-            },
-            bottom: {
-              position: {name: 'bottom'},
-              attrs: {
-                circle: {
-                  r: 4,
-                  magnet: true,
-                  stroke: '#5F95FF',
-                  strokeWidth: 1,
-                  fill: '#fff',
-                  style: {
-                    visibility: 'hidden',
-                  },
-                },
-              },
-            },
-            left: {
-              position: {name: 'left'},
-              attrs: {
-                circle: {
-                  r: 4,
-                  magnet: true,
-                  stroke: '#5F95FF',
-                  strokeWidth: 1,
-                  fill: '#fff',
-                  style: {
-                    visibility: 'hidden',
-                  },
-                },
-              },
-            },
-          },
-          items: [
-            {
-              id: 'top1',
-              group: 'top',
-            },
-            {
-              id: 'right1',
-              group: 'right',
-            },
-            {
-              id: 'bottom1',
-              group: 'bottom',
-            },
-            {
-              id: 'left1',
-              group: 'left',
-            },
-          ],
-        },
-        initJson: {
-          "cells": [
+    computed: {
+      RBDDefault() {
+        let url = `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getSvgImage?token=${Cookies.get('token')}&id=`
+        let result = `
+        {
+          "cells":
+          [
             {
               "position": {
                 "x": -600,
@@ -322,7 +102,7 @@
               },
               "size": {
                 "width": 60,
-                "height": 60
+                "height": 40
               },
               "attrs": {
                 "text": {
@@ -332,7 +112,7 @@
                   "refY2": 4
                 },
                 "image": {
-                  "xlink:href": "/modelImg/start.svg"
+                  "xlink:href": "${url}10011"
                 }
               },
               "visible": true,
@@ -444,8 +224,8 @@
                 "y": 0
               },
               "size": {
-                "width": 100,
-                "height": 60
+                "width": 60,
+                "height": 40
               },
               "attrs": {
                 "text": {
@@ -455,7 +235,7 @@
                   "refY2": 4
                 },
                 "image": {
-                  "xlink:href": "/modelImg/dashedBox.svg"
+                  "xlink:href": "${url}10015"
                 }
               },
               "visible": true,
@@ -567,7 +347,7 @@
               },
               "size": {
                 "width": 60,
-                "height": 60
+                "height": 40
               },
               "attrs": {
                 "text": {
@@ -577,7 +357,7 @@
                   "refY2": 4
                 },
                 "image": {
-                  "xlink:href": "/modelImg/end.svg"
+                  "xlink:href": "${url}10012"
                 }
               },
               "visible": true,
@@ -723,6 +503,221 @@
             }
           ]
         }
+        `
+        return JSON.parse(result)
+      }
+    },
+    data() {
+      return {
+        nodeX:'',
+        nodeY:'',
+        isFirstLoad: true,
+        hasMoveNode: false,
+        hasMoveSingleNode: null,
+        nodeAdded: false,
+        connectNode: {},
+        modelId: '',
+        modelName: '',
+        modelType: '',
+        timer: null,
+        imagesList: [
+          {
+            imgPath: 'parallel',
+            imgName: 'parallel',
+            nodeType: 'parallel',
+            imgWidth: 50,
+            imgHeight: 50,
+            imgId: '9',
+            data: {}
+          },
+          {imgPath: 'vote', imgName: 'vote', nodeType: 'vote', imgWidth: 50, imgHeight: 50, imgId: '6', data: {}},
+          {
+            imgPath: 'switch',
+            imgName: 'switch',
+            nodeType: 'switch',
+            imgWidth: 50,
+            imgHeight: 50,
+            imgId: '5',
+            data: {}
+          },
+          {
+            imgPath: 'bridgeConnection',
+            imgName: 'bridgeConnection',
+            nodeType: 'bridgeConnection',
+            imgWidth: 50,
+            imgHeight: 50,
+            imgId: '10',
+            data: {}
+          },
+          // {
+          //   imgPath: 'dashedBox',
+          //   imgName: 'dashedBox',
+          //   nodeType: 'dashedBox',
+          //   imgWidth: 60,
+          //   imgHeight: 60,
+          //   imgId: '10000',
+          //   data: {}
+          // },
+        ],
+        imagesList2: [],
+        nodeType: '',
+        first: true,
+        shape: '',
+        projectList: [],
+        diagramList: [],
+        diagramId: '',
+        projectId: '',
+        diagramJson: '',
+        diagramIdDisabled: false,
+        dataForm: {
+          id: null,
+          pid: null,
+          model_tag: '',
+          model_name: '',
+          product_id: null,
+          content: null,
+          publishContent: null,
+          hasPublish: 0,
+          urlPref: '',
+          nodeArr: []
+        },
+        type: '',
+        id: '',
+        graph: null,
+        globalGridAttr: {
+          productType: '',
+          voteNum: '',
+          repairMttcr: '',
+          repairMttcrOtherParams2: '',
+          repairMttcrOtherParams3: '',
+          repairDistribType: '',
+          reliabDistribType: '',
+          taskMtbcfOtherParams2: '',
+          taskMtbcfOtherParams3: '',
+          isRepair: 0,
+          taskMtbcf: '',
+          numberInputValue: '',
+          statusImg: '',
+          nodeTypeExt: '',
+          type: 'mesh',
+          size: 10,
+          color: '#e5e5e5',
+          thickness: 1,
+          colorSecond: '#d0d0d0',
+          thicknessSecond: 1,
+          factor: 4,
+          bgColor: '#e5e5e5',
+          showImage: true,
+          repeat: 'watermark',
+          position: 'center',
+          bgSize: JSON.stringify({width: 150, height: 150}),
+          opacity: 0.1,
+
+          stroke: '#5F95FF',
+          strokeWidth: 1,
+          connector: 'rounded',
+          router: 'manhattan',
+          label: '',
+          nodeStroke: '#5F95FF',
+          nodeStrokeWidth: 1,
+          nodeFill: '#ffffff',
+          nodeFontSize: 12,
+          nodeColor: '#080808',
+          nodeText: '',
+          nodeDate: '',
+          nodeUsers: '',
+          nodeDataDate: '',
+          nodeDataText: '',
+          dataId: '',
+          inspectName: '',
+          distance: 0.5,
+          angle: 0,
+        },
+        isReady: false,
+        curCel: Cell,
+        left_p: document.documentElement.clientHeight - 100,
+        ports: {
+          groups: {
+            top: {
+              position: {name: 'top'},
+              attrs: {
+                circle: {
+                  r: 4,
+                  magnet: true,
+                  stroke: '#5F95FF',
+                  strokeWidth: 1,
+                  fill: '#fff',
+                  style: {
+                    visibility: 'hidden',
+                  },
+                },
+              },
+            },
+            right: {
+              position: {name: 'right'},
+              attrs: {
+                circle: {
+                  r: 4,
+                  magnet: true,
+                  stroke: '#5F95FF',
+                  strokeWidth: 1,
+                  fill: '#fff',
+                  style: {
+                    visibility: 'hidden',
+                  },
+                },
+              },
+            },
+            bottom: {
+              position: {name: 'bottom'},
+              attrs: {
+                circle: {
+                  r: 4,
+                  magnet: true,
+                  stroke: '#5F95FF',
+                  strokeWidth: 1,
+                  fill: '#fff',
+                  style: {
+                    visibility: 'hidden',
+                  },
+                },
+              },
+            },
+            left: {
+              position: {name: 'left'},
+              attrs: {
+                circle: {
+                  r: 4,
+                  magnet: true,
+                  stroke: '#5F95FF',
+                  strokeWidth: 1,
+                  fill: '#fff',
+                  style: {
+                    visibility: 'hidden',
+                  },
+                },
+              },
+            },
+          },
+          items: [
+            {
+              id: 'top1',
+              group: 'top',
+            },
+            {
+              id: 'right1',
+              group: 'right',
+            },
+            {
+              id: 'bottom1',
+              group: 'bottom',
+            },
+            {
+              id: 'left1',
+              group: 'left',
+            },
+          ],
+        }
       }
     },
     watch: {
@@ -755,8 +750,10 @@
           token: Cookies.get('token'),
         }
         let res = await this.$http.get(`/taskReliability/ModelLine/getDiagram`, {params: params})
-        if (res.data !== null && (res.data.content != null)) {
-          this.dataForm = res.data
+        this.dataForm = res.data
+        if (res.data.content != null) {
+          console.log(this.dataForm, 'getDiagram datafrom')
+          console.log(res.data, 'getDiagram res.data')
           this.diagramJson = JSON.parse(this.dataForm.content)
           this.graph.fromJSON(this.diagramJson)
           this.isFirstLoad = false;
@@ -766,14 +763,14 @@
           // this.graph.centerContent()
           // this.graph.zoomToFit()
         } else {
-          this.graph.fromJSON(RBDDefault)
+          this.graph.fromJSON(this.RBDDefault)
           this.isFirstLoad = false
         }
       },
       async clearDiagram() {
-        this.dataForm.id = null
         // this.graph.fromJSON(this.emptyJson)
-        this.graph.fromJSON(RBDDefault)
+        console.log(this.RBDDefault, 'clearDiagram')
+        this.graph.fromJSON(this.RBDDefault)
         this.graph.positionContent('left')
         this.isFirstLoad = false;
         // this.graph.centerContent()
@@ -802,9 +799,6 @@
               }
             },
           },
-          // panning: {
-          //   enabled: true,
-          // },
           scroller: {
             enabled: true,
             pageVisible: true,
@@ -825,9 +819,6 @@
           connecting: {
             router: {
               name: 'manhattan',
-              // args: {
-              //   padding: 1,
-              // },
             },
             connector: {
               name: 'rounded',
@@ -838,6 +829,7 @@
             anchor: 'center',
             connectionPoint: 'anchor',
             allowBlank: false,
+            allowLoop:false, // 鏄惁鍏佽鍒涘缓寰幆杩炵嚎锛屽嵆杈圭殑璧峰鑺傜偣鍜岀粓姝㈣妭鐐逛负鍚屼竴鑺傜偣锛岄粯璁や负 true
             snap: {
               radius: 20,
             },
@@ -845,9 +837,10 @@
               return new Shape.Edge({
                 attrs: {
                   line: {
+                    //  sourceMarker: 'block', // 瀹炲績绠ご
                     stroke: '#A2B1C3',
                     strokeWidth: 2,
-                    targetMarker: {fill: 'none'}
+                    targetMarker: null
                   }
                 },
                 labels: [{
@@ -910,7 +903,7 @@
           getDropNode: (node) => {
             const {width, height} = node.size()
             if (node.getData().type && node.getData().nodeType === 'dashedBox') {
-              return node.clone().size(100, 60)
+              return node.clone().size(60, 40)
             }
             if (node.getData().type && node.getData().type === 'imageNodes2') {
               return node.clone({keepId: true})
@@ -994,9 +987,10 @@
         }
         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;
+        /*for(let i =0;i<this.imagesList2.length;i++){
 
+        }*/
+        console.log(this.imagesList2, 'getProduct(productId)234567890')
         const imageNodes2 = this.imagesList2.map((item) =>
           this.graph.createNode({
             shape: 'image',
@@ -1006,18 +1000,24 @@
             id: item.dataId, // 鎵嬪姩璁剧疆鑺傜偣鐨� ID
             data: {
               type: 'imageNodes2',
-              isRepair: item.isRepair,
               dataId: item.dataId,
               nodeType: item.nodeType,
               nodeTypeExt: item.nodeTypeExt,
               productType: item.productType,
               statusImg: item.statusImg,
-              reliabDistribType: item.reliabDistribType,
-              repairDistribType: item.repairDistribType,
-              repairMttcr: item.repairMttcr,
-              repairMttcrOther: item.repairMttcrOther,
+
+              reliabDistribType: item.reliabDistribType ? item.reliabDistribType : 1,
               taskMtbcf: item.taskMtbcf,
-              taskMtbcfOther: item.taskMtbcfOther,
+              taskMtbcfOther2: item.taskMtbcfOtherParams2,
+              taskMtbcfOther3: item.taskMtbcfOtherParams3,
+
+              isRepair: item.isRepair,
+              repairDistribType: item.repairDistribType ? item.repairDistribType : 1,
+              repairMttcr: item.repairMttcr,
+              repairMttcrOther2: item.repairMttcrOtherParams2,
+              repairMttcrOther3: item.repairMttcrOtherParams3,
+              successRate:item.successRate,
+
               imgHeight: item.imgHeight,
               imgWidth: item.imgWidth,
               voteNum: '',
@@ -1067,6 +1067,42 @@
         stencil.load(imageNodes, 'group1')
         stencil.load(imageNodes2, 'group2')
 
+// konami code!
+        // 鍗曞嚮node鑺傜偣
+        // this.graph.on('node:click', ({ e, x, y, node, view}) => {
+        //   Mousetrap.bind('up', function(e) {
+        //     e.preventDefault();
+        //     node.getBBox().x
+        //     node.getBBox().y
+        //     setTimeout(()=>{
+        //       node.position(node.getBBox().x,node.getBBox().y -0.5)
+        //       console.log(x,y,'鎸変笅浜嗏啈閿� up');
+        //     },100)
+        //   })
+        //   Mousetrap.bind('down', function(e) {
+        //     e.preventDefault();
+        //     setTimeout(()=>{
+        //       node.position(node.getBBox().x,node.getBBox().y+0.5)
+        //       console.log(x,y,'鎸変笅浜嗏啌閿� down');
+        //     },100)
+        //
+        //   })
+        //   Mousetrap.bind('left', function(e) {
+        //     e.preventDefault();
+        //     setTimeout(()=>{
+        //       node.position(node.getBBox().x-0.5,node.getBBox().y)
+        //       console.log(x,y,'鎸変笅浜嗏啇閿� left');
+        //     },100)
+        //
+        //   })
+        //   Mousetrap.bind('right', function(e) {
+        //     e.preventDefault();
+        //     setTimeout(()=>{
+        //       node.position(node.getBBox().x+0.5,node.getBBox().y)
+        //       console.log(x,y,'鎸変笅浜嗏啋閿� right');
+        //     },100)
+        //   })
+        // })
         this.graph.bindKey(['meta+c', 'ctrl+c'], () => {
           const cells = this.graph.getSelectedCells()
           if (cells.length) {
@@ -1117,7 +1153,7 @@
         })
 
         this.graph.on('blank:click', ({cell}) => {
-          this.reset()
+          // this.reset()
           // this.type.value = "grid"
           this.type = 'grid'
           // this.id = cell.id
@@ -1154,41 +1190,33 @@
             }
           }
           node.remove()
-
-          /*//濡傛灉鑺傜偣涓庤妭鐐圭浉浜�
-          console.log(node.position().x, node.position().x, 'node.position().x')
-          if (nodeType === 'bridgeConnection') {
-            this.getBridgeConnection()
-          }*/
         });
         this.graph.on('cell:contextmenu', ({cell}) => {
           // this.type.value = cell.isNode() ? "node" : "edge"
           this.type = cell.isNode() ? 'node' : 'edge'
-          this.shape = cell.shape
-          this.id = cell.id
+          /*          this.shape = cell.shape
+                    this.id = cell.id*/
           if (this.type === 'node') {
-            this.nodeType = cell.getData().nodeType
-            // console.log(this.nodeType, cell.id, 'this.nodeType')
+            //this.nodeType = cell.getData().nodeType
+            this.$refs.configNode.loadData(cell)
+          } else {
+            this.$refs.configNode.loadData(cell)
           }
-          // console.log(this.shape, 'this.shape')
-          // this.nodeOpt(this.id, this.globalGridAttr)
         })
         //鍗曞嚮杈硅妭鐐�
         this.graph.on('edge:click', ({edge}) => {
-          this.reset()
-          edge.attr('line/stroke', 'orange')
-          edge.prop('labels/0', {
-            attrs: {
-              body: {
-                stroke: 'orange',
-              },
-            },
+          // this.reset()
+          // edge.attr('line/stroke', 'orange')
+          // edge.prop('labels/0', {
+          //   attrs: {
+          //     body: {
+          //       stroke: 'orange',
+          //     },
+          //   },
+          //
+          // })
+        })
 
-          })
-        })
-        // 鍗曞嚮node鑺傜偣
-        this.graph.on('node:click', ({node}) => {
-        })
         // 鎺у埗杩炴帴妗╂樉绀�/闅愯棌
         this.graph.on('node:delete', ({view, e}) => {
           e.stopPropagation()
@@ -1337,6 +1365,7 @@
             }
 
             let isSeriesNode = this.isSeriesNode(startNode, node)
+            let isMultipleBrach = this.isMultipleBrach(node)
             if (isSeriesNode) {
               //涓茶仈
               let inLine = this.getInLinesOfNode(startNode)
@@ -1373,8 +1402,7 @@
                 })
                 return false
               })
-            }
-            if (this.isMultipleBrach(node)) {
+            }else if (this.isMultipleBrach(node)) {
               //鎻愮ず鏄惁瑕佸垹闄�
               this.$confirm('鏄惁鍒犻櫎璇ヨ妭鐐�?', '鎻愮ず', {
                 confirmButtonText: '纭畾',
@@ -1402,9 +1430,12 @@
                 })
                 return false
               })
+            }else {
+              //鎻愮ず涓嶈兘鍒犻櫎
+              this.$message({message: '璇ユ潯绾胯矾涓婂彧鏈夎鑺傜偣锛屾棤娉曞垹闄�', type: 'warning'})
+              return false; // 鍙栨秷鎿嶄綔
             }
           }
-          //鎻愮ず涓嶈兘鍒犻櫎
         } else {
           //鎻愮ず涓嶈兘鍒犻櫎
           this.$message({message: '鍙兘閫変腑涓�涓妭鐐�', type: 'warning'})
@@ -1416,23 +1447,56 @@
       },
       async saveDiagram() {
         console.log(JSON.stringify(this.graph.toJSON()), 'graph.toJSON()')
+        //   鑾峰彇鎵�鏈夊瓙鑺傜偣
+        this.getNodeArr()
         this.dataForm.content = JSON.stringify(this.graph.toJSON())
         this.dataForm.urlPref = window.SITE_CONFIG['apiURL']
         console.log(this.dataForm, 'dataFrom')
         await this.$http[this.dataForm.id === null ? 'post' : 'put'](`/taskReliability/ModelLine/`, this.dataForm).then(async res => {
           if (res.msg === 'success') {
+            this.$emit('refreshDataList')
             this.$alert('淇濆瓨鎴愬姛', '鎻愮ず', {
               confirmButtonText: '纭畾'
             })
           }
         })
       },
+      getNodeArr(){
+        const nodes = this.graph.getNodes()
+        let nodeArr2 = []
+        // 妫�鏌ラ櫎褰撳墠鑺傜偣涔嬪鐨勬墍鏈夎妭鐐圭殑鍖呭洿妗嗘槸鍚︾浉浜�
+        for (const node of nodes) {
+          console.log(node, 'saveDiagram node')
+          if (node.getData().nodeType == 'node'  && node.getData().dataId) {
+            nodeArr2.push(node.getData().dataId)
+          }
+        }
+        this.dataForm.nodeArr = nodeArr2
+      },
       async analyzeDiagram() {
         console.log(JSON.stringify(this.graph.toJSON()), 'graph.toJSON()')
+        // 妫�鏌ラ櫎褰撳墠鑺傜偣涔嬪鐨勬墍鏈夎妭鐐圭殑鍖呭洿妗嗘槸鍚︾浉浜�
+        //   鑾峰彇鎵�鏈夊瓙鑺傜偣
+        this.getNodeArr()
+        const nodes = this.graph.getNodes()
+        for (const node of nodes) {
+          if(node.getData().nodeType === 'dashedBox'){
+            this.$message({message: '璇ユā鍨嬩腑瀛樺湪铏氭锛屾棤娉曚繚瀛�', type: 'warning'})
+            return false; // 鍙栨秷娣诲姞鑺傜偣鎿嶄綔
+          }
+          if(node.getData().nodeType === 'vote'){
+            const edges = this.graph.getConnectedEdges(node);
+            if(node.getData().voteNum>=edges.length){
+              this.$message({message: '琛ㄥ喅鏁伴噺涓嶈兘楂樹簬璇ヨ妭鐐圭殑杩涚嚎鏁伴噺', type: 'warning'})
+              return false; // 鍙栨秷娣诲姞鑺傜偣鎿嶄綔
+            }
+          }
+        }
         this.dataForm.content = JSON.stringify(this.graph.toJSON())
         this.dataForm.urlPref = window.SITE_CONFIG['apiURL']
         await this.$http['post'](`/taskReliability/ModelLine/analyze`, this.dataForm).then(async res => {
           if (res.msg === 'success') {
+            this.$emit('refreshDataList')
             this.$alert('瑙f瀽鎴愬姛', '鎻愮ず', {
               confirmButtonText: '纭畾'
             })
@@ -1672,8 +1736,8 @@
           width = 60
           height = 60
         } else if (dragNodeType === 'dashedBox') {
-          width = 100
-          height = 60
+          width = 60
+          height = 40
         } else if (dragNodeType === 'bridgeConnection') {
           width = 550
           height = 175
@@ -1830,11 +1894,11 @@
         const rightTopDashedBox = this.createDashedBox(x + 380, y)
 
         const leftConnectNode = this.createConnectNode(x, y + 87)
-        const alignCenterDashedBox = this.createDashedBox(x + 210, y + 87)
+        const alignCenterDashedBox = this.createDashedBox(x + 209, y + 87)
         const rightConnectNode = this.createBridgeNode(x + 530, y + 87)
 
-        const leftBottomDashedBox = this.createDashedBox(x + 50, y + 160)
-        const rightBottomDashedBox = this.createDashedBox(x + 370, y + 160)
+        const leftBottomDashedBox = this.createDashedBox(x + 40, y + 160)
+        const rightBottomDashedBox = this.createDashedBox(x + 380, y + 160)
 
         rightConnectNode.setData({startNodeId: leftConnectNode.id})
         leftConnectNode.setData({endNodeId: rightConnectNode.id})
@@ -1854,39 +1918,39 @@
           source: {cell: leftConnectNode, port: 'right1'},
           target: {cell: leftTopDashedBox, port: 'left1'},
           router: {name: 'manhattan'},
-          connector: {name: 'rounded'}
+          connector: {name: 'rounded'},
         })
         this.graph.addEdge({
           source: {cell: leftConnectNode, port: 'right1'},
           target: {cell: leftBottomDashedBox, port: 'left1'},
           router: {name: 'manhattan'},
-          connector: {name: 'rounded'}
+          connector: {name: 'rounded'},
         })
 
         let edgeTop = this.graph.addEdge({
           source: {cell: leftTopDashedBox, port: 'right1'},
           target: {cell: rightTopDashedBox, port: 'left1'},
           router: {name: 'manhattan'},
-          connector: {name: 'rounded'}
+          connector: {name: 'rounded'},
         })
         let edgeBottom = this.graph.addEdge({
           source: {cell: leftBottomDashedBox, port: 'right1'},
           target: {cell: rightBottomDashedBox, port: 'left1'},
           router: {name: 'manhattan'},
-          connector: {name: 'rounded'}
+          connector: {name: 'rounded'},
         })
 
         this.graph.addEdge({
           source: {cell: rightTopDashedBox, port: 'right1'},
           target: {cell: rightConnectNode, port: 'left1'},
           router: {name: 'manhattan'},
-          connector: {name: 'rounded'}
+          connector: {name: 'rounded'},
         })
         this.graph.addEdge({
           source: {cell: rightBottomDashedBox, port: 'right1'},
           target: {cell: rightConnectNode, port: 'left1'},
           router: {name: 'manhattan'},
-          connector: {name: 'rounded'}
+          connector: {name: 'rounded'},
         })
 
         this.graph.addEdge({
@@ -1909,8 +1973,8 @@
         let dashedBox = this.graph.addNode({
           shape: 'image',
           // imageUrl: require('/public/modelImg/' + item.imgPath + '.png'),
-          width: 100,
-          height: 60,
+          width: 60,
+          height: 40,
           id: dashId,
           data: {
             isSelfCreated: true,

--
Gitblit v1.9.1