gerson
2024-07-07 d5f17f079d4af2a173015dc86a4d6d472731fac6
echart 图表问题;raw_mode
已修改7个文件
192 ■■■■ 文件已修改
src/components/chat/Chat.vue 12 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/chat/chatComponents/recordSetCom/RecordSetCom.vue 72 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/chat/chatComponents/summaryCom/SummaryCom.vue 72 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/layout/component/sidebar/components/MenuList.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/stores/chatRoom.ts 27 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/project/ch/home/component/waterRight/bottom.vue 3 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/project/ch/home/component/waterRight/center.vue 4 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/chat/Chat.vue
@@ -57,7 +57,7 @@
import { GetHistoryAnswer, QueryHistoryDetail, QuestionAi, SetHistoryAnswerState, getQuestionProcess } from '/@/api/ai/chat';
import PlayBar from '/@/components/chat/components/playBar/PlayBar.vue';
import router from '/@/router';
import { activeChatRoom, activeLLMId, activeRoomId, activeSampleId, activeSectionAId } from '/@/stores/chatRoom';
import { activeChatRoom, activeLLMId, activeRoomId, activeSampleId, activeSectionAId, roomConfig } from '/@/stores/chatRoom';
import { v4 as uuidv4 } from 'uuid';
let isTalking = ref(false);
@@ -159,6 +159,7 @@
        // FIXME: 暂时这样
        section_a_id: currentSectionId,
        history_group_id: currentRouteId,
        raw_mode: roomConfig.value?.[currentRouteId]?.isAnswerByLLM ?? false,
    } as any;
    if (currentSampleId) {
@@ -191,14 +192,16 @@
let currentSampleId = null;
let currentLLMId = null;
const getAnswerById = async (historyId: string) => {
    return await GetHistoryAnswer({
        history_id: historyId,
    });
};
const sendChatMessage = async (content: ChatContent = messageContent.value) => {
    if (!messageContent.value?.values) return;
    if (messageList.value.length===0) {
    if (messageList.value.length === 0) {
        if (activeSampleId.value) {
            currentSampleId = activeSampleId.value;
        }
@@ -243,7 +246,6 @@
        messageList.value.at(-1).content = content;
    }
};
onMounted(async () => {
    const res = await QueryHistoryDetail({
@@ -297,10 +299,10 @@
    }
);
onActivated(()=>{
onActivated(() => {
    if (forbidScroll) return;
    nextTick(() => scrollToBottom());
})
});
//#region ====================== 聊天内容操作 ======================
src/components/chat/chatComponents/recordSetCom/RecordSetCom.vue
@@ -1,14 +1,14 @@
<template>
    <el-tabs v-model="activeName" class="demo-tabs min-w-[38rem]  flex-column" @tab-click="handleClick">
    <el-tabs v-model="activeName" class="demo-tabs min-w-[38rem] flex-column" @tab-click="handleClick">
        <el-tab-pane class="h-full" label="Chart" name="first">
            <el-select class="flex-0 w-36" v-model="selectChartType" @change="selectChartTypeChange">
            <!-- <el-select class="flex-0 w-36" v-model="selectChartType" @change="selectChartTypeChange">
                <el-option
                    v-for="item in Object.keys(chartTypeMapName)"
                    :key="item"
                    :value="parseInt(item)"
                    :label="chartTypeMapName[item]"
                ></el-option>
            </el-select>
            </el-select> -->
            <div class="flex-auto">
                <div ref="chartRef" class="h-full"></div>
            </div>
@@ -42,8 +42,6 @@
    },
});
const selectChartTypeChange = () => {
    drawChart();
};
@@ -71,16 +69,65 @@
    chartInstance.setOption({
        grid: {
            // bottom: 120,
            right:'15%',
            bottom: '15%',
            right: '15%',
            bottom: '5%',
        },
        tooltip: {
            show: true,
            trigger: 'axis',
        },
        toolbox: {
            show: true,
            feature: {
                dataZoom: {
                    yAxisIndex: 'none',
                },
                myBar: {
                    title: '转化为柱状图',
                    show: true,
                    icon: 'path://M580.8 228.8h-136v500.8h136V228.8z m-40 460.8h-56V268.8h56v420.8zM788.8 420.8h-136v308.8h136V420.8z m-40 268.8h-56V460.8h56v228.8zM372.8 326.4h-136v401.6h136V326.4z m-40 363.2h-56V366.4h56v323.2zM208 788.8h608v40H208z',
                    onclick: () => {
                        chartInstance.setOption({
                            series: {
                                data: props.data.values,
                                type: 'bar',
                            },
                        });
                    },
                },
                myScatter: {
                    title: '转化为散点图',
                    show: true,
                    icon: 'path://M445.7 609.8c0 19.4 10.3 37.3 27.1 46.9 16.8 9.7 37.4 9.7 54.2 0 16.8-9.7 27.1-27.6 27.1-46.9 0-29.9-24.3-54.2-54.2-54.2s-54.2 24.3-54.2 54.2z m0 0M179.2 613.8c-42.2 0-76.5 34.3-76.5 76.5s34.3 76.5 76.5 76.5 76.5-34.3 76.5-76.5-34.3-76.5-76.5-76.5z m0 0M144.9 401.1c0 29 23.5 52.5 52.5 52.5s52.5-23.5 52.5-52.5-23.5-52.5-52.5-52.5-52.5 23.5-52.5 52.5z m0 0M598.7 404c0 42.2 34.3 76.5 76.5 76.5 42.3 0 76.5-34.3 76.5-76.5 0-42.3-34.3-76.5-76.5-76.5-42.3 0-76.5 34.3-76.5 76.5z m0 0M849.3 169.2c-42.2 0-76.5 34.3-76.5 76.5s34.3 76.5 76.5 76.5 76.5-34.3 76.5-76.5-34.3-76.5-76.5-76.5z m0 0M261.6 583.1c0 13.2 7.1 25.5 18.5 32.1 11.5 6.6 25.6 6.6 37.1 0s18.5-18.9 18.5-32.1c0-20.5-16.6-37.1-37.1-37.1-20.4 0.1-37 16.7-37 37.1z m0 0M276.8 425.1c0 42.3 34.3 76.5 76.5 76.5 42.3 0 76.5-34.3 76.5-76.5s-34.3-76.5-76.5-76.5-76.5 34.3-76.5 76.5z m0 0M445.7 421.4c0 18.5 9.9 35.5 25.8 44.8 16 9.2 35.7 9.2 51.7 0s25.8-26.3 25.8-44.8c0-28.5-23.1-51.7-51.7-51.7-28.5 0-51.6 23.2-51.6 51.7z m0 0M398.2 208.8c0 42.3 34.3 76.5 76.5 76.5s76.5-34.3 76.5-76.5c0-42.3-34.3-76.5-76.5-76.5s-76.5 34.3-76.5 76.5z m0 0M693.7 599.2c0 42.3 34.3 76.5 76.5 76.5s76.5-34.3 76.5-76.5-34.3-76.5-76.5-76.5c-42.3 0-76.5 34.3-76.5 76.5z m0 0M62.1 828.9H959v60.7H62.1z',
                    onclick: () => {
                        chartInstance.setOption({
                            data: props.data.values,
                            type: 'scatter',
                        });
                    },
                },
                myRestore: {
                    title: '还原',
                    show: true,
                    icon: 'path://M909.637 478.524c-15.444-189.946-167.065-345.049-356.655-364.38-99.805-10.176-193.011 16.474-267.901 67.887l18.467-68.842c5.725-21.337-6.933-43.274-28.27-48.998s-43.274 6.934-48.998 28.271l-41.455 154.536c-5.724 21.337 6.933 43.273 28.271 48.998l154.536 41.455c21.337 5.724 43.273-6.934 48.998-28.271 5.724-21.337-6.934-43.274-28.271-48.998l-54.194-14.538c58.917-39.301 131.457-59.686 208.999-52.061 147.885 14.543 268.327 132.461 285.589 280.053 23.02 196.82-133.879 363.973-327.45 358.219-135.107-4.017-252.98-96.111-294.938-224.602-17.513-53.632-18.92-105.027-9.92-152.849 3.188-16.946-4.238-34.086-19.172-42.707l-0.049-0.028c-23.737-13.705-54.358-0.164-59.404 26.777-7.724 41.233-9.128 84.686-2.965 129.403 25.571 185.535 181.03 330.336 367.878 343.176C727.656 927.857 929.6 724.049 909.637 478.524z',
                    onclick: () => {
                        chartInstance.setOption({
                            data: props.data.values,
                            type: 'line',
                        });
                    },
                },
                dataView: {
                    readOnly: true,
                },
                saveAsImage: {},
            },
        },
        title: {
            text: props.data.title,
            left: 'center',
        },
        xAxis: {
            name: props.data?.names[0],
@@ -104,14 +151,13 @@
onMounted(() => {
    setTimeout(() => {
        const parent = chartRef.value.parentElement;
        if(!parent){
        if (!parent) {
        }
        const parentBound = parent.getBoundingClientRect();
        chartInstance = echarts.init(chartRef.value,undefined,{
            width:parentBound.width,
            height:parentBound.height
        chartInstance = echarts.init(chartRef.value, undefined, {
            width: parentBound.width,
            height: parentBound.height,
        });
        drawChart();
src/components/chat/chatComponents/summaryCom/SummaryCom.vue
@@ -13,15 +13,11 @@
            </div>
        </template>
        <div class="flex-column w-full mt-10" v-if="recordSetList && recordSetList.length > 0">
            <el-select class="flex-0 w-36 ml-auto mr-16" v-model="selectChartType" @change="selectChartTypeChange">
                <el-option
                    v-for="item in Object.keys(chartTypeMapName)"
                    :key="item"
                    :value="parseInt(item)"
                    :label="chartTypeMapName[item]"
                ></el-option>
            </el-select>
        <div
            class="flex-column w-full"
            :class="{ 'mt-10': summaryList && summaryList.length > 0 }"
            v-if="recordSetList && recordSetList.length > 0"
        >
            <div class="min-h-[48rem] flex-auto w-full">
                <div ref="chartRefList" v-for="(item, index) in recordSetList" :key="index"></div>
            </div>
@@ -134,15 +130,69 @@
            type: chartTypeMapEchart[selectChartType.value],
        };
    });
    instance.setOption({
        grid: {
            // bottom: 120,
            // right: '15%',
            bottom: '15%',
            bottom: '5%',
        },
        toolbox: {
            show: true,
            feature: {
                dataZoom: {
                    yAxisIndex: 'none',
                },
                myBar: {
                    title: '转化为柱状图',
                    show: true,
                    icon: 'path://M580.8 228.8h-136v500.8h136V228.8z m-40 460.8h-56V268.8h56v420.8zM788.8 420.8h-136v308.8h136V420.8z m-40 268.8h-56V460.8h56v228.8zM372.8 326.4h-136v401.6h136V326.4z m-40 363.2h-56V366.4h56v323.2zM208 788.8h608v40H208z',
                    onclick: () => {
                        instance.setOption({
                            series: seriesData.map((item) => ({
                                ...item,
                                type: 'bar',
                            })),
                        });
                    },
                },
                myScatter: {
                    title: '转化为散点图',
                    show: true,
                    icon: 'path://M445.7 609.8c0 19.4 10.3 37.3 27.1 46.9 16.8 9.7 37.4 9.7 54.2 0 16.8-9.7 27.1-27.6 27.1-46.9 0-29.9-24.3-54.2-54.2-54.2s-54.2 24.3-54.2 54.2z m0 0M179.2 613.8c-42.2 0-76.5 34.3-76.5 76.5s34.3 76.5 76.5 76.5 76.5-34.3 76.5-76.5-34.3-76.5-76.5-76.5z m0 0M144.9 401.1c0 29 23.5 52.5 52.5 52.5s52.5-23.5 52.5-52.5-23.5-52.5-52.5-52.5-52.5 23.5-52.5 52.5z m0 0M598.7 404c0 42.2 34.3 76.5 76.5 76.5 42.3 0 76.5-34.3 76.5-76.5 0-42.3-34.3-76.5-76.5-76.5-42.3 0-76.5 34.3-76.5 76.5z m0 0M849.3 169.2c-42.2 0-76.5 34.3-76.5 76.5s34.3 76.5 76.5 76.5 76.5-34.3 76.5-76.5-34.3-76.5-76.5-76.5z m0 0M261.6 583.1c0 13.2 7.1 25.5 18.5 32.1 11.5 6.6 25.6 6.6 37.1 0s18.5-18.9 18.5-32.1c0-20.5-16.6-37.1-37.1-37.1-20.4 0.1-37 16.7-37 37.1z m0 0M276.8 425.1c0 42.3 34.3 76.5 76.5 76.5 42.3 0 76.5-34.3 76.5-76.5s-34.3-76.5-76.5-76.5-76.5 34.3-76.5 76.5z m0 0M445.7 421.4c0 18.5 9.9 35.5 25.8 44.8 16 9.2 35.7 9.2 51.7 0s25.8-26.3 25.8-44.8c0-28.5-23.1-51.7-51.7-51.7-28.5 0-51.6 23.2-51.6 51.7z m0 0M398.2 208.8c0 42.3 34.3 76.5 76.5 76.5s76.5-34.3 76.5-76.5c0-42.3-34.3-76.5-76.5-76.5s-76.5 34.3-76.5 76.5z m0 0M693.7 599.2c0 42.3 34.3 76.5 76.5 76.5s76.5-34.3 76.5-76.5-34.3-76.5-76.5-76.5c-42.3 0-76.5 34.3-76.5 76.5z m0 0M62.1 828.9H959v60.7H62.1z',
                    onclick: () => {
                        instance.setOption({
                            series: seriesData.map((item) => ({
                                ...item,
                                type: 'scatter',
                            })),
                        });
                    },
                },
                myRestore: {
                    title: '还原',
                    show: true,
                    icon: 'path://M909.637 478.524c-15.444-189.946-167.065-345.049-356.655-364.38-99.805-10.176-193.011 16.474-267.901 67.887l18.467-68.842c5.725-21.337-6.933-43.274-28.27-48.998s-43.274 6.934-48.998 28.271l-41.455 154.536c-5.724 21.337 6.933 43.273 28.271 48.998l154.536 41.455c21.337 5.724 43.273-6.934 48.998-28.271 5.724-21.337-6.934-43.274-28.271-48.998l-54.194-14.538c58.917-39.301 131.457-59.686 208.999-52.061 147.885 14.543 268.327 132.461 285.589 280.053 23.02 196.82-133.879 363.973-327.45 358.219-135.107-4.017-252.98-96.111-294.938-224.602-17.513-53.632-18.92-105.027-9.92-152.849 3.188-16.946-4.238-34.086-19.172-42.707l-0.049-0.028c-23.737-13.705-54.358-0.164-59.404 26.777-7.724 41.233-9.128 84.686-2.965 129.403 25.571 185.535 181.03 330.336 367.878 343.176C727.656 927.857 929.6 724.049 909.637 478.524z',
                    onclick: () => {
                        instance.setOption({
                            series: seriesData.map((item) => ({
                                ...item,
                                type: 'line',
                            })),
                        });
                    },
                },
                dataView: {
                    readOnly: true,
                },
                saveAsImage: {},
            },
        },
        tooltip: {
            show: true,
            trigger: 'axis',
        },
        title: {
            text: data?.title,
src/layout/component/sidebar/components/MenuList.vue
@@ -37,7 +37,7 @@
            </div>
        </div>
    </div>
    <div class="pc-login" v-show="state.isShowLogin">
    <div class="pc-login  items-center justify-center" style="display:flex" v-show="state.isShowLogin">
        <div class="login_box">
            <div class="sign_in">
                <i class="ywicon icon-guanbi closes" @click="handleClose"></i>
src/stores/chatRoom.ts
@@ -2,12 +2,31 @@
import type { ChatRoomItem } from '../layout/component/sidebar/components/types';
import { Local } from '../utils/storage';
export type RoomConfig = {
    /** 是否直接调用大模型(通义千问)回答 */
    isAnswerByLLM: boolean;
};
export type RoomConfigKey = keyof RoomConfig;
export const roomConfig = ref<Record<string, RoomConfig>>(null);
export const setRoomConfig = <T extends RoomConfigKey>(roomId: string, key: T, value: RoomConfig[T]) => {
    if (!roomConfig.value) {
        roomConfig.value = {};
    }
    if (!roomConfig.value[roomId]) {
        roomConfig.value[roomId] = {
            [key]: value,
        } as any;
    } else {
        roomConfig.value[roomId][key] = value;
    }
};
export const chatRoomList = ref<ChatRoomItem[]>([]);
export const activeRoomId = ref(null);
export const activeChatRoom = computed(() => chatRoomList.value?.find((item) => item.id === activeRoomId.value));
export const activeSampleId = ref(null);
export const activeSectionAId= ref(null);
export const activeLLMId= ref(null);
export const activeSectionAId = ref(null);
export const activeLLMId = ref(null);
src/views/project/ch/home/component/waterRight/bottom.vue
@@ -40,7 +40,7 @@
import { onMounted, reactive, computed } from 'vue';
import { getSectionList } from '/@/api/ai/chat';
import router from '/@/router';
import { activeSectionAId } from '/@/stores/chatRoom';
import { activeRoomId, activeSectionAId, setRoomConfig } from '/@/stores/chatRoom';
let state = reactive({
    applicationScenarios: [],
@@ -48,6 +48,7 @@
});
const changeScenarios = async (item) => {
    activeSectionAId.value = item.section_id;
    setRoomConfig(activeRoomId.value, 'isAnswerByLLM', false);
};
const getMainSectionList = async () => {
    const res = await getSectionList();
src/views/project/ch/home/component/waterRight/center.vue
@@ -152,7 +152,7 @@
import { Search } from '@element-plus/icons-vue';
import { computed, onMounted, reactive, ref, watch } from 'vue';
import { getSelectSample, getUserTemplateList } from '/@/api/ai/chat';
import { activeSampleId } from '/@/stores/chatRoom';
import { activeRoomId, activeSampleId, roomConfig, setRoomConfig } from '/@/stores/chatRoom';
import emitter from '/@/utils/mitt';
import { useSearch } from '/@/hooks/useSearch';
import { debounce, getRecentDateRange } from '/@/utils/util';
@@ -275,6 +275,7 @@
const changeExample = (item) => {
    emitter.emit('updateChatInput', item.sample_question);
    setRoomConfig(activeRoomId.value,'isAnswerByLLM',false);
    activeSampleId.value = item.sample_id;
};
//获取用户模板
@@ -320,6 +321,7 @@
};
//#region ====================== templateUseClick ======================
const templateUseClick = (row) => {
    setRoomConfig(activeRoomId.value,'isAnswerByLLM',true);
    emitter.emit('updateChatInput', row.template_value);
};
//#endregion