Browse Source

feat:消息列表组件增加图像分析敏感词显示判断;新增敏感词枚举;新增每次消息结束后重新获取点数信息;

dxj
李朋徽 1 year ago
parent
commit
a8acb98afd
  1. 28
      src/components/AppMessage/index.vue
  2. 42
      src/enums/mqttEnum.ts
  3. 2
      src/hooks/useMqtt.ts

28
src/components/AppMessage/index.vue

@ -9,6 +9,7 @@ import { MessageStatusEnum, MessageTypeEnum } from '@/enums/messageEnum'
import { MenuTypeEnum } from '@/enums/menuEnum'
import { copyText } from '@/utils/copyTextToClipboard'
import { useMessageStore } from '@/store/moules/messageStore/index'
import { MqttContentErrorEnum } from '@/enums/mqttEnum'
const props = defineProps({
elIndex: {
@ -133,27 +134,24 @@ onMounted(async () => {
>
<img class="icon-ai" src="@/assets/images/conversation/logo.png" alt="">
<div class="content" :class="[aiWidthType === 'auto' ? 'width-auto' : 'width-full']">
<MdPreview
v-if="
conversationData?.type === MenuTypeEnum.TEXT_TO_TEXT
|| conversationData?.type === MenuTypeEnum.ROLE
|| conversationData?.type === MenuTypeEnum.REPOSITORY
|| conversationData?.type === MenuTypeEnum.VISUAL_ANALYSIS
"
:editor-id="`preview-only-ai${index}`"
:model-value="item.content"
/>
<div v-if="conversationData?.type === MenuTypeEnum.TEXT_TO_IMAGE" class="pt-2 pb-2">
<Image
v-if="!item.content.includes(MqttContentErrorEnum.SENSITIVE_WORD)"
class="mb-2"
:width="200"
:height="200"
:src="item.content"
fallback=""
></Image>
<p v-if="!item.content.includes('http')">
<p v-if="!item.content.includes('http')" class="mb-0">
{{ item.content }}
</p>
</div>
<MdPreview
v-else
:editor-id="`preview-only-ai${index}`"
:model-value="item.content"
/>
</div>
<div v-if="item.messageType !== MessageTypeEnum.DESCRIBE" class="w-full">
<div v-if="item.messageStatus === MessageStatusEnum.ERROR" class="error">
@ -165,7 +163,13 @@ onMounted(async () => {
<SvgIcon class="icon" name="copy"></SvgIcon>
复制
</div>
<div v-if="index === list.length - 1" class="reload" @click="reloadMessage">
<div
v-if="
index === list.length - 1
&& conversationData?.type !== MenuTypeEnum.VISUAL_ANALYSIS"
class="reload"
@click="reloadMessage"
>
<SvgIcon class="icon" name="again"></SvgIcon>
重新回答
</div>

42
src/enums/mqttEnum.ts

@ -1,11 +1,3 @@
/*
* @Description:
* @Author: yeke
* @Date: 2024-01-09 14:10:43
* @LastEditors: yeke
* @LastEditTime: 2024-01-10 14:25:19
*/
/**
* @description: mqtt
* @param UNCONNECTED
@ -17,22 +9,22 @@
*/
export enum MqttConnectStateEnum {
// 未连接
UNCONNECTED = "unConnected",
UNCONNECTED = 'unConnected',
// 连接中
CONNECTING = "connecting",
CONNECTING = 'connecting',
// 已连接
CONNECTED = "connected",
CONNECTED = 'connected',
// 连接失败
CONNECT_FAILED = "connectFailed",
CONNECT_FAILED = 'connectFailed',
// 断开连接
DISCONNECTED = "disConnected",
DISCONNECTED = 'disConnected',
// 断开中
DISCONNECTING = "disconnecting",
DISCONNECTING = 'disconnecting',
// 断开失败
DISCONNECT_FAILED = "disconnectFailed",
DISCONNECT_FAILED = 'disconnectFailed',
// 重连中
RECONNECTING = "reConnecting",
RECONNECTING = 'reConnecting',
}
/**
@ -44,11 +36,19 @@ export enum MqttConnectStateEnum {
*/
export enum MqttSubcribeStateEnum {
// 未订阅
UNSUBSCRIBED = "unSubscribed",
UNSUBSCRIBED = 'unSubscribed',
// 订阅中
SUBSCRIBING = "subscribing",
SUBSCRIBING = 'subscribing',
// 订阅成功
SUBSCRIBE_SUCCESS = "subscribeSuccess",
SUBSCRIBE_SUCCESS = 'subscribeSuccess',
// 订阅失败
SUBSCRIBE_FAILED = "subscribeFailed",
SUBSCRIBE_FAILED = 'subscribeFailed',
}
/**
* @description: mqtt message_content
* @param SENSITIVE_WORD
*/
export enum MqttContentErrorEnum {
SENSITIVE_WORD = '不符合安全规范,请重新输入',
}

2
src/hooks/useMqtt.ts

@ -4,7 +4,6 @@ import { MqttService } from '@/utils/mqtt'
import { useUserStore } from '@/store/moules/userStore/index'
import { useMessageStore } from '@/store/moules/messageStore/index'
import { MessageStatusEnum, MessageTypeEnum, ModelTypeEnum } from '@/enums/messageEnum'
import { MenuTypeEnum } from '@/enums/menuEnum'
export function useMqtt() {
const userStore = useUserStore()
@ -64,6 +63,7 @@ export function useMqtt() {
avatar: '',
messageStatus: MessageStatusEnum.END,
})
userStore.getChatInfoFun()
}
})
})

Loading…
Cancel
Save