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.
Sonarr/src/UI/ManualImport/ManualImportLayout.js

252 lines
7.3 KiB

var _ = require('underscore');
var vent = require('vent');
var Marionette = require('marionette');
var Backgrid = require('backgrid');
var CommandController = require('../Commands/CommandController');
var EmptyView = require('./EmptyView');
var SelectFolderView = require('./Folder/SelectFolderView');
var LoadingView = require('../Shared/LoadingView');
var ManualImportRow = require('./ManualImportRow');
var SelectAllCell = require('../Cells/SelectAllCell');
var PathCell = require('./Cells/PathCell');
var SeriesCell = require('./Cells/SeriesCell');
var SeasonCell = require('./Cells/SeasonCell');
var EpisodesCell = require('./Cells/EpisodesCell');
var QualityCell = require('./Cells/QualityCell');
var FileSizeCell = require('../Cells/FileSizeCell');
var ApprovalStatusCell = require('../Cells/ApprovalStatusCell');
var ManualImportCollection = require('./ManualImportCollection');
var Messenger = require('../Shared/Messenger');
module.exports = Marionette.Layout.extend({
className : 'modal-lg',
template : 'ManualImport/ManualImportLayoutTemplate',
regions : {
workspace : '.x-workspace'
},
ui : {
importButton : '.x-import'
},
events : {
'click .x-import' : '_import'
},
columns : [
{
name : '',
cell : SelectAllCell,
headerCell : 'select-all',
sortable : false
},
{
name : 'relativePath',
label : 'Relative Path',
cell : PathCell,
sortable : true
},
{
name : 'series',
label : 'Series',
cell : SeriesCell,
sortable : true
},
{
name : 'seasonNumber',
label : 'Season',
cell : SeasonCell,
sortable : true
},
{
name : 'episodes',
label : 'Episode(s)',
cell : EpisodesCell,
sortable : false
},
{
name : 'quality',
label : 'Quality',
cell : QualityCell,
sortable : true
},
{
name : 'size',
label : 'Size',
cell : FileSizeCell,
sortable : true
},
{
name : 'rejections',
label : '<i class="icon-sonarr-header-rejections" />',
tooltip : 'Rejections',
cell : ApprovalStatusCell,
sortable : false,
sortType : 'fixed',
direction : 'ascending',
title : 'Import Rejected'
}
],
initialize : function(options) {
this.folder = options.folder;
this.downloadId = options.downloadId;
this.title = options.title;
this.templateHelpers = {
title : this.title || this.folder
};
},
onRender : function() {
if (this.folder || this.downloadId) {
this._showLoading();
this._loadCollection();
}
else {
this._showSelectFolder();
this.ui.importButton.hide();
}
},
_showLoading : function () {
this.workspace.show(new LoadingView());
},
_loadCollection : function () {
this.manualImportCollection = new ManualImportCollection({ folder: this.folder, downloadId: this.downloadId });
this.manualImportCollection.fetch();
this.listenTo(this.manualImportCollection, 'sync', this._showTable);
this.listenTo(this.manualImportCollection, 'backgrid:selected', this._updateButtons);
},
_showTable : function () {
if (this.manualImportCollection.length === 0) {
this.workspace.show(new EmptyView());
return;
}
this.fileView = new Backgrid.Grid({
columns : this.columns,
collection : this.manualImportCollection,
className : 'table table-hover',
row : ManualImportRow
});
this.workspace.show(this.fileView);
this._updateButtons();
},
_showSelectFolder : function () {
this.selectFolderView = new SelectFolderView();
this.workspace.show(this.selectFolderView);
this.listenTo(this.selectFolderView, 'manualImport', this._manualImport);
this.listenTo(this.selectFolderView, 'automaticImport', this._automaticImport);
},
_manualImport : function (e) {
this.folder = e.folder;
this.templateHelpers.title = this.folder;
this.render();
},
_automaticImport : function (e) {
CommandController.Execute('downloadedEpisodesScan', {
name : 'downloadedEpisodesScan',
path : e.folder
});
vent.trigger(vent.Commands.CloseModalCommand);
},
_import : function () {
var selected = this.fileView.getSelectedModels();
if (selected.length === 0) {
return;
}
if (_.any(selected, function (model) {
return !model.has('series');
})) {
this._showErrorMessage('Series must be chosen for each selected file');
return;
}
if (_.any(selected, function (model) {
return !model.has('season');
})) {
this._showErrorMessage('Season must be chosen for each selected file');
return;
}
if (_.any(selected, function (model) {
return !model.has('episodes') || model.get('episodes').length === 0;
})) {
this._showErrorMessage('One or more episodes must be chosen for each selected file');
return;
}
CommandController.Execute('manualImport', {
name : 'manualImport',
files : _.map(selected, function (file) {
return {
path : file.get('path'),
seriesId : file.get('series').id,
episodeIds : _.map(file.get('episodes'), 'id'),
quality : file.get('quality'),
downloadId : file.get('downloadId')
};
})
});
vent.trigger(vent.Commands.CloseModalCommand);
},
_updateButtons : function (model, selected) {
if (!this.fileView) {
this.ui.importButton.attr('disabled', 'disabled');
return;
}
if (!model) {
return;
}
var selectedModels = this.fileView.getSelectedModels();
var selectedCount = 0;
if (selected) {
selectedCount = _.any(selectedModels, { id : model.id }) ? selectedModels.length : selectedModels.length + 1;
}
else {
selectedCount = _.any(selectedModels, { id : model.id }) ? selectedModels.length - 1 : selectedModels.length;
}
if (selectedCount === 0) {
this.ui.importButton.attr('disabled', 'disabled');
}
else {
this.ui.importButton.removeAttr('disabled');
}
},
_showErrorMessage : function (message) {
Messenger.show({
message : message,
type : 'error',
hideAfter : 5
});
}
});