From 9dd6e403c6d8b181b23b0abd004774f3851ac84b Mon Sep 17 00:00:00 2001 From: wangjiahao <1522128093@qq.com> Date: Wed, 4 Aug 2021 21:44:50 +0800 Subject: [PATCH] =?UTF-8?q?refactor:=E4=BB=AA=E8=A1=A8=E6=9D=BF=E8=81=94?= =?UTF-8?q?=E5=8A=A8=E7=9B=AE=E6=A0=87=E8=A7=86=E5=9B=BE=E8=8E=B7=E5=8F=96?= =?UTF-8?q?=E6=96=B9=E5=BC=8F=E4=BC=98=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../mapper/ext/ExtPanelViewLinkageMapper.xml | 24 ++-- .../io/dataease/dto/PanelViewLinkageDTO.java | 11 ++ .../panel/PanelViewLinkageService.java | 16 +-- .../canvas/components/Editor/EditBar.vue | 6 +- .../canvas/components/Editor/LinkageField.vue | 112 ++++++++++++++++++ 5 files changed, 152 insertions(+), 17 deletions(-) create mode 100644 frontend/src/components/canvas/components/Editor/LinkageField.vue diff --git a/backend/src/main/java/io/dataease/base/mapper/ext/ExtPanelViewLinkageMapper.xml b/backend/src/main/java/io/dataease/base/mapper/ext/ExtPanelViewLinkageMapper.xml index eafe5f0337..871a934e03 100644 --- a/backend/src/main/java/io/dataease/base/mapper/ext/ExtPanelViewLinkageMapper.xml +++ b/backend/src/main/java/io/dataease/base/mapper/ext/ExtPanelViewLinkageMapper.xml @@ -4,6 +4,7 @@ + @@ -11,13 +12,22 @@ diff --git a/backend/src/main/java/io/dataease/dto/PanelViewLinkageDTO.java b/backend/src/main/java/io/dataease/dto/PanelViewLinkageDTO.java index d9b1420e50..509e82a97b 100644 --- a/backend/src/main/java/io/dataease/dto/PanelViewLinkageDTO.java +++ b/backend/src/main/java/io/dataease/dto/PanelViewLinkageDTO.java @@ -12,6 +12,9 @@ import java.util.List; */ public class PanelViewLinkageDTO extends PanelViewLinkage { + //目标视图名称 + private String targetViewName; + //关联状态 private boolean linkageActive = true; @@ -21,6 +24,14 @@ public class PanelViewLinkageDTO extends PanelViewLinkage { } + public String getTargetViewName() { + return targetViewName; + } + + public void setTargetViewName(String targetViewName) { + this.targetViewName = targetViewName; + } + public PanelViewLinkageDTO(boolean linkageActive) { this.linkageActive = linkageActive; } diff --git a/backend/src/main/java/io/dataease/service/panel/PanelViewLinkageService.java b/backend/src/main/java/io/dataease/service/panel/PanelViewLinkageService.java index 9f3806ec42..a6534ee50f 100644 --- a/backend/src/main/java/io/dataease/service/panel/PanelViewLinkageService.java +++ b/backend/src/main/java/io/dataease/service/panel/PanelViewLinkageService.java @@ -31,14 +31,14 @@ public class PanelViewLinkageService { Map result = Optional.ofNullable(extPanelViewLinkageMapper.getViewLinkageGather(request.getPanelId(),request.getSourceViewId())) .orElse(new ArrayList<>()).stream() .collect(Collectors.toMap(PanelViewLinkageDTO::getTargetViewId,PanelViewLinkageDTO->PanelViewLinkageDTO)); - Set innerTargetIds = result.keySet(); - - // 将对应没有建立关联关系的targetId 也补充进去 - request.getTargetViewIds().stream().forEach(targetId->{ - if(!innerTargetIds.contains(targetId)){ - result.put(targetId,new PanelViewLinkageDTO(false)); - } - }); +// Set innerTargetIds = result.keySet(); +// +// // 将对应没有建立关联关系的targetId 也补充进去 +// request.getTargetViewIds().stream().forEach(targetId->{ +// if(!innerTargetIds.contains(targetId)){ +// result.put(targetId,new PanelViewLinkageDTO(false)); +// } +// }); return result; } return new HashMap<>(); diff --git a/frontend/src/components/canvas/components/Editor/EditBar.vue b/frontend/src/components/canvas/components/Editor/EditBar.vue index 9618b138ef..3511c7fccf 100644 --- a/frontend/src/components/canvas/components/Editor/EditBar.vue +++ b/frontend/src/components/canvas/components/Editor/EditBar.vue @@ -2,7 +2,8 @@
- + +
@@ -19,9 +20,10 @@ import { mapState } from 'vuex' import bus from '@/utils/bus' import SettingMenu from '@/components/canvas/components/Editor/SettingMenu' +import LinkageField from '@/components/canvas/components/Editor/LinkageField' export default { - components: { SettingMenu }, + components: { SettingMenu, LinkageField }, props: { element: { diff --git a/frontend/src/components/canvas/components/Editor/LinkageField.vue b/frontend/src/components/canvas/components/Editor/LinkageField.vue new file mode 100644 index 0000000000..c5626e4578 --- /dev/null +++ b/frontend/src/components/canvas/components/Editor/LinkageField.vue @@ -0,0 +1,112 @@ + + + + +