From 7c723bef7e4d9aaf1ac07da4a369b28f572e551c Mon Sep 17 00:00:00 2001 From: jinlin <jinlin> Date: 星期二, 28 五月 2024 11:58:48 +0800 Subject: [PATCH] 修改 --- web/src/views/modules/basicInfo/TyProductModel-AddOrUpdate.vue | 2 web/src/views/modules/taskReliability/RBD-edit-img.vue | 766 ++++++++++++++++++++++++++++++++++++++++++----------- web/src/views/modules/basicInfo/SelectPicture.vue | 2 web/src/views/modules/basicInfo/XhProductModel.vue | 2 zt/core/src/main/java/com/zt/core/config/shiro/ShiroConfig.java | 2 web/src/views/modules/basicInfo/TyProductModel.vue | 2 web/src/views/modules/basicInfo/XhProductModel-AddOrUpdate.vue | 2 modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/model/TyProductModel.java | 4 modules/mainPart/src/main/java/com/zt/life/modules/mainPart/sysPictureBase/controller/SysPictureBaseController.java | 25 - modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/controller/TyProductModelController.java | 1 10 files changed, 612 insertions(+), 196 deletions(-) diff --git a/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/controller/TyProductModelController.java b/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/controller/TyProductModelController.java index e0882fc..09b7a69 100644 --- a/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/controller/TyProductModelController.java +++ b/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/controller/TyProductModelController.java @@ -63,7 +63,6 @@ @GetMapping("tree") public Result<List<TyProductModel>> getTreeList() { List<TyProductModel> list = tyProductModelService.getAllTree(); - return Result.ok(list); } diff --git a/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/model/TyProductModel.java b/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/model/TyProductModel.java index 12cc60b..d832e3f 100644 --- a/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/model/TyProductModel.java +++ b/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/basicInfo/model/TyProductModel.java @@ -51,6 +51,10 @@ @ApiModelProperty(value = "鍥剧墖鍚嶇О") private String operatImgName; + @TableField(exist = false) + @ApiModelProperty(value = "鍥剧墖鍚嶇О") + private String svgContent; + @ApiModelProperty(value = "鎺掑簭") private Integer sort; diff --git a/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/sysPictureBase/controller/SysPictureBaseController.java b/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/sysPictureBase/controller/SysPictureBaseController.java index 8147d2a..6bc2ac5 100644 --- a/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/sysPictureBase/controller/SysPictureBaseController.java +++ b/modules/mainPart/src/main/java/com/zt/life/modules/mainPart/sysPictureBase/controller/SysPictureBaseController.java @@ -84,31 +84,6 @@ } } } -/* if (file != null) { - BufferedImage bufferedImage = null; - try { - String fileName = file.getOriginalFilename(); - String[] arr = fileName.split("\\."); - String suffixName = arr[arr.length - 1].toLowerCase(); - - bufferedImage = ImageIO.read(file.getInputStream()); - // 瀹藉害 - int width = bufferedImage.getWidth(); - sysPictureBase.setWidth(width); - // 楂樺害 - int height = bufferedImage.getHeight(); - sysPictureBase.setHeight(height); - sysPictureBaseService.update(sysPictureBase); - String tempUploadDir = localPath + "/product_img/"; - File dir = new File(tempUploadDir); - if (!dir.exists()) { - dir.mkdirs(); - } - ImageIO.write(bufferedImage, suffixName, new File(tempUploadDir + sysPictureBase.getId().toString())); - } catch (IOException e) { - e.printStackTrace(); - } - }*/ return Result.ok(); } diff --git a/web/src/views/modules/basicInfo/SelectPicture.vue b/web/src/views/modules/basicInfo/SelectPicture.vue index d471c31..b865137 100644 --- a/web/src/views/modules/basicInfo/SelectPicture.vue +++ b/web/src/views/modules/basicInfo/SelectPicture.vue @@ -30,7 +30,7 @@ export default { data() { return { - url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getProductImg?token=${Cookies.get('token')}&id=`, + url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getSvgImage?token=${Cookies.get('token')}&id=`, name: 'SelectPicture', type: '', dataForm: { diff --git a/web/src/views/modules/basicInfo/TyProductModel-AddOrUpdate.vue b/web/src/views/modules/basicInfo/TyProductModel-AddOrUpdate.vue index f9d2d33..cda8fca 100644 --- a/web/src/views/modules/basicInfo/TyProductModel-AddOrUpdate.vue +++ b/web/src/views/modules/basicInfo/TyProductModel-AddOrUpdate.vue @@ -43,7 +43,7 @@ name: 'TyProductModel', data() { return { - url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getProductImg?token=${Cookies.get('token')}&id=`, + url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getSvgImage?token=${Cookies.get('token')}&id=`, fileId: '', productList: [], dataForm: { diff --git a/web/src/views/modules/basicInfo/TyProductModel.vue b/web/src/views/modules/basicInfo/TyProductModel.vue index bfb3068..6ac117c 100644 --- a/web/src/views/modules/basicInfo/TyProductModel.vue +++ b/web/src/views/modules/basicInfo/TyProductModel.vue @@ -50,7 +50,7 @@ export default { data() { return { - url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getProductImg?token=${Cookies.get('token')}&id=`, + url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getSvgImage?token=${Cookies.get('token')}&id=`, dataForm: { operationalStatus:'', standbyState:'', diff --git a/web/src/views/modules/basicInfo/XhProductModel-AddOrUpdate.vue b/web/src/views/modules/basicInfo/XhProductModel-AddOrUpdate.vue index e0f2b52..361ed3c 100644 --- a/web/src/views/modules/basicInfo/XhProductModel-AddOrUpdate.vue +++ b/web/src/views/modules/basicInfo/XhProductModel-AddOrUpdate.vue @@ -32,7 +32,7 @@ data() { return { disabled: false, - url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getProductImg?token=${Cookies.get('token')}&id=`, + url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getSvgImage?token=${Cookies.get('token')}&id=`, isTree: false, isShow: true, fileId: '', diff --git a/web/src/views/modules/basicInfo/XhProductModel.vue b/web/src/views/modules/basicInfo/XhProductModel.vue index 21e8f90..b1444f6 100644 --- a/web/src/views/modules/basicInfo/XhProductModel.vue +++ b/web/src/views/modules/basicInfo/XhProductModel.vue @@ -57,7 +57,7 @@ export default { data() { return { - url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getProductImg?token=${Cookies.get('token')}&id=`, + url: `${window.SITE_CONFIG['apiURL']}/sysPictureBase/getSvgImage?token=${Cookies.get('token')}&id=`, productType: '', dataForm: { name: '', diff --git a/web/src/views/modules/taskReliability/RBD-edit-img.vue b/web/src/views/modules/taskReliability/RBD-edit-img.vue index 07ec2d5..d483b9c 100644 --- a/web/src/views/modules/taskReliability/RBD-edit-img.vue +++ b/web/src/views/modules/taskReliability/RBD-edit-img.vue @@ -312,6 +312,416 @@ group: 'left', }, ], + }, + initJson: { + "cells": [ + { + "position": { + "x": -600, + "y": 0 + }, + "size": { + "width": 60, + "height": 60 + }, + "attrs": { + "text": { + "refY": "100%", + "textVerticalAnchor": "top", + "text": "start", + "refY2": 4 + }, + "image": { + "xlink:href": "/modelImg/start.svg" + } + }, + "visible": true, + "shape": "image", + "id": "10000", + "data": { + "type": "imageNodes", + "endNodeId": "20000", + "dataId": "", + "nodeType": "start", + "nodeTypeExt": "", + "voteNum": "" + }, + "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" + } + ] + }, + "zIndex": 1 + }, + { + "position": { + "x": 0, + "y": 0 + }, + "size": { + "width": 100, + "height": 60 + }, + "attrs": { + "text": { + "refY": "100%", + "textVerticalAnchor": "top", + "text": "dashedBox", + "refY2": 4 + }, + "image": { + "xlink:href": "/modelImg/dashedBox.svg" + } + }, + "visible": true, + "shape": "image", + "id": 15000, + "data": { + "type": "imageNodes", + "dataId": "", + "nodeType": "dashedBox", + "nodeTypeExt": "", + "voteNum": "" + }, + "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" + } + ] + }, + "zIndex": 2 + }, + { + "position": { + "x": 600, + "y": 0 + }, + "size": { + "width": 60, + "height": 60 + }, + "attrs": { + "text": { + "refY": "100%", + "textVerticalAnchor": "top", + "text": "end", + "refY2": 4 + }, + "image": { + "xlink:href": "/modelImg/end.svg" + } + }, + "visible": true, + "shape": "image", + "id": "20000", + "data": { + "type": "imageNodes", + "startNodeId": "10000", + "dataId": "", + "nodeType": "end", + "nodeTypeExt": "", + "voteNum": "" + }, + "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" + } + ] + }, + "zIndex": 3 + }, + { + "shape": "edge", + "id": "66c81c68-0827-4a3c-8343-e2c453d3e9e7", + "router": { + "name": "manhattan" + }, + "connector": { + "name": "rounded" + }, + "source": { + "cell": "10000", + "port": "right1" + }, + "target": { + "cell": 15000, + "port": "left1" + }, + "zIndex": 4 + }, + { + "shape": "edge", + "id": "a0f3cf90-6d37-4ee0-a254-90b4ec2b6a7f", + "router": { + "name": "manhattan" + }, + "connector": { + "name": "rounded" + }, + "source": { + "cell": 15000, + "port": "right1" + }, + "target": { + "cell": "20000", + "port": "left1" + }, + "zIndex": 5 + } + ] } } }, @@ -348,7 +758,7 @@ if (res.data !== null && (res.data.content != null)) { this.dataForm = res.data this.diagramJson = JSON.parse(this.dataForm.content) - this.graph.fromJSON(this.diagramJson) + this.graph.fromJSON(this.diagramJson) this.isFirstLoad = false; console.log(this.diagramJson.cells.length, 'this.diagramJson.cells.length') @@ -689,122 +1099,7 @@ }) //delete this.graph.bindKey('delete', () => { - const cells = this.graph.getSelectedCells() - console.log(cells, 'cells') - if (cells.length === 1) { - let node = cells[0] - if (!node.isNode()) { - 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 - let deleteType = 0 - if (nodeType === 'node' || nodeType === 'dashedBox') { - deleteType = 1 - } else if ('parallel,switch,vote,bridge'.indexOf(nodeType) > -1) { - deleteType = 2 - } - let canDelete = false - if (nodeType === 'start' || nodeType === 'end') { - this.$message({message: '鏃犳硶鍒犻櫎璧峰鍜岀粨鏉熻妭鐐�', type: 'warning'}) - return false; // 鍙栨秷鎿嶄綔 - } - if (deleteType > 0) { - let startNode = null - if (deleteType === 1) { - startNode = node - } else if (deleteType === 2) { - startNode = this.graph.getCellById(node.getData().startNodeId) - } - let isSeriesNode = this.isSeriesNode(startNode, node) - if (isSeriesNode) { - let inLine = this.getInLinesOfNode(startNode) - let outLine = this.getOutLinesOfNode(node) - let inLineIsToLine = this.hasOtherLineToMyLine(inLine[0].id) - let inNode = isSeriesNode.inNode - let outNode = isSeriesNode.outNode - console.log(inLine, outLine, 'inLine,outLine') - console.log(inNode, outNode, 'inNode,outNode') - //鎻愮ず鏄惁瑕佸垹闄� - 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 - }) - } - if (this.isMultipleBrach(node)) { - //鎻愮ず鏄惁瑕佸垹闄� - 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 - }) - } - } - //鎻愮ず涓嶈兘鍒犻櫎 - } else { - //鎻愮ず涓嶈兘鍒犻櫎 - this.$message({message: '鍙兘閫変腑涓�涓妭鐐�', type: 'warning'}) - return false; // 鍙栨秷鎿嶄綔 - } + this.deleteCompment() }) // zoom this.graph.bindKey(['ctrl+1', 'meta+1'], () => { @@ -995,6 +1290,127 @@ }) }) }, + deleteCompment() { + const cells = this.graph.getSelectedCells() + console.log(cells, 'cells') + if (cells.length === 1) { + let node = cells[0] + if (!node.isNode()) { + this.$confirm('鏄惁鍒犻櫎璇ヨ繛鎺ョ嚎?', '鎻愮ず', { + confirmButtonText: '纭畾', + cancelButtonText: '鍙栨秷', + type: 'warning' + }).then(() => { + node.remove() + this.$message({ + type: 'success', + message: '鍒犻櫎鎴愬姛!' + }) + }).catch(() => { + this.$message({ + type: 'info', + message: '宸插彇娑堝垹闄�' + }) + }) + // this.$message({message: '璇烽�変腑鑺傜偣', type: 'warning'}) + return false; // 鍙栨秷鎿嶄綔 + } + let nodeType = node.getData().nodeType + let deleteType = 0 + if (nodeType === 'node' || nodeType === 'dashedBox') { + deleteType = 1 + } else if ('parallel,switch,vote,bridge'.indexOf(nodeType) > -1) { + deleteType = 2 + } + + let canDelete = false + if (nodeType === 'start' || nodeType === 'end') { + this.$message({message: '涓嶅厑璁稿垹闄よ捣濮嬪拰缁撴潫鑺傜偣', type: 'warning'}) + return false; // 鍙栨秷鎿嶄綔 + } + if (deleteType > 0) { + let startNode = null + if (deleteType === 1) { + startNode = node + } else if (deleteType === 2) { + startNode = this.graph.getCellById(node.getData().startNodeId) + } + + let isSeriesNode = this.isSeriesNode(startNode, node) + if (isSeriesNode) { + //涓茶仈 + let inLine = this.getInLinesOfNode(startNode) + let outLine = this.getOutLinesOfNode(node) + let inLineIsToLine = this.hasOtherLineToMyLine(inLine[0].id) + let inNode = isSeriesNode.inNode + let outNode = isSeriesNode.outNode + console.log(inLine, outLine, 'inLine,outLine') + console.log(inNode, outNode, 'inNode,outNode') + //鎻愮ず鏄惁瑕佸垹闄� + 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 + }) + } + if (this.isMultipleBrach(node)) { + //鎻愮ず鏄惁瑕佸垹闄� + 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 + }) + } + } + //鎻愮ず涓嶈兘鍒犻櫎 + } else { + //鎻愮ず涓嶈兘鍒犻櫎 + this.$message({message: '鍙兘閫変腑涓�涓妭鐐�', type: 'warning'}) + return false; // 鍙栨秷鎿嶄綔 + } + }, async search() { await this.getDiagram(); }, @@ -1167,7 +1583,7 @@ } else { offHeight = 70 } - let centerX = 0, centerY = 0; + let centerX = 0, centerY = 0; if (graphNodeType === 'dashedBox') { //铏氭 const edges = this.graph.getConnectedEdges(graphNode); // 鑾峰彇鐢诲竷涓婂師鏈夌殑鑺傜偣鎵�鏈夎繘鏉ョ殑绾� @@ -1184,16 +1600,24 @@ endNode = this.graph.getCellById(endNodeId) } if (startNode && endNode) { - centerX = graphNode.position().x+graphNode.getBBox().width/2 - centerY = graphNode.position().y+graphNode.getBBox().height/2 + 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){ + if (!result) { dragNode.remove() this.$message({message: '娌℃湁瓒冲鐨勭┖闂存斁缃鑺傜偣锛岃鎵╁ぇ鍓╀綑绌洪棿', type: 'warning'}) return } - inEdges[0].target = {cell: result.newStartNode.id, port: 'left1'} - outEdges[0].source = {cell: result.newEndNode.id, port: 'right1'} + + let startPort = 'right1' + let endPort = 'left1' + if ((inEdges[0].target.port == 'top1' || outEdges[0].source.port == 'bottom1') && ('parallel,switch,vote,bridge'.indexOf(dragNodeType)) == -1) { + startPort = 'bottom1' + endPort = 'top1' + } + + inEdges[0].target = {cell: result.newStartNode.id, port: endPort} + outEdges[0].source = {cell: result.newEndNode.id, port: startPort} graphNode.remove() } } else { //骞惰缁撴瀯 @@ -1212,14 +1636,14 @@ this.getYRange(inEdges, graphNodeStartNode, pointXY) console.log(pointXY, 'new') - let minX = graphNodeStartNode.position().x + graphNode.getBBox().width+15 + let minX = graphNodeStartNode.position().x + graphNode.getBBox().width + 15 let maxX = graphNode.position().x let centerX = minX + (maxX - minX) / 2 - 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 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){ + if (!result) { dragNode.remove() this.$message({message: '娌℃湁瓒冲鐨勭┖闂存斁缃鑺傜偣锛岃鎵╁ぇ鍓╀綑绌洪棿', type: 'warning'}) return @@ -1239,27 +1663,27 @@ } }, addNodeAndConnect(targetNode, dragNode, centerX, centerY) { // graphCell鏄敾甯冧笂鍘熸湁鐨勮妭鐐广�俤ragNode鏄綋鍓嶆嫋鎷界殑鑺傜偣 - let width =100, + let width = 100, height = 80, - leftTopX = centerX , + leftTopX = centerX, leftTopY = centerY let dragNodeType = dragNode.getData().nodeType if (dragNodeType === 'node') { - width =60 + width = 60 height = 60 - }else if (dragNodeType === 'dashedBox') { - width =100 + } else if (dragNodeType === 'dashedBox') { + width = 100 height = 60 } else if (dragNodeType === 'bridgeConnection') { - width =550 + width = 550 height = 175 } else { - width =270 + width = 270 height = 60 } - leftTopX = centerX - width/2 - leftTopY = centerY - height/2 - if (!this.canPlace(targetNode,dragNode,{leftTopX, leftTopY, width, height})){ + leftTopX = centerX - width / 2 + leftTopY = centerY - height / 2 + if (!this.canPlace(targetNode, dragNode, {leftTopX, leftTopY, width, height})) { return false } @@ -1274,22 +1698,32 @@ }, // 鐩镐氦鐨勮竟 addNodeAndInsertEdge(graphEdge, dragNode) { - const Source = graphEdge.getSourceCell() - const Target = graphEdge.getTargetCell() + 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 + let centerX = 0 + let centerY = 0 + if (!source.isNode() || !target.isNode()) { + if (source.isNode()) { + centerX = source.position().x + source.getBBox().width / 2 + centerY = dragNode.position().y + dragNode.getBBox().height / 2 + } else { + centerX = target.position().x + target.getBBox().width / 2 + centerY = dragNode.position().y + dragNode.getBBox().height / 2 + } + } else { + centerX = dragNode.position().x + dragNode.getBBox().width / 2 + 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 isRight = true; let startPort = 'right1' @@ -1298,16 +1732,18 @@ startPort = 'bottom1' endPort = 'top1' } + if (this.hasOtherLineToMyLine(graphEdge.id)) { let leftX = startNode.position().x + startNode.getBBox().width let rightX = endNode.position().x - let centerX = dragNode.position().x + dragNode.getBBox().width / 2 + // let centerX = dragNode.position().x + dragNode.getBBox().width / 2 if (centerX - leftX < rightX - centerX) { isRight = false } } - let result = this.addNodeAndConnect(null, dragNode, dragNode.position().x, centerY) - if (!result){ + + let result = this.addNodeAndConnect(null, dragNode, centerX, centerY) + if (!result) { dragNode.remove() this.$message({message: '娌℃湁瓒冲鐨勭┖闂存斁缃鑺傜偣锛岃鎵╁ぇ鍓╀綑绌洪棿', type: 'warning'}) return @@ -1389,16 +1825,16 @@ })*/ }, createBridgeConnection(x, y, dragNode) { - console.log(x,y,'leftX centerY') + 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, y + 87) - const alignCenterDashedBox = this.createDashedBox(x+ 210, y + 87) + const alignCenterDashedBox = this.createDashedBox(x + 210, 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 + 50, y + 160) + const rightBottomDashedBox = this.createDashedBox(x + 370, y + 160) rightConnectNode.setData({startNodeId: leftConnectNode.id}) leftConnectNode.setData({endNodeId: rightConnectNode.id}) @@ -1719,30 +2155,30 @@ console.log(edges, '鑾峰彇鐢诲竷涓婄殑缁撴潫鑺傜偣鎵�鏈夌殑绾� edges') return edges.filter(edge => edge.source.cell === node.id) }, - canPlace(targetNode,dragNode,box2){ + canPlace(targetNode, dragNode, box2) { const nodes = this.graph.getNodes() let intersectNodes = [] // 妫�鏌ラ櫎褰撳墠鑺傜偣涔嬪鐨勬墍鏈夎妭鐐圭殑鍖呭洿妗嗘槸鍚︾浉浜� for (const otherNode of nodes) { if (otherNode === dragNode || otherNode === targetNode) continue; - const bbox1 = otherNode.getBBox(); - if (bbox1.x < box2.leftTopX + box2.width && - bbox1.x + bbox1.width > box2.leftTopX && - bbox1.y < box2.leftTopY + box2.height && - bbox1.y + bbox1.height > box2.leftTopY) { - intersectNodes.push(otherNode); - } + const bbox1 = otherNode.getBBox(); + if (bbox1.x < box2.leftTopX + box2.width && + bbox1.x + bbox1.width > box2.leftTopX && + bbox1.y < box2.leftTopY + box2.height && + bbox1.y + bbox1.height > box2.leftTopY) { + intersectNodes.push(otherNode); + } } - console.log(box2,'box2') - console.log(intersectNodes,'intersectNodes') + console.log(box2, 'box2') + console.log(intersectNodes, 'intersectNodes') return intersectNodes.length <= 0; }, - undo(){ + undo() { if (this.graph.history.canUndo()) { this.graph.history.undo() } }, - redo(){ + redo() { if (this.graph.history.canRedo()) { this.graph.history.redo() } diff --git a/zt/core/src/main/java/com/zt/core/config/shiro/ShiroConfig.java b/zt/core/src/main/java/com/zt/core/config/shiro/ShiroConfig.java index dff9d3d..f3d9cc3 100644 --- a/zt/core/src/main/java/com/zt/core/config/shiro/ShiroConfig.java +++ b/zt/core/src/main/java/com/zt/core/config/shiro/ShiroConfig.java @@ -113,6 +113,8 @@ filterMap.put("/sys/userRegister", "anon"); filterMap.put("/ztProduct/getShipList", "anon"); + filterMap.put("/sysPictureBase/getSvgImage","anon"); + filterMap.put("/product/getShipList","anon"); filterMap.put("/teamGroup/class/tree","anon"); filterMap.put("/taskReliability/SimulatAssess/calculate","anon"); -- Gitblit v1.9.1