【增加】增加发送 stream 中可以进行取消
parent
c1b9baf8b6
commit
b0de27a721
|
@ -151,7 +151,12 @@
|
||||||
<textarea class="prompt-input" v-model="prompt" @keyup.enter="onSend" placeholder="问我任何问题...(Shift+Enter 换行,按下 Enter 发送)"></textarea>
|
<textarea class="prompt-input" v-model="prompt" @keyup.enter="onSend" placeholder="问我任何问题...(Shift+Enter 换行,按下 Enter 发送)"></textarea>
|
||||||
<div class="prompt-btns">
|
<div class="prompt-btns">
|
||||||
<el-switch/>
|
<el-switch/>
|
||||||
<el-button type="primary" size="default" @click="onSend()">发送</el-button>
|
<el-button type="primary" size="default" @click="onSend()" :loading="conversationInProgress" v-if="conversationInProgress == false">
|
||||||
|
{{ conversationInProgress ? '进行中' : '发送'}}
|
||||||
|
</el-button>
|
||||||
|
<el-button type="danger" size="default" @click="stopStream()" v-if="conversationInProgress == true">
|
||||||
|
停止
|
||||||
|
</el-button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</el-footer>
|
</el-footer>
|
||||||
|
@ -170,6 +175,8 @@ const { copy } = useClipboard();
|
||||||
const searchName = ref('') // 查询的内容
|
const searchName = ref('') // 查询的内容
|
||||||
const conversationId = ref('1781604279872581648') // 对话id
|
const conversationId = ref('1781604279872581648') // 对话id
|
||||||
const conversationInProgress = ref<Boolean>() // 对话进行中
|
const conversationInProgress = ref<Boolean>() // 对话进行中
|
||||||
|
conversationInProgress.value = false
|
||||||
|
|
||||||
const conversationInAbortController = ref<any>() // 对话进行中 abort 控制器(控制 stream 对话)
|
const conversationInAbortController = ref<any>() // 对话进行中 abort 控制器(控制 stream 对话)
|
||||||
|
|
||||||
const prompt = ref<string>() // prompt
|
const prompt = ref<string>() // prompt
|
||||||
|
@ -204,6 +211,10 @@ const searchConversation = () => {
|
||||||
|
|
||||||
/** send */
|
/** send */
|
||||||
const onSend = async () => {
|
const onSend = async () => {
|
||||||
|
// 进行中不允许发送
|
||||||
|
if (conversationInProgress.value) {
|
||||||
|
return
|
||||||
|
}
|
||||||
const content = prompt.value;
|
const content = prompt.value;
|
||||||
// 清空输入框
|
// 清空输入框
|
||||||
prompt.value = ''
|
prompt.value = ''
|
||||||
|
@ -322,12 +333,19 @@ const onDelete = async (id) => {
|
||||||
message: '删除成功!',
|
message: '删除成功!',
|
||||||
type: 'success',
|
type: 'success',
|
||||||
})
|
})
|
||||||
|
// tip:如果 stream 进行中的 message,就需要调用 controller 结束
|
||||||
|
stopStream()
|
||||||
|
// 重新获取 message 列表
|
||||||
|
await messageList();
|
||||||
|
}
|
||||||
|
|
||||||
|
const stopStream = async () => {
|
||||||
// tip:如果 stream 进行中的 message,就需要调用 controller 结束
|
// tip:如果 stream 进行中的 message,就需要调用 controller 结束
|
||||||
if (conversationInAbortController.value) {
|
if (conversationInAbortController.value) {
|
||||||
conversationInAbortController.value.abort()
|
conversationInAbortController.value.abort()
|
||||||
}
|
}
|
||||||
// 重新获取 message 列表
|
// 设置为 false
|
||||||
await messageList();
|
conversationInProgress.value = false
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 初始化 **/
|
/** 初始化 **/
|
||||||
|
|
Loading…
Reference in New Issue