You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Lidarr/src/UI/Shared/Toolbar/Sorting/SortingButtonView.js

70 lines
1.9 KiB

var Backbone = require('backbone');
var Marionette = require('marionette');
var _ = require('underscore');
module.exports = Marionette.ItemView.extend({
template : 'Shared/Toolbar/Sorting/SortingButtonViewTemplate',
tagName : 'li',
ui : {
icon : 'i'
},
events : {
'click' : 'onClick'
},
initialize : function(options) {
this.viewCollection = options.viewCollection;
this.listenTo(this.viewCollection, 'drone:sort', this.render);
this.listenTo(this.viewCollection, 'backgrid:sort', this.render);
},
onRender : function() {
if (this.viewCollection.state) {
var sortKey = this.viewCollection.state.sortKey;
var name = this.viewCollection._getSortMapping(sortKey).name;
var order = this.viewCollection.state.order;
if (name === this.model.get('name')) {
this._setSortIcon(order);
} else {
this._removeSortIcon();
}
}
},
onClick : function(e) {
e.preventDefault();
var collection = this.viewCollection;
var event = 'drone:sort';
var direction = collection.state.order;
if (direction === 'ascending' || direction === -1) {
direction = 'descending';
} else {
direction = 'ascending';
}
collection.setSorting(this.model.get('name'), direction);
collection.trigger(event, this.model, direction);
},
_convertDirectionToIcon : function(dir) {
if (dir === 'ascending' || dir === -1) {
return 'icon-sort-up';
}
return 'icon-sort-down';
},
_setSortIcon : function(dir) {
this._removeSortIcon();
this.ui.icon.addClass(this._convertDirectionToIcon(dir));
},
_removeSortIcon : function() {
this.ui.icon.removeClass('icon-sort-up icon-sort-down');
}
});