checkboxes now control list membership behavior, autocomplete is turned off
parent
e963c3c1ec
commit
2d53f317b0
|
@ -82,7 +82,8 @@ var ListWidgetChildView = Backbone.View.extend({
|
|||
tagName: 'tr',
|
||||
|
||||
events:{
|
||||
"click .btn-delete-list-item":'deleteItem'
|
||||
"click .btn-delete-list-item":'deleteItem',
|
||||
"change .checkbox-list-item":'toggleCheckbox'
|
||||
},
|
||||
|
||||
deleteItem:function (e) {
|
||||
|
@ -110,6 +111,17 @@ var ListWidgetChildView = Backbone.View.extend({
|
|||
});
|
||||
|
||||
},
|
||||
|
||||
toggleCheckbox:function(e) {
|
||||
e.preventDefault();
|
||||
e.stopImmediatePropagation();
|
||||
if ($(e.target).is(':checked')) {
|
||||
this.options.collection.add(this.model);
|
||||
} else {
|
||||
this.options.collection.remove(this.model);
|
||||
}
|
||||
|
||||
},
|
||||
|
||||
initialize:function (options) {
|
||||
this.options = {toggle: false, checked: false};
|
||||
|
@ -212,11 +224,6 @@ var ListWidgetView = Backbone.View.extend({
|
|||
this.$el.html(this.template({placeholder:this.options.placeholder,
|
||||
helpBlockText:this.options.helpBlockText}));
|
||||
|
||||
// bind autocomplete options
|
||||
if (this.options.autocomplete) {
|
||||
$('input', this.$el).typeahead({source:this.options.autocomplete});
|
||||
}
|
||||
|
||||
_self = this;
|
||||
|
||||
if (_.size(this.collection.models) == 0 && _.size(this.options.autocomplete) == 0) {
|
||||
|
@ -247,7 +254,7 @@ var ListWidgetView = Backbone.View.extend({
|
|||
checked = false;
|
||||
}
|
||||
|
||||
var el = new this.childView({model:model, toggle: true, checked: checked}).render().el;
|
||||
var el = new this.childView({model:model, toggle: true, checked: checked, collection: _self.collection}).render().el;
|
||||
$("tbody", _self.el).append(el);
|
||||
|
||||
}, this);
|
||||
|
@ -257,7 +264,7 @@ var ListWidgetView = Backbone.View.extend({
|
|||
// now render everything not in the autocomplete list
|
||||
_.each(values.models, function (model) {
|
||||
|
||||
var el = new this.childView({model:model}).render().el;
|
||||
var el = new this.childView({model:model, collection: _self.collection}).render().el;
|
||||
$("tbody", _self.el).append(el);
|
||||
}, this);
|
||||
}
|
||||
|
|
|
@ -36,7 +36,7 @@
|
|||
<% if (!opt.toggle) { %>
|
||||
<a class="btn btn-small btn-delete-list-item" href="#"><i class="icon-minus-sign"></i></a>
|
||||
<% } else { %>
|
||||
<input type="checkbox" <%- opt.checked ? 'checked="checked"' : '' %> />
|
||||
<input class="checkbox-list-item" type="checkbox" <%- opt.checked ? 'checked="checked"' : '' %> />
|
||||
<% } %>
|
||||
</td>
|
||||
</script>
|
||||
|
|
Loading…
Reference in New Issue