REVIEW 公众号的自动回复菜单

This commit is contained in:
YunaiV
2023-04-19 19:07:45 +08:00
parent a3b4edf505
commit 48e50190e0
3 changed files with 17 additions and 29 deletions

View File

@@ -93,7 +93,6 @@
</el-table-column> </el-table-column>
</el-table> </el-table>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import WxVideoPlayer from '@/views/mp/components/wx-video-play/main.vue' import WxVideoPlayer from '@/views/mp/components/wx-video-play/main.vue'
import WxVoicePlayer from '@/views/mp/components/wx-voice-play/main.vue' import WxVoicePlayer from '@/views/mp/components/wx-voice-play/main.vue'
@@ -114,5 +113,3 @@ const emit = defineEmits<{
(e: 'on-delete', v: number) (e: 'on-delete', v: number)
}>() }>()
</script> </script>
<style scoped></style>

View File

@@ -1,5 +1,5 @@
// 消息类型Follow: 关注时回复Message: 消息回复Keyword: 关键词回复) // 消息类型Follow: 关注时回复Message: 消息回复Keyword: 关键词回复)
// 作为tab.nameenum的数字不能随意修改与api参数相关 // 作为 tab.nameenum 的数字不能随意修改,与 api 参数相关
export enum MsgType { export enum MsgType {
Follow = 1, Follow = 1,
Message = 2, Message = 2,
@@ -31,6 +31,7 @@ export interface ReplyForm {
responseHqMusicUrl?: string responseHqMusicUrl?: string
} }
// TODO @Dhb52ObjData 这个类名可以在看看ObjData 有点通用
export interface ObjData { export interface ObjData {
type: ReplyType type: ReplyType
accountId?: number accountId?: number

View File

@@ -49,11 +49,12 @@
:loading="loading" :loading="loading"
:list="list" :list="list"
:msg-type="msgType" :msg-type="msgType"
@on-update="(id) => onUpdate(id)" @on-update="onUpdate"
@on-delete="(id) => onDelete(id)" @on-delete="onDelete"
/> />
<!-- 添加或修改自动回复的对话框 --> <!-- 添加或修改自动回复的对话框 -->
<!-- TODO @Dhb52 -->
<el-dialog :title="dialogTitle" v-model="showFormDialog" width="800px" destroy-on-close> <el-dialog :title="dialogTitle" v-model="showFormDialog" width="800px" destroy-on-close>
<el-form ref="formRef" :model="replyForm" :rules="rules" label-width="80px"> <el-form ref="formRef" :model="replyForm" :rules="rules" label-width="80px">
<el-form-item label="消息类型" prop="requestMessageType" v-if="msgType === MsgType.Message"> <el-form-item label="消息类型" prop="requestMessageType" v-if="msgType === MsgType.Message">
@@ -70,7 +71,7 @@
<el-form-item label="匹配类型" prop="requestMatch" v-if="msgType === MsgType.Keyword"> <el-form-item label="匹配类型" prop="requestMatch" v-if="msgType === MsgType.Keyword">
<el-select v-model="replyForm.requestMatch" placeholder="请选择匹配类型" clearable> <el-select v-model="replyForm.requestMatch" placeholder="请选择匹配类型" clearable>
<el-option <el-option
v-for="dict in getDictOptions(DICT_TYPE.MP_AUTO_REPLY_REQUEST_MATCH)" v-for="dict in getIntDictOptions(DICT_TYPE.MP_AUTO_REPLY_REQUEST_MATCH)"
:key="dict.value" :key="dict.value"
:label="dict.label" :label="dict.label"
:value="dict.value" :value="dict.value"
@@ -95,26 +96,19 @@
import WxReplySelect from '@/views/mp/components/wx-reply/main.vue' import WxReplySelect from '@/views/mp/components/wx-reply/main.vue'
import WxAccountSelect from '@/views/mp/components/wx-account-select/main.vue' import WxAccountSelect from '@/views/mp/components/wx-account-select/main.vue'
import * as MpAutoReplyApi from '@/api/mp/autoReply' import * as MpAutoReplyApi from '@/api/mp/autoReply'
import { DICT_TYPE, getDictOptions } from '@/utils/dict' import { DICT_TYPE, getDictOptions, getIntDictOptions } from '@/utils/dict'
import { ContentWrap } from '@/components/ContentWrap' import { ContentWrap } from '@/components/ContentWrap'
import type { TabPaneName } from 'element-plus' import type { TabPaneName } from 'element-plus'
import ReplyTable from './components/ReplyTable.vue' import ReplyTable from './components/ReplyTable.vue'
import { MsgType, ReplyForm, ObjData } from './components/types' import { MsgType, ReplyForm, ObjData } from './components/types'
const message = useMessage() // 消息
const message = useMessage() const msgType = ref<MsgType>(MsgType.Keyword) // 消息类型
const RequestMessageTypes = ['text', 'image', 'voice', 'video', 'shortvideo', 'location', 'link'] // 允许选择的请求消息类型
const formRef = ref() const loading = ref(true) // 遮罩层
const total = ref(0) // 总条数
const msgType = ref<MsgType>(MsgType.Keyword) const list = ref<any[]>([]) // 自动回复列表
// 允许选择的请求消息类型 const formRef = ref() // 表单 ref
const RequestMessageTypes = ['text', 'image', 'voice', 'video', 'shortvideo', 'location', 'link']
// 遮罩层
const loading = ref(true)
// 总条数
const total = ref(0)
// 自动回复列表
const list = ref<any[]>([])
// 查询参数 // 查询参数
interface QueryParams { interface QueryParams {
pageNo: number pageNo: number
@@ -127,13 +121,9 @@ const queryParams: QueryParams = reactive({
accountId: undefined accountId: undefined
}) })
// 弹出层标题 const dialogTitle = ref('') // 弹出层标题
const dialogTitle = ref('') const showFormDialog = ref(false) // 是否显示弹出层
// 是否显示弹出层 const replyForm = ref<ReplyForm>({}) // 表单参数
const showFormDialog = ref(false)
// 表单参数
const replyForm = ref<ReplyForm>({})
// 回复消息 // 回复消息
const objData = ref<ObjData>({ const objData = ref<ObjData>({
type: 'text', type: 'text',