zhangxiao
2024-08-05 f6ba464aa7856b8201e313fe79e651aab34e6509
src/views/session/sessionManager/index.vue
@@ -1,12 +1,23 @@
<script setup lang="ts">
    import { IconMoreVertical,IconQuestionCircleFill,IconPoweroff,IconCommon ,IconSend} from '@arco-design/web-vue/es/icon';
    import img1 from '@/assets/images/u64.png'
    import img2 from '@/assets/images/u69.png'
  import {
    IconMoreVertical,
    IconQuestionCircleFill,
    IconPoweroff,
    IconCommon,
    IconSend,
  } from '@arco-design/web-vue/es/icon';
  import img1 from '@/assets/images/u64.png';
  import img2 from '@/assets/images/u69.png';
    import img3 from '@/assets/images/u74.png';
    import AddSession from './components/addSession.vue'
  import AddSession from './components/addSession.vue';
    import { ref, onMounted, computed, reactive, nextTick,watch } from 'vue';
    import { useUserStore,useAppStore } from '@/store';
    import { sessionListApi, deleteSessionApi,getSessionDetailsApi,chatApi }from '@/api/session';
  import {
    sessionListApi,
    deleteSessionApi,
    getSessionDetailsApi,
    chatApi,
  } from '@/api/session';
    import { Message } from '@arco-design/web-vue';
    const userStore = useUserStore();
    const appStore = useAppStore();
@@ -19,7 +30,7 @@
    const inputMsg=ref('');
    const scrollbar = ref(null);
    const currIndex = ref(0)
  const currIndex = ref(0);
    const displayedText = ref('');// 正在显示的文字
    let timer: number|null = null;
    const streamStr=ref('');
