UI Cleanup - Updated Cells subtree.

pull/2/head
Taloth Saldono 10 years ago
parent 83b8ab8fe9
commit 7b5c0a952b

@ -5,14 +5,20 @@ require('bootstrap');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
className : 'approval-status-cell', className : 'approval-status-cell',
template : 'Cells/ApprovalStatusCellTemplate', template : 'Cells/ApprovalStatusCellTemplate',
render : function(){
render : function() {
var rejections = this.model.get(this.column.get('name')); var rejections = this.model.get(this.column.get('name'));
if(rejections.length === 0) {
if (rejections.length === 0) {
return this; return this;
} }
this.templateFunction = Marionette.TemplateCache.get(this.template); this.templateFunction = Marionette.TemplateCache.get(this.template);
var html = this.templateFunction(rejections); var html = this.templateFunction(rejections);
this.$el.html('<i class="icon-exclamation-sign"/>'); this.$el.html('<i class="icon-exclamation-sign"/>');
this.$el.popover({ this.$el.popover({
content : html, content : html,
html : true, html : true,
@ -21,6 +27,7 @@ module.exports = Backgrid.Cell.extend({
placement : 'left', placement : 'left',
container : this.$el container : this.$el
}); });
return this; return this;
} }
}); });

@ -3,17 +3,24 @@ var Backgrid = require('backgrid');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
className : 'delete-episode-file-cell', className : 'delete-episode-file-cell',
events : {"click" : '_onClick'},
render : function(){ events : {
'click' : '_onClick'
},
render : function() {
this.$el.empty(); this.$el.empty();
this.$el.html('<i class="icon-nd-delete"></i>'); this.$el.html('<i class="icon-nd-delete"></i>');
return this; return this;
}, },
_onClick : function(){
_onClick : function() {
var self = this; var self = this;
if(window.confirm('Are you sure you want to delete \'{0}\' from disk?'.format(this.model.get('path')))) {
this.model.destroy().done(function(){ if (window.confirm('Are you sure you want to delete \'{0}\' from disk?'.format(this.model.get('path')))) {
vent.trigger(vent.Events.EpisodeFileDeleted, {episodeFile : self.model}); this.model.destroy().done(function() {
vent.trigger(vent.Events.EpisodeFileDeleted, { episodeFile : self.model });
}); });
} }
} }

@ -7,38 +7,49 @@ module.exports = Backgrid.CellEditor.extend({
className : 'quality-cell-editor', className : 'quality-cell-editor',
template : 'Cells/Edit/QualityCellEditorTemplate', template : 'Cells/Edit/QualityCellEditorTemplate',
tagName : 'select', tagName : 'select',
events : {
"change" : 'save', events : {
"blur" : 'close', 'change' : 'save',
"keydown" : 'close' 'blur' : 'close',
'keydown' : 'close'
}, },
render : function(){
render : function() {
var self = this; var self = this;
var profileSchemaCollection = new ProfileSchemaCollection(); var profileSchemaCollection = new ProfileSchemaCollection();
var promise = profileSchemaCollection.fetch(); var promise = profileSchemaCollection.fetch();
promise.done(function(){
promise.done(function() {
var templateName = self.template; var templateName = self.template;
self.schema = profileSchemaCollection.first(); self.schema = profileSchemaCollection.first();
var selected = _.find(self.schema.get('items'), function(model){
var selected = _.find(self.schema.get('items'), function(model) {
return model.quality.id === self.model.get(self.column.get('name')).quality.id; return model.quality.id === self.model.get(self.column.get('name')).quality.id;
}); });
if(selected) {
if (selected) {
selected.quality.selected = true; selected.quality.selected = true;
} }
self.templateFunction = Marionette.TemplateCache.get(templateName); self.templateFunction = Marionette.TemplateCache.get(templateName);
var data = self.schema.toJSON(); var data = self.schema.toJSON();
var html = self.templateFunction(data); var html = self.templateFunction(data);
self.$el.html(html); self.$el.html(html);
}); });
return this; return this;
}, },
save : function(e){
save : function(e) {
var model = this.model; var model = this.model;
var column = this.column; var column = this.column;
var selected = parseInt(this.$el.val(), 10); var selected = parseInt(this.$el.val(), 10);
var profileItem = _.find(this.schema.get('items'), function(model){
var profileItem = _.find(this.schema.get('items'), function(model) {
return model.quality.id === selected; return model.quality.id === selected;
}); });
var newQuality = { var newQuality = {
quality : profileItem.quality, quality : profileItem.quality,
revision : { revision : {
@ -46,14 +57,17 @@ module.exports = Backgrid.CellEditor.extend({
real : 0 real : 0
} }
}; };
model.set(column.get('name'), newQuality); model.set(column.get('name'), newQuality);
model.save(); model.save();
model.trigger('backgrid:edited', model, column, new Backgrid.Command(e)); model.trigger('backgrid:edited', model, column, new Backgrid.Command(e));
}, },
close : function(e){
close : function(e) {
var model = this.model; var model = this.model;
var column = this.column; var column = this.column;
var command = new Backgrid.Command(e); var command = new Backgrid.Command(e);
model.trigger('backgrid:edited', model, column, command); model.trigger('backgrid:edited', model, column, command);
} }
}); });

@ -3,14 +3,18 @@ var NzbDroneCell = require('./NzbDroneCell');
var CommandController = require('../Commands/CommandController'); var CommandController = require('../Commands/CommandController');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'episode-actions-cell', className : 'episode-actions-cell',
events : {
"click .x-automatic-search" : '_automaticSearch', events : {
"click .x-manual-search" : '_manualSearch' 'click .x-automatic-search' : '_automaticSearch',
'click .x-manual-search' : '_manualSearch'
}, },
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
this.$el.html('<i class="icon-search x-automatic-search" title="Automatic Search"></i>' + '<i class="icon-nd-manual-search x-manual-search" title="Manual Search"></i>'); this.$el.html('<i class="icon-search x-automatic-search" title="Automatic Search"></i>' + '<i class="icon-nd-manual-search x-manual-search" title="Manual Search"></i>');
CommandController.bindToCommand({ CommandController.bindToCommand({
element : this.$el.find('.x-automatic-search'), element : this.$el.find('.x-automatic-search'),
command : { command : {
@ -18,16 +22,19 @@ module.exports = NzbDroneCell.extend({
episodeIds : [this.model.get('id')] episodeIds : [this.model.get('id')]
} }
}); });
this.delegateEvents(); this.delegateEvents();
return this; return this;
}, },
_automaticSearch : function(){
_automaticSearch : function() {
CommandController.Execute('episodeSearch', { CommandController.Execute('episodeSearch', {
name : 'episodeSearch', name : 'episodeSearch',
episodeIds : [this.model.get('id')] episodeIds : [this.model.get('id')]
}); });
}, },
_manualSearch : function(){
_manualSearch : function() {
vent.trigger(vent.Commands.ShowEpisodeDetails, { vent.trigger(vent.Commands.ShowEpisodeDetails, {
episode : this.cellValue, episode : this.cellValue,
hideSeriesLink : true, hideSeriesLink : true,

@ -4,37 +4,52 @@ var SeriesCollection = require('../Series/SeriesCollection');
var Messenger = require('../Shared/Messenger'); var Messenger = require('../Shared/Messenger');
module.exports = ToggleCell.extend({ module.exports = ToggleCell.extend({
className : 'toggle-cell episode-monitored', className : 'toggle-cell episode-monitored',
_originalOnClick : ToggleCell.prototype._onClick, _originalOnClick : ToggleCell.prototype._onClick,
_onClick : function(e){
_onClick : function(e) {
var series = SeriesCollection.get(this.model.get('seriesId')); var series = SeriesCollection.get(this.model.get('seriesId'));
if(!series.get('monitored')) {
if (!series.get('monitored')) {
Messenger.show({ Messenger.show({
message : 'Unable to change monitored state when series is not monitored', message : 'Unable to change monitored state when series is not monitored',
type : 'error' type : 'error'
}); });
return; return;
} }
if(e.shiftKey && this.model.episodeCollection.lastToggled) {
if (e.shiftKey && this.model.episodeCollection.lastToggled) {
this._selectRange(); this._selectRange();
return; return;
} }
this._originalOnClick.apply(this, arguments); this._originalOnClick.apply(this, arguments);
this.model.episodeCollection.lastToggled = this.model; this.model.episodeCollection.lastToggled = this.model;
}, },
_selectRange : function(){
_selectRange : function() {
var episodeCollection = this.model.episodeCollection; var episodeCollection = this.model.episodeCollection;
var lastToggled = episodeCollection.lastToggled; var lastToggled = episodeCollection.lastToggled;
var currentIndex = episodeCollection.indexOf(this.model); var currentIndex = episodeCollection.indexOf(this.model);
var lastIndex = episodeCollection.indexOf(lastToggled); var lastIndex = episodeCollection.indexOf(lastToggled);
var low = Math.min(currentIndex, lastIndex); var low = Math.min(currentIndex, lastIndex);
var high = Math.max(currentIndex, lastIndex); var high = Math.max(currentIndex, lastIndex);
var range = _.range(low + 1, high); var range = _.range(low + 1, high);
_.each(range, function(index){
_.each(range, function(index) {
var model = episodeCollection.at(index); var model = episodeCollection.at(index);
model.set('monitored', lastToggled.get('monitored')); model.set('monitored', lastToggled.get('monitored'));
model.save(); model.save();
}); });
this.model.set('monitored', lastToggled.get('monitored')); this.model.set('monitored', lastToggled.get('monitored'));
this.model.save(); this.model.save();
this.model.episodeCollection.lastToggled = undefined; this.model.episodeCollection.lastToggled = undefined;

@ -4,52 +4,65 @@ var _ = require('underscore');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'episode-number-cell', className : 'episode-number-cell',
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
var airDateField = this.column.get('airDateUtc') || 'airDateUtc'; var airDateField = this.column.get('airDateUtc') || 'airDateUtc';
var seasonField = this.column.get('seasonNumber') || 'seasonNumber'; var seasonField = this.column.get('seasonNumber') || 'seasonNumber';
var episodeField = this.column.get('episodes') || 'episodeNumber'; var episodeField = this.column.get('episodes') || 'episodeNumber';
var absoluteEpisodeField = 'absoluteEpisodeNumber'; var absoluteEpisodeField = 'absoluteEpisodeNumber';
if(this.model) {
if (this.model) {
var result = 'Unknown'; var result = 'Unknown';
var airDate = this.model.get(airDateField); var airDate = this.model.get(airDateField);
var seasonNumber = this.model.get(seasonField); var seasonNumber = this.model.get(seasonField);
var episodes = this.model.get(episodeField); var episodes = this.model.get(episodeField);
var absoluteEpisodeNumber = this.model.get(absoluteEpisodeField); var absoluteEpisodeNumber = this.model.get(absoluteEpisodeField);
if(this.cellValue) {
if(!seasonNumber) { if (this.cellValue) {
if (!seasonNumber) {
seasonNumber = this.cellValue.get(seasonField); seasonNumber = this.cellValue.get(seasonField);
} }
if(!episodes) {
if (!episodes) {
episodes = this.cellValue.get(episodeField); episodes = this.cellValue.get(episodeField);
} }
if(absoluteEpisodeNumber === undefined) {
if (absoluteEpisodeNumber === undefined) {
absoluteEpisodeNumber = this.cellValue.get(absoluteEpisodeField); absoluteEpisodeNumber = this.cellValue.get(absoluteEpisodeField);
} }
if(!airDate) {
if (!airDate) {
this.model.get(airDateField); this.model.get(airDateField);
} }
} }
if(episodes) {
if (episodes) {
var paddedEpisodes; var paddedEpisodes;
var paddedAbsoluteEpisode; var paddedAbsoluteEpisode;
if(episodes.constructor === Array) {
paddedEpisodes = _.map(episodes, function(episodeNumber){ if (episodes.constructor === Array) {
paddedEpisodes = _.map(episodes, function(episodeNumber) {
return FormatHelpers.pad(episodeNumber, 2); return FormatHelpers.pad(episodeNumber, 2);
}).join(); }).join();
} } else {
else {
paddedEpisodes = FormatHelpers.pad(episodes, 2); paddedEpisodes = FormatHelpers.pad(episodes, 2);
paddedAbsoluteEpisode = FormatHelpers.pad(absoluteEpisodeNumber, 2); paddedAbsoluteEpisode = FormatHelpers.pad(absoluteEpisodeNumber, 2);
} }
result = '{0}x{1}'.format(seasonNumber, paddedEpisodes); result = '{0}x{1}'.format(seasonNumber, paddedEpisodes);
if(absoluteEpisodeNumber !== undefined && paddedAbsoluteEpisode) {
if (absoluteEpisodeNumber !== undefined && paddedAbsoluteEpisode) {
result += ' ({0})'.format(paddedAbsoluteEpisode); result += ' ({0})'.format(paddedAbsoluteEpisode);
} }
} } else if (airDate) {
else if(airDate) {
result = new Date(airDate).toLocaleDateString(); result = new Date(airDate).toLocaleDateString();
} }
this.$el.html(result); this.$el.html(result);
} }
this.delegateEvents(); this.delegateEvents();

@ -4,18 +4,25 @@ var NzbDroneCell = require('./NzbDroneCell');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'episode-progress-cell', className : 'episode-progress-cell',
template : 'Cells/EpisodeProgressCellTemplate', template : 'Cells/EpisodeProgressCellTemplate',
render : function(){
render : function() {
var episodeCount = this.model.get('episodeCount'); var episodeCount = this.model.get('episodeCount');
var episodeFileCount = this.model.get('episodeFileCount'); var episodeFileCount = this.model.get('episodeFileCount');
var percent = 100; var percent = 100;
if(episodeCount > 0) {
if (episodeCount > 0) {
percent = episodeFileCount / episodeCount * 100; percent = episodeFileCount / episodeCount * 100;
} }
this.model.set('percentOfEpisodes', percent); this.model.set('percentOfEpisodes', percent);
this.templateFunction = Marionette.TemplateCache.get(this.template); this.templateFunction = Marionette.TemplateCache.get(this.template);
var data = this.model.toJSON(); var data = this.model.toJSON();
var html = this.templateFunction(data); var html = this.templateFunction(data);
this.$el.html(html); this.$el.html(html);
return this; return this;
} }
}); });

@ -6,93 +6,122 @@ var moment = require('moment');
var FormatHelpers = require('../Shared/FormatHelpers'); var FormatHelpers = require('../Shared/FormatHelpers');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'episode-status-cell', className : 'episode-status-cell',
render : function(){
render : function() {
this.listenTo(QueueCollection, 'sync', this._renderCell); this.listenTo(QueueCollection, 'sync', this._renderCell);
this._renderCell(); this._renderCell();
return this; return this;
}, },
_renderCell : function(){
if(this.episodeFile) { _renderCell : function() {
if (this.episodeFile) {
this.stopListening(this.episodeFile, 'change', this._refresh); this.stopListening(this.episodeFile, 'change', this._refresh);
} }
this.$el.empty(); this.$el.empty();
if(this.model) {
if (this.model) {
var icon; var icon;
var tooltip; var tooltip;
var hasAired = moment(this.model.get('airDateUtc')).isBefore(moment()); var hasAired = moment(this.model.get('airDateUtc')).isBefore(moment());
this.episodeFile = this._getFile(); this.episodeFile = this._getFile();
if(this.episodeFile) {
if (this.episodeFile) {
this.listenTo(this.episodeFile, 'change', this._refresh); this.listenTo(this.episodeFile, 'change', this._refresh);
var quality = this.episodeFile.get('quality'); var quality = this.episodeFile.get('quality');
var revision = quality.revision; var revision = quality.revision;
var size = FormatHelpers.bytes(this.episodeFile.get('size')); var size = FormatHelpers.bytes(this.episodeFile.get('size'));
var title = 'Episode downloaded'; var title = 'Episode downloaded';
if(revision.real && revision.real > 0) {
if (revision.real && revision.real > 0) {
title += '[REAL]'; title += '[REAL]';
} }
if(revision.version && revision.version > 1) {
if (revision.version && revision.version > 1) {
title += ' [PROPER]'; title += ' [PROPER]';
} }
if(size !== '') {
if (size !== '') {
title += ' - {0}'.format(size); title += ' - {0}'.format(size);
} }
if(this.episodeFile.get('qualityCutoffNotMet')) {
if (this.episodeFile.get('qualityCutoffNotMet')) {
this.$el.html('<span class="badge badge-inverse" title="{0}">{1}</span>'.format(title, quality.quality.name)); this.$el.html('<span class="badge badge-inverse" title="{0}">{1}</span>'.format(title, quality.quality.name));
} } else {
else {
this.$el.html('<span class="badge" title="{0}">{1}</span>'.format(title, quality.quality.name)); this.$el.html('<span class="badge" title="{0}">{1}</span>'.format(title, quality.quality.name));
} }
return; return;
} }
else { else {
var model = this.model; var model = this.model;
var downloading = QueueCollection.findEpisode(model.get('id')); var downloading = QueueCollection.findEpisode(model.get('id'));
if(downloading) {
var progress = 100 - downloading.get('sizeleft') / downloading.get('size') * 100; if (downloading) {
if(progress === 0) { var progress = 100 - (downloading.get('sizeleft') / downloading.get('size') * 100);
if (progress === 0) {
icon = 'icon-nd-downloading'; icon = 'icon-nd-downloading';
tooltip = 'Episode is downloading'; tooltip = 'Episode is downloading';
} }
else { else {
this.$el.html('<div class="progress" title="Episode is downloading - {0}% {1}">'.format(progress.toFixed(1), downloading.get('title')) + '<div class="progress-bar progress-bar-purple" style="width: {0}%;"></div></div>'.format(progress)); this.$el.html('<div class="progress" title="Episode is downloading - {0}% {1}">'.format(progress.toFixed(1), downloading.get('title')) +
'<div class="progress-bar progress-bar-purple" style="width: {0}%;"></div></div>'.format(progress));
return; return;
} }
} }
else if(this.model.get('grabbed')) {
else if (this.model.get('grabbed')) {
icon = 'icon-nd-downloading'; icon = 'icon-nd-downloading';
tooltip = 'Episode is downloading'; tooltip = 'Episode is downloading';
} }
else if(!this.model.get('airDateUtc')) {
else if (!this.model.get('airDateUtc')) {
icon = 'icon-nd-tba'; icon = 'icon-nd-tba';
tooltip = 'TBA'; tooltip = 'TBA';
} }
else if(hasAired) {
else if (hasAired) {
icon = 'icon-nd-missing'; icon = 'icon-nd-missing';
tooltip = 'Episode missing from disk'; tooltip = 'Episode missing from disk';
} } else {
else {
icon = 'icon-nd-not-aired'; icon = 'icon-nd-not-aired';
tooltip = 'Episode has not aired'; tooltip = 'Episode has not aired';
} }
} }
this.$el.html('<i class="{0}" title="{1}"/>'.format(icon, tooltip)); this.$el.html('<i class="{0}" title="{1}"/>'.format(icon, tooltip));
} }
}, },
_getFile : function(){
_getFile : function() {
var hasFile = this.model.get('hasFile'); var hasFile = this.model.get('hasFile');
if(hasFile) {
if (hasFile) {
var episodeFile; var episodeFile;
if(reqres.hasHandler(reqres.Requests.GetEpisodeFileById)) {
if (reqres.hasHandler(reqres.Requests.GetEpisodeFileById)) {
episodeFile = reqres.request(reqres.Requests.GetEpisodeFileById, this.model.get('episodeFileId')); episodeFile = reqres.request(reqres.Requests.GetEpisodeFileById, this.model.get('episodeFileId'));
} }
else if(this.model.has('episodeFile')) {
else if (this.model.has('episodeFile')) {
episodeFile = new Backbone.Model(this.model.get('episodeFile')); episodeFile = new Backbone.Model(this.model.get('episodeFile'));
} }
if(episodeFile) {
if (episodeFile) {
return episodeFile; return episodeFile;
} }
} }
return undefined; return undefined;
} }
}); });

@ -2,17 +2,24 @@ var vent = require('vent');
var NzbDroneCell = require('./NzbDroneCell'); var NzbDroneCell = require('./NzbDroneCell');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'episode-title-cell', className : 'episode-title-cell',
events : {"click" : '_showDetails'},
render : function(){ events : {
'click' : '_showDetails'
},
render : function() {
var title = this.cellValue.get('title'); var title = this.cellValue.get('title');
if(!title || title === '') {
if (!title || title === '') {
title = 'TBA'; title = 'TBA';
} }
this.$el.html(title); this.$el.html(title);
return this; return this;
}, },
_showDetails : function(){
_showDetails : function() {
var hideSeriesLink = this.column.get('hideSeriesLink'); var hideSeriesLink = this.column.get('hideSeriesLink');
vent.trigger(vent.Commands.ShowEpisodeDetails, { vent.trigger(vent.Commands.ShowEpisodeDetails, {
episode : this.cellValue, episode : this.cellValue,

@ -2,11 +2,14 @@ var NzbDroneCell = require('./NzbDroneCell');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'history-event-type-cell', className : 'history-event-type-cell',
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
if(this.cellValue) {
if (this.cellValue) {
var icon; var icon;
var toolTip; var toolTip;
switch (this.cellValue.get('eventType')) { switch (this.cellValue.get('eventType')) {
case 'grabbed': case 'grabbed':
icon = 'icon-nd-downloading'; icon = 'icon-nd-downloading';
@ -32,8 +35,10 @@ module.exports = NzbDroneCell.extend({
icon = 'icon-question'; icon = 'icon-question';
toolTip = 'unknown event'; toolTip = 'unknown event';
} }
this.$el.html('<i class="{0}" title="{1}" data-placement="right"/>'.format(icon, toolTip)); this.$el.html('<i class="{0}" title="{1}" data-placement="right"/>'.format(icon, toolTip));
} }
return this; return this;
} }
}); });

@ -3,7 +3,8 @@ var FormatHelpers = require('../Shared/FormatHelpers');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
className : 'file-size-cell', className : 'file-size-cell',
render : function(){
render : function() {
var size = this.model.get(this.column.get('name')); var size = this.model.get(this.column.get('name'));
this.$el.html(FormatHelpers.bytes(size)); this.$el.html(FormatHelpers.bytes(size));
this.delegateEvents(); this.delegateEvents();

@ -2,7 +2,8 @@ var Backgrid = require('backgrid');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
className : 'indexer-cell', className : 'indexer-cell',
render : function(){
render : function() {
var indexer = this.model.get(this.column.get('name')); var indexer = this.model.get(this.column.get('name'));
this.$el.html(indexer); this.$el.html(indexer);
return this; return this;

@ -2,41 +2,56 @@ var Backgrid = require('backgrid');
var Backbone = require('backbone'); var Backbone = require('backbone');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
_originalInit : Backgrid.Cell.prototype.initialize, _originalInit : Backgrid.Cell.prototype.initialize,
initialize : function(){
initialize : function() {
this._originalInit.apply(this, arguments); this._originalInit.apply(this, arguments);
this.cellValue = this._getValue(); this.cellValue = this._getValue();
this.listenTo(this.model, 'change', this._refresh); this.listenTo(this.model, 'change', this._refresh);
if(this._onEdit) {
this.listenTo(this.model, 'backgrid:edit', function(model, column, cell, editor){ if (this._onEdit) {
if(column.get('name') === this.column.get('name')) { this.listenTo(this.model, 'backgrid:edit', function(model, column, cell, editor) {
if (column.get('name') === this.column.get('name')) {
this._onEdit(model, column, cell, editor); this._onEdit(model, column, cell, editor);
} }
}); });
} }
}, },
_refresh : function(){
_refresh : function() {
this.cellValue = this._getValue(); this.cellValue = this._getValue();
this.render(); this.render();
}, },
_getValue : function(){
_getValue : function() {
var cellValue = this.column.get('cellValue'); var cellValue = this.column.get('cellValue');
if(cellValue) {
if(cellValue === 'this') { if (cellValue) {
if (cellValue === 'this') {
return this.model; return this.model;
} }
} }
var name = this.column.get('name'); var name = this.column.get('name');
if(name === 'this') {
if (name === 'this') {
return this.model; return this.model;
} }
var value = this.model.get(name); var value = this.model.get(name);
if(!value) {
if (!value) {
return undefined; return undefined;
} }
if(!value.get && typeof value === 'object') {
//if not a model
if (!value.get && typeof value === 'object') {
value = new Backbone.Model(value); value = new Backbone.Model(value);
} }
return value; return value;
} }
}); });

@ -4,13 +4,18 @@ var _ = require('underscore');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
className : 'profile-cell', className : 'profile-cell',
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
var profileId = this.model.get(this.column.get('name')); var profileId = this.model.get(this.column.get('name'));
var profile = _.findWhere(ProfileCollection.models, {id : profileId});
if(profile) { var profile = _.findWhere(ProfileCollection.models, { id : profileId });
if (profile) {
this.$el.html(profile.get('name')); this.$el.html(profile.get('name'));
} }
return this; return this;
} }
}); });

@ -5,19 +5,23 @@ var UiSettings = require('../Shared/UiSettingsModel');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'relative-date-cell', className : 'relative-date-cell',
render : function(){
render : function() {
var dateStr = this.model.get(this.column.get('name')); var dateStr = this.model.get(this.column.get('name'));
if(dateStr) {
if (dateStr) {
var date = moment(dateStr); var date = moment(dateStr);
var result = '<span title="{0}">{1}</span>'; var result = '<span title="{0}">{1}</span>';
var tooltip = date.format(UiSettings.longDateTime()); var tooltip = date.format(UiSettings.longDateTime());
var text; var text;
if(UiSettings.get('showRelativeDates')) {
if (UiSettings.get('showRelativeDates')) {
text = FormatHelpers.relativeDate(dateStr); text = FormatHelpers.relativeDate(dateStr);
} } else {
else {
text = date.format(UiSettings.get('shortDateFormat')); text = date.format(UiSettings.get('shortDateFormat'));
} }
this.$el.html(result.format(tooltip, text)); this.$el.html(result.format(tooltip, text));
} }
return this; return this;

@ -5,21 +5,26 @@ var UiSettings = require('../Shared/UiSettingsModel');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'relative-time-cell', className : 'relative-time-cell',
render : function(){
render : function() {
var dateStr = this.model.get(this.column.get('name')); var dateStr = this.model.get(this.column.get('name'));
if(dateStr) {
if (dateStr) {
var date = moment(dateStr); var date = moment(dateStr);
var result = '<span title="{0}">{1}</span>'; var result = '<span title="{0}">{1}</span>';
var tooltip = date.format(UiSettings.longDateTime()); var tooltip = date.format(UiSettings.longDateTime());
var text; var text;
if(UiSettings.get('showRelativeDates')) {
if (UiSettings.get('showRelativeDates')) {
text = date.fromNow(); text = date.fromNow();
} } else {
else {
text = date.format(UiSettings.shortDateTime()); text = date.format(UiSettings.shortDateTime());
} }
this.$el.html(result.format(tooltip, text)); this.$el.html(result.format(tooltip, text));
} }
return this; return this;
} }
}); });

@ -2,16 +2,19 @@ var NzbDroneCell = require('./NzbDroneCell');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'release-title-cell', className : 'release-title-cell',
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
var title = this.model.get('title'); var title = this.model.get('title');
var infoUrl = this.model.get('infoUrl'); var infoUrl = this.model.get('infoUrl');
if(infoUrl) {
if (infoUrl) {
this.$el.html('<a href="{0}">{1}</a>'.format(infoUrl, title)); this.$el.html('<a href="{0}">{1}</a>'.format(infoUrl, title));
} } else {
else {
this.$el.html(title); this.$el.html(title);
} }
return this; return this;
} }
}); });

@ -2,10 +2,13 @@ var Backgrid = require('backgrid');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
className : 'season-folder-cell', className : 'season-folder-cell',
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
var seasonFolder = this.model.get(this.column.get('name')); var seasonFolder = this.model.get(this.column.get('name'));
this.$el.html(seasonFolder.toString()); this.$el.html(seasonFolder.toString());
return this; return this;
} }
}); });

@ -3,32 +3,41 @@ var _ = require('underscore');
var BackgridSelectAll = require('backgrid.selectall'); var BackgridSelectAll = require('backgrid.selectall');
module.exports = BackgridSelectAll.extend({ module.exports = BackgridSelectAll.extend({
enterEditMode : function(e){ enterEditMode : function(e) {
if(e.shiftKey && this.model.collection.lastToggled) { if (e.shiftKey && this.model.collection.lastToggled) {
this._selectRange(); this._selectRange();
} }
var checked = $(e.target).prop('checked'); var checked = $(e.target).prop('checked');
this.model.collection.lastToggled = this.model; this.model.collection.lastToggled = this.model;
this.model.collection.checked = checked; this.model.collection.checked = checked;
}, },
onChange : function(e){
onChange : function(e) {
var checked = $(e.target).prop('checked'); var checked = $(e.target).prop('checked');
this.$el.parent().toggleClass('selected', checked); this.$el.parent().toggleClass('selected', checked);
this.model.trigger('backgrid:selected', this.model, checked); this.model.trigger('backgrid:selected', this.model, checked);
}, },
_selectRange : function(){
_selectRange : function() {
var collection = this.model.collection; var collection = this.model.collection;
var lastToggled = collection.lastToggled; var lastToggled = collection.lastToggled;
var checked = collection.checked; var checked = collection.checked;
var currentIndex = collection.indexOf(this.model); var currentIndex = collection.indexOf(this.model);
var lastIndex = collection.indexOf(lastToggled); var lastIndex = collection.indexOf(lastToggled);
var low = Math.min(currentIndex, lastIndex); var low = Math.min(currentIndex, lastIndex);
var high = Math.max(currentIndex, lastIndex); var high = Math.max(currentIndex, lastIndex);
var range = _.range(low + 1, high); var range = _.range(low + 1, high);
_.each(range, function(index){
_.each(range, function(index) {
var model = collection.at(index); var model = collection.at(index);
model.trigger('backgrid:select', model, checked); model.trigger('backgrid:select', model, checked);
}); });
this.model.collection.lastToggled = undefined; this.model.collection.lastToggled = undefined;
this.model.collection.checked = undefined; this.model.collection.checked = undefined;
} }

@ -3,15 +3,23 @@ var NzbDroneCell = require('./NzbDroneCell');
var CommandController = require('../Commands/CommandController'); var CommandController = require('../Commands/CommandController');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'series-actions-cell', className : 'series-actions-cell',
ui : {refresh : '.x-refresh'},
events : { ui : {
"click .x-edit" : '_editSeries', refresh : '.x-refresh'
"click .x-refresh" : '_refreshSeries' },
events : {
'click .x-edit' : '_editSeries',
'click .x-refresh' : '_refreshSeries'
}, },
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
this.$el.html('<i class="icon-refresh x-refresh hidden-xs" title="" data-original-title="Update series info and scan disk"></i> ' + '<i class="icon-nd-edit x-edit" title="" data-original-title="Edit Series"></i>');
this.$el.html('<i class="icon-refresh x-refresh hidden-xs" title="" data-original-title="Update series info and scan disk"></i> ' +
'<i class="icon-nd-edit x-edit" title="" data-original-title="Edit Series"></i>');
CommandController.bindToCommand({ CommandController.bindToCommand({
element : this.$el.find('.x-refresh'), element : this.$el.find('.x-refresh'),
command : { command : {
@ -19,13 +27,16 @@ module.exports = NzbDroneCell.extend({
seriesId : this.model.get('id') seriesId : this.model.get('id')
} }
}); });
this.delegateEvents(); this.delegateEvents();
return this; return this;
}, },
_editSeries : function(){
vent.trigger(vent.Commands.EditSeriesCommand, {series : this.model}); _editSeries : function() {
vent.trigger(vent.Commands.EditSeriesCommand, { series : this.model });
}, },
_refreshSeries : function(){
_refreshSeries : function() {
CommandController.Execute('refreshSeries', { CommandController.Execute('refreshSeries', {
name : 'refreshSeries', name : 'refreshSeries',
seriesId : this.model.id seriesId : this.model.id

@ -1,26 +1,32 @@
var NzbDroneCell = require('./NzbDroneCell'); var NzbDroneCell = require('./NzbDroneCell');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
className : 'series-status-cell', className : 'series-status-cell',
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
var monitored = this.model.get('monitored'); var monitored = this.model.get('monitored');
var status = this.model.get('status'); var status = this.model.get('status');
if(status === 'ended') {
if (status === 'ended') {
this.$el.html('<i class="icon-stop grid-icon" title="Ended"></i>'); this.$el.html('<i class="icon-stop grid-icon" title="Ended"></i>');
this._setStatusWeight(3); this._setStatusWeight(3);
} }
else if(!monitored) {
else if (!monitored) {
this.$el.html('<i class="icon-pause grid-icon" title="Not Monitored"></i>'); this.$el.html('<i class="icon-pause grid-icon" title="Not Monitored"></i>');
this._setStatusWeight(2); this._setStatusWeight(2);
} }
else { else {
this.$el.html('<i class="icon-play grid-icon" title="Continuing"></i>'); this.$el.html('<i class="icon-play grid-icon" title="Continuing"></i>');
this._setStatusWeight(1); this._setStatusWeight(1);
} }
return this; return this;
}, },
_setStatusWeight : function(weight){
this.model.set('statusWeight', weight, {silent : true}); _setStatusWeight : function(weight) {
this.model.set('statusWeight', weight, { silent : true });
} }
}); });

@ -2,12 +2,15 @@ var Marionette = require('marionette');
var NzbDroneCell = require('./NzbDroneCell'); var NzbDroneCell = require('./NzbDroneCell');
module.exports = NzbDroneCell.extend({ module.exports = NzbDroneCell.extend({
render : function(){ render : function() {
var templateName = this.column.get('template') || this.template; var templateName = this.column.get('template') || this.template;
this.templateFunction = Marionette.TemplateCache.get(templateName); this.templateFunction = Marionette.TemplateCache.get(templateName);
var data = this.cellValue.toJSON(); var data = this.cellValue.toJSON();
var html = this.templateFunction(data); var html = this.templateFunction(data);
this.$el.html(html); this.$el.html(html);
this.delegateEvents(); this.delegateEvents();
return this; return this;
} }

@ -2,31 +2,45 @@ var Backgrid = require('backgrid');
module.exports = Backgrid.Cell.extend({ module.exports = Backgrid.Cell.extend({
className : 'toggle-cell', className : 'toggle-cell',
events : {"click" : '_onClick'},
_onClick : function(){ events : {
'click' : '_onClick'
},
_onClick : function() {
var self = this; var self = this;
this.$el.tooltip('hide'); this.$el.tooltip('hide');
var name = this.column.get('name'); var name = this.column.get('name');
this.model.set(name, !this.model.get(name)); this.model.set(name, !this.model.get(name));
this.$('i').addClass('icon-spinner icon-spin'); this.$('i').addClass('icon-spinner icon-spin');
this.model.save().always(function(){
this.model.save().always(function() {
self.render(); self.render();
}); });
}, },
render : function(){
render : function() {
this.$el.empty(); this.$el.empty();
this.$el.html('<i />'); this.$el.html('<i />');
var name = this.column.get('name'); var name = this.column.get('name');
if(this.model.get(name)) {
if (this.model.get(name)) {
this.$('i').addClass(this.column.get('trueClass')); this.$('i').addClass(this.column.get('trueClass'));
} } else {
else {
this.$('i').addClass(this.column.get('falseClass')); this.$('i').addClass(this.column.get('falseClass'));
} }
var tooltip = this.column.get('tooltip'); var tooltip = this.column.get('tooltip');
if(tooltip) {
if (tooltip) {
this.$('i').attr('title', tooltip); this.$('i').attr('title', tooltip);
} }
return this; return this;
} }
}); });
Loading…
Cancel
Save