fix: 修复部分多会话逻辑

This commit is contained in:
ChenZhaoYu 2023-02-15 22:31:55 +08:00
parent 58464b2cee
commit 0423b87530
6 changed files with 46 additions and 26 deletions

View File

@ -6,7 +6,6 @@ export function useChat() {
function addChat( function addChat(
message: string, message: string,
args?: { reversal?: boolean; error?: boolean; options?: Chat.ChatOptions }, args?: { reversal?: boolean; error?: boolean; options?: Chat.ChatOptions },
uuid?: number | null,
) { ) {
historyStore.addChat( historyStore.addChat(
{ {
@ -16,7 +15,6 @@ export function useChat() {
error: args?.error ?? false, error: args?.error ?? false,
options: args?.options ?? undefined, options: args?.options ?? undefined,
}, },
uuid,
) )
} }

View File

@ -7,7 +7,6 @@ import { useChat } from './hooks/useChat'
import { fetchChatAPI } from '@/api' import { fetchChatAPI } from '@/api'
import { HoverButton, SvgIcon } from '@/components/common' import { HoverButton, SvgIcon } from '@/components/common'
import { useHistoryStore } from '@/store' import { useHistoryStore } from '@/store'
import { isNumber } from '@/utils/is'
let controller = new AbortController() let controller = new AbortController()
@ -23,6 +22,7 @@ const prompt = ref('')
const loading = ref(false) const loading = ref(false)
const currentActive = computed(() => historyStore.active) const currentActive = computed(() => historyStore.active)
const heartbeat = computed(() => historyStore.heartbeat)
const list = computed<Chat.Chat[]>(() => historyStore.getCurrentChat) const list = computed<Chat.Chat[]>(() => historyStore.getCurrentChat)
const chatList = computed<Chat.Chat[]>(() => list.value.filter(item => (!item.reversal && !item.error))) const chatList = computed<Chat.Chat[]>(() => list.value.filter(item => (!item.reversal && !item.error)))
@ -71,9 +71,8 @@ function handleEnter(event: KeyboardEvent) {
function addMessage( function addMessage(
message: string, message: string,
args?: { reversal?: boolean; error?: boolean; options?: Chat.ChatOptions }, args?: { reversal?: boolean; error?: boolean; options?: Chat.ChatOptions },
uuid?: number | null,
) { ) {
addChat(message, args, uuid) addChat(message, args)
scrollToBottom() scrollToBottom()
} }
@ -96,10 +95,18 @@ onMounted(() => {
scrollToBottom() scrollToBottom()
}) })
watch(
heartbeat,
() => {
handleCancel()
scrollToBottom()
},
)
watch( watch(
currentActive, currentActive,
(active) => { (_, oldActive) => {
if (isNumber(active)) { if (oldActive !== null) {
handleCancel() handleCancel()
scrollToBottom() scrollToBottom()
} }

View File

@ -12,17 +12,21 @@ function handleSelect(index: number) {
historyStore.chooseHistory(index) historyStore.chooseHistory(index)
} }
function handleEdit(index: number, isEdit: boolean) { function handleEdit(index: number, isEdit: boolean, event?: MouseEvent) {
historyStore.editHistory(index, isEdit) historyStore.editHistory(index, isEdit)
event?.stopPropagation()
} }
function handleRemove(index: number) { function handleRemove(index: number, event?: MouseEvent) {
historyStore.removeHistory(index) historyStore.removeHistory(index)
event?.stopPropagation()
} }
function handleEnter(index: number, isEdit: boolean, event: KeyboardEvent) { function handleEnter(index: number, isEdit: boolean, event: KeyboardEvent) {
if (event.key === 'Enter') if (event.key === 'Enter') {
handleEdit(index, isEdit) handleEdit(index, isEdit)
event.stopPropagation()
}
} }
</script> </script>
@ -31,8 +35,8 @@ function handleEnter(index: number, isEdit: boolean, event: KeyboardEvent) {
<div class="flex flex-col gap-2 text-sm"> <div class="flex flex-col gap-2 text-sm">
<div v-for="(item, index) of dataSources" :key="index"> <div v-for="(item, index) of dataSources" :key="index">
<a <a
class="relative flex items-center gap-3 px-3 py-3 break-all border rounded-md cursor-pointer pr-14 hover:bg-neutral-100 group" class="relative flex items-center gap-3 px-3 py-3 break-all border rounded-md cursor-pointer hover:bg-neutral-100 group"
:class="historyStore.active === index && ['border-[#4b9e5f]', 'bg-neutral-100', 'text-[#4b9e5f]']" :class="historyStore.active === index && ['border-[#4b9e5f]', 'bg-neutral-100', 'text-[#4b9e5f]', 'pr-14']"
@click="handleSelect(index)" @click="handleSelect(index)"
> >
<span> <span>
@ -45,17 +49,17 @@ function handleEnter(index: number, isEdit: boolean, event: KeyboardEvent) {
/> />
<span v-else>{{ item.title }}</span> <span v-else>{{ item.title }}</span>
</div> </div>
<div class="absolute z-10 flex visible right-1"> <div v-if="historyStore.active === index" class="absolute z-10 flex visible right-1">
<template v-if="item.isEdit"> <template v-if="item.isEdit">
<button class="p-1" @click="handleEdit(index, false)"> <button class="p-1" @click="handleEdit(index, false, $event)">
<SvgIcon icon="ri:save-line" /> <SvgIcon icon="ri:save-line" />
</button> </button>
</template> </template>
<template v-else> <template v-else>
<button class="p-1"> <button class="p-1">
<SvgIcon icon="ri:edit-line" @click="handleEdit(index, true)" /> <SvgIcon icon="ri:edit-line" @click="handleEdit(index, true, $event)" />
</button> </button>
<button class="p-1" @click="handleRemove(index)"> <button class="p-1" @click="handleRemove(index, $event)">
<SvgIcon icon="ri:delete-bin-line" /> <SvgIcon icon="ri:delete-bin-line" />
</button> </button>
</template> </template>

View File

@ -5,10 +5,11 @@ const LOCAL_NAME = 'historyChat'
export interface HistoryState { export interface HistoryState {
historyChat: Chat.HistoryChat[] historyChat: Chat.HistoryChat[]
active: number | null active: number | null
heartbeat: boolean
} }
export function defaultSetting() { export function defaultSetting() {
return { historyChat: [], active: null } return { historyChat: [], active: null, heartbeat: false }
} }
export function getLocalHistory() { export function getLocalHistory() {

View File

@ -1,6 +1,7 @@
import { defineStore } from 'pinia' import { defineStore } from 'pinia'
import type { HistoryState } from './helper' import type { HistoryState } from './helper'
import { getLocalHistory, setLocalHistory } from './helper' import { getLocalHistory, setLocalHistory } from './helper'
export const useHistoryStore = defineStore('history-store', { export const useHistoryStore = defineStore('history-store', {
state: (): HistoryState => getLocalHistory(), state: (): HistoryState => getLocalHistory(),
getters: { getters: {
@ -18,16 +19,16 @@ export const useHistoryStore = defineStore('history-store', {
}, },
}, },
actions: { actions: {
addChat(data: Chat.Chat, uuid: number | null = null) { addChat(data: Chat.Chat) {
if (this.active === null) { if (this.active === null) {
this.historyChat.push({ title: data.message, isEdit: false, data: [data] }) this.historyChat.push({ title: data.message, isEdit: false, data: [data] })
this.active = this.historyChat.length - 1 this.active = this.historyChat.length - 1
} }
else { else {
const active = uuid !== null ? uuid : this.active if (this.historyChat[this.active].title === 'New Chat')
if (this.historyChat[active].title === 'New Chat') this.historyChat[this.active].title = data.message
this.historyChat[active].title = data.message
this.historyChat[active].data.push(data) this.historyChat[this.active].data.push(data)
} }
setLocalHistory(this.$state) setLocalHistory(this.$state)
}, },
@ -52,14 +53,19 @@ export const useHistoryStore = defineStore('history-store', {
removeHistory(index: number) { removeHistory(index: number) {
this.historyChat.splice(index, 1) this.historyChat.splice(index, 1)
if (this.active === index) { if (this.active === index) {
if (this.historyChat.length === 0) if (this.historyChat.length === 0)
this.active = null this.active = null
else if (this.active === this.historyChat.length) else if (this.active === this.historyChat.length)
this.active-- this.active = this.historyChat.length - 1
else
this.active = 0
} }
if (this.historyChat.length === 0)
this.active = null
this.toggleHeartbeat()
setLocalHistory(this.$state) setLocalHistory(this.$state)
}, },
@ -69,5 +75,9 @@ export const useHistoryStore = defineStore('history-store', {
this.active = index this.active = index
setLocalHistory(this.$state) setLocalHistory(this.$state)
}, },
toggleHeartbeat() {
this.heartbeat = !this.heartbeat
},
}, },
}) })

View File

@ -15,7 +15,7 @@ export default defineConfig((env) => {
server: { server: {
port: 1002, port: 1002,
host: '0.0.0.0', host: '0.0.0.0',
open: true, open: false,
proxy: { proxy: {
'/api': { '/api': {
target: viteEnv.VITE_APP_API_BASE_URL, target: viteEnv.VITE_APP_API_BASE_URL,