Update aspect list checkmarks only after the stream was fetched
This commit is contained in:
parent
1c7e5b7026
commit
63e9d7b73f
6 changed files with 23 additions and 13 deletions
|
|
@ -21,7 +21,14 @@ app.models.StreamAspects = app.models.Stream.extend({
|
||||||
var url = this.url();
|
var url = this.url();
|
||||||
var ids = this.aspects_ids;
|
var ids = this.aspects_ids;
|
||||||
this.deferred = this.items.fetch(this._fetchOpts({url : url, data : { 'a_ids': ids }}))
|
this.deferred = this.items.fetch(this._fetchOpts({url : url, data : { 'a_ids': ids }}))
|
||||||
.done(_.bind(this.triggerFetchedEvents, this));
|
.done(_.bind(this.fetchDone, this));
|
||||||
|
},
|
||||||
|
|
||||||
|
fetchDone: function() {
|
||||||
|
this.triggerFetchedEvents();
|
||||||
|
if (app.aspects) {
|
||||||
|
app.aspects.trigger('aspectStreamFetched');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// @license-end
|
// @license-end
|
||||||
|
|
|
||||||
|
|
@ -14,7 +14,7 @@ app.views.Aspect = app.views.Base.extend({
|
||||||
toggleAspect: function(evt) {
|
toggleAspect: function(evt) {
|
||||||
if (evt) { evt.preventDefault(); };
|
if (evt) { evt.preventDefault(); };
|
||||||
this.model.toggleSelected();
|
this.model.toggleSelected();
|
||||||
this.$el.find('.icons-check_yes_ok').toggleClass('selected');
|
|
||||||
app.router.aspects_stream();
|
app.router.aspects_stream();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -12,6 +12,7 @@ app.views.AspectsList = app.views.Base.extend({
|
||||||
initialize: function() {
|
initialize: function() {
|
||||||
this.collection.on('change', this.toggleSelector, this);
|
this.collection.on('change', this.toggleSelector, this);
|
||||||
this.collection.on('change', this.updateStreamTitle, this);
|
this.collection.on('change', this.updateStreamTitle, this);
|
||||||
|
this.collection.on('aspectStreamFetched', this.updateAspectList, this);
|
||||||
},
|
},
|
||||||
|
|
||||||
postRenderTemplate: function() {
|
postRenderTemplate: function() {
|
||||||
|
|
@ -30,17 +31,10 @@ app.views.AspectsList = app.views.Base.extend({
|
||||||
toggleAll: function(evt) {
|
toggleAll: function(evt) {
|
||||||
if (evt) { evt.preventDefault(); };
|
if (evt) { evt.preventDefault(); };
|
||||||
|
|
||||||
var aspects = this.$('li:not(:last)')
|
|
||||||
if (this.collection.allSelected()) {
|
if (this.collection.allSelected()) {
|
||||||
this.collection.deselectAll();
|
this.collection.deselectAll();
|
||||||
aspects.each(function(i){
|
|
||||||
$(this).find('.icons-check_yes_ok').removeClass('selected');
|
|
||||||
});
|
|
||||||
} else {
|
} else {
|
||||||
this.collection.selectAll();
|
this.collection.selectAll();
|
||||||
aspects.each(function(i){
|
|
||||||
$(this).find('.icons-check_yes_ok').addClass('selected');
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this.toggleSelector();
|
this.toggleSelector();
|
||||||
|
|
@ -60,6 +54,17 @@ app.views.AspectsList = app.views.Base.extend({
|
||||||
$('.stream_title').text(this.collection.toSentence());
|
$('.stream_title').text(this.collection.toSentence());
|
||||||
},
|
},
|
||||||
|
|
||||||
|
updateAspectList: function() {
|
||||||
|
this.collection.each(function(aspect) {
|
||||||
|
var element = this.$("li[data-aspect_id="+aspect.get('id')+"]");
|
||||||
|
if (aspect.get('selected')) {
|
||||||
|
element.find('.icons-check_yes_ok').addClass('selected');
|
||||||
|
} else {
|
||||||
|
element.find('.icons-check_yes_ok').removeClass('selected');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
hideAspectsList: function() {
|
hideAspectsList: function() {
|
||||||
this.$el.empty();
|
this.$el.empty();
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -91,14 +91,14 @@ end
|
||||||
Then /^I should see "([^"]*)" aspect selected$/ do |aspect_name|
|
Then /^I should see "([^"]*)" aspect selected$/ do |aspect_name|
|
||||||
aspect = @me.aspects.where(:name => aspect_name).first
|
aspect = @me.aspects.where(:name => aspect_name).first
|
||||||
within("#aspects_list") do
|
within("#aspects_list") do
|
||||||
page.should have_css "li[data-aspect_id='#{aspect.id}'] .selected"
|
current_scope.should have_css "li[data-aspect_id='#{aspect.id}'] .selected"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
Then /^I should see "([^"]*)" aspect unselected$/ do |aspect_name|
|
Then /^I should see "([^"]*)" aspect unselected$/ do |aspect_name|
|
||||||
aspect = @me.aspects.where(:name => aspect_name).first
|
aspect = @me.aspects.where(:name => aspect_name).first
|
||||||
within("#aspects_list") do
|
within("#aspects_list") do
|
||||||
page.should have_no_css "li[data-aspect_id='#{aspect.id}'] .selected"
|
current_scope.should have_no_css "li[data-aspect_id='#{aspect.id}'] .selected"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -28,7 +28,6 @@ describe("app.views.Aspect", function(){
|
||||||
it('it should deselect the aspect', function(){
|
it('it should deselect the aspect', function(){
|
||||||
this.view.$el.children('a.selectable').trigger('click');
|
this.view.$el.children('a.selectable').trigger('click');
|
||||||
expect(this.view.toggleAspect).toHaveBeenCalled();
|
expect(this.view.toggleAspect).toHaveBeenCalled();
|
||||||
expect(this.view.$el.children('.icons-check_yes_ok').hasClass('selected')).toBeFalsy();
|
|
||||||
expect(app.router.aspects_stream).toHaveBeenCalled();
|
expect(app.router.aspects_stream).toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -48,7 +48,6 @@ describe("app.views.AspectsList", function(){
|
||||||
|
|
||||||
it('should show all the aspects selected', function(){
|
it('should show all the aspects selected', function(){
|
||||||
expect(this.view.toggleAll).toHaveBeenCalled();
|
expect(this.view.toggleAll).toHaveBeenCalled();
|
||||||
expect(this.view.$('.selected').length).toBe(3);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should show \'Deselect all\' link', function(){
|
it('should show \'Deselect all\' link', function(){
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue