From 42f37a4137fee8e7d9cd645f198d2822fe890aa0 Mon Sep 17 00:00:00 2001 From: clay <20932067@zju.edu.cn> Date: Sat, 24 Jul 2021 23:55:43 +0800 Subject: [PATCH] =?UTF-8?q?top=E5=9B=BE=E5=AD=97=E6=AE=B5=E4=BF=AE?= =?UTF-8?q?=E6=94=B9=E5=AE=8C=E6=88=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../topology/src/behavior/hover-event-edit.js | 18 +- .../top/packages/topology/src/topology.vue | 263 +++++++++++++----- ebts-ui/src/views/tool/top/topology.vue | 1 + .../src/main/resources/application-druid.yml | 6 +- 4 files changed, 213 insertions(+), 75 deletions(-) diff --git a/ebts-ui/src/views/tool/top/packages/topology/src/behavior/hover-event-edit.js b/ebts-ui/src/views/tool/top/packages/topology/src/behavior/hover-event-edit.js index 1b83d59..7a6691f 100644 --- a/ebts-ui/src/views/tool/top/packages/topology/src/behavior/hover-event-edit.js +++ b/ebts-ui/src/views/tool/top/packages/topology/src/behavior/hover-event-edit.js @@ -41,24 +41,34 @@ export default { hourItem=hoverNode; }else { if (hourItem!=null){ - hourItem.setState("hover", false) + try { + hourItem.setState("hover", false) + }catch (e){ + } } } }, onNodeOut(event) { + console.log(hourItem) const name = event.shape.get("name"); let hoverNode = event.item; if (name && name.startsWith("marker")) { hoverNode.setState("hover", false); } - if (hourItem!=null){ - hourItem.setState("hover", false) + if (hourItem!=null&&hourItem.destroyed){ + try { + hourItem.setState("hover", false) + }catch (e){ + } } hoverNode.setState("hover", false); }, onNodeLeave(event) { if (hourItem!=null){ - hourItem.setState("hover", false) + try { + hourItem.setState("hover", false) + }catch (e){ + } } } } diff --git a/ebts-ui/src/views/tool/top/packages/topology/src/topology.vue b/ebts-ui/src/views/tool/top/packages/topology/src/topology.vue index bce4ef5..c21cc1f 100644 --- a/ebts-ui/src/views/tool/top/packages/topology/src/topology.vue +++ b/ebts-ui/src/views/tool/top/packages/topology/src/topology.vue @@ -75,30 +75,40 @@ 节点标签 +
+ 修改 +
- 字段信息 - +
{{ value }} @@ -189,6 +199,98 @@
  • 移除分组
  • +
    + + + + + + + + + + + + + + + + + + + + + + + + +
    @@ -219,37 +321,10 @@ export default { 'toolbar-edit': ToolbarEdit }, props: { - // graphData: { - // type: Object, - // default: () => { - // return { nodes: [], edges: [] } - // } - // }, nodeTypeList: { type: Array, default: () => { - return [ - // { - // guid: 'server', - // label: '服务器', - // imgSrc: '' - // }, - // { - // guid: 'database', - // label: '数据库', - // imgSrc: '' - // }, - // { - // guid: 'firewall', - // label: '防火墙', - // imgSrc: '' - // }, - // { - // guid: 'client', - // label: '客户端', - // imgSrc: '' - // } - ] + return [] } }, relationalMap:{ @@ -277,11 +352,13 @@ export default { graphBg: 'default-style', toolbarShow: true, rightMenuShow: false, - imgSrc: '', + // imgSrc: '', + imgSrc:'', graphData: { nodes: [], edges: [] }, + tableColumnEditOpen:false, loading: false, clientWidth: window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth, clientHeight: window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight, @@ -376,7 +453,11 @@ export default { selectedNodeModel.label = newVal.label selectedNodeModel.appConfig = newVal.appConfig selectedNodeModel.attrs = newVal.attrs - this.selectedNode.update(selectedNodeModel) + try { + this.selectedNode.update(selectedNodeModel) + }catch (e) { + + } }, 300) } }, @@ -393,7 +474,10 @@ export default { let selectedEdgeModel = this.selectedEdge.getModel() selectedEdgeModel.label = newVal.label selectedEdgeModel.appConfig = newVal.appConfig - this.selectedEdge.update(selectedEdgeModel) + try { + this.selectedEdge.update(selectedEdgeModel) + }catch (e) { + } }, 300) } } @@ -430,7 +514,37 @@ export default { this.clearHistoryData() }, methods: { + //todo + ucTypeChang(index, row) { + console.log(typeof this.selectedNodeParams.attrs[index].ucMock) + if (row.ucType == 'input' && row.ucCon != 'BETWEEN') { + this.selectedNodeParams.attrs[index].type = 1 + if (typeof (this.selectedNodeParams.attrs[index].ucMock) != 'string') { + this.selectedNodeParams.attrs[index].ucMock = '' + } + } else if (row.ucType == 'input' && row.ucCon == 'BETWEEN') { + this.selectedNodeParams.attrs[index].type = 2 + this.selectedNodeParams.attrs[index].ucMock = {begin: '', end: ''} + } else if (row.ucType == 'datetime' && row.ucCon != 'BETWEEN') { + this.selectedNodeParams.attrs[index].type = 3 + this.selectedNodeParams.attrs[index].ucMock = '' + } else if (row.ucType == 'datetime' && row.ucCon == 'BETWEEN') { + this.selectedNodeParams.attrs[index].type = 4 + this.selectedNodeParams.attrs[index].ucMock = [] + } + }, + + + + closeEditColumns(){ + this.tableColumnEditOpen = false + }, + // 修改字段信息 + editColumns(){ + this.tableColumnEditOpen = true + + }, // 连线的三个选择框触发实践 tableCommentChang(e){ if (this.selectedEdgeParams.relationalItem.mainKey !== e){ @@ -1053,23 +1167,28 @@ export default { this.addHistoryData(key, historyData) // ************** 记录【添加节点】前的数据状态 end ************** let graphData = graph.save(); + console.log(graphData) let relational = [] - for (let i = 0; i < graphData.nodes.length; i++) { - relational.push(graphData.nodes[i].tableId) - } let starts = false - // todo - for (let i = 0; i < relational.length; i++) { - this.relationalMap.map(item => { - if (item.mainId === relational[i] && item.childId === nodeType.id) { - starts = true - } - }) - this.relationalMap.map(item => { - if (item.childId === relational[i] && item.mainId === nodeType.id) { - starts = true - } - }) + if (graphData.nodes.length > 0){ + for (let i = 0; i < graphData.nodes.length; i++) { + relational.push(graphData.nodes[i].tableId) + } + // todo + for (let i = 0; i < relational.length; i++) { + this.relationalMap.map(item => { + if (item.mainId === relational[i] && item.childId === nodeType.id) { + starts = true + } + }) + this.relationalMap.map(item => { + if (item.childId === relational[i] && item.mainId === nodeType.id) { + starts = true + } + }) + } + }else { + starts = true } // 开始添加 if (starts){ @@ -1078,6 +1197,11 @@ export default { for (let i = 0; i < nodeType.topSearchColumnList.length; i++) { let item = nodeType.topSearchColumnList[i] if (item.isUse === 1) { + item.isQuery = 0 + item.ucCon = null + item.ucType = null + item.type = 1 + item.ucMock = null attrs.push(item) } } @@ -1286,6 +1410,7 @@ export default { this.changeGraphTheme('defaultStyle') this.$emit('doChangeMode', graphMode) }, + // 保存函数 saveDataHandler() { let graphData = this.getGraphData() this.$emit('doSaveData', graphData) diff --git a/ebts-ui/src/views/tool/top/topology.vue b/ebts-ui/src/views/tool/top/topology.vue index de098e1..df90786 100644 --- a/ebts-ui/src/views/tool/top/topology.vue +++ b/ebts-ui/src/views/tool/top/topology.vue @@ -90,6 +90,7 @@ export default { this.randomChange() }, doSaveData(graphData) { + console.log(JSON.stringify(graphData)) let data = { id : this.topId, topJson:JSON.stringify(graphData) diff --git a/ebts/ebts-admin/src/main/resources/application-druid.yml b/ebts/ebts-admin/src/main/resources/application-druid.yml index b2d4778..b95fec8 100644 --- a/ebts/ebts-admin/src/main/resources/application-druid.yml +++ b/ebts/ebts-admin/src/main/resources/application-druid.yml @@ -10,9 +10,11 @@ spring: # username: hcybase # password: hcybase@2020 # url: jdbc:mysql://13.75.92.40:3306/gen?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 +# username: gen +# password: zcsbKxPseM8LhFdT url: jdbc:mysql://127.0.0.1:3306/gen?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8 - username: gen - password: zcsbKxPseM8LhFdT + username: root + password: 926425 # 从库数据源 slave: # 从数据源开关/默认关闭