@@ -82,7 +93,10 @@
    };
    const sendMessage= async ()=>{
        if(inputMsg.value){
            const {code,data} =await chatApi({conversation_id:activeSessionId.value,messages:inputMsg.value});
      const { code, data } = await chatApi({
        conversation_id: activeSessionId.value,
        messages: inputMsg.value,
      });
            const res= await getSessionDetailsApi(activeSessionId.value);
            if(res.code===200){
                sessionDetailList.value=res.data.message.map((item,index)=>{
@@ -118,16 +132,20 @@
            setTimeout(startDisplayStr, 100);
        } else {
            clearTimeout(timer!);
            timer = null
      timer = null;
        }
    }
    watch(() => scrollbar.value, (newScroll, oldScroll) => {
  };
  watch(
    () => scrollbar.value,
    (newScroll, oldScroll) => {
      if (newScroll) {
        // 获取a-scroll的高度
        const height = newScroll.$el.offsetHeight;
        console.log('a-scroll height changed to:', height);
      }
    },{deep:true})
    },
    { deep: true }
  );
</script>
<template>
@@ -137,12 +155,22 @@
            <a-col :span="5">
                <a-card class="left">
                    <template #cover>
                        <a-button type="outline" class="card-btn" @click="modalObj.add=true">
            <a-button
              type="outline"
              class="card-btn"
              @click="modalObj.add = true"
            >
                            +新建会话
                        </a-button>
                    </template>
                    <a-scrollbar class="left-list" style="height: 60vh;overflow-y: auto;">
                        <div class="item" :class="{isLeftActive:activeSessionId===session.id}" v-for="session in sessionList" :key="session.id" @click="querySessionDetail(session)">
          <a-scrollbar class="left-list" style="height: 60vh; overflow-y: auto">
            <div
              class="item"
              :class="{ isLeftActive: activeSessionId === session.id }"
              v-for="session in sessionList"
              :key="session.id"
              @click="querySessionDetail(session)"
            >
                            <div class="item-left">
                                <IconQuestionCircleFill/> 
                                {{session.name}}
@@ -155,7 +183,12 @@
                                            <a-button type="text" size="mini">编辑</a-button>
                                        </div>-->
                                        <div>
                                            <a-button type="text" size="mini" @click="deleteSession(session)">删除</a-button>
                      <a-button
                        type="text"
                        size="mini"
                        @click="deleteSession(session)"
                        >删除</a-button
                      >
                                        </div>
                                    </template>
                                </a-popover>
@@ -195,24 +228,38 @@
                            <a-col :span="6" class="item">可能会出现错误的内容</a-col>
                        </a-row>
                        <a-row justify="center" class="right-middle-list">
                            <a-col :span="6" class="item">“提供一些庆祝10岁孩子生日的创意?”</a-col>
              <a-col :span="6" class="item"
                >“提供一些庆祝10岁孩子生日的创意?”</a-col
              >
                            <a-col :span="6" class="item">允许用户对答案进行修正</a-col>
                            <a-col :span="6" class="item">可能会产生有害或虚假的内容</a-col>
                        </a-row>
                        <a-row justify="center" class="right-middle-list">
                            <a-col :span="6" class="item">“如何在Javascript中发出http请求?”</a-col>
              <a-col :span="6" class="item"
                >“如何在Javascript中发出http请求?”</a-col
              >
                            <a-col :span="6" class="item">可以接受或拒绝不恰当的训练</a-col>
                            <a-col :span="6" class="item">对2023年以后得世界和事件了解有限</a-col>
              <a-col :span="6" class="item"
                >对2023年以后得世界和事件了解有限</a-col
              >
                        </a-row>
                    </div>
                    <a-scrollbar ref="scrollbar" id="home" v-else class="chat-list" style="width:90%;overflow:auto;height: 70vh;margin: 0px auto">
          <a-scrollbar
            ref="scrollbar"
            id="home"
            v-else
            class="chat-list"
            style="width: 90%; overflow: auto; height: 70vh; margin: 0px auto"
          >
                        <div class="chat-item" v-for="sessionDetail in sessionDetailList">
                            <a-comment
                                v-if="sessionDetail.role==='user'"
                                avatar="https://p1-arco.byteimg.com/tos-cn-i-uwbnlip3yd/3ee5f13fb09879ecb5185e440cef6eb9.png~tplv-uwbnlip3yd-webp.webp"
                            >
                                <template #content>
                                    <div :class="{light:theme==='light'}">{{sessionDetail.content}}</div>
                  <div :class="{ light: theme === 'light' }">{{
                    sessionDetail.content
                  }}</div>
                                </template>
                            </a-comment>
                            <a-comment
@@ -220,8 +267,13 @@
                                    avatar="https://p1-arco.byteimg.com/tos-cn-i-uwbnlip3yd/9eeb1800d9b78349b24682c3518ac4a3.png~tplv-uwbnlip3yd-webp.webp"
                            >
                                <template #content>
                                    <a-card class="chat-item-answer"  style="background-color: rgba(63, 64, 79, 1);">
                                        <div :class="{light:theme==='light'}">{{sessionDetail.content}}</div>
                  <a-card
                    class="chat-item-answer"
                    style="background-color: rgba(63, 64, 79, 1)"
                  >
                    <div :class="{ light: theme === 'light' }">{{
                      sessionDetail.content
                    }}</div>
                                    </a-card>
                                </template>
                            </a-comment>
@@ -230,7 +282,13 @@
                                avatar="https://p1-arco.byteimg.com/tos-cn-i-uwbnlip3yd/9eeb1800d9b78349b24682c3518ac4a3.png~tplv-uwbnlip3yd-webp.webp"
                            >
                                <template #content>
                                    <a-textarea readonly auto-size v-model="displayedText" class="chat-item-answer"  style="background-color: rgba(63, 64, 79, 1);">
                  <a-textarea
                    readonly
                    auto-size
                    v-model="displayedText"
                    class="chat-item-answer"
                    style="background-color: rgba(63, 64, 79, 1)"
                  >
                                    </a-textarea>
                                </template>
                            </a-comment>
@@ -238,12 +296,18 @@
                    </a-scrollbar>
                    <div class="bottom">
                        <div class="input">
                            <a-input v-model="inputMsg" @keydown.enter="sendMessage">
              <a-input
                v-model="inputMsg"
                @keydown.enter="sendMessage"
                placeholder="输入您想了解的内容,按Enter发送"
              >
                            <template #suffix>
                                <icon-send  style="cursor: pointer" @click="sendMessage"/>
                            </template>
                        </a-input></div>
                        <div class="text">内容由AI生成,仅供参考,请遵守《用户协议》、《个人信息保护规则》,基于ChatGPT大模型,版本:V3.3.0</div>
                </template> </a-input
            ></div>
            <div class="text"
              >内容由AI生成,仅供参考,请遵守《用户协议》、《个人信息保护规则》,基于ChatGPT大模型,版本:V3.3.0</div
            >
                    </div>
                </a-card>
            </a-col>
@@ -260,7 +324,8 @@
    }
    .container{
        background-color: #1d2129;
        .left,.right{
    .left,
    .right {
            color: white;
            height: calc(100vh - 60px);
            border: 0px;
@@ -351,7 +416,6 @@
                    }
                }
            }
        }
    }
</style>