REVIEW 公众号的自动回复菜单
parent
a3b4edf505
commit
48e50190e0
|
@ -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>
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
// 消息类型(Follow: 关注时回复;Message: 消息回复;Keyword: 关键词回复)
|
// 消息类型(Follow: 关注时回复;Message: 消息回复;Keyword: 关键词回复)
|
||||||
// 作为tab.name,enum的数字不能随意修改,与api参数相关
|
// 作为 tab.name,enum 的数字不能随意修改,与 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 @Dhb52:ObjData 这个类名可以在看看,ObjData 有点通用
|
||||||
export interface ObjData {
|
export interface ObjData {
|
||||||
type: ReplyType
|
type: ReplyType
|
||||||
accountId?: number
|
accountId?: number
|
||||||
|
|
|
@ -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',
|
||||||
|
|
Loading…
Reference in New Issue