Browse Source

[Feat 0000] 为可配置首页添加标题跳转功能

houzekong 1 year ago
parent
commit
c54f7e41c0

+ 1 - 1
src/views/vent/deviceManager/configurationTable/types.ts

@@ -190,7 +190,7 @@ export interface ModuleData {
   complex_list: ModuleDataComplexList[];
   complex_list: ModuleDataComplexList[];
   /** 如果目前没有数据可以对接,可使用模拟数据先行展示 */
   /** 如果目前没有数据可以对接,可使用模拟数据先行展示 */
   mock?: any[];
   mock?: any[];
-  /** 如果模块需要跳转,可以在这里配置,formatter 格式,取值时和 readFrom 执行同一规则 */
+  /** 如果模块需要跳转,可以在这里配置,不支持 formatter 格式 */
   to?: string;
   to?: string;
 }
 }
 export interface ShowStyle {
 export interface ShowStyle {

+ 5 - 2
src/views/vent/home/configurable/components/ModuleCommon.vue

@@ -1,7 +1,7 @@
 <template>
 <template>
   <ventBox1 class="module-common" :style="style">
   <ventBox1 class="module-common" :style="style">
     <template #title>
     <template #title>
-      <div>{{ moduleName }}</div>
+      <div @click="clickHandler">{{ moduleName }}</div>
     </template>
     </template>
     <template #container>
     <template #container>
       <slot></slot>
       <slot></slot>
@@ -20,7 +20,7 @@
     moduleName: string;
     moduleName: string;
     visible: boolean;
     visible: boolean;
   }>();
   }>();
