From 97814f5764993914c6d3667b2fdd0c613fff0ac1 Mon Sep 17 00:00:00 2001 From: clay <20932067@zju.edu.cn> Date: Sat, 24 Jul 2021 00:53:18 +0800 Subject: [PATCH] =?UTF-8?q?top=E4=BA=A4=E4=BA=92=E5=AE=9E=E7=8E=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ebts-ui/src/api/tool/top.js | 31 ++ ebts-ui/src/router/index.js | 18 + ebts-ui/src/views/tool/query/index.vue | 2 + ebts-ui/src/views/tool/top/index.vue | 318 ++++++++++++++++ .../topology/src/behavior/dice-er-node.js | 1 + .../topology/src/behavior/drag-add-edge.js | 92 +++-- .../top/packages/topology/src/edge/base.js | 2 +- .../packages/topology/src/node/dice-er-box.js | 11 +- .../top/packages/topology/src/topology.vue | 354 ++++++++++-------- ebts-ui/src/views/tool/top/topology.vue | 34 +- .../src/main/resources/application-druid.yml | 4 +- .../src/main/resources/application.yml | 4 +- .../controller/TopQueryController.java | 88 +++++ .../ebts/generator/dao/TopSearchTableDao.java | 2 + .../com/ebts/generator/entity/UniQuery.java | 19 + .../generator/service/TopQueryService.java | 18 + .../service/impl/TopQueryServiceImpl.java | 33 ++ .../mapper/generator/TopSearchTableMapper.xml | 9 + .../mapper/generator/UniQueryMapper.xml | 14 +- 19 files changed, 853 insertions(+), 201 deletions(-) create mode 100644 ebts-ui/src/api/tool/top.js create mode 100644 ebts-ui/src/views/tool/top/index.vue create mode 100644 ebts/ebts-generator/src/main/java/com/ebts/generator/controller/TopQueryController.java create mode 100644 ebts/ebts-generator/src/main/java/com/ebts/generator/service/TopQueryService.java create mode 100644 ebts/ebts-generator/src/main/java/com/ebts/generator/service/impl/TopQueryServiceImpl.java diff --git a/ebts-ui/src/api/tool/top.js b/ebts-ui/src/api/tool/top.js new file mode 100644 index 0000000..7561bd8 --- /dev/null +++ b/ebts-ui/src/api/tool/top.js @@ -0,0 +1,31 @@ +/** + * @author: Clay + * @date: 2021/7/23 21:40 + * @description:top + * @email: clay@hchyun.com + */ +import request from '@/utils/request' + +// 查询万能查询详细 +export function getQuery(id) { + return request({ + url: '/top/' + id, + method: 'get' + }) +} + +// 查询万能查询详细 +export function getTables() { + return request({ + url: '/top/', + method: 'get' + }) +} +// 查询万能查询详细 +export function updateQuery(data) { + return request({ + url: '/top', + method: 'put', + data:data + }) +} diff --git a/ebts-ui/src/router/index.js b/ebts-ui/src/router/index.js index 31ba445..5a60479 100644 --- a/ebts-ui/src/router/index.js +++ b/ebts-ui/src/router/index.js @@ -132,6 +132,24 @@ export const constantRoutes = [ } ] }, + { + path: '/top/edit/:topId(\\d+)', + component: (resolve) => require(['@/views/tool/top/topology'], resolve), + hidden: true, + }, + // { + // path: '/top', + // component: Layout, + // hidden: true, + // children: [ + // { + // path: 'edit/:topId(\\d+)', + // component: (resolve) => require(['@/views/tool/top/topology'], resolve), + // name: 'top', + // meta: { title: 'top查询配置' } + // } + // ] + // }, { path: '/job', component: Layout, diff --git a/ebts-ui/src/views/tool/query/index.vue b/ebts-ui/src/views/tool/query/index.vue index 00bdb04..bd75000 100644 --- a/ebts-ui/src/views/tool/query/index.vue +++ b/ebts-ui/src/views/tool/query/index.vue @@ -189,6 +189,7 @@ export default { pageSize: 10, uqName: null, uqDescribe: null, + type:1 }, // 表单参数 form: {}, @@ -270,6 +271,7 @@ export default { /** 提交按钮 */ submitForm() { this.$refs["form"].validate(valid => { + this.form.type = 1 if (valid) { if (this.form.id != null) { updateQuery(this.form).then(response => { diff --git a/ebts-ui/src/views/tool/top/index.vue b/ebts-ui/src/views/tool/top/index.vue new file mode 100644 index 0000000..70ebaff --- /dev/null +++ b/ebts-ui/src/views/tool/top/index.vue @@ -0,0 +1,318 @@ + + + diff --git a/ebts-ui/src/views/tool/top/packages/topology/src/behavior/dice-er-node.js b/ebts-ui/src/views/tool/top/packages/topology/src/behavior/dice-er-node.js index 964ed96..e819f7c 100644 --- a/ebts-ui/src/views/tool/top/packages/topology/src/behavior/dice-er-node.js +++ b/ebts-ui/src/views/tool/top/packages/topology/src/behavior/dice-er-node.js @@ -183,6 +183,7 @@ export default { }); vm.selectedEdgeParams = { label: clickEdgeModel.label || "", + relationalItem: clickEdgeModel.relationalItem, sourceAttrs:clickEdgeModel.sourceAttrs, targetAttrs:clickEdgeModel.targetAttrs, appConfig: { ...edgeAppConfig, ...clickEdgeModel.appConfig } diff --git a/ebts-ui/src/views/tool/top/packages/topology/src/behavior/drag-add-edge.js b/ebts-ui/src/views/tool/top/packages/topology/src/behavior/drag-add-edge.js index c27c0af..1f08188 100644 --- a/ebts-ui/src/views/tool/top/packages/topology/src/behavior/drag-add-edge.js +++ b/ebts-ui/src/views/tool/top/packages/topology/src/behavior/drag-add-edge.js @@ -33,7 +33,7 @@ export default { self.evtInfo = { action: null, node: event.item, - target: event.target + target: event.target, }; if (self.evtInfo.target && self.evtInfo.target.attrs.name) { // todo...未来可能针对锚点增加其它功能(例如拖拽调整大小) @@ -79,7 +79,6 @@ export default { let sourceAnchor = self.evtInfo.node.getAnchorPoints(); let sourceNodeModel = self.evtInfo.node.getModel(); - console.log("sourceNodeModel",sourceNodeModel) // 锚点数据 let anchorPoints = self.evtInfo.node.getAnchorPoints(); // 处理线条目标点 @@ -90,6 +89,11 @@ export default { y: event.y }) } + let relational = vm.relationalMap.map(item => { + if (item.mainId === sourceNodeModel.tableId) { + return item + } + }) self.drawEdge.currentLine = self.graph.addItem("edge", { // id: G6.Util.uniqueId(), // 这种生成id的方式有bug,会重复 id: utils.generateUUID(), @@ -98,6 +102,7 @@ export default { sourceAttrs:sourceNodeModel.attrs, sourceAnchor: sourceAnchor ? sourceAnchor.anchorIndex : "", // 终止节点/位置 + relational: relational, target: { x: event.x, y: event.y @@ -132,41 +137,58 @@ export default { // 锚点数据 let anchorPoints = targetNode.getAnchorPoints(); // 处理线条目标点 - if (anchorPoints && anchorPoints.length) { - // 获取距离指定坐标最近的一个锚点 - targetAnchor = targetNode.getLinkPoint({ - x: event.x, - y: event.y - }); - } - self.graph.updateItem(self.drawEdge.currentLine, { - target: targetNodeModel.id, - targetAnchor: targetAnchor ? targetAnchor.anchorIndex : "", - targetAttrs:targetNodeModel.attrs, - }); - - // ************** 记录historyData的逻辑 start ************** - if (this.historyData) { - let graph = this.graph; - // 如果当前点过【撤销】了,拖拽节点后没有【重做】功能 - // 重置undoCount,拖拽后的数据给(当前所在historyIndex + 1),且清空这个时间点之后的记录 - if (vm.undoCount > 0) { - vm.historyIndex = vm.historyIndex - vm.undoCount; // 此时的historyIndex应当更新为【撤销】后所在的索引位置 - for (let i = 1; i <= vm.undoCount; i++) { - let key = `graph_history_${vm.historyIndex + i}`; - vm.removeHistoryData(key); + let relational = self.drawEdge.currentLine.getModel().relational + let starts = false; + let relationalItem = null; + relational.map(item => { + if (item){ + if (item.childId === targetNodeModel.tableId) { + starts = true + relationalItem = item } - vm.undoCount = 0; - } else { - // 正常顺序执行的情况,记录拖拽前的数据状态 - let key = `graph_history_${vm.historyIndex}`; - vm.addHistoryData(key, this.historyData); } - // 记录拖拽后的数据状态 - vm.historyIndex += 1; - let key = `graph_history_${vm.historyIndex}`; - let currentData = JSON.stringify(graph.save()); - vm.addHistoryData(key, currentData); + }) + if (starts) { + if (anchorPoints && anchorPoints.length) { + // 获取距离指定坐标最近的一个锚点 + targetAnchor = targetNode.getLinkPoint({ + x: event.x, + y: event.y + }); + } + self.graph.updateItem(self.drawEdge.currentLine, { + target: targetNodeModel.id, + relationalItem:relationalItem, + targetAnchor: targetAnchor ? targetAnchor.anchorIndex : "", + targetAttrs: targetNodeModel.attrs, + }); + + // ************** 记录historyData的逻辑 start ************** + if (this.historyData) { + let graph = this.graph; + // 如果当前点过【撤销】了,拖拽节点后没有【重做】功能 + // 重置undoCount,拖拽后的数据给(当前所在historyIndex + 1),且清空这个时间点之后的记录 + if (vm.undoCount > 0) { + vm.historyIndex = vm.historyIndex - vm.undoCount; // 此时的historyIndex应当更新为【撤销】后所在的索引位置 + for (let i = 1; i <= vm.undoCount; i++) { + let key = `graph_history_${vm.historyIndex + i}`; + vm.removeHistoryData(key); + } + vm.undoCount = 0; + } else { + // 正常顺序执行的情况,记录拖拽前的数据状态 + let key = `graph_history_${vm.historyIndex}`; + vm.addHistoryData(key, this.historyData); + } + // 记录拖拽后的数据状态 + vm.historyIndex += 1; + let key = `graph_history_${vm.historyIndex}`; + let currentData = JSON.stringify(graph.save()); + vm.addHistoryData(key, currentData); + } + }else { + self.graph.removeItem(self.drawEdge.currentLine); + vm.msgError("两表之间无关联关系") } // ************** 记录historyData的逻辑 end ************** } diff --git a/ebts-ui/src/views/tool/top/packages/topology/src/edge/base.js b/ebts-ui/src/views/tool/top/packages/topology/src/edge/base.js index a694c89..b93b5bb 100644 --- a/ebts-ui/src/views/tool/top/packages/topology/src/edge/base.js +++ b/ebts-ui/src/views/tool/top/packages/topology/src/edge/base.js @@ -20,7 +20,7 @@ export default { }, name: 'edge-shape' }) - console.log(keyShape.attrs.endArrow = true) + keyShape.attrs.endArrow = true return keyShape }, setState(name, value, item) { diff --git a/ebts-ui/src/views/tool/top/packages/topology/src/node/dice-er-box.js b/ebts-ui/src/views/tool/top/packages/topology/src/node/dice-er-box.js index cf4467f..1d17813 100644 --- a/ebts-ui/src/views/tool/top/packages/topology/src/node/dice-er-box.js +++ b/ebts-ui/src/views/tool/top/packages/topology/src/node/dice-er-box.js @@ -189,12 +189,15 @@ export default { const isSelected = Math.floor(startIndex) + i === Number(selectedIndex); let { - key = "", type + columnName = "", columnType,columnComment } = e; - if (type) { - key += " - " + type; + if (columnComment){ + columnName+= " : " + columnComment } - const label = key.length > 26 ? key.slice(0, 24) + "..." : key; + if (columnType) { + columnName += " - " + columnType; + } + const label = columnName.length > 26 ? columnName.slice(0, 24) + "..." : columnName; listContainer.addShape("rect", { attrs: { 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 54dd640..bce4ef5 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 @@ -11,20 +11,46 @@
-
- +
+
+
+ +

