From 09a7dbdf5c1c41bfa163a169965dbb8de5739eba Mon Sep 17 00:00:00 2001 From: luyuan <1162963624@qq.com> Date: Wed, 5 Aug 2020 10:47:08 +0800 Subject: [PATCH] 1 --- main.js | 5 +- pages/information/information.vue | 13 + static/imservice.js | 481 ++++++++++++++++++++++++++++++ static/restapi.js | 79 +++++ 4 files changed, 576 insertions(+), 2 deletions(-) create mode 100644 static/imservice.js create mode 100644 static/restapi.js diff --git a/main.js b/main.js index d85f00a..66cc346 100644 --- a/main.js +++ b/main.js @@ -1,11 +1,12 @@ import Vue from 'vue' import App from './App' - +import IMService from './static/imservice.js' import uView from "uview-ui"; Vue.config.productionTip = false Vue.use(uView); App.mpType = 'app' - +Vue.prototype.imService = new IMService(); +Vue.prototype.a = 1; import store from '@/common/store/index.js' Vue.prototype.$store = store; diff --git a/pages/information/information.vue b/pages/information/information.vue index 80dcc2c..2db2f7a 100644 --- a/pages/information/information.vue +++ b/pages/information/information.vue @@ -91,6 +91,19 @@ onLoad() { // /消息模块的请求 this.messageIndex() + if(this.$store.state.hasLogin){ + const user = uni.getStorageSync('user_info'); + console.log(user) + this.imService.login(user.member.member_id,user.member.member_nickname,user.member.member_avatar) + this.imService.connectIM() + let that = this + setTimeout(function(){ + that.imService.disconnect() + },1000) + setTimeout(function(){ + that.imService.connectIM() + },2000) + } }, methods: { // 选中某个复选框时,由checkbox时触发 diff --git a/static/imservice.js b/static/imservice.js new file mode 100644 index 0000000..4e8d1b6 --- /dev/null +++ b/static/imservice.js @@ -0,0 +1,481 @@ +/* + * @Author: jack.lu + * @Date: 2020-4-21 10:10:20 + * @Last Modified by: jack.lu + * @Last Modified time: 2020-4-21 15:01:41 + */ + +import GoEasyIM from './goeasy-im-1.0.9'; +import restApi from './restapi'; + +function Friend(uuid, name, avatar) { + this.uuid = uuid; + this.name = name; + this.avatar = avatar; + this.online = false; + this.unReadMessage = 0; +} + +function Group(uuid, name, avatar) { + this.uuid = uuid; + this.name = name; + this.avatar = avatar; + this.unReadMessage = 0; +} + +function CurrentUser(uuid, name, avatar) { + this.uuid = uuid; + this.name = name; + this.avatar = avatar; +} + +function IMService() { + this.im = GoEasyIM.getInstance({ + host:'hangzhou.goeasy.io',//qos=1 + appkey:'BC-453aa755c4ea48148abefc55a86df283' + }); + //当前“我” + this.currentUser = null; + //我的好友 + this.friends = {}; + //我的群 + this.groups = {}; + //私聊消息记录,map格式,每个好友对应一个数组 + this.privateMessages = {}; + + //群聊消息记录,map格式,每个群对应一个数组 + this.groupMessages = {}; + + /* + * 监听器们 + * + * 可以在页面里,根据需求,重写以下监听器, + * 便于当各种事件触发时,页面能够执行对应的响应 + * + */ + //收到一条私聊消息 + this.onNewPrivateMessageReceive = function (friendId, message) {}; + //完成一次私聊历史加载 + this.onPrivateHistoryLoad = function (friendId, messages) {}; + //收到一条群聊消息 + this.onNewGroupMessageReceive = function (groupId, message) {}; + //完成一次群聊历史加载 + this.onGroupHistoryLoad = function (groupId, messages) {}; + //好友列表发生改变 + this.onFriendListChange = function (friends) {}; + //群列表发生改变 + this.onGroupListChange = function (groups) {}; +} + +//登录 +IMService.prototype.login = function (uuid, name, avatar) { + //初始化当前用户 + this.currentUser = new CurrentUser(uuid, name, avatar); + //初始化联系人信息,包括群 + // this.initialContacts(); + return true; + +}; + +//初始化联系人信息 +IMService.prototype.initialContacts = function (friendList) { + //查询并初始化好友信息 + // let friendList = restApi.findFriends(this.currentUser); + + //将用户列表初始化为一个map,便于后续根据friendId得到friend + friendList.map(friend => { + this.friends[friend.uuid] = new Friend(friend.uuid, friend.name, friend.avatar); + }); + + //查询并初始化与自己相关的群信息 + // let groupList = restApi.findGroups(this.currentUser); + + // //将群列表初始化为一个map,方便后续根据groupId索引 + // groupList.map(group => { + // this.groups[group.uuid] = new Group(group.uuid, group.name, group.avatar); + // }); +}; + +//获取群成员 +IMService.prototype.getGroupMembers = function (groupId) { + let members = restApi.findGroupMembers(groupId); + let membersMap = {}; + members.map(item => { + membersMap[item.uuid] = item + }); + return membersMap; +}; + +IMService.prototype.getGroupMessages = function (groupId) { + if (!this.groupMessages[groupId]) { + this.groupMessages[groupId] = { + sentMessages:[], + pendingMessages:[] + }; + } + return this.groupMessages[groupId] +}; + + +IMService.prototype.getPrivateMessages = function (friendId) { + if (!this.privateMessages[friendId]) { + this.privateMessages[friendId] = { + sentMessages:[], + pendingMessages:[] + }; + } + return this.privateMessages[friendId] +}; + +//重置群聊未读消息 +IMService.prototype.resetGroupUnReadMessage = function (group) { + this.groups[group.uuid].unReadMessage = 0; + this.onGroupListChange(this.groups); +}; + +//将好友的未读消息数字清零 +IMService.prototype.resetFriendUnReadMessage = function (friend) { + if(friend && friend.uuid){ + this.friends[friend.uuid].unReadMessage = 0; + } + this.onFriendListChange(this.friends); +}; + +//连接GoEasy +IMService.prototype.connectIM = function () { + //初始化IM相关的监听器 + this.initialIMListeners(); + this.im.connect({ + id: this.currentUser.uuid, + data: { + avatar: this.currentUser.avatar, + name: this.currentUser.name + } + }).then(() => { + console.log('连接成功') + //订阅与自己相关的群信息 + this.subscribeGroupMessage(); + //初始化好友们的在线状态 + this.initialFriendOnlineStatus(); + //订阅我的好友们的上下线信息 + this.subscribeFriendsPresence(); + }).catch(error => { + console.log('连接失败,请确保网络正常,appkey和host正确,code:' + error.code + " content:" + error.content); + }); +}; + +//IM监听 +IMService.prototype.initialIMListeners = function () { + this.im.on(GoEasyIM.EVENT.CONNECTED, () => { + console.log('连接成功.') + }); + + this.im.on(GoEasyIM.EVENT.DISCONNECTED, () => { + console.log('连接断开.') + }); + + //监听好友上下线 + this.im.on(GoEasyIM.EVENT.USER_PRESENCE, (user) => { + console.log(user) + //更新好友在线状态 + let onlineStatus = user.action == 'online' ? true : false; + let friend = this.friends[user.userId]; + friend.online = onlineStatus; + + //如果页面传入了相应的listener,执行listener + this.onFriendListChange(this.friends); + }); + + //监听私聊消息 + this.im.on(GoEasyIM.EVENT.PRIVATE_MESSAGE_RECEIVED, (message) => { + console.log(message) + //如果不是自己发的,朋友未读消息数 +1 + if (message.senderId != this.currentUser.uuid) { + let friend = this.friends[message.senderId]; + if(friend && friend == undefined){ + const token = uni.getStorageSync('token'); + console.log(token,that.id) + uni.request({ + url:"https://dmmall.sdbairui.com/api/Specialci/getAtwillUserInfo", + data:{ + userId:message.senderId + }, + method:"POST", + header:{ + "Authorization" : 'Bearer' + " " + token + }, + success(res){ + console.log(res) + } + }) + }else{ + friend.unReadMessage++; + this.onFriendListChange(this.friends); + } + + } + //更新私聊消息记录 + let friendId; + if (this.currentUser.uuid == message.senderId) { + friendId = message.receiverId; + } else { + friendId = message.senderId; + } + removePrivatePendingMessage(this, friendId, message); + + let friendMessages = this.getPrivateMessages(friendId); + friendMessages.sentMessages.push(message); + + //如果页面传入了相应的listener,执行listener + this.onNewPrivateMessageReceive(friendId, message); + }); + + //监听群聊消息 + this.im.on(GoEasyIM.EVENT.GROUP_MESSAGE_RECEIVED, (message) => { + let groupId = message.groupId; + //群未读消息+1 + let group = this.groups[groupId]; + group.unReadMessage++; + removeGroupPendingMessage(this, groupId, message); + //如果页面传入了相应的listener,执行listener + this.onGroupListChange(this.groups); + + //更新群聊消息记录 + let groupMessages = this.getGroupMessages(groupId); + let sentMessages = groupMessages.sentMessages; + sentMessages.push(message); + //如果页面传入了相应的listener,执行listener + this.onNewGroupMessageReceive(groupId, message); + }) +}; + + +//订阅群消息 +IMService.prototype.subscribeGroupMessage = function () { + let groupIds = Object.keys(this.groups); + this.im.subscribeGroup(groupIds) + .then(() => { + console.log('订阅群消息成功') + }) + .catch(error => { + console.log('订阅群消息失败') + console.log(error) + }) +}; + +//初始化好友在线状态 +IMService.prototype.initialFriendOnlineStatus = function () { + let friendIds = Object.keys(this.friends); + this.im.hereNow({ + userIds: friendIds + }).then(result => { + let onlineFriends = result.content; + onlineFriends.map(user => { + let friend = this.friends[user.userId]; + friend.online = true; + }); + this.onFriendListChange(this.friends); + }).catch(error => { + console.log(error) + if (error.code == 401) { + console.log("获取在线用户失败,您尚未开通用户在线状态,请登录GoEasy,查看应用详情里自助启用."); + } + }) +}; + +//监听所有好友上下线 +IMService.prototype.subscribeFriendsPresence = function () { + let friendIds = Object.keys(this.friends); + this.im.subscribeUserPresence(friendIds) + .then(() => { + console.log('监听好友上下线成功') + }) + .catch(error => { + console.log(error); + if (error.code == 401) { + console.log("监听好友上下线失败,您尚未开通用户状态提醒,请登录GoEasy,查看应用详情里自助启用."); + } + }); +}; + +//加载单聊历史消息 +IMService.prototype.loadPrivateHistoryMessage = function (friendId, timeStamp) { + this.im.history({ + friendId: friendId, + lastTimestamp: timeStamp + }).then(result => { + let history = result.content; + let privateMessages = this.getPrivateMessages(friendId); + let friendMessages = privateMessages.sentMessages; + for (let i = history.length - 1; i >=0; i--) { + friendMessages.unshift(history[i]) + } + //如果页面传入了相应的listener,执行listener + this.onPrivateHistoryLoad(friendId, history); + }).catch(error => { + console.log(error); + if (error.code == 401) { + console.log("您尚未开通历史消息,请登录GoEasy,查看应用详情里自助启用."); + } + }) +}; + +//发送私聊消息 +IMService.prototype.sendPrivateTextMessage = function (friendId, text) { + let textMessage = this.im.createTextMessage({ + text: text + }); + this.sendPrivateMessage(friendId, textMessage); +}; + +//私聊图片消息 +IMService.prototype.sendPrivateImageMessage = function (friendId, imageFile) { + let imageMessage = this.im.createImageMessage({ + file: imageFile, + onProgress :function (progress) { + console.log(progress) + } + }); + this.sendPrivateMessage(friendId, imageMessage); +}; + +//私聊视频消息 +IMService.prototype.sendPrivateVideoMessage = function (friendId, videoFile) { + let videoMessage = this.im.createVideoMessage({ + file: videoFile, + onProgress :function (progress) { + console.log(progress) + } + }); + this.sendPrivateMessage(friendId, videoMessage); +}; + +IMService.prototype.sendPrivateAudioMessage = function (friendId, audiofile) { + let audioMessage = this.im.createAudioMessage({ + file: audiofile, + onProgress :function (progress) { + console.log(progress) + } + }); + + this.sendPrivateMessage(friendId, audioMessage); +}; + +//发送私聊消息 +IMService.prototype.sendPrivateMessage = function (friendId, message) { + + //加入pendingMessage列表,成功后将会被挪除 + let privateMessages = this.getPrivateMessages(friendId); + privateMessages.pendingMessages.push(message); + + //发送 + this.im.sendPrivateMessage(friendId, message) + .then((res) => { + console.log(res) + }) + .catch(e => { + console.log(e) + }) +}; + +//发送群聊消息 +IMService.prototype.sendGroupTextMessage = function (groupId, message) { + let textMessage = this.im.createTextMessage({ + text:message + }); + this.sendGroupMessage(groupId, textMessage); +}; +//私聊图片消息 +IMService.prototype.sendGroupImageMessage = function (groupId, imageFile) { + let imageMessage = this.im.createImageMessage({ + file: imageFile, + onProgress :function (progress) { + console.log(progress) + } + }); + this.sendGroupMessage(groupId, imageMessage); +}; + + +//私聊视频消息 +IMService.prototype.sendGroupVideoMessage = function (groupId, videoFile) { + let videoMessage = this.im.createVideoMessage({ + file: videoFile, + onProgress :function (progress) { + console.log(progress) + } + }); + this.sendGroupMessage(groupId, videoMessage); +}; + +IMService.prototype.sendGroupAudioMessage = function (groupId, audioFile) { + let audioMessage = this.im.createAudioMessage({ + file: audioFile, + onProgress :function (progress) { + console.log(progress) + } + }); + this.sendGroupMessage(groupId, audioMessage); +}; + +IMService.prototype.sendGroupMessage =function(groupId, groupMessage) { + //先放入Pending列表,待成功后挪除 + let groupMessages = this.getGroupMessages(groupId); + let pendingMessages = groupMessages.pendingMessages; + pendingMessages.push(groupMessage) + + this.im.sendGroupMessage(groupId, groupMessage) + .then((res) => { + console.log(res) + }) + .catch(e => { + console.log(e) + }) +} + +//群聊历史消息 +IMService.prototype.loadGroupHistoryMessage = function (groupId, timeStamp) { + this.im.history({ + groupId: groupId, + lastTimestamp: timeStamp + }).then(result => { + let history = result.content; + let groupMessages = this.getGroupMessages(groupId); + let sentGroupMessages = groupMessages.sentMessages; + for (let i = history.length - 1; i >= 0; i--) { + sentGroupMessages.unshift(history[i]); + } + this.onGroupHistoryLoad(groupId, history); + }).catch(error => { + console.log(error) + if (error.code == 401) { + console.log("您尚未开通历史消息,请登录GoEasy,查看应用详情里自助启用."); + } + }) +}; + +IMService.prototype.disconnect = function () { + this.im.disconnect() +}; + + +function removePrivatePendingMessage(imService,friendId, message){ + let privateMessages = imService.getPrivateMessages(friendId); + let pendingMessages = privateMessages.pendingMessages; + let pendingMessageIndex = pendingMessages.findIndex(item => item.messageId == message.messageId); + if(pendingMessageIndex > -1) { + pendingMessages.splice(pendingMessageIndex,1); + } +} + + +function removeGroupPendingMessage(imService,groupId, message){ + let groupMessages = imService.getGroupMessages(groupId); + let pendingMessages = groupMessages.pendingMessages; + let pendingMessageIndex = pendingMessages.findIndex(item => item.messageId == message.messageId); + if(pendingMessageIndex > -1) { + pendingMessages.splice(pendingMessageIndex,1); + } +} + +export default IMService; \ No newline at end of file diff --git a/static/restapi.js b/static/restapi.js new file mode 100644 index 0000000..52df538 --- /dev/null +++ b/static/restapi.js @@ -0,0 +1,79 @@ +//用户数据示例 +let users = [ + { + "uuid": "08c0a6ec-a42b-47b2-bb1e-15e0f5f9a19a", + "name": "Mattie", + "password": "123", + "avatar": '../../static/images/Avatar-1.png' + }, + { + "uuid": "3bb179af-bcc5-4fe0-9dac-c05688484649", + "name": "Wallace", + "password": "123", + "avatar": '../../static/images/Avatar-2.png' + }, + { + "uuid": "fdee46b0-4b01-4590-bdba-6586d7617f95", + "name": "Tracy", + "password": "123", + "avatar": '../../static/images/Avatar-3.png' + }, + { + "uuid": "33c3693b-dbb0-4bc9-99c6-fa77b9eb763f", + "name": "Juanita", + "password": "123", + "avatar": '../../static/images/Avatar-4.png' + } +]; + +//群数据示例 +let groups = [ + { + "uuid": "group-a42b-47b2-bb1e-15e0f5f9a19a", + "name": "群1", + "userList": ['08c0a6ec-a42b-47b2-bb1e-15e0f5f9a19a', '3bb179af-bcc5-4fe0-9dac-c05688484649', 'fdee46b0-4b01-4590-bdba-6586d7617f95', '33c3693b-dbb0-4bc9-99c6-fa77b9eb763f'] + }, + { + "uuid": "group-4b01-4590-bdba-6586d7617f95", + "name": "群2", + "userList": ['08c0a6ec-a42b-47b2-bb1e-15e0f5f9a19a', 'fdee46b0-4b01-4590-bdba-6586d7617f95', '33c3693b-dbb0-4bc9-99c6-fa77b9eb763f'] + }, + { + "uuid": "group-dbb0-4bc9-99c6-fa77b9eb763f", + "name": "群3", + "userList": ['08c0a6ec-a42b-47b2-bb1e-15e0f5f9a19a', '3bb179af-bcc5-4fe0-9dac-c05688484649'] + } +]; + + +function RestApi() { + +} + +RestApi.prototype.findFriends = function (user) { + var friendList = users.filter(v => v.uuid != user.uuid); + return friendList; +} + +RestApi.prototype.findGroups = function (user) { + var groupList = groups.filter(v => v.userList.find(id => id == user.uuid)); + return groupList; +} + +RestApi.prototype.findUser = function (username, password) { + var user = users.find(user => (user.name == username && user.password == password)) + return user; +} + +RestApi.prototype.findGroupMembers = function (groupId) { + let members = []; + let group = groups.find(v => v.uuid == groupId); + users.map(user => { + if (group.userList.find(v => v == user.uuid)) { + members.push(user) + } + }); + return members; +} + +export default new RestApi(); \ No newline at end of file