mp:支持 wx-reply 发送图片消息

pull/2/head
YunaiV 2023-01-12 00:24:04 +08:00
parent ec872c702c
commit 29cf770457
3 changed files with 215 additions and 112 deletions

View File

@ -94,3 +94,6 @@ export function setTenantId(username) {
export function removeTenantId() {
localStorage.removeItem(TenantIdKey)
}
export class getToken {
}

View File

@ -81,7 +81,7 @@
</div>
</div>
<div class="msg-send" v-loading="sendLoading">
<WxReplySelect :objData="objData"></WxReplySelect>
<wx-reply-select :objData="objData" />
<el-button type="success" size="small" class="send-but" @click="sendMsg">(S)</el-button>
</div>
</div>
@ -95,6 +95,7 @@ import {getMessagePage, sendMessage} from '@/api/mp/message'
import WxNews from '@/views/mp/components/wx-news/main.vue';
import WxLocation from '@/views/mp/components/wx-location/main.vue';
import WxMusic from '@/views/mp/components/wx-music/main.vue';
import {getUser} from "@/api/mp/user";
export default {
name: "wxMsg",
@ -110,7 +111,7 @@ import {getMessagePage, sendMessage} from '@/api/mp/message'
userId: {
type: String,
required: true
}
},
},
data() {
return {
@ -126,17 +127,27 @@ import {getMessagePage, sendMessage} from '@/api/mp/message'
user: { // 使
nickname: '用户',
avatar: require("@/assets/images/profile.jpg"),
accountId: 0, //
},
mp: {
nickname: '公众号',
avatar: require("@/assets/images/wechat.png"),
},
objData:{ //
repType: 'text'
objData: { //
type: 'text',
},
}
},
created() {
//
getUser(this.userId).then(response => {
this.user.nickname = response.data.nickname | this.user.nickname;
this.user.avatar = response.data.avatar | this.user.avatar;
//
this.objData.accountId = response.data.accountId;
})
//
this.refreshChange()
},
methods:{
@ -144,7 +155,7 @@ import {getMessagePage, sendMessage} from '@/api/mp/message'
if (!this.objData) {
return;
}
if (this.objData.repType === 'news') {
if (this.objData.type === 'news') {
this.objData.content.articles = [this.objData.content.articles[0]]
this.$message({
showClose: true,
@ -157,7 +168,6 @@ import {getMessagePage, sendMessage} from '@/api/mp/message'
userId: this.userId
}, {
...this.objData,
type: this.objData.repType,
// content: this.objData.repContent,
// TODO
})).then(response => {
@ -167,7 +177,8 @@ import {getMessagePage, sendMessage} from '@/api/mp/message'
this.scrollToBottom()
// objData
this.objData = {
repType: 'text'
type: 'text',
content: '',
}
}).catch(() => {
this.sendLoading = false

View File

@ -1,30 +1,36 @@
<!--
- Copyright (C) 2018-2019
- All rights reserved, Designed By www.joolun.com
芋道源码
移除多余的 rep 为前缀的变量 message 消息更简单
代码优化补充注释提升阅读性
-->
<template>
<el-tabs type="border-card" v-model="objData.repType" @tab-click="handleClick">
<el-tabs type="border-card" v-model="objData.type" @tab-click="handleClick">
<!-- 类型 1文本 -->
<el-tab-pane name="text">
<span slot="label"><i class="el-icon-document"></i> 文本</span>
<el-input type="textarea" :rows="5" placeholder="请输入内容" v-model="objData.content" />
<el-input type="textarea" :rows="5" placeholder="请输入内容" v-model="objData.content" @input="inputContent" />
</el-tab-pane>
<!-- 类型 2图片 -->
<el-tab-pane name="image">
<span slot="label"><i class="el-icon-picture"></i> 图片</span>
<el-row>
<div class="select-item" v-if="objData.repUrl">
<img class="material-img" :src="objData.repUrl">
<p class="item-name" v-if="objData.repName">{{objData.repName}}</p>
<!-- 情况一已经选择好素材或者上传好图片 -->
<div class="select-item" v-if="objData.url">
<img class="material-img" :src="objData.url">
<el-row class="ope-row">
<el-button type="danger" icon="el-icon-delete" circle @click="deleteObj"></el-button>
</el-row>
</div>
<div v-if="!objData.repUrl">
<!-- 情况二未做完上述操作 -->
<div v-else>
<el-row style="text-align: center">
<!-- 选择素材 -->
<el-col :span="12" class="col-select">
<el-button type="success" @click="openMaterial"><i class="el-icon-circle-check el-icon--right"></i></el-button>
</el-col>
<!-- 文件上传 -->
<el-col :span="12" class="col-add">
<el-upload :action="actionUrl" :headers="headers" multiple :limit="1" :file-list="fileList" :data="uploadData"
:before-upload="beforeImageUpload" :on-success="handleUploadSuccess">
@ -34,6 +40,7 @@
</el-col>
</el-row>
</div>
<!-- 点击选择素材会打开下面的弹窗 -->
<el-dialog title="选择图片" :visible.sync="dialogImageVisible" width="90%" append-to-body>
<WxMaterialSelect :objData="objData" @selectMaterial="selectMaterial"></WxMaterialSelect>
</el-dialog>
@ -82,7 +89,7 @@
<el-input v-model="objData.repDesc" placeholder="请输入描述"></el-input>
<div style="margin: 20px 0;"></div>
<div style="text-align: center;">
<a target="_blank" v-if="objData.repUrl" :href="objData.repUrl"><i class="icon-shipinbofang">&nbsp;</i></a>
<a target="_blank" v-if="objData.url" :href="objData.url"><i class="icon-shipinbofang">&nbsp;</i></a>
</div>
<div style="margin: 20px 0;"></div>
<div style="text-align: center">
@ -138,7 +145,7 @@
</div>
</div>
<el-dialog title="选择图片" :visible.sync="dialogThumbVisible" width="80%" append-to-body>
<WxMaterialSelect :objData="{repType:'image'}" @selectMaterial="selectMaterial"></WxMaterialSelect>
<WxMaterialSelect :objData="{type:'image'}" @selectMaterial="selectMaterial"></WxMaterialSelect>
</el-dialog>
</el-col>
<el-col :span="18">
@ -148,7 +155,7 @@
</el-col>
</el-row>
<div style="margin: 20px 0;"></div>
<el-input v-model="objData.repUrl" placeholder="请输入音乐链接"></el-input>
<el-input v-model="objData.url" placeholder="请输入音乐链接"></el-input>
<div style="margin: 20px 0;"></div>
<el-input v-model="objData.repHqUrl" placeholder="请输入高质量音乐链接"></el-input>
</el-tab-pane>
@ -160,7 +167,7 @@
import WxNews from '@/views/mp/components/wx-news/main.vue'
// import WxMaterialSelect from '@/components/wx-material-select/main.vue'
import WxVoicePlayer from '@/views/mp/components/wx-voice-play/main.vue';
import { getToken } from '@/utils/auth'
import {getAccessToken, getToken} from '@/utils/auth'
export default {
name: "wxReplySelect",
@ -170,11 +177,11 @@
WxVoicePlayer
},
props: {
objData:{
type: Object
objData: { //
type: Object, // Object 便
required: true,
},
// 12稿
newsType:{
newsType:{ // 12稿
type: String,
default: "1"
},
@ -193,124 +200,176 @@
descs:[]//
},
tableLoading: false,
dialogNewsVisible:false,
dialogImageVisible:false,
dialogVoiceVisible:false,
dialogVideoVisible:false,
dialogThumbVisible:false,
tempObj: new Map().set(this.objData.repType,Object.assign({},this.objData)),
fileList:[],
uploadData:{
"mediaType":this.objData.repType,
tempObj: new Map().set( // tab
this.objData.type, //
Object.assign({}, this.objData)), //
// ========== ==========
dialogNewsVisible: false, //
dialogImageVisible: false, //
dialogVoiceVisible: false, //
dialogVideoVisible: false, //
dialogThumbVisible: false, //
// ========== ==========
fileList: [], //
uploadData: {
"accountId": undefined,
"type": this.objData.type,
"title":'',
"introduction":''
},
actionUrl: process.env.VUE_APP_BASE_API +'/wxmaterial/materialFileUpload',
headers: {
Authorization: 'Bearer ' + getToken()
}
actionUrl: process.env.VUE_APP_BASE_API +'/admin-api/mp/material/upload-temporary',
headers: { Authorization: "Bearer " + getAccessToken() }, //
}
},
computed: {
},
methods:{
beforeThumbImageUpload(file){
const isType = file.type === 'image/jpeg' || file.type === 'image/png' || file.type === 'image/gif' || file.type === 'image/bmp' || file.type === 'image/jpg';
const isLt = file.size / 1024 / 1024 < 2;
const isType = file.type === 'image/jpeg'
|| file.type === 'image/png'
|| file.type === 'image/gif'
|| file.type === 'image/bmp'
|| file.type === 'image/jpg';
if (!isType) {
this.$message.error('上传图片格式不对!');
return false;
}
const isLt = file.size / 1024 / 1024 < 2;
if (!isLt) {
this.$message.error('上传图片大小不能超过2M!');
this.$message.error('上传图片大小不能超过 2M!');
return false;
}
return isType && isLt;
},
deleteObj(){
this.$delete(this.objData,'repName')
this.$delete(this.objData,'repUrl')
this.$delete(this.objData,'content')
this.uploadData.accountId = this.objData.accountId;
return true;
},
beforeVoiceUpload(file){
this.tableLoading = true
const isType = file.type === 'audio/mp3' || file.type === 'audio/wma' || file.type === 'audio/wav' || file.type === 'audio/amr';
const isLt = file.size / 1024 / 1024 < 2;
//
const isType = file.type === 'audio/mp3'
|| file.type === 'audio/wma'
|| file.type === 'audio/wav'
|| file.type === 'audio/amr';
if (!isType) {
this.$message.error('上传语音格式不对!');
return false;
}
//
const isLt = file.size / 1024 / 1024 < 2;
if (!isLt) {
this.$message.error('上传语音大小不能超过2M!');
this.$message.error('上传语音大小不能超过 2M!');
return false;
}
return isType && isLt;
this.uploadData.accountId = this.objData.accountId;
return true;
},
beforeImageUpload(file){
const isType = file.type === 'image/jpeg' || file.type === 'image/png' || file.type === 'image/gif' || file.type === 'image/bmp' || file.type === 'image/jpg';
const isLt = file.size / 1024 / 1024 < 2;
//
const isType = file.type === 'image/jpeg'
|| file.type === 'image/png'
|| file.type === 'image/gif'
|| file.type === 'image/bmp'
|| file.type === 'image/jpg';
if (!isType) {
this.$message.error('上传图片格式不对!');
return false;
}
//
const isLt = file.size / 1024 / 1024 < 2;
if (!isLt) {
this.$message.error('上传图片大小不能超过2M!');
this.$message.error('上传图片大小不能超过 2M!');
return false;
}
return isType && isLt;
this.uploadData.accountId = this.objData.accountId;
return true;
},
handleUploadSuccess(response, file, fileList){
if(response.code == 200){
this.fileList = []
this.uploadData.title = ''
this.uploadData.introduction = ''
let item = response.data
this.selectMaterial(item)
}else{
handleUploadSuccess(response, file, fileList) {
if (response.code !== 0) {
this.$message.error('上传出错:' + response.msg)
return false;
}
},
handleClick(tab, event){
this.uploadData.mediaType = this.objData.repType
let tempObjItem = this.tempObj.get(this.objData.repType)
if(tempObjItem){
this.objData.repName = tempObjItem.repName ? tempObjItem.repName : null
this.objData.repMediaId = tempObjItem.repMediaId ? tempObjItem.repMediaId : null
this.objData.media_id = tempObjItem.media_id ? tempObjItem.media_id : null
this.objData.repUrl = tempObjItem.repUrl ? tempObjItem.repUrl : null
this.objData.content = tempObjItem.content ? tempObjItem.content : null
this.objData.repDesc = tempObjItem.repDesc ? tempObjItem.repDesc : null
}else{
this.$delete(this.objData,'repName')
this.$delete(this.objData,'repMediaId')
this.$delete(this.objData,'media_id')
this.$delete(this.objData,'repUrl')
this.$delete(this.objData,'content')
this.$delete(this.objData,'repDesc')
}
},
selectMaterial(item){
let tempObjItem = {}
tempObjItem.repType = this.objData.repType
tempObjItem.repMediaId = item.mediaId
tempObjItem.media_id = item.mediaId
tempObjItem.content = item.content
this.dialogNewsVisible = false
this.dialogImageVisible = false
this.dialogVoiceVisible = false
this.dialogVideoVisible = false
this.objData.repMediaId = item.mediaId
this.objData.media_id = item.mediaId
//
this.fileList = []
this.uploadData.title = ''
this.uploadData.introduction = ''
//
let item = response.data
this.selectMaterial(item)
},
/**
* 切换消息类型的 tab
*
* @param tab tab
*/
handleClick(tab) {
//
this.uploadData.type = this.objData.type;
if (this.uploadData.type === 'music') { //
this.uploadData.type = 'thumb';
}
// tempObj objData
let tempObjItem = this.tempObj.get(this.objData.type)
// console.log(this.objData.type)
// console.log(tempObjItem)
console.log(this.objData)
// console.log(this.tempObj)
if (tempObjItem) {
this.objData.content = tempObjItem.content ? tempObjItem.content : null
this.objData.mediaId = tempObjItem.mediaId ? tempObjItem.mediaId : null
this.objData.url = tempObjItem.url ? tempObjItem.url : null
// TODO
// this.objData.repName = tempObjItem.repName ? tempObjItem.repName : null
// this.objData.repMediaId = tempObjItem.repMediaId ? tempObjItem.repMediaId : null
// this.objData.repDesc = tempObjItem.repDesc ? tempObjItem.repDesc : null
return;
}
// objData
this.objData.mediaId = undefined;
this.objData.content = undefined;
// this.$delete(this.objData,'repName')
// this.$delete(this.objData,'repMediaId')
// this.$delete(this.objData,'mediaId')
// this.$delete(this.objData,'url')
// this.$delete(this.objData,'content') // TODO
// this.$delete(this.objData,'repDesc')
},
/**
* 选择素材将设置设置到 objData 变量
*
* @param item 素材
*/
selectMaterial(item) {
//
this.closeMaterial();
// tempObjItem
let tempObjItem = {}
tempObjItem.type = this.objData.type
tempObjItem.mediaId = item.mediaId
// tempObjItem.repMediaId = item.mediaId // TODO
// tempObjItem.content = item.content // TODO
// this.objData.repMediaId = item.mediaId
this.objData.mediaId = item.mediaId
this.objData.content = item.content
if(this.objData.repType == 'music'){
if (this.objData.type === 'music') {
tempObjItem.repThumbMediaId = item.mediaId
tempObjItem.repThumbUrl = item.url
this.objData.repThumbMediaId = item.mediaId
this.objData.repThumbUrl = item.url
this.dialogThumbVisible = false
}else{
tempObjItem.repName = item.name
tempObjItem.repUrl = item.url
this.objData.repName = item.name
this.objData.repUrl = item.url
this.dialogThumbVisible = false // TODO
} else{
// tempObjItem.repName = item.name
// tempObjItem.url = item.url
// this.objData.repName = item.name
this.objData.mediaId = item.mediaId
this.objData.url = item.url
}
if(this.objData.repType == 'video'){
if(this.objData.type == 'video'){
// getMaterialVideo({
// mediaId:item.mediaId
// }).then(response => {
@ -318,33 +377,54 @@
// let data = response.data
// this.$set(this.objData,'repName',data.title)
// this.$set(this.objData,'repDesc',data.description)
// this.$set(this.objData,'repUrl',data.downUrl)
// this.$set(this.objData,'url',data.downUrl)
// tempObjItem.repDesc = data.description
// tempObjItem.repUrl = data.downUrl
// tempObjItem.url = data.downUrl
// }
// })
}
this.tempObj.set(this.objData.repType,tempObjItem)
//
this.tempObj.set(this.objData.type, tempObjItem)
},
openMaterial(){
if(this.objData.repType == 'news'){
openMaterial() {
if (this.objData.type === 'news') {
this.dialogNewsVisible = true
}else if(this.objData.repType == 'image'){
} else if(this.objData.type === 'image') {
this.dialogImageVisible = true
}else if(this.objData.repType == 'voice'){
} else if(this.objData.type === 'voice') {
this.dialogVoiceVisible = true
}else if(this.objData.repType == 'video'){
} else if(this.objData.type === 'video') {
this.dialogVideoVisible = true
}else if(this.objData.repType == 'music'){
} else if(this.objData.type === 'music') {
this.dialogThumbVisible = true
}
},
closeMaterial() {
this.dialogNewsVisible = false
this.dialogImageVisible = false
this.dialogVoiceVisible = false
this.dialogVideoVisible = false
},
deleteObj() {
if (this.objData.type === 'news') {
// TODO
} else if(this.objData.type === 'image') {
this.$delete(this.objData, 'url')
this.$delete(this.objData, 'mediaId')
} else if(this.objData.type === 'voice') {
// TODO
} else if(this.objData.type === 'video') {
// TODO
} else if(this.objData.type === 'music') {
// TODO
}
},
getPage(page, params) {
this.tableLoading = true
// getPage(Object.assign({
// current: page.currentPage,
// size: page.pageSize,
// type:this.objData.repType
// type:this.objData.type
// }, params)).then(response => {
// this.tableData = response.data.items
// this.page.total = response.data.totalCount
@ -357,6 +437,15 @@
this.page.currentPage = 1
this.page.pageSize = val
this.getPage(this.page)
},
/**
* 输入时缓存每次 objData tempObj
*
* why不确定为什么 v-model="objData.content" 不能自动缓存所以通过这样的方式
*/
inputContent() {
let tempObjItem = {...this.objData};
this.tempObj.set(this.objData.type, tempObjItem);
}
}
};