-  defineEmits(['close']);
+  const emit = defineEmits(['close', 'click']);
 
 
   const style = computed(() => {
   const style = computed(() => {
     const size = props.showStyle.size;
     const size = props.showStyle.size;
@@ -35,6 +35,9 @@
   //   }
   //   }
   //   return ModuleLeft;
   //   return ModuleLeft;
   // }
   // }
+  function clickHandler() {
+    emit('click');
+  }
 </script>
 </script>
 <style scoped>
 <style scoped>
   .module-common .box1-center {
   .module-common .box1-center {

+ 9 - 2
src/views/vent/home/configurable/components/ModuleEnhanced.vue

@@ -1,5 +1,12 @@
 <template>
 <template>
-  <component :is="getModuleComponent(showStyle.position)" :style="style" :title="moduleName" :visible="visible" @close="$emit('close')">
+  <component
+    :is="getModuleComponent(showStyle.position)"
+    :style="style"
+    :title="moduleName"
+    :visible="visible"
+    @close="$emit('close')"
+    @click="$emit('click')"
+  >
     <slot></slot>
     <slot></slot>
   </component>
   </component>
 </template>
 </template>
@@ -15,7 +22,7 @@
     moduleName: string;
     moduleName: string;
     visible: boolean;
     visible: boolean;
   }>();
   }>();
-  defineEmits(['close']);
+  defineEmits(['close', 'click']);
 
 
   const style = computed(() => {
   const style = computed(() => {
     const size = props.showStyle.size;
     const size = props.showStyle.size;

+ 9 - 2
src/views/vent/home/configurable/components/ModuleOriginal.vue

@@ -1,5 +1,12 @@
 <template>
 <template>
-  <component :is="getModuleComponent(showStyle.position)" :style="style" :title="moduleName" :visible="visible" @close="$emit('close')">
+  <component
+    :is="getModuleComponent(showStyle.position)"
+    :style="style"
+    :title="moduleName"
+    :visible="visible"
+    @close="$emit('close')"
+    @click="$emit('click')"
+  >
     <slot></slot>
     <slot></slot>
   </component>
   </component>
 </template>
 </template>
@@ -14,7 +21,7 @@
     moduleName: string;
     moduleName: string;
     visible: boolean;
     visible: boolean;
   }>();
   }>();
-  defineEmits(['close']);
+  defineEmits(['close', 'click']);
 
 
   const style = computed(() => {
   const style = computed(() => {
     const size = props.showStyle.size;
     const size = props.showStyle.size;

+ 5 - 2
src/views/vent/home/configurable/components/enhanced/moduleBottom.vue

@@ -4,7 +4,7 @@
     <div v-if="visible" class="module-content">
     <div v-if="visible" class="module-content">
       <div class="module-content__title__expand">
       <div class="module-content__title__expand">
         <span class="action-btn close-btn" @click="closeModel"></span>
         <span class="action-btn close-btn" @click="closeModel"></span>
-        {{ title }}
+        <span @click="clickHandler">{{ title }}</span>
       </div>
       </div>
       <div class="module-slot">
       <div class="module-slot">
         <slot></slot>
         <slot></slot>
@@ -21,11 +21,14 @@
 </template>
 </template>
 <script lang="ts" setup>
 <script lang="ts" setup>
   defineProps<{ title: string; visible: boolean }>();
   defineProps<{ title: string; visible: boolean }>();
-  const emit = defineEmits(['close']);
+  const emit = defineEmits(['close', 'click']);
 
 
   function closeModel() {
   function closeModel() {
     emit('close');
     emit('close');
   }
   }
+  function clickHandler() {
+    emit('click');
+  }
 </script>
 </script>
 <style lang="less" scoped>
 <style lang="less" scoped>
   .module-bottom {
   .module-bottom {

+ 5 - 2
src/views/vent/home/configurable/components/enhanced/moduleLeft.vue

@@ -4,7 +4,7 @@
     <div v-if="visible" class="module-content">
     <div v-if="visible" class="module-content">
       <div class="module-content__title__expand">
       <div class="module-content__title__expand">
         <span class="action-btn close-btn" @click="closeModel"></span>
         <span class="action-btn close-btn" @click="closeModel"></span>
-        {{ title }}
+        <span @click="clickHandler">{{ title }}</span>
       </div>
       </div>
       <div class="module-slot">
       <div class="module-slot">
         <slot></slot>
         <slot></slot>
@@ -21,11 +21,14 @@
 </template>
 </template>
 <script lang="ts" setup>
 <script lang="ts" setup>
   defineProps<{ title: string; visible: boolean }>();
   defineProps<{ title: string; visible: boolean }>();
-  const emit = defineEmits(['close']);
+  const emit = defineEmits(['close', 'click']);
 
 
   function closeModel() {
   function closeModel() {
     emit('close');
     emit('close');
   }
   }
+  function clickHandler() {
+    emit('click');
+  }
 </script>
 </script>
 <style lang="less" scoped>
 <style lang="less" scoped>
   .module-left {
   .module-left {

+ 5 - 2
src/views/vent/home/configurable/components/enhanced/moduleRight.vue

@@ -4,7 +4,7 @@
     <div v-if="visible" class="module-content">
     <div v-if="visible" class="module-content">
       <div class="module-content__title__expand">
       <div class="module-content__title__expand">
         <span class="action-btn close-btn" @click="closeModel"></span>
         <span class="action-btn close-btn" @click="closeModel"></span>
-        {{ title }}
+        <span @click="clickHandler">{{ title }}</span>
       </div>
       </div>
       <div class="module-slot">
       <div class="module-slot">
         <slot></slot>
         <slot></slot>
@@ -21,11 +21,14 @@
 </template>
 </template>
 <script lang="ts" setup>
 <script lang="ts" setup>
   defineProps<{ title: string; visible: boolean }>();
   defineProps<{ title: string; visible: boolean }>();
-  const emit = defineEmits(['close']);
+  const emit = defineEmits(['close', 'click']);
 
 
   function closeModel() {
   function closeModel() {
     emit('close');
     emit('close');
   }
   }
+  function clickHandler() {
+    emit('click');
+  }
 </script>
 </script>
 <style lang="less" scoped>
 <style lang="less" scoped>
   .module-right {
   .module-right {

+ 5 - 2
src/views/vent/home/configurable/components/original/moduleBottom.vue

@@ -4,7 +4,7 @@
     <div v-if="visible" class="module-content">
     <div v-if="visible" class="module-content">
       <div class="module-content__title__expand">
       <div class="module-content__title__expand">
         <span class="action-btn close-btn" @click="closeModel"></span>
         <span class="action-btn close-btn" @click="closeModel"></span>
-        {{ title }}
+        <span @click="clickHandler">{{ title }}</span>
       </div>
       </div>
       <div class="module-slot">
       <div class="module-slot">
         <slot></slot>
         <slot></slot>
@@ -21,11 +21,14 @@
 </template>
 </template>
 <script lang="ts" setup>
 <script lang="ts" setup>
   defineProps<{ title: string; visible: boolean }>();
   defineProps<{ title: string; visible: boolean }>();
-  const emit = defineEmits(['close']);
+  const emit = defineEmits(['close', 'click']);
 
 
   function closeModel() {
   function closeModel() {
     emit('close');
     emit('close');
   }
   }
+  function clickHandler() {
+    emit('click');
+  }
 </script>
 </script>
 <style lang="less" scoped>
 <style lang="less" scoped>
   .module-bottom {
   .module-bottom {

+ 5 - 2
src/views/vent/home/configurable/components/original/moduleLeft.vue

@@ -4,7 +4,7 @@
     <div v-if="visible" class="module-content">
     <div v-if="visible" class="module-content">
       <div class="module-content__title__expand">
       <div class="module-content__title__expand">
         <span class="action-btn close-btn" @click="closeModel"></span>
         <span class="action-btn close-btn" @click="closeModel"></span>
-        {{ title }}
+        <span @click="clickHandler">{{ title }}</span>
       </div>
       </div>
       <div class="module-slot">
       <div class="module-slot">
         <slot></slot>
         <slot></slot>
@@ -21,11 +21,14 @@
 </template>
 </template>
 <script lang="ts" setup>
 <script lang="ts" setup>
   defineProps<{ title: string; visible: boolean }>();
   defineProps<{ title: string; visible: boolean }>();
-  const emit = defineEmits(['close']);
+  const emit = defineEmits(['close', 'click']);
 
 
   function closeModel() {
   function closeModel() {
     emit('close');
     emit('close');
   }
   }
+  function clickHandler() {
+    emit('click');
+  }
 </script>
 </script>
 <style lang="less" scoped>
 <style lang="less" scoped>
   .module-left {
   .module-left {

+ 24 - 2
src/views/vent/home/configurable/index.vue

@@ -15,12 +15,26 @@
     </a-dropdown> -->
     </a-dropdown> -->
     <!-- 采用定位方式以避免出现各个模块隐藏时其他模块下移的问题 -->
     <!-- 采用定位方式以避免出现各个模块隐藏时其他模块下移的问题 -->
     <template v-if="isOriginal">
     <template v-if="isOriginal">
-      <ModuleOriginal v-for="cfg in configs" :key="cfg.deviceType" :show-style="cfg.showStyle" :module-name="cfg.moduleName" :visible="true">
+      <ModuleOriginal
+        v-for="cfg in configs"
+        :key="cfg.deviceType"
+        :show-style="cfg.showStyle"
+        :module-name="cfg.moduleName"
+        :visible="true"
+        @click="redirectTo(cfg)"
+      >
         <Content v-bind="cfg" />
         <Content v-bind="cfg" />
       </ModuleOriginal>
       </ModuleOriginal>
     </template>
     </template>
     <template v-else-if="isCommon">
     <template v-else-if="isCommon">
-      <ModuleCommon v-for="cfg in configs" :key="cfg.deviceType" :show-style="cfg.showStyle" :module-name="cfg.moduleName" :visible="true">
+      <ModuleCommon
+        v-for="cfg in configs"
+        :key="cfg.deviceType"
+        :show-style="cfg.showStyle"
+        :module-name="cfg.moduleName"
+        :visible="true"
+        @click="redirectTo(cfg)"
+      >
         <Content v-bind="cfg" />
         <Content v-bind="cfg" />
       </ModuleCommon>
       </ModuleCommon>
     </template>
     </template>
@@ -33,6 +47,7 @@
         :show-style="cfg.showStyle"
         :show-style="cfg.showStyle"
         :module-name="cfg.moduleName"
         :module-name="cfg.moduleName"
         @close="cfg.visible = false"
         @close="cfg.visible = false"
+        @click="redirectTo(cfg)"
       >
       >
         <Content v-bind="cfg" />
         <Content v-bind="cfg" />
       </ModuleEnhanced>
       </ModuleEnhanced>
@@ -57,6 +72,7 @@
   import Content from './components/content.vue';
   import Content from './components/content.vue';
   import { testConfigA } from './configurable.data';
   import { testConfigA } from './configurable.data';
   import { useRoute } from 'vue-router';
   import { useRoute } from 'vue-router';
+  import { openWindow } from '/@/utils';
 
 
   interface EnhancedConfig extends Config {
   interface EnhancedConfig extends Config {
     visible: boolean;
     visible: boolean;
@@ -73,6 +89,12 @@
   });
   });
   const { configs, isOriginal, isCommon, fetchConfigs } = useInitConfigs();
   const { configs, isOriginal, isCommon, fetchConfigs } = useInitConfigs();
 
 
+  function redirectTo(config: Config) {
+    const { to } = config.moduleData;
+    if (!to) return;
+    openWindow(to);
+  }
+
   onMounted(() => {
   onMounted(() => {
     const query = useRoute().query;
     const query = useRoute().query;
     if (query.fire) {
     if (query.fire) {