Hook up group creation flow UI
Checkboxes add and remove members as well as exposing the group update ui. The conversation window is opened after saving the group.
This commit is contained in:
parent
b3e32a2642
commit
a00632c728
5 changed files with 60 additions and 9 deletions
|
@ -59,7 +59,7 @@
|
||||||
<div class='group-avatar'>
|
<div class='group-avatar'>
|
||||||
<div><input type='file' name='avatar' class='file-input'></div>
|
<div><input type='file' name='avatar' class='file-input'></div>
|
||||||
</div>
|
</div>
|
||||||
<button>Create group</button>
|
<button class='create-group'>Create group</button>
|
||||||
</div>
|
</div>
|
||||||
<div class='results'>
|
<div class='results'>
|
||||||
<div class='new-contact'></div>
|
<div class='new-contact'></div>
|
||||||
|
|
|
@ -43,7 +43,10 @@ var Whisper = Whisper || {};
|
||||||
|
|
||||||
checkbox: function(e) {
|
checkbox: function(e) {
|
||||||
e.stopPropagation();
|
e.stopPropagation();
|
||||||
this.$el.trigger('checkbox', {modelId: this.model.id});
|
this.$el.trigger('checkbox', {
|
||||||
|
modelId: this.model.id,
|
||||||
|
checked: e.target.checked
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
render: function() {
|
render: function() {
|
||||||
|
|
|
@ -52,6 +52,7 @@
|
||||||
'click .fab': 'showCompose',
|
'click .fab': 'showCompose',
|
||||||
'open #contacts': 'openConversation',
|
'open #contacts': 'openConversation',
|
||||||
'open .contacts': 'openConversation',
|
'open .contacts': 'openConversation',
|
||||||
|
'open .new-conversation': 'openConversation',
|
||||||
'open .new-contact': 'createConversation',
|
'open .new-contact': 'createConversation',
|
||||||
},
|
},
|
||||||
openConversation: function(e, data) {
|
openConversation: function(e, data) {
|
||||||
|
|
|
@ -30,7 +30,7 @@ var Whisper = Whisper || {};
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return s.toLowerCase().split(/[\s\-_+]+/)
|
return s.toLowerCase().split(/[\s\-_+]+/);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -41,6 +41,7 @@ var Whisper = Whisper || {};
|
||||||
Mustache.parse(this.template);
|
Mustache.parse(this.template);
|
||||||
this.$el.html($(Mustache.render(this.template)));
|
this.$el.html($(Mustache.render(this.template)));
|
||||||
this.$input = this.$el.find('input.new-message');
|
this.$input = this.$el.find('input.new-message');
|
||||||
|
this.$group_update = this.$el.find('.new-group-update-form');
|
||||||
|
|
||||||
this.typeahead_collection = new typeahead();
|
this.typeahead_collection = new typeahead();
|
||||||
this.typeahead_view = new Whisper.ConversationListView({
|
this.typeahead_view = new Whisper.ConversationListView({
|
||||||
|
@ -61,18 +62,62 @@ var Whisper = Whisper || {};
|
||||||
type: 'private'
|
type: 'private'
|
||||||
})
|
})
|
||||||
}).render();
|
}).render();
|
||||||
|
|
||||||
|
this.newGroupUpdateView = new Whisper.NewGroupUpdateView({
|
||||||
|
model: new Whisper.Conversation({ type: 'group' }),
|
||||||
|
el: this.$group_update
|
||||||
|
});
|
||||||
|
this.group_members = new Whisper.ConversationCollection();
|
||||||
this.$el.find('.new-contact').append(this.new_contact.el);
|
this.$el.find('.new-contact').append(this.new_contact.el);
|
||||||
},
|
},
|
||||||
|
|
||||||
events: {
|
events: {
|
||||||
'change input.new-message': 'filterContacts',
|
'change input.new-message': 'filterContacts',
|
||||||
'keyup input.new-message': 'filterContacts'
|
'keyup input.new-message': 'filterContacts',
|
||||||
|
'checkbox .contact': 'updateGroup',
|
||||||
|
'click .create-group': 'createGroup'
|
||||||
|
},
|
||||||
|
|
||||||
|
updateGroup: function(e, data) {
|
||||||
|
this.$input.focus();
|
||||||
|
if (data.checked) {
|
||||||
|
this.group_members.add({id: data.modelId});
|
||||||
|
} else {
|
||||||
|
this.group_members.remove({id: data.modelId});
|
||||||
|
}
|
||||||
|
this.group_members
|
||||||
|
if (this.group_members.length) {
|
||||||
|
this.$group_update.show();
|
||||||
|
} else {
|
||||||
|
this.$group_update.hide();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
createGroup: function() {
|
||||||
|
return this.newGroupUpdateView.avatarInput.getFiles().then(function(avatarFiles) {
|
||||||
|
var attributes = {
|
||||||
|
type: 'group',
|
||||||
|
name: this.$el.find('.new-group-update-form .name').val(),
|
||||||
|
avatar: avatarFiles[0],
|
||||||
|
members: this.group_members.pluck('id')
|
||||||
|
};
|
||||||
|
return textsecure.messaging.createGroup(
|
||||||
|
attributes.members, attributes.name, attributes.avatar
|
||||||
|
).then(function(groupId) {
|
||||||
|
var id = getString(groupId);
|
||||||
|
var group = new Whisper.Conversation(attributes);
|
||||||
|
group.save({ id: id, groupId: id }).then(function() {
|
||||||
|
this.$el.trigger('open', {modelId: id});
|
||||||
|
}.bind(this));
|
||||||
|
}.bind(this));
|
||||||
|
}.bind(this));
|
||||||
},
|
},
|
||||||
|
|
||||||
reset: function() {
|
reset: function() {
|
||||||
this.new_contact.$el.hide();
|
this.new_contact.$el.hide();
|
||||||
this.$input.val('').focus();
|
this.$input.val('').focus();
|
||||||
this.typeahead_view.collection.reset(this.typeahead_collection.models);
|
this.typeahead_view.collection.reset(this.typeahead_collection.models);
|
||||||
|
this.group_members.reset([]);
|
||||||
},
|
},
|
||||||
|
|
||||||
filterContacts: function() {
|
filterContacts: function() {
|
||||||
|
|
|
@ -22,11 +22,13 @@
|
||||||
tagName: "div",
|
tagName: "div",
|
||||||
className: "new-group-update-form",
|
className: "new-group-update-form",
|
||||||
initialize: function(options) {
|
initialize: function(options) {
|
||||||
this.template = $('#new-group-update-form').html();
|
if (this.$el.html().length === 0) {
|
||||||
Mustache.parse(this.template);
|
this.template = $('#new-group-update-form').html();
|
||||||
this.$el.html(
|
Mustache.parse(this.template);
|
||||||
Mustache.render(this.template, this.model.attributes)
|
this.$el.html(
|
||||||
);
|
Mustache.render(this.template, this.model.attributes)
|
||||||
|
);
|
||||||
|
}
|
||||||
this.avatarInput = new Whisper.FileInputView({
|
this.avatarInput = new Whisper.FileInputView({
|
||||||
el: this.$el.find('.group-avatar')
|
el: this.$el.find('.group-avatar')
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue