Popout inbox
Rather than opening the inbox in its own window, let it appear as a browser action popup by default, but allow promotion to its own window if requested.
This commit is contained in:
parent
cecb438a52
commit
31e7d285e3
9 changed files with 52 additions and 4 deletions
|
@ -163,6 +163,7 @@
|
||||||
<script type="text/x-tmpl-mustache" id="inbox">
|
<script type="text/x-tmpl-mustache" id="inbox">
|
||||||
<div class='title-bar' id='header'>
|
<div class='title-bar' id='header'>
|
||||||
<div class='socket-status'></div>
|
<div class='socket-status'></div>
|
||||||
|
<button class='popout hide'></button>
|
||||||
</div>
|
</div>
|
||||||
<div class='gutter'>
|
<div class='gutter'>
|
||||||
<div class='conversations scrollable'></div>
|
<div class='conversations scrollable'></div>
|
||||||
|
|
BIN
images/popout.png
Normal file
BIN
images/popout.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 451 B |
|
@ -67,8 +67,6 @@
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
extension.browserAction(window.openInbox);
|
|
||||||
|
|
||||||
// refresh views
|
// refresh views
|
||||||
var views = extension.windows.getViews();
|
var views = extension.windows.getViews();
|
||||||
for (var i = 0; i < views.length; ++i) {
|
for (var i = 0; i < views.length; ++i) {
|
||||||
|
|
15
js/index.js
15
js/index.js
|
@ -20,10 +20,23 @@
|
||||||
|
|
||||||
window.Whisper = window.Whisper || {};
|
window.Whisper = window.Whisper || {};
|
||||||
if (bg.textsecure.storage.getUnencrypted("number_id") === undefined) {
|
if (bg.textsecure.storage.getUnencrypted("number_id") === undefined) {
|
||||||
window.location = '/options.html';
|
extension.navigator.tabs.create('/options.html');
|
||||||
|
window.close();
|
||||||
} else {
|
} else {
|
||||||
new bg.Whisper.InboxView().$el.prependTo(bg.$('body',document));
|
new bg.Whisper.InboxView().$el.prependTo(bg.$('body',document));
|
||||||
bg.textsecure.storage.putUnencrypted("unreadCount", 0);
|
bg.textsecure.storage.putUnencrypted("unreadCount", 0);
|
||||||
extension.navigator.setBadgeText("");
|
extension.navigator.setBadgeText("");
|
||||||
|
|
||||||
|
window.addEventListener('beforeunload', function () {
|
||||||
|
chrome.browserAction.setPopup({popup: 'index.html'}); // pop in
|
||||||
|
});
|
||||||
|
|
||||||
|
extension.windows.getCurrent(function (windowInfo) {
|
||||||
|
if (windowInfo.type === 'normal') {
|
||||||
|
bg.$('body', document).addClass('pop-in');
|
||||||
|
} else {
|
||||||
|
bg.$('.popout', document).remove();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}());
|
}());
|
||||||
|
|
|
@ -129,6 +129,12 @@
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
window.popoutInbox = function() {
|
||||||
|
chrome.browserAction.setPopup({popup: ''});
|
||||||
|
extension.browserAction(window.openInbox);
|
||||||
|
window.openInbox();
|
||||||
|
};
|
||||||
|
|
||||||
// make sure windows are cleaned up on close
|
// make sure windows are cleaned up on close
|
||||||
extension.windows.onClosed(function (windowId) {
|
extension.windows.onClosed(function (windowId) {
|
||||||
if (windowMap.windowId[windowId]) {
|
if (windowMap.windowId[windowId]) {
|
||||||
|
|
|
@ -80,6 +80,10 @@
|
||||||
events: {
|
events: {
|
||||||
'click .fab': 'showCompose',
|
'click .fab': 'showCompose',
|
||||||
'select .contact': 'openConversation',
|
'select .contact': 'openConversation',
|
||||||
|
'click .popout': 'popout'
|
||||||
|
},
|
||||||
|
popout: function() {
|
||||||
|
bg.popoutInbox();
|
||||||
},
|
},
|
||||||
openConversation: function(e, data) {
|
openConversation: function(e, data) {
|
||||||
bg.openConversation(data.modelId);
|
bg.openConversation(data.modelId);
|
||||||
|
|
|
@ -16,7 +16,8 @@
|
||||||
"default_icon": {
|
"default_icon": {
|
||||||
"19": "icon.png"
|
"19": "icon.png"
|
||||||
},
|
},
|
||||||
"default_title": "TextSecure"
|
"default_title": "TextSecure",
|
||||||
|
"default_popup": "index.html"
|
||||||
},
|
},
|
||||||
|
|
||||||
"background": {
|
"background": {
|
||||||
|
|
|
@ -95,6 +95,11 @@ input.search {
|
||||||
}
|
}
|
||||||
|
|
||||||
.index {
|
.index {
|
||||||
|
&.pop-in {
|
||||||
|
min-height: 330px;
|
||||||
|
min-width: 260px;
|
||||||
|
}
|
||||||
|
|
||||||
color: $grey_d;
|
color: $grey_d;
|
||||||
background: #eee;
|
background: #eee;
|
||||||
|
|
||||||
|
@ -136,3 +141,12 @@ input.search {
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.popout {
|
||||||
|
float: right;
|
||||||
|
background: url('/images/popout.png') no-repeat center center;
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.title-bar:hover .popout {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
|
@ -319,6 +319,9 @@ input.search {
|
||||||
.index {
|
.index {
|
||||||
color: #454545;
|
color: #454545;
|
||||||
background: #eee; }
|
background: #eee; }
|
||||||
|
.index.pop-in {
|
||||||
|
min-height: 330px;
|
||||||
|
min-width: 260px; }
|
||||||
.index .new-group-update-form {
|
.index .new-group-update-form {
|
||||||
display: none;
|
display: none;
|
||||||
padding: 0.5em; }
|
padding: 0.5em; }
|
||||||
|
@ -345,6 +348,14 @@ input.search {
|
||||||
.conversations .unread .contact-details .last-timestamp {
|
.conversations .unread .contact-details .last-timestamp {
|
||||||
font-weight: bold; }
|
font-weight: bold; }
|
||||||
|
|
||||||
|
.popout {
|
||||||
|
float: right;
|
||||||
|
background: url("/images/popout.png") no-repeat center center;
|
||||||
|
display: none; }
|
||||||
|
|
||||||
|
.title-bar:hover .popout {
|
||||||
|
display: inline-block; }
|
||||||
|
|
||||||
.conversation {
|
.conversation {
|
||||||
padding: 36px 0; }
|
padding: 36px 0; }
|
||||||
.conversation .file-input .close {
|
.conversation .file-input .close {
|
||||||
|
|
Loading…
Reference in a new issue