maxkb/ui/src/views/log/component/ChatRecordDrawer.vue
wangdan-fit2cloud bb11b9bdc1 feat:
2023-12-11 10:35:26 +08:00

130 lines
2.7 KiB
Vue

<template>
<el-drawer
v-model="visible"
size="50%"
append-to-body
@close="closeHandel"
class="chat-record-drawer"
>
<template #header>
<h4>{{ application?.name }}</h4>
</template>
<div
v-loading="paginationConfig.current_page === 1 && loading"
class="h-full"
style="padding: 24px 0"
>
<InfiniteScroll
:size="recordList.length"
:total="paginationConfig.total"
:page_size="paginationConfig.page_size"
v-model:current_page="paginationConfig.current_page"
@load="getChatRecord"
:loading="loading"
>
<AiChat :data="application" :record="recordList" log></AiChat>
</InfiniteScroll>
</div>
<template #footer>
<div>
<el-button @click="pre" :disabled="pre_disable || loading">上一条</el-button>
<el-button @click="next" :disabled="next_disable || loading">下一条</el-button>
</div>
</template>
</el-drawer>
</template>
<script setup lang="ts">
import { ref, reactive, computed, watch } from 'vue'
import { useRoute } from 'vue-router'
import logApi from '@/api/log'
import { type chatType } from '@/api/type/application'
import { type ApplicationFormType } from '@/api/type/application'
const props = withDefaults(
defineProps<{
/**
* 应用信息
*/
application?: ApplicationFormType
/**
* 对话 记录id
*/
chartId?: string
/**
* 下一条
*/
next: () => void
/**
* 上一条
*/
pre: () => void
pre_disable: boolean
next_disable: boolean
}>(),
{}
)
defineEmits(['update:chartId'])
const route = useRoute()
const {
params: { id }
} = route
const loading = ref(false)
const visible = ref(false)
const recordList = ref<chatType[]>([])
const paginationConfig = reactive({
current_page: 1,
page_size: 10,
total: 0
})
function closeHandel() {
recordList.value = []
paginationConfig.total = 0
paginationConfig.current_page = 1
}
function getChatRecord() {
if (props.chartId && visible.value) {
logApi.getChatRecordLog(id as string, props.chartId, paginationConfig, loading).then((res) => {
paginationConfig.total = res.data.total
recordList.value = [...recordList.value, ...res.data.records]
})
}
}
watch(
() => props.chartId,
() => {
recordList.value = []
paginationConfig.total = 0
paginationConfig.current_page = 1
getChatRecord()
}
)
const open = () => {
getChatRecord()
visible.value = true
}
defineExpose({
open
})
</script>
<style lang="scss">
.chat-record-drawer {
.el-drawer__body {
background: var(--app-layout-bg-color);
padding: 0;
}
.el-divider__text {
background: var(--app-layout-bg-color);
}
}
</style>