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.
95 lines
3.5 KiB
95 lines
3.5 KiB
'use strict';
|
|
|
|
define(['app', 'Quality/QualityProfileCollection', 'Series/Index/SeriesItemView'], function (app, qualityProfileCollection) {
|
|
NzbDrone.Series.Index.SeriesIndexCollectionView = Backbone.Marionette.CompositeView.extend({
|
|
itemView: NzbDrone.Series.Index.SeriesItemView,
|
|
itemViewContainer: 'tbody',
|
|
template: 'Series/Index/SeriesIndexTemplate',
|
|
qualityProfileCollection: qualityProfileCollection,
|
|
//emptyView: NzbDrone.Series.EmptySeriesCollectionView,
|
|
|
|
initialize: function () {
|
|
this.collection = new NzbDrone.Series.SeriesCollection();
|
|
//Todo: This caused the onRendered event to be trigger twice, which displays two empty collection messages
|
|
//http://stackoverflow.com/questions/13065176/backbone-marionette-composit-view-onrender-executing-twice
|
|
this.collection.fetch();
|
|
this.qualityProfileCollection.fetch();
|
|
|
|
this.itemViewOptions = { qualityProfiles: this.qualityProfileCollection };
|
|
},
|
|
|
|
ui:{
|
|
table : '.x-series-table'
|
|
},
|
|
|
|
onItemRemoved: function()
|
|
{
|
|
this.ui.table.trigger('update');
|
|
},
|
|
|
|
onCompositeCollectionRendered: function()
|
|
{
|
|
this.ui.table.trigger('update');
|
|
|
|
if(!this.tableSorter && this.collection.length > 0)
|
|
{
|
|
this.tableSorter = this.ui.table.tablesorter({
|
|
textExtraction: function (node) {
|
|
return node.innerHTML;
|
|
},
|
|
sortList: [[1,0]],
|
|
headers: {
|
|
0: {
|
|
sorter: 'title'
|
|
},
|
|
1: {
|
|
sorter: 'innerHtml'
|
|
},
|
|
5: {
|
|
sorter: 'date'
|
|
},
|
|
6: {
|
|
sorter: false
|
|
},
|
|
7: {
|
|
sorter: false
|
|
}
|
|
}
|
|
});
|
|
|
|
//Todo: We should extract these common settings out
|
|
this.ui.table.find('th.header').each(function(){
|
|
$(this).append('<i class="icon-sort pull-right">');
|
|
});
|
|
|
|
this.ui.table.bind("sortEnd", function() {
|
|
$(this).find('th.header i').each(function(){
|
|
$(this).remove();
|
|
});
|
|
|
|
$(this).find('th.header').each(function () {
|
|
if (!$(this).hasClass('headerSortDown') && !$(this).hasClass('headerSortUp'))
|
|
$(this).append('<i class="icon-sort pull-right">');
|
|
});
|
|
|
|
$(this).find('th.headerSortDown').each(function(){
|
|
$(this).append('<i class="icon-sort-up pull-right">');
|
|
});
|
|
|
|
$(this).find('th.headerSortUp').each(function(){
|
|
$(this).append('<i class="icon-sort-down pull-right">');
|
|
});
|
|
});
|
|
}
|
|
else
|
|
{
|
|
this.ui.table.trigger('update');
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
NzbDrone.Series.Index.EmptySeriesCollectionView = Backbone.Marionette.CompositeView.extend({
|
|
template: 'Series/Index/EmptySeriesCollectionTemplate',
|
|
tagName: 'tr'
|
|
}); |