52857f09ea
As discussed in similar issue there: https://github.com/GoogleChrome/chromedeveditor/issues/1023 - it is not possible to add onClosed event listener on an 'abstract' current window property, it needs to be set on the particular window instance instead. Before that change, the clean up function was never actually called, because the listener was never properly attached. That was probably the reason of existence for "panel isn't actually open ... and so we try again." code that was executed if the previous window wasn't cleaned up properly (so actually every time). This code is no longer needed, I guess, as the windows are now cleaned up properly.
218 lines
7.4 KiB
JavaScript
218 lines
7.4 KiB
JavaScript
/*global $, Whisper, Backbone, textsecure, extension*/
|
|
/* vim: ts=4:sw=4:expandtab:
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
// This script should only be included in background.html
|
|
// Whisper.windowMap is defined in background.js
|
|
(function () {
|
|
'use strict';
|
|
|
|
window.Whisper = window.Whisper || {};
|
|
|
|
var windowMap = new Whisper.Bimap('windowId', 'modelId');
|
|
var conversations = new Whisper.ConversationCollection();
|
|
|
|
window.inbox = new Whisper.ConversationCollection([], {
|
|
comparator: function(model) {
|
|
return -model.get('active_at');
|
|
}
|
|
});
|
|
|
|
inbox.on('change:active_at', inbox.sort);
|
|
inbox.on('change:unreadCount', function(model, count) {
|
|
var prev = model.previous('unreadCount') || 0;
|
|
if (count < prev) { // decreased
|
|
var newUnreadCount = storage.get("unreadCount", 0) - (prev - count);
|
|
setUnreadCount(newUnreadCount);
|
|
storage.put("unreadCount", newUnreadCount);
|
|
}
|
|
});
|
|
|
|
function updateInbox() {
|
|
conversations.fetchActive().then(function() {
|
|
inbox.reset(conversations.filter(function(model) {
|
|
return model.get('active_at');
|
|
}));
|
|
});
|
|
}
|
|
|
|
extension.on('updateInbox', updateInbox);
|
|
updateInbox();
|
|
setUnreadCount(storage.get("unreadCount", 0));
|
|
|
|
function setUnreadCount(count) {
|
|
if (count > 0) {
|
|
extension.navigator.setBadgeText(count);
|
|
} else {
|
|
extension.navigator.setBadgeText("");
|
|
}
|
|
}
|
|
|
|
window.getConversationForWindow = function(windowId) {
|
|
return conversations.get(windowMap.modelIdFrom(windowId));
|
|
};
|
|
|
|
window.updateConversation = function(conversationId) {
|
|
var conversation = conversations.get(conversationId);
|
|
if (conversation) {
|
|
conversation.fetch();
|
|
conversation.fetchMessages();
|
|
}
|
|
};
|
|
|
|
function closeConversation (windowId) {
|
|
windowMap.remove('windowId', windowId);
|
|
}
|
|
|
|
window.getConversation = function(attrs) {
|
|
var conversation = window.inbox.get(attrs.id) || attrs;
|
|
conversation = conversations.add(conversation);
|
|
return conversation;
|
|
};
|
|
|
|
window.notifyConversation = function(message) {
|
|
var conversationId = message.get('conversationId');
|
|
var windowId = windowMap.windowIdFrom(conversationId);
|
|
if (windowId) {
|
|
// already open
|
|
updateConversation(conversationId);
|
|
extension.windows.drawAttention(windowId);
|
|
} else if (Whisper.Notifications.isEnabled()) {
|
|
var conversation = getConversation({id: message.get('conversationId')});
|
|
var sender = getConversation({id: message.get('source')});
|
|
conversation.fetch().then(function() {
|
|
sender.fetch().then(function() {
|
|
var notification = new Notification(sender.getTitle(), {
|
|
body: message.getDescription(),
|
|
icon: sender.getAvatarUrl(),
|
|
tag: conversation.id
|
|
});
|
|
notification.onclick = function() {
|
|
openConversation(conversation.id);
|
|
};
|
|
});
|
|
});
|
|
conversation.fetchMessages();
|
|
} else {
|
|
openConversation(conversationId);
|
|
extension.windows.drawAttention(windowId);
|
|
}
|
|
};
|
|
|
|
window.openConversation = function openConversation (modelId) {
|
|
var conversation = getConversation({id: modelId});
|
|
conversation.fetch().then(function() {
|
|
conversation.fetchContacts();
|
|
});
|
|
conversation.fetchMessages();
|
|
|
|
var windowId = windowMap.windowIdFrom(modelId);
|
|
|
|
// prevent multiple copies of the same conversation from being opened
|
|
if (!windowId) {
|
|
// open the panel
|
|
extension.windows.open({
|
|
id: modelId,
|
|
url: 'conversation.html',
|
|
type: 'panel',
|
|
frame: 'none',
|
|
focused: true,
|
|
width: 300,
|
|
height: 440
|
|
}, function (windowInfo) {
|
|
windowId = windowInfo.id;
|
|
windowMap.add({ windowId: windowId, modelId: modelId });
|
|
|
|
windowInfo.onClosed.addListener(function () {
|
|
onWindowClosed(windowId);
|
|
});
|
|
|
|
// close the panel if background.html is refreshed
|
|
extension.windows.beforeUnload(function() {
|
|
// TODO: reattach after reload instead of closing.
|
|
extension.windows.remove(windowId);
|
|
});
|
|
});
|
|
} else {
|
|
// focus the panel
|
|
extension.windows.focus(windowId, function (error) {
|
|
if (error) {
|
|
closeConversation(windowId); // panel isn't actually open...
|
|
openConversation(modelId); // ...and so we try again.
|
|
}
|
|
});
|
|
}
|
|
};
|
|
|
|
/* Inbox window controller */
|
|
var inboxOpened = false;
|
|
var inboxWindowId = 'inbox';
|
|
window.openInbox = function() {
|
|
if (inboxOpened === false) {
|
|
inboxOpened = true;
|
|
extension.windows.open({
|
|
id: 'inbox',
|
|
url: 'index.html',
|
|
type: 'panel',
|
|
frame: 'none',
|
|
focused: true,
|
|
width: 260, // 280 for chat
|
|
height: 440 // 420 for chat
|
|
}, function (windowInfo) {
|
|
inboxWindowId = windowInfo.id;
|
|
|
|
windowInfo.onClosed.addListener(function () {
|
|
onWindowClosed(inboxWindowId);
|
|
});
|
|
|
|
// close the panel if background.html is refreshed
|
|
extension.windows.beforeUnload(function() {
|
|
// TODO: reattach after reload instead of closing.
|
|
extension.windows.remove(inboxWindowId);
|
|
});
|
|
});
|
|
} else if (inboxOpened === true) {
|
|
extension.windows.focus(inboxWindowId, function (error) {
|
|
if (error) {
|
|
inboxOpened = false;
|
|
openInbox();
|
|
}
|
|
});
|
|
}
|
|
};
|
|
|
|
extension.onLaunched(function() {
|
|
storage.onready(function() {
|
|
if (textsecure.registration.isDone()) {
|
|
openInbox();
|
|
} else {
|
|
extension.install();
|
|
}
|
|
});
|
|
});
|
|
|
|
// make sure windows are cleaned up on close
|
|
var onWindowClosed = function (windowId) {
|
|
if (windowMap.windowId[windowId]) {
|
|
closeConversation(windowId);
|
|
}
|
|
|
|
if (windowId === inboxWindowId) {
|
|
inboxWindowId = 0;
|
|
inboxOpened = false;
|
|
}
|
|
};
|
|
})();
|