mirror of
				https://gitee.com/hhyykk/ipms-sjy-ui.git
				synced 2025-11-04 20:28:45 +08:00 
			
		
		
		
	REVIEW 公众号的自动回复菜单
This commit is contained in:
		@@ -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',
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user