{{nodeType.tableComment}}

+
+
+ + + + + + + + + + + + + + +
{{ value }} - -
@@ -91,7 +115,7 @@ 查询方式
@@ -103,12 +127,12 @@
主表字段
- +
@@ -116,12 +140,12 @@
关联字段
- +
@@ -205,29 +229,35 @@ export default { type: Array, default: () => { return [ - { - guid: 'server', - label: '服务器', - imgSrc: '' - }, - { - guid: 'database', - label: '数据库', - imgSrc: '' - }, - { - guid: 'firewall', - label: '防火墙', - imgSrc: '' - }, - { - guid: 'client', - label: '客户端', - imgSrc: '' - } + // { + // guid: 'server', + // label: '服务器', + // imgSrc: '' + // }, + // { + // guid: 'database', + // label: '数据库', + // imgSrc: '' + // }, + // { + // guid: 'firewall', + // label: '防火墙', + // imgSrc: '' + // }, + // { + // guid: 'client', + // label: '客户端', + // imgSrc: '' + // } ] } }, + relationalMap:{ + type:Array, + default:() =>{ + return{} + } + }, nodeAppConfig: { type: Object, default: () => { @@ -243,9 +273,11 @@ export default { }, data() { return { + topId: null, graphBg: 'default-style', toolbarShow: true, rightMenuShow: false, + imgSrc: '', graphData: { nodes: [], edges: [] @@ -369,6 +401,7 @@ export default { created() { }, mounted() { + console.log(this.topId) Node.obj.diceErBox.sendThis(this) Behavior.obj.dragAddEdge.sendThis(this) Behavior.obj.dragEventEdit.sendThis(this) @@ -397,6 +430,50 @@ export default { this.clearHistoryData() }, methods: { + + // 连线的三个选择框触发实践 + tableCommentChang(e){ + if (this.selectedEdgeParams.relationalItem.mainKey !== e){ + this.selectedEdgeParams.appConfig.tableComment = null + this.msgError("主表关联字段为:"+this.selectedEdgeParams.relationalItem.mainKey) + } + }, + associatedChange(e){ + this.selectedEdgeParams.label = null + let type = this.selectedEdgeParams.relationalItem.type + let start = true + if (e === 'left'){ + console.log('left') + if (type.indexOf('1')===-1 && type.indexOf('2')===-1){ + this.msgError("查询方式有误") + start = false + } + }else if (e === 'right'){ + console.log(type.indexOf('3')) + if (type.indexOf('3')===-1){ + this.msgError("查询方式有误") + start = false + } + }else if (e === 'inner'){ + console.log(type.indexOf('1')) + if (type.indexOf('1')===-1){ + this.msgError("查询方式有误") + start = false + } + } + if (start){ + this.selectedEdgeParams.label = this.selectedEdgeParams.appConfig.associated+' join' + }else { + this.selectedEdgeParams.appConfig.associated = null + } + }, + relCommentChange(e){ + if (this.selectedEdgeParams.relationalItem.childKey !==e){ + this.selectedEdgeParams.appConfig.relComment = null + this.msgError("字表关联字段为:"+this.selectedEdgeParams.relationalItem.mainKey) + } + }, + openFullScreenLoading() { this.loading = true }, @@ -975,112 +1052,86 @@ export default { let key = `graph_history_${this.historyIndex}` this.addHistoryData(key, historyData) // ************** 记录【添加节点】前的数据状态 end ************** - - // 开始添加 - let droppoint = graph.getPointByClient(clientX, clientY) - console.log(droppoint.x, droppoint.y) - let node = graph.addItem('node', { - id: utils.generateUUID(), - x: (droppoint.x) - (125), - y: (droppoint.y) - (158), - label: nodeType.label, - // labelCfg: { - // position: "bottom" - // }, - //todo 设置拖拽的属性 - table: 'test_table', - type: 'dice-er-box', - attrs: [ - { - key: 'id', - type: 'number(6)', - comment: '主键id', - isUse: 1 - }, - { - key: 'key', - type: 'varchar(255)', - comment: '关键字', - isUse: 1 - }, - { - key: 'gender', - type: 'enum(M, F)', - comment: 'gender', - isUse: 1 - }, - { - key: 'birthday', - type: 'date', - comment: '生日', - isUse: 1 - }, - { - key: 'hometown', - type: 'varchar(255)', - comment: '家乡', - isUse: 1 - }, - { - key: 'country', - type: 'varchar(255)', - comment: '国家', - isUse: 1 - }, - { - key: 'nation', - type: 'varchar(255)', - comment: 'nation', - isUse: 1 - }, - { - key: 'jobId', - type: 'number(3)', - comment: '工作id', - isUse: 1 - }, - { - key: 'phone', - type: 'varchar(255)', - comment: '电话', - isUse: 1 - } - ], - // img: nodeType.imgSrc, - size: [55, 55], - width: 250, - height: 316, - anchorPoints: [ - [0.5, 0], // top - [1, 0.5], // right - [0.5, 1], // bottom - [0, 0.5] // left - ], - // 自定义属性 - appState: { - alert: false - } - }) - - // ************** 记录【添加节点】后的数据状态 start ************** - if (node) { - // 如果当前点过【撤销】了,【添加节点】后将取消【重做】功能 - // 重置undoCount,【添加节点】后的数据状态给(当前所在historyIndex + 1),且清空这个时间点之后的记录 - if (this.undoCount > 0) { - this.historyIndex = this.historyIndex - this.undoCount // 此时的historyIndex应当更新为【撤销】后所在的索引位置 - for (let i = 1; i <= this.undoCount; i++) { - let key = `graph_history_${this.historyIndex + i}` - this.removeHistoryData(key) - } - this.undoCount = 0 - } - // 记录【添加节点】后的数据状态 - this.historyIndex += 1 - let key = `graph_history_${this.historyIndex}` - let currentData = JSON.stringify(graph.save()) - this.addHistoryData(key, currentData) + let graphData = graph.save(); + 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 (starts){ + let droppoint = graph.getPointByClient(clientX, clientY) + let attrs = [] + for (let i = 0; i < nodeType.topSearchColumnList.length; i++) { + let item = nodeType.topSearchColumnList[i] + if (item.isUse === 1) { + attrs.push(item) + } + } + + let node = graph.addItem('node', { + id: utils.generateUUID(), + x: (droppoint.x) - (125), + y: (droppoint.y) - (158), + label: nodeType.tableName + ':' + nodeType.tableComment, + // labelCfg: { + // position: "bottom" + // }, + //todo 设置拖拽的属性 + tableId: nodeType.id, + table: nodeType.tableName, + type: 'dice-er-box', + attrs: attrs, + size: [55, 55], + width: 250, + height: 316, + anchorPoints: [ + [0.5, 0], // top + [1, 0.5], // right + [0.5, 1], // bottom + [0, 0.5] // left + ], + // 自定义属性 + appState: { + alert: false + } + }) + + // ************** 记录【添加节点】后的数据状态 start ************** + if (node) { + // 如果当前点过【撤销】了,【添加节点】后将取消【重做】功能 + // 重置undoCount,【添加节点】后的数据状态给(当前所在historyIndex + 1),且清空这个时间点之后的记录 + if (this.undoCount > 0) { + this.historyIndex = this.historyIndex - this.undoCount // 此时的historyIndex应当更新为【撤销】后所在的索引位置 + for (let i = 1; i <= this.undoCount; i++) { + let key = `graph_history_${this.historyIndex + i}` + this.removeHistoryData(key) + } + this.undoCount = 0 + } + // 记录【添加节点】后的数据状态 + this.historyIndex += 1 + let key = `graph_history_${this.historyIndex}` + let currentData = JSON.stringify(graph.save()) + this.addHistoryData(key, currentData) + } + // ************** 记录【添加节点】后的数据状态 end ************** + }else { + this.msgError("此表无关联关系!") } - // ************** 记录【添加节点】后的数据状态 end ************** } }, unselectAllNodes() { @@ -1245,6 +1296,11 @@ export default {