From aefc8f607405a5e4ce67ac62810b68fac9d93f89 Mon Sep 17 00:00:00 2001 From: yangyin <1850366751@qq.com> Date: 星期二, 29 十月 2024 11:52:48 +0800 Subject: [PATCH] 修改页面 --- src/views/project/ch/home/component/waterRight/bottom.vue | 65 ++++++++++++++++---------------- 1 files changed, 33 insertions(+), 32 deletions(-) diff --git a/src/views/project/ch/home/component/waterRight/bottom.vue b/src/views/project/ch/home/component/waterRight/bottom.vue index 4a9a0ff..384e966 100644 --- a/src/views/project/ch/home/component/waterRight/bottom.vue +++ b/src/views/project/ch/home/component/waterRight/bottom.vue @@ -4,29 +4,23 @@ <div class="flex item-center"> <span>搴旂敤鍦烘櫙</span> </div> - <!-- <div class="cursor-pointer"> - <el-button link class="changeBatch" @click="lookMore" - >鏌ョ湅鏇村 - <el-icon> - <ArrowRight /> - </el-icon> - </el-button> - </div> --> </div> - <div class="main" v-show="state.applicationScenarios && state.applicationScenarios.length < 3"> - <div - class="main_item flex cursor-pointer" - v-for="item in state.applicationScenarios" - :key="item.group_id" - :class="{ main_item_active: item.group_id === activeSectionAId }" - @click="changeScenarios(item)" - > - <div :class="['myiconfont icon-' + item.Icon]"></div> + <div class="main" v-show="state.applicationScenarios && state.applicationScenarios.length <= 3"> + <div class="flex flex-wrap items-center"> + <div + class="main_item flex cursor-pointer" + v-for="item in state.applicationScenarios" + :key="item.group_id" + :class="{ main_item_active: item.group_id === topGroupId }" + @click="changeScenarios(item)" + > + <div :class="['ywifont ywicon-' + item.Icon]"></div> - <div class="right"> - <h4>{{ item.group_name }}</h4> - <p>{{ item.group_title }}</p> + <div class="right"> + <h4>{{ item.group_name }}</h4> + <p>{{ item.group_title }}</p> + </div> </div> </div> </div> @@ -38,7 +32,7 @@ class="main_item flex cursor-pointer" v-for="item in group" :key="item.group_id" - :class="{ main_item_active: item.group_id === activeSectionAId }" + :class="{ main_item_active: item.group_id === topGroupId }" @click="changeScenarios(item)" > <div :class="['ywifont ywicon-' + item.Icon]"></div> @@ -54,10 +48,10 @@ </template> <script setup lang="ts"> -import { computed, onMounted, reactive, ref } from 'vue'; +import { computed, reactive, ref, watch } from 'vue'; import { getSectionList } from '/@/api/ai/chat'; import router from '/@/router'; -import { activeSectionAId, sectionAList } from '/@/stores/chatRoom'; +import { activeGroupType, sceneGroupList, sectionAList, topGroupId } from '/@/stores/chatRoom'; let state = reactive({ applicationScenarios: [], scenariosIds: [], @@ -66,7 +60,7 @@ (event: 'tagListClick', data): void; }>(); const changeScenarios = async (item) => { - activeSectionAId.value = item.group_id; + topGroupId.value = item.group_id; const curGroupID = item.p_group_id; const curID = item.group_id; let curGroupIDs = []; @@ -106,13 +100,15 @@ const getMainSectionList = async () => { const res = await getSectionList(); let result = []; - res.groups.forEach((sectionItem, index) => { + sceneGroupList.value.forEach((sectionItem, index) => { sectionItem.Icon = getIconByIndex(index); - result.push(sectionItem); + if (activeGroupType.value == sectionItem.group_type) { + result.push(sectionItem); + } }); state.applicationScenarios = result; - sectionAList.value = res.groups; - res.groups?.[0] && changeScenarios(res.groups[0]); + sectionAList.value = sceneGroupList.value; + result?.[0] && changeScenarios(result[0]); }; const groupedArray = computed(() => { const groups = []; @@ -128,13 +124,17 @@ router.push({ name: 'Scenario', query: { - ID: activeSectionAId.value, + ID: topGroupId.value, }, }); }; -onMounted(() => { - getMainSectionList(); -}); +watch( + () => activeGroupType.value, + () => { + getMainSectionList(); + }, + { immediate: true } +); </script> <style scoped lang="scss"> .pc-scenes { @@ -182,6 +182,7 @@ &_item { width: 50%; border-radius: 5px; + max-height: 100px; padding: 18px 12px; -webkit-transition: background-color 0.1s ease-in-out; -o-transition: background-color 0.1s ease-in-out; -- Gitblit v1.9.3