From 457cc6cf166d3b6c22be4f78c1db8802a7fbb4c7 Mon Sep 17 00:00:00 2001 From: wujingjing <gersonwu@qq.com> Date: 星期一, 07 四月 2025 17:53:19 +0800 Subject: [PATCH] DigitalHuman --- src/views/project/ch/home/component/waterRight/bottom.vue | 132 +++++++++++++++++++++---------------------- 1 files changed, 65 insertions(+), 67 deletions(-) diff --git a/src/views/project/ch/home/component/waterRight/bottom.vue b/src/views/project/ch/home/component/waterRight/bottom.vue index 1bca77a..8e5396a 100644 --- a/src/views/project/ch/home/component/waterRight/bottom.vue +++ b/src/views/project/ch/home/component/waterRight/bottom.vue @@ -4,44 +4,38 @@ <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> <div class="block main" v-show="state.applicationScenarios && state.applicationScenarios.length > 3"> - <el-carousel height="80"> + <el-carousel height="80" :interval="5000" indicator-position="none"> <el-carousel-item v-for="group in groupedArray" :key="group" class="set-carousel-item"> <div 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="['myiconfont icon-' + item.Icon]"></div> + <div :class="['ywifont ywicon-' + item.Icon]"></div> <div class="right"> <h4>{{ item.group_name }}</h4> <p>{{ item.group_title }}</p> @@ -54,11 +48,8 @@ </template> <script setup lang="ts"> -import { computed, onMounted, reactive } from 'vue'; -import { getSectionList } from '/@/api/ai/chat'; -import router from '/@/router'; -import { activeRoomId, activeSectionAId, sectionAList, setRoomConfig } from '/@/stores/chatRoom'; - +import { computed, reactive, ref } from 'vue'; +import { activeGroupType, sceneGroupList, topGroupId } from '/@/stores/chatRoom'; let state = reactive({ applicationScenarios: [], scenariosIds: [], @@ -67,37 +58,53 @@ (event: 'tagListClick', data): void; }>(); const changeScenarios = async (item) => { - activeSectionAId.value = item.group_id; - setRoomConfig(activeRoomId.value, 'isAnswerByLLM', false); + topGroupId.value = item.group_id; + const curGroupID = item.p_group_id; + const curID = item.group_id; + let curGroupIDs = []; + //鍒ゆ柇褰撳墠涓虹埗绾� + if (!curGroupID) { + state.applicationScenarios.forEach((item) => { + if (curID == item.p_group_id) { + curGroupIDs.push(item.group_id); + } + }); + } else { + curGroupIDs.push(curID); + } + emits('tagListClick', curGroupIDs); + // setRoomConfig(activeRoomId.value, 'isAnswerByLLM', false); +}; +const iconList = ref([ + 'duoweidu', + 'zhibiao', + 'shujuzhongxin', + 'shujuguanli', + 'wendang', + 'grid', + 'liebiao', + 'wentifankui', + 'cedian', + 'shuzhuangtu', + 'bengzhan', + 'gerenxinxi_o', + 'bengzhan1', + 'yingyongzhongxin', +]); +const getIconByIndex = (index) => { + const iconCount = iconList.value.length; + return iconList.value[index % iconCount]; }; const getMainSectionList = async () => { - const res = await getSectionList(); let result = []; - const iconList = [ - 'biaodan', - 'putong', - 'zhongduancanshuchaxun', - 'shidu', - 'fuwenbenkuang', - 'fuwenben', - 'jiliandongxuanzeqi', - 'jinridaiban', - 'gongju', - 'tuodong', - 'xingqiu', - 'fuhao-yingwen', - 'tupianyulan', - 'siweidaotu', - 'fuwenben', - 'xuanzeqi', - 'zhongyingwenyuyan', - ]; - res.groups.forEach((sectionItem, index) => { - sectionItem.Icon = iconList[index]; + await sceneGroupList.value.forEach((sectionItem, index) => { + sectionItem.Icon = getIconByIndex(index); + if (activeGroupType.value == sectionItem.group_type) { + result.push(sectionItem); + } }); - state.applicationScenarios = res.groups; - sectionAList.value = res.groups; - res.groups?.[0] && changeScenarios(res.groups[0]); + state.applicationScenarios = result; + result?.[0] && changeScenarios(result[0]); }; const groupedArray = computed(() => { const groups = []; @@ -107,18 +114,8 @@ } return groups; }); - -// 鏌ョ湅鏇村 -const lookMore = () => { - router.push({ - name: 'Scenario', - query: { - ID: activeSectionAId.value, - }, - }); -}; -onMounted(() => { - getMainSectionList(); +defineExpose({ + getMainSectionList, }); </script> <style scoped lang="scss"> @@ -167,6 +164,7 @@ &_item { width: 50%; border-radius: 5px; + 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