Destroy all globals
Well, not *all* globals..
This commit is contained in:
parent
c0681beca7
commit
fd3a72d435
7 changed files with 30 additions and 40 deletions
|
@ -181,6 +181,4 @@
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
Whisper.Conversations = new Whisper.ConversationCollection();
|
|
||||||
})();
|
})();
|
||||||
|
|
|
@ -28,10 +28,6 @@
|
||||||
if (missing.length) {
|
if (missing.length) {
|
||||||
console.log("Message missing attributes: " + missing);
|
console.log("Message missing attributes: " + missing);
|
||||||
}
|
}
|
||||||
},
|
|
||||||
|
|
||||||
conversation: function() {
|
|
||||||
return Whisper.Conversations.get(this.get('conversationId'));
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,6 @@ var Whisper = Whisper || {};
|
||||||
tagName: 'div',
|
tagName: 'div',
|
||||||
id: 'contacts',
|
id: 'contacts',
|
||||||
itemView: Whisper.ConversationListItemView,
|
itemView: Whisper.ConversationListItemView,
|
||||||
collection: Whisper.Conversations,
|
|
||||||
|
|
||||||
events: {
|
events: {
|
||||||
'click .contact': 'select',
|
'click .contact': 'select',
|
||||||
|
|
|
@ -14,9 +14,9 @@
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
(function () {
|
(function () {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
window.Whisper = window.Whisper || {};
|
window.Whisper = window.Whisper || {};
|
||||||
|
|
||||||
Whisper.InboxView = Backbone.View.extend({
|
Whisper.InboxView = Backbone.View.extend({
|
||||||
initialize: function () {
|
initialize: function () {
|
||||||
|
@ -27,16 +27,21 @@
|
||||||
window.addEventListener('resize', this.resize.bind(this));
|
window.addEventListener('resize', this.resize.bind(this));
|
||||||
this.conversations = new Whisper.ConversationCollection();
|
this.conversations = new Whisper.ConversationCollection();
|
||||||
|
|
||||||
new Whisper.ConversationListView({el: $('#contacts'), collection: Whisper.Conversations});
|
new Whisper.ConversationListView({
|
||||||
Whisper.Conversations.fetch({reset: true}).then(function() {
|
el : $('#contacts'),
|
||||||
if (Whisper.Conversations.length) {
|
collection : this.conversations
|
||||||
Whisper.Conversations.at(0).trigger('render');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this.conversations.fetch({reset: true}).then(function() {
|
||||||
|
if (this.conversations.length) {
|
||||||
|
this.conversations.at(0).trigger('render');
|
||||||
|
}
|
||||||
|
}.bind(this));
|
||||||
|
|
||||||
extension.onMessage('message', function(message) {
|
extension.onMessage('message', function(message) {
|
||||||
Whisper.Conversations.fetch({id: message.conversationId}).then(function() {
|
this.conversations.fetch({id: message.conversationId}).then(function() {
|
||||||
Whisper.Conversations.get(message.conversationId).fetchMessages();
|
this.conversations.get(message.conversationId).fetchMessages();
|
||||||
});
|
}.bind(this));
|
||||||
}.bind(this));
|
}.bind(this));
|
||||||
|
|
||||||
},
|
},
|
||||||
|
@ -44,18 +49,21 @@
|
||||||
'click #new-message': 'new_message',
|
'click #new-message': 'new_message',
|
||||||
'click #new-group': 'new_group'
|
'click #new-group': 'new_group'
|
||||||
},
|
},
|
||||||
|
|
||||||
new_message: function (e) {
|
new_message: function (e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
$('.conversation').hide().trigger('close'); // detach any existing conversation views
|
$('.conversation').hide().trigger('close'); // detach any existing conversation views
|
||||||
this.view = new Whisper.NewConversationView();
|
this.view = new Whisper.NewConversationView({
|
||||||
//todo: less new
|
collection: this.conversations
|
||||||
|
});
|
||||||
|
this.setContent(this.view.render().$el.show());
|
||||||
},
|
},
|
||||||
|
|
||||||
new_group: function (e) {
|
new_group: function (e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
$('.conversation').trigger('close'); // detach any existing conversation views
|
$('.conversation').trigger('close'); // detach any existing conversation views
|
||||||
new Whisper.NewGroupView();
|
var view = new Whisper.NewGroupView({
|
||||||
|
collection: this.conversations
|
||||||
|
});
|
||||||
|
this.setContent(view.render().$el.show());
|
||||||
},
|
},
|
||||||
resize: function (e) {
|
resize: function (e) {
|
||||||
var windowheight = window.innerHeight,
|
var windowheight = window.innerHeight,
|
||||||
|
|
|
@ -53,7 +53,7 @@ var Whisper = Whisper || {};
|
||||||
initialize: function() {
|
initialize: function() {
|
||||||
this.template = $('#new-message-form').html();
|
this.template = $('#new-message-form').html();
|
||||||
Mustache.parse(this.template);
|
Mustache.parse(this.template);
|
||||||
this.render();
|
this.$el.html($(Mustache.render(this.template)));
|
||||||
this.input = new MessageRecipientInputView({el: this.$el.find('input.number')});
|
this.input = new MessageRecipientInputView({el: this.$el.find('input.number')});
|
||||||
this.fileInput = new Whisper.FileInputView({el: this.$el.find('.attachments')});
|
this.fileInput = new Whisper.FileInputView({el: this.$el.find('.attachments')});
|
||||||
},
|
},
|
||||||
|
@ -67,7 +67,7 @@ var Whisper = Whisper || {};
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
var number = this.input.verifyNumber();
|
var number = this.input.verifyNumber();
|
||||||
if (number) {
|
if (number) {
|
||||||
var convo = Whisper.Conversations.findOrCreateForRecipient(number);
|
var convo = this.collection.findOrCreateForRecipient(number);
|
||||||
var message_input = this.$el.find('input.send-message');
|
var message_input = this.$el.find('input.send-message');
|
||||||
var message = message_input.val();
|
var message = message_input.val();
|
||||||
if (message.length > 0 || this.fileInput.hasFiles()) {
|
if (message.length > 0 || this.fileInput.hasFiles()) {
|
||||||
|
@ -79,12 +79,6 @@ var Whisper = Whisper || {};
|
||||||
this.remove();
|
this.remove();
|
||||||
convo.trigger('render');
|
convo.trigger('render');
|
||||||
}
|
}
|
||||||
},
|
|
||||||
|
|
||||||
render: function() {
|
|
||||||
this.$el.html(Mustache.render(this.template));
|
|
||||||
Whisper.Layout.setContent(this.$el.show());
|
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ var Whisper = Whisper || {};
|
||||||
initialize: function() {
|
initialize: function() {
|
||||||
this.template = $('#new-group-form').html();
|
this.template = $('#new-group-form').html();
|
||||||
Mustache.parse(this.template);
|
Mustache.parse(this.template);
|
||||||
this.render();
|
this.$el.html($(Mustache.render(this.template)));
|
||||||
this.input = this.$el.find('input.number');
|
this.input = this.$el.find('input.number');
|
||||||
new Whisper.GroupRecipientsInputView({el: this.$el.find('input.numbers')}).$el.appendTo(this.$el);
|
new Whisper.GroupRecipientsInputView({el: this.$el.find('input.numbers')}).$el.appendTo(this.$el);
|
||||||
},
|
},
|
||||||
|
@ -37,17 +37,11 @@ var Whisper = Whisper || {};
|
||||||
var numbers = this.$el.find('input.numbers').val().split(',');
|
var numbers = this.$el.find('input.numbers').val().split(',');
|
||||||
var name = this.$el.find('input.name').val();
|
var name = this.$el.find('input.name').val();
|
||||||
var view = this;
|
var view = this;
|
||||||
Whisper.Conversations.createGroup(numbers, name).then(function(convo){
|
this.collection.createGroup(numbers, name).then(function(convo){
|
||||||
convo.sendMessage(view.$el.find('input.send-message').val());
|
convo.sendMessage(view.$el.find('input.send-message').val());
|
||||||
view.remove();
|
view.remove();
|
||||||
convo.trigger('render');
|
convo.trigger('render');
|
||||||
});
|
});
|
||||||
},
|
|
||||||
|
|
||||||
render: function() {
|
|
||||||
this.$el.prepend($(Mustache.render(this.template)));
|
|
||||||
Whisper.Layout.setContent(this.$el.show());
|
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
describe('MessageView', function() {
|
describe('MessageView', function() {
|
||||||
|
var conversations = new Whisper.ConversationCollection();
|
||||||
before(function(done) {
|
before(function(done) {
|
||||||
Whisper.Conversations.fetch().then(done);
|
conversations.fetch().then(done);
|
||||||
});
|
});
|
||||||
|
|
||||||
var convo = Whisper.Conversations.add({id: 'foo'});
|
var convo = conversations.add({id: 'foo'});
|
||||||
var message = convo.messages().add({
|
var message = convo.messages().add({
|
||||||
conversationId: convo.id,
|
conversationId: convo.id,
|
||||||
body: 'hello world',
|
body: 'hello world',
|
||||||
|
|
Loading…
Reference in a new issue