1
0
mirror of https://github.com/moparisthebest/kaiwa synced 2025-01-11 13:48:42 -05:00

Streamline resource specific properties

This commit is contained in:
Lance Stout 2013-09-13 00:08:48 -07:00
parent 1a95d60a3b
commit 2f544b82b3
2 changed files with 75 additions and 48 deletions

View File

@ -227,22 +227,7 @@ module.exports = function (client, app) {
}); });
} }
if (!contact.activeContact && msg.from.bare === contact.jid) { contact.addMessage(message, true);
contact.unreadCount++;
app.notifier.show({
title: contact.displayName,
description: msg.body,
icon: contact.avatar,
onclick: _.bind(app.navigate, app, '/chat/' + contact.jid)
});
}
contact.messages.add(message);
var newInteraction = new Date(message.created);
if (!contact.lastInteraction || contact.lastInteraction < newInteraction) {
contact.lastInteraction = newInteraction;
}
if (!contact.lockedResource) { if (!contact.lockedResource) {
contact.lockedResource = msg.from.full; contact.lockedResource = msg.from.full;

View File

@ -35,25 +35,70 @@ module.exports = HumanModel.define({
groups: ['array', true, []], groups: ['array', true, []],
avatarID: ['string', true, ''] avatarID: ['string', true, '']
}, },
session: {
topResource: 'string',
lockedResource: 'string',
offlineStatus: ['string', true, ''],
avatar: 'string',
chatState: ['string', true, 'gone'],
lastSentMessage: 'object',
activeContact: ['bool', true, false],
unreadCount: ['number', true, 0],
lastInteraction: 'date'
},
derived: { derived: {
displayName: { displayName: {
deps: ['name', 'jid'], deps: ['name', 'jid'],
fn: function () { fn: function () {
if (this.name) { return this.name || this.jid;
return this.name;
}
return this.jid;
} }
}, },
status: { status: {
deps: ['topResourceStatus', 'offlineStatus'], deps: ['topResource', 'lockedResource', 'offlineStatus'],
fn: function () { fn: function () {
if (this.topResourceStatus) { if (this.lockedResource) {
return this.topResourceStatus; return this.resources.get(this.lockedResource).status;
}
if (this.topResource) {
return this.resources.get(this.topResource).status;
} }
return this.offlineStatus; return this.offlineStatus;
} }
}, },
show: {
deps: ['topResource', 'lockedResource'],
fn: function () {
if (this.lockedResource) {
return this.resources.get(this.lockedResource).show || 'online';
}
if (this.topResource) {
return this.resources.get(this.topResource).show || 'online';
}
return 'offline';
}
},
idleSince: {
deps: ['topResource', 'lockedResource'],
fn: function () {
if (this.lockedResource) {
return this.resources.get(this.lockedResource).idleSince;
}
if (this.topResource) {
return this.resources.get(this.topResource).idleSince;
}
}
},
timezoneOffset: {
deps: ['topResource', 'lockedResource'],
fn: function () {
if (this.lockedResource) {
return this.resources.get(this.lockedResource).timezoneOffset;
}
if (this.topResource) {
return this.resources.get(this.topResource).timezoneOffset;
}
}
},
formattedTZO: { formattedTZO: {
deps: ['timezoneOffset', 'displayName'], deps: ['timezoneOffset', 'displayName'],
fn: function () { fn: function () {
@ -77,20 +122,6 @@ module.exports = HumanModel.define({
} }
} }
}, },
session: {
topResourceStatus: ['string', true, ''],
offlineStatus: ['string', true, ''],
idleSince: 'date',
avatar: 'string',
show: ['string', true, 'offline'],
chatState: ['string', true, 'gone'],
lockedResource: 'string',
lastSentMessage: 'object',
timezoneOffset: ['number', false, 0],
activeContact: ['bool', true, false],
unreadCount: ['number', true, 0],
lastInteraction: 'date'
},
collections: { collections: {
resources: Resources, resources: Resources,
messages: Messages messages: Messages
@ -143,14 +174,30 @@ module.exports = HumanModel.define({
var res = this.resources.first(); var res = this.resources.first();
if (res) { if (res) {
this.offlineStatus = ''; this.offlineStatus = '';
this.topResourceStatus = res.status; this.topResource = res.id;
this.show = res.show || 'online';
this.lockedResource = undefined;
} else { } else {
this.topResourceStatus = '';
this.show = 'offline';
this.chatState = 'gone'; this.chatState = 'gone';
} }
this.lockedResource = undefined;
},
addMessage: function (message, notify) {
if (notify && !this.activeContact && message.from.bare === this.jid) {
this.unreadCount++;
app.notifier.show({
title: this.displayName,
description: message.body,
icon: this.avatar,
onclick: _.bind(app.navigate, app, '/chat/' + this.jid)
});
}
this.messages.add(message);
var newInteraction = new Date(message.created);
if (!this.lastInteraction || this.lastInteraction < newInteraction) {
this.lastInteraction = newInteraction;
}
}, },
fetchHistory: function () { fetchHistory: function () {
var self = this; var self = this;
@ -198,12 +245,7 @@ module.exports = HumanModel.define({
var message = new Message(msg); var message = new Message(msg);
message.archivedId = result.mam.id; message.archivedId = result.mam.id;
var newInteraction = new Date(message.created); self.addMessage(message, false);
if (!self.lastInteraction || newInteraction > self.lastInteraction) {
self.lastInteraction = newInteraction;
}
self.messages.add(message);
}); });
}); });
}); });