2015-12-04 17:20:05 +01:00
|
|
|
/*
|
2016-01-07 12:44:50 +01:00
|
|
|
Copyright 2015, 2016 OpenMarket Ltd
|
2015-12-04 17:20:05 +01:00
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2016-01-06 19:07:24 +01:00
|
|
|
var MatrixClientPeg = require('./MatrixClientPeg');
|
|
|
|
|
2015-12-04 17:20:05 +01:00
|
|
|
module.exports = {
|
|
|
|
/**
|
|
|
|
* Returns true iff this event arriving in a room should affect the room's
|
|
|
|
* count of unread messages
|
|
|
|
*/
|
|
|
|
eventTriggersUnreadCount: function(ev) {
|
|
|
|
if (ev.getType() == "m.room.member") {
|
|
|
|
return false;
|
|
|
|
} else if (ev.getType == 'm.room.message' && ev.getContent().msgtype == 'm.notify') {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
2016-01-06 19:07:24 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
doesRoomHaveUnreadMessages: function(room) {
|
|
|
|
var readUpToId = room.getEventReadUpTo(MatrixClientPeg.get().credentials.userId);
|
2016-01-06 19:28:13 +01:00
|
|
|
// this just looks at whatever history we have, which if we've only just started
|
|
|
|
// up probably won't be very much, so if the last couple of events are ones that
|
|
|
|
// don't count, we don't know if there are any events that do count between where
|
|
|
|
// we have and the read receipt. We could fetch more history to try & find out,
|
2016-01-21 14:22:13 +01:00
|
|
|
// but currently we just guess.
|
|
|
|
|
|
|
|
// Loop through messages, starting with the most recent...
|
2016-01-06 19:07:24 +01:00
|
|
|
for (var i = room.timeline.length - 1; i >= 0; --i) {
|
|
|
|
var ev = room.timeline[i];
|
|
|
|
|
|
|
|
if (ev.getId() == readUpToId) {
|
2016-01-21 14:22:13 +01:00
|
|
|
// If we've read up to this event, there's nothing more recents
|
|
|
|
// that counts and we can stop looking because the user's read
|
|
|
|
// this and everything before.
|
|
|
|
return false;
|
|
|
|
} else if (this.eventTriggersUnreadCount(ev)) {
|
|
|
|
// We've found a message that counts before we hit
|
|
|
|
// the read marker, so this room is definitely unread.
|
|
|
|
return true;
|
2016-01-06 19:07:24 +01:00
|
|
|
}
|
|
|
|
}
|
2016-01-21 14:22:13 +01:00
|
|
|
// If we got here, we didn't find a message that counted but didn't
|
|
|
|
// find the read marker either, so we guess and say that the room
|
|
|
|
// is unread on the theory that false positives are better than
|
|
|
|
// false negatives here.
|
|
|
|
return true;
|
2015-12-04 17:20:05 +01:00
|
|
|
}
|
|
|
|
};
|