commit
647ea5456b
Binary file not shown.
@ -0,0 +1,16 @@
|
|||||||
|
'use strict';
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'backgrid'
|
||||||
|
], function (Backgrid) {
|
||||||
|
return Backgrid.Cell.extend({
|
||||||
|
|
||||||
|
className : 'season-folder-cell',
|
||||||
|
|
||||||
|
render: function () {
|
||||||
|
var seasonFolder = this.model.get('seasonFolder');
|
||||||
|
this.$el.html(seasonFolder.toString());
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,5 @@
|
|||||||
|
body.control-panel-visible {
|
||||||
|
ul.messenger.messenger-fixed.messenger-on-bottom {
|
||||||
|
bottom: 95px;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,156 @@
|
|||||||
|
'use strict';
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'underscore',
|
||||||
|
'marionette',
|
||||||
|
'backgrid',
|
||||||
|
'vent',
|
||||||
|
'Series/SeriesCollection',
|
||||||
|
'Quality/QualityProfileCollection',
|
||||||
|
'AddSeries/RootFolders/Collection',
|
||||||
|
'Shared/Toolbar/ToolbarLayout',
|
||||||
|
'AddSeries/RootFolders/Layout',
|
||||||
|
'Config'
|
||||||
|
], function (_,
|
||||||
|
Marionette,
|
||||||
|
Backgrid,
|
||||||
|
vent,
|
||||||
|
SeriesCollection,
|
||||||
|
QualityProfiles,
|
||||||
|
RootFolders,
|
||||||
|
ToolbarLayout,
|
||||||
|
RootFolderLayout,
|
||||||
|
Config) {
|
||||||
|
return Marionette.ItemView.extend({
|
||||||
|
template: 'Series/Editor/SeriesEditorFooterViewTemplate',
|
||||||
|
|
||||||
|
ui: {
|
||||||
|
monitored : '.x-monitored',
|
||||||
|
qualityProfile: '.x-quality-profiles',
|
||||||
|
seasonFolder : '.x-season-folder',
|
||||||
|
rootFolder : '.x-root-folder',
|
||||||
|
selectedCount : '.x-selected-count',
|
||||||
|
saveButton : '.x-save',
|
||||||
|
container : '.series-editor-footer'
|
||||||
|
},
|
||||||
|
|
||||||
|
events: {
|
||||||
|
'click .x-save' : '_updateAndSave',
|
||||||
|
'change .x-root-folder': '_rootFolderChanged'
|
||||||
|
},
|
||||||
|
|
||||||
|
templateHelpers: function () {
|
||||||
|
return {
|
||||||
|
qualityProfiles: QualityProfiles,
|
||||||
|
rootFolders : RootFolders.toJSON()
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
initialize: function (options) {
|
||||||
|
RootFolders.fetch().done(function () {
|
||||||
|
RootFolders.synced = true;
|
||||||
|
});
|
||||||
|
|
||||||
|
this.editorGrid = options.editorGrid;
|
||||||
|
this.listenTo(SeriesCollection, 'backgrid:selected', this._updateInfo);
|
||||||
|
this.listenTo(RootFolders, 'all', this.render);
|
||||||
|
},
|
||||||
|
|
||||||
|
onRender: function () {
|
||||||
|
this._updateInfo();
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateAndSave: function () {
|
||||||
|
var selected = this.editorGrid.getSelectedModels();
|
||||||
|
|
||||||
|
var monitored = this.ui.monitored.val();
|
||||||
|
var profile = this.ui.qualityProfile.val();
|
||||||
|
var seasonFolder = this.ui.seasonFolder.val();
|
||||||
|
var rootFolder = this.ui.rootFolder.val();
|
||||||
|
|
||||||
|
_.each(selected, function (model) {
|
||||||
|
if (monitored === 'true') {
|
||||||
|
model.set('monitored', true);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (monitored === 'false') {
|
||||||
|
model.set('monitored', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (profile !== 'noChange') {
|
||||||
|
model.set('qualityProfileId', parseInt(profile, 10));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (seasonFolder === 'true') {
|
||||||
|
model.set('seasonFolder', true);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (seasonFolder === 'false') {
|
||||||
|
model.set('seasonFolder', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rootFolder !== 'noChange') {
|
||||||
|
var rootFolderPath = RootFolders.get(parseInt(rootFolder, 10));
|
||||||
|
|
||||||
|
model.set('rootFolderPath', rootFolderPath.get('path'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
SeriesCollection.save();
|
||||||
|
|
||||||
|
this.listenTo(SeriesCollection, 'save', this._afterSave);
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateInfo: function () {
|
||||||
|
var selected = this.editorGrid.getSelectedModels();
|
||||||
|
var selectedCount = selected.length;
|
||||||
|
|
||||||
|
this.ui.selectedCount.html('{0} series selected'.format(selectedCount));
|
||||||
|
|
||||||
|
if (selectedCount === 0) {
|
||||||
|
this.ui.monitored.attr('disabled', '');
|
||||||
|
this.ui.qualityProfile.attr('disabled', '');
|
||||||
|
this.ui.seasonFolder.attr('disabled', '');
|
||||||
|
this.ui.rootFolder.attr('disabled', '');
|
||||||
|
this.ui.saveButton.attr('disabled', '');
|
||||||
|
}
|
||||||
|
|
||||||
|
else {
|
||||||
|
this.ui.monitored.removeAttr('disabled', '');
|
||||||
|
this.ui.qualityProfile.removeAttr('disabled', '');
|
||||||
|
this.ui.seasonFolder.removeAttr('disabled', '');
|
||||||
|
this.ui.rootFolder.removeAttr('disabled', '');
|
||||||
|
this.ui.saveButton.removeAttr('disabled', '');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_rootFolderChanged: function () {
|
||||||
|
var rootFolderValue = this.ui.rootFolder.val();
|
||||||
|
if (rootFolderValue === 'addNew') {
|
||||||
|
var rootFolderLayout = new RootFolderLayout();
|
||||||
|
this.listenToOnce(rootFolderLayout, 'folderSelected', this._setRootFolder);
|
||||||
|
vent.trigger(vent.Commands.OpenModalCommand, rootFolderLayout);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Config.setValue(Config.Keys.DefaultRootFolderId, rootFolderValue);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
_setRootFolder: function (options) {
|
||||||
|
vent.trigger(vent.Commands.CloseModalCommand);
|
||||||
|
this.ui.rootFolder.val(options.model.id);
|
||||||
|
this._rootFolderChanged();
|
||||||
|
},
|
||||||
|
|
||||||
|
_afterSave: function () {
|
||||||
|
this.ui.monitored.val('noChange');
|
||||||
|
this.ui.qualityProfile.val('noChange');
|
||||||
|
this.ui.seasonFolder.val('noChange');
|
||||||
|
this.ui.rootFolder.val('noChange');
|
||||||
|
|
||||||
|
SeriesCollection.each(function (model) {
|
||||||
|
model.trigger('backgrid:select', model, false);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,148 @@
|
|||||||
|
'use strict';
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'vent',
|
||||||
|
'marionette',
|
||||||
|
'backgrid',
|
||||||
|
'Series/Index/EmptyView',
|
||||||
|
'Series/SeriesCollection',
|
||||||
|
'Cells/SeriesTitleCell',
|
||||||
|
'Cells/QualityProfileCell',
|
||||||
|
'Cells/SeriesStatusCell',
|
||||||
|
'Cells/SeasonFolderCell',
|
||||||
|
'Shared/Toolbar/ToolbarLayout',
|
||||||
|
'Series/Editor/SeriesEditorFooterView'
|
||||||
|
], function (vent,
|
||||||
|
Marionette,
|
||||||
|
Backgrid,
|
||||||
|
EmptyView,
|
||||||
|
SeriesCollection,
|
||||||
|
SeriesTitleCell,
|
||||||
|
QualityProfileCell,
|
||||||
|
SeriesStatusCell,
|
||||||
|
SeasonFolderCell,
|
||||||
|
ToolbarLayout,
|
||||||
|
FooterView) {
|
||||||
|
return Marionette.Layout.extend({
|
||||||
|
template: 'Series/Editor/SeriesEditorLayoutTemplate',
|
||||||
|
|
||||||
|
regions: {
|
||||||
|
seriesRegion: '#x-series-editor',
|
||||||
|
toolbar : '#x-toolbar'
|
||||||
|
},
|
||||||
|
|
||||||
|
ui: {
|
||||||
|
monitored : '.x-monitored',
|
||||||
|
qualityProfiles: '.x-quality-profiles',
|
||||||
|
rootFolder : '.x-root-folder',
|
||||||
|
selectedCount : '.x-selected-count'
|
||||||
|
},
|
||||||
|
|
||||||
|
events: {
|
||||||
|
'click .x-save' : '_updateAndSave',
|
||||||
|
'change .x-root-folder': '_rootFolderChanged'
|
||||||
|
},
|
||||||
|
|
||||||
|
columns:
|
||||||
|
[
|
||||||
|
{
|
||||||
|
name : '',
|
||||||
|
cell : 'select-row',
|
||||||
|
headerCell: 'select-all',
|
||||||
|
sortable : false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name : 'statusWeight',
|
||||||
|
label : '',
|
||||||
|
cell : SeriesStatusCell
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name : 'title',
|
||||||
|
label : 'Title',
|
||||||
|
cell : SeriesTitleCell,
|
||||||
|
cellValue: 'this'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name : 'qualityProfileId',
|
||||||
|
label: 'Quality',
|
||||||
|
cell : QualityProfileCell
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name : 'monitored',
|
||||||
|
label: 'Season Folder',
|
||||||
|
cell : SeasonFolderCell
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name : 'path',
|
||||||
|
label: 'Path',
|
||||||
|
cell : 'string'
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
|
leftSideButtons: {
|
||||||
|
type : 'default',
|
||||||
|
storeState: false,
|
||||||
|
items :
|
||||||
|
[
|
||||||
|
{
|
||||||
|
title : 'Season Pass',
|
||||||
|
icon : 'icon-bookmark',
|
||||||
|
route : 'seasonpass'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title : 'Update Library',
|
||||||
|
icon : 'icon-refresh',
|
||||||
|
command : 'refreshseries',
|
||||||
|
successMessage: 'Library was updated!',
|
||||||
|
errorMessage : 'Library update failed!'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
|
||||||
|
onRender: function () {
|
||||||
|
this._showToolbar();
|
||||||
|
this._showTable();
|
||||||
|
|
||||||
|
this._fetchCollection();
|
||||||
|
},
|
||||||
|
|
||||||
|
onClose: function () {
|
||||||
|
vent.trigger(vent.Commands.CloseControlPanelCommand);
|
||||||
|
},
|
||||||
|
|
||||||
|
_showTable: function () {
|
||||||
|
if (SeriesCollection.length === 0) {
|
||||||
|
this.seriesRegion.show(new EmptyView());
|
||||||
|
this.toolbar.close();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.editorGrid = new Backgrid.Grid({
|
||||||
|
collection: SeriesCollection,
|
||||||
|
columns : this.columns,
|
||||||
|
className : 'table table-hover'
|
||||||
|
});
|
||||||
|
|
||||||
|
this.seriesRegion.show(this.editorGrid);
|
||||||
|
this._showFooter();
|
||||||
|
},
|
||||||
|
|
||||||
|
_fetchCollection: function () {
|
||||||
|
SeriesCollection.fetch();
|
||||||
|
},
|
||||||
|
|
||||||
|
_showToolbar: function () {
|
||||||
|
this.toolbar.show(new ToolbarLayout({
|
||||||
|
left :
|
||||||
|
[
|
||||||
|
this.leftSideButtons
|
||||||
|
],
|
||||||
|
context: this
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
|
||||||
|
_showFooter: function () {
|
||||||
|
vent.trigger(vent.Commands.OpenControlPanelCommand, new FooterView({ editorGrid: this.editorGrid }));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,24 @@
|
|||||||
|
'use strict';
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'vent',
|
||||||
|
'AppLayout',
|
||||||
|
'marionette'
|
||||||
|
], function (vent, AppLayout, Marionette) {
|
||||||
|
|
||||||
|
return Marionette.AppRouter.extend({
|
||||||
|
|
||||||
|
initialize: function () {
|
||||||
|
vent.on(vent.Commands.OpenControlPanelCommand, this._openControlPanel, this);
|
||||||
|
vent.on(vent.Commands.CloseControlPanelCommand, this._closeControlPanel, this);
|
||||||
|
},
|
||||||
|
|
||||||
|
_openControlPanel: function (view) {
|
||||||
|
AppLayout.controlPanelRegion.show(view);
|
||||||
|
},
|
||||||
|
|
||||||
|
_closeControlPanel: function () {
|
||||||
|
AppLayout.controlPanelRegion.closePanel();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,35 @@
|
|||||||
|
'use strict';
|
||||||
|
define(
|
||||||
|
[
|
||||||
|
'jquery',
|
||||||
|
'backbone',
|
||||||
|
'marionette'
|
||||||
|
], function ($,Backbone, Marionette) {
|
||||||
|
var region = Marionette.Region.extend({
|
||||||
|
el: '#control-panel-region',
|
||||||
|
|
||||||
|
constructor: function () {
|
||||||
|
Backbone.Marionette.Region.prototype.constructor.apply(this, arguments);
|
||||||
|
this.on('show', this.showPanel, this);
|
||||||
|
},
|
||||||
|
|
||||||
|
getEl: function (selector) {
|
||||||
|
var $el = $(selector);
|
||||||
|
|
||||||
|
return $el;
|
||||||
|
},
|
||||||
|
|
||||||
|
showPanel: function () {
|
||||||
|
$('body').addClass('control-panel-visible');
|
||||||
|
this.$el.animate({ 'margin-bottom': 0, 'opacity': 1 }, { queue: false, duration: 300 });
|
||||||
|
},
|
||||||
|
|
||||||
|
closePanel: function () {
|
||||||
|
$('body').removeClass('control-panel-visible');
|
||||||
|
this.$el.animate({ 'margin-bottom': -100, 'opacity': 0 }, { queue: false, duration: 300 });
|
||||||
|
this.reset();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return region;
|
||||||
|
});
|
Loading…
Reference in new issue