From f10033a1afd73b60fd09092a42f1565e2cb54b99 Mon Sep 17 00:00:00 2001 From: Igor Zhukov Date: Wed, 6 Jul 2016 19:20:39 +0300 Subject: [PATCH] Fixed message unread --- app/js/lib/mtproto.js | 6 +++--- app/js/messages_manager.js | 19 ++++++++++++------- app/js/services.js | 3 ++- app/partials/desktop/message.html | 4 ++-- app/partials/mobile/message.html | 4 ++-- 5 files changed, 21 insertions(+), 15 deletions(-) diff --git a/app/js/lib/mtproto.js b/app/js/lib/mtproto.js index 2f344f6d..666442e5 100644 --- a/app/js/lib/mtproto.js +++ b/app/js/lib/mtproto.js @@ -1470,7 +1470,7 @@ angular.module('izhukov.mtproto', ['izhukov.utils']) var self = this Storage.get('dc').then(function (baseDcID) { if (baseDcID == self.dcID && !self.upload && updatesProcessor) { - updatesProcessor(message) + updatesProcessor(message, true) } }) break @@ -1551,7 +1551,7 @@ angular.module('izhukov.mtproto', ['izhukov.utils']) // console.log('Update', message) if (updatesProcessor) { - updatesProcessor(message) + updatesProcessor(message, true) } break @@ -1561,7 +1561,7 @@ angular.module('izhukov.mtproto', ['izhukov.utils']) function startAll () { if (akStopped) { akStopped = false - updatesProcessor({_: 'new_session_created'}) + updatesProcessor({_: 'new_session_created'}, true) } } diff --git a/app/js/messages_manager.js b/app/js/messages_manager.js index 1f775d10..fef7a8aa 100644 --- a/app/js/messages_manager.js +++ b/app/js/messages_manager.js @@ -1118,15 +1118,15 @@ angular.module('myApp.services') return } - var toPeerID = AppPeersManager.getPeerID(apiMessage.to_id) + var peerID = getMessagePeer(apiMessage) var isChannel = apiMessage.to_id._ == 'peerChannel' - var channelID = isChannel ? -toPeerID : 0 + var channelID = isChannel ? -peerID : 0 var isBroadcast = isChannel && !AppChatsManager.isMegagroup(channelID) var mid = AppMessagesIDsManager.getFullMessageID(apiMessage.id, channelID) apiMessage.mid = mid - var dialog = getDialogByPeerID(toPeerID)[0] + var dialog = getDialogByPeerID(peerID)[0] if (dialog && mid > 0) { var dialogKey = apiMessage.pFlags.out ? 'read_outbox_max_id' @@ -1137,6 +1137,7 @@ angular.module('myApp.services') else if (options.isNew) { apiMessage.pFlags.unread = true } + // console.log(dT(), 'msg unread', mid, apiMessage.pFlags.out, dialog && dialog[apiMessage.pFlags.out ? 'read_outbox_max_id' : 'read_inbox_max_id']) if (apiMessage.reply_to_msg_id) { apiMessage.reply_to_mid = AppMessagesIDsManager.getFullMessageID(apiMessage.reply_to_msg_id, channelID) @@ -1150,8 +1151,8 @@ angular.module('myApp.services') fwdHeader.date -= ServerTimeManager.serverTimeOffset } - apiMessage.toID = toPeerID - apiMessage.fromID = apiMessage.pFlags.post ? toPeerID : apiMessage.from_id + apiMessage.peerID = peerID + apiMessage.fromID = apiMessage.pFlags.post ? peerID : apiMessage.from_id apiMessage.signID = apiMessage.pFlags.post && apiMessage.from_id || fwdHeader && fwdHeader.channel_id && fwdHeader.from_id @@ -1483,7 +1484,7 @@ angular.module('myApp.services') apiFileName = 'document.' + file.type.split('/')[1] } - console.log(attachType, apiFileName, file.type) + // console.log(attachType, apiFileName, file.type) if (historyStorage === undefined) { historyStorage = historiesStorage[peerID] = {count: null, history: [], pending: []} @@ -2658,6 +2659,7 @@ angular.module('myApp.services') } saveMessages([message], {isNew: true}) + // console.warn(dT(), 'message unread', message.mid, message.pFlags.unread) if (historyStorage !== undefined) { var history = historyStorage.history @@ -2821,6 +2823,8 @@ angular.module('myApp.services') var messageID, message var i + // console.warn(dT(), 'read', peerID, isOut ? 'out' : 'in', maxID) + if (peerID > 0 && isOut) { AppUsersManager.forceUserOnline(peerID) } @@ -2838,7 +2842,7 @@ angular.module('myApp.services') if (!message.pFlags.unread) { break } - // console.log('read', messageID, message.pFlags.unread, message) + // console.warn('read', messageID, message.pFlags.unread, message) if (message && message.pFlags.unread) { message.pFlags.unread = false if (messagesForHistory[messageID]) { @@ -2869,6 +2873,7 @@ angular.module('myApp.services') } if (newUnreadCount !== false) { + // console.warn(dT(), 'cnt', peerID, newUnreadCount) $rootScope.$broadcast('dialog_unread', {peerID: peerID, count: newUnreadCount}) } if (foundAffected) { diff --git a/app/js/services.js b/app/js/services.js index 7c4429b9..9d5aca99 100755 --- a/app/js/services.js +++ b/app/js/services.js @@ -2909,7 +2909,8 @@ angular.module('myApp.services', ['myApp.i18n', 'izhukov.utils']) } } - function processUpdateMessage (updateMessage) { + function processUpdateMessage (updateMessage, fromMTProto) { + // return forceGetDifference() var processOpts = { date: updateMessage.date, seq: updateMessage.seq, diff --git a/app/partials/desktop/message.html b/app/partials/desktop/message.html index 456e7d64..e718c6a6 100644 --- a/app/partials/desktop/message.html +++ b/app/partials/desktop/message.html @@ -8,7 +8,7 @@
- +
@@ -44,7 +44,7 @@
- []  : + []  : diff --git a/app/partials/mobile/message.html b/app/partials/mobile/message.html index 3754a7df..54ec3a9f 100644 --- a/app/partials/mobile/message.html +++ b/app/partials/mobile/message.html @@ -9,7 +9,7 @@
- +
@@ -43,7 +43,7 @@
- +