| | |
| | | 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); |
| | |
| | | // FIXME: 暂时这样 |
| | | section_a_id: currentSectionId, |
| | | history_group_id: currentRouteId, |
| | | raw_mode: roomConfig.value?.[currentRouteId]?.isAnswerByLLM ?? false, |
| | | } as any; |
| | | |
| | | if (currentSampleId) { |
| | |
| | | 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; |
| | | } |
| | |
| | | messageList.value.at(-1).content = content; |
| | | } |
| | | }; |
| | | |
| | | |
| | | onMounted(async () => { |
| | | const res = await QueryHistoryDetail({ |
| | |
| | | } |
| | | ); |
| | | |
| | | onActivated(()=>{ |
| | | onActivated(() => { |
| | | if (forbidScroll) return; |
| | | nextTick(() => scrollToBottom()); |
| | | }) |
| | | }); |
| | | |
| | | //#region ====================== 聊天内容操作 ====================== |
| | | |
| | |
| | | <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> |
| | |
| | | }, |
| | | }); |
| | | |
| | | |
| | | |
| | | const selectChartTypeChange = () => { |
| | | drawChart(); |
| | | }; |
| | |
| | | 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], |
| | |
| | | |
| | | 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(); |
| | |
| | | </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> |
| | |
| | | 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, |
| | |
| | | </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> |
| | |
| | | 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); |
| | |
| | | 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: [], |
| | |
| | | }); |
| | | const changeScenarios = async (item) => { |
| | | activeSectionAId.value = item.section_id; |
| | | setRoomConfig(activeRoomId.value, 'isAnswerByLLM', false); |
| | | }; |
| | | const getMainSectionList = async () => { |
| | | const res = await getSectionList(); |
| | |
| | | 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'; |
| | |
| | | |
| | | const changeExample = (item) => { |
| | | emitter.emit('updateChatInput', item.sample_question); |
| | | setRoomConfig(activeRoomId.value,'isAnswerByLLM',false); |
| | | activeSampleId.value = item.sample_id; |
| | | }; |
| | | //获取用户模板 |
| | |
| | | }; |
| | | //#region ====================== templateUseClick ====================== |
| | | const templateUseClick = (row) => { |
| | | setRoomConfig(activeRoomId.value,'isAnswerByLLM',true); |
| | | emitter.emit('updateChatInput', row.template_value); |
| | | }; |
| | | //#endregion |