Files
chatgpt-ui/pages/index.vue
2023-04-03 23:37:50 +08:00

47 lines
1.2 KiB
Vue

<script setup>
definePageMeta({
middleware: ["auth"],
path: '/:id?',
keepalive: true
})
const route = useRoute()
const currentConversation = useConversation()
const conversation = ref(getDefaultConversationData())
const loadConversation = async () => {
const { data, error } = await useAuthFetch('/api/chat/conversations/' + route.params.id)
if (!error.value) {
conversation.value = Object.assign(conversation.value, data.value)
}
}
const loadMessage = async () => {
const { data, error } = await useAuthFetch('/api/chat/messages/?conversationId=' + route.params.id)
if (!error.value) {
conversation.value.messages = data.value
}
}
onMounted(async () => {
if (route.params.id) {
conversation.value.loadingMessages = true
await loadConversation()
await loadMessage()
conversation.value.loadingMessages = false
} else {
conversation.value = getDefaultConversationData()
watch(currentConversation, (val) => {
conversation.value = Object.assign({}, val)
})
}
})
onActivated(async () => {
currentConversation.value = Object.assign({}, conversation.value)
})
</script>
<template>
<Conversation :conversation="conversation" />
</template>