commonjsed SearchResultView

pull/2/head
Mark McDowall 10 years ago
parent 408a4e0a81
commit 32dd545ef9

@ -1,303 +1,288 @@
'use strict'; var _ = require('underscore');
define( var vent = require('vent');
[ var AppLayout = require('../AppLayout');
'underscore', var Backbone = require('backbone');
'vent', var Marionette = require('marionette');
'AppLayout', var Profiles = require('../Profile/ProfileCollection');
'backbone', var RootFolders = require('./RootFolders/RootFolderCollection');
'marionette', var RootFolderLayout = require('./RootFolders/RootFolderLayout');
'Profile/ProfileCollection', var SeriesCollection = require('../Series/SeriesCollection');
'AddSeries/RootFolders/RootFolderCollection', var Config = require('../Config');
'AddSeries/RootFolders/RootFolderLayout', var Messenger = require('../Shared/Messenger');
'Series/SeriesCollection', var AsValidatedView = require('../Mixins/AsValidatedView');
'Config',
'Shared/Messenger', require('jquery.dotdotdot');
'Mixins/AsValidatedView',
'jquery.dotdotdot' var view = Marionette.ItemView.extend({
], function (_,
vent, template: 'AddSeries/SearchResultViewTemplate',
AppLayout,
Backbone, ui: {
Marionette, profile : '.x-profile',
Profiles, rootFolder : '.x-root-folder',
RootFolders, seasonFolder : '.x-season-folder',
RootFolderLayout, seriesType : '.x-series-type',
SeriesCollection, monitor : '.x-monitor',
Config, monitorTooltip : '.x-monitor-tooltip',
Messenger, addButton : '.x-add',
AsValidatedView) { addSearchButton : '.x-add-search',
overview : '.x-overview'
var view = Marionette.ItemView.extend({ },
template: 'AddSeries/SearchResultViewTemplate', events: {
'click .x-add' : '_addWithoutSearch',
ui: { 'click .x-add-search' : '_addAndSearch',
profile : '.x-profile', 'change .x-profile' : '_profileChanged',
rootFolder : '.x-root-folder', 'change .x-root-folder' : '_rootFolderChanged',
seasonFolder : '.x-season-folder', 'change .x-season-folder' : '_seasonFolderChanged',
seriesType : '.x-series-type', 'change .x-series-type' : '_seriesTypeChanged',
monitor : '.x-monitor', 'change .x-monitor' : '_monitorChanged'
monitorTooltip : '.x-monitor-tooltip', },
addButton : '.x-add',
addSearchButton : '.x-add-search', initialize: function () {
overview : '.x-overview'
}, if (!this.model) {
throw 'model is required';
events: { }
'click .x-add' : '_addWithoutSearch',
'click .x-add-search' : '_addAndSearch', this.templateHelpers = {};
'change .x-profile' : '_profileChanged', this._configureTemplateHelpers();
'change .x-root-folder' : '_rootFolderChanged',
'change .x-season-folder' : '_seasonFolderChanged', this.listenTo(vent, Config.Events.ConfigUpdatedEvent, this._onConfigUpdated);
'change .x-series-type' : '_seriesTypeChanged', this.listenTo(this.model, 'change', this.render);
'change .x-monitor' : '_monitorChanged' this.listenTo(RootFolders, 'all', this._rootFoldersUpdated);
}, },
initialize: function () { onRender: function () {
if (!this.model) { var defaultProfile = Config.getValue(Config.Keys.DefaultProfileId);
throw 'model is required'; var defaultRoot = Config.getValue(Config.Keys.DefaultRootFolderId);
} var useSeasonFolder = Config.getValueBoolean(Config.Keys.UseSeasonFolder, true);
var defaultSeriesType = Config.getValue(Config.Keys.DefaultSeriesType, 'standard');
this.templateHelpers = {}; var defaultMonitorEpisodes = Config.getValue(Config.Keys.MonitorEpisodes, 'missing');
this._configureTemplateHelpers();
if (Profiles.get(defaultProfile)) {
this.listenTo(vent, Config.Events.ConfigUpdatedEvent, this._onConfigUpdated); this.ui.profile.val(defaultProfile);
this.listenTo(this.model, 'change', this.render); }
this.listenTo(RootFolders, 'all', this._rootFoldersUpdated);
}, if (RootFolders.get(defaultRoot)) {
this.ui.rootFolder.val(defaultRoot);
onRender: function () { }
var defaultProfile = Config.getValue(Config.Keys.DefaultProfileId); this.ui.seasonFolder.prop('checked', useSeasonFolder);
var defaultRoot = Config.getValue(Config.Keys.DefaultRootFolderId); this.ui.seriesType.val(defaultSeriesType);
var useSeasonFolder = Config.getValueBoolean(Config.Keys.UseSeasonFolder, true); this.ui.monitor.val(defaultMonitorEpisodes);
var defaultSeriesType = Config.getValue(Config.Keys.DefaultSeriesType, 'standard');
var defaultMonitorEpisodes = Config.getValue(Config.Keys.MonitorEpisodes, 'missing'); //TODO: make this work via onRender, FM?
//works with onShow, but stops working after the first render
if (Profiles.get(defaultProfile)) { this.ui.overview.dotdotdot({
this.ui.profile.val(defaultProfile); height: 120
}
if (RootFolders.get(defaultRoot)) {
this.ui.rootFolder.val(defaultRoot);
}
this.ui.seasonFolder.prop('checked', useSeasonFolder);
this.ui.seriesType.val(defaultSeriesType);
this.ui.monitor.val(defaultMonitorEpisodes);
//TODO: make this work via onRender, FM?
//works with onShow, but stops working after the first render
this.ui.overview.dotdotdot({
height: 120
});
this.templateFunction = Marionette.TemplateCache.get('AddSeries/MonitoringTooltipTemplate');
var content = this.templateFunction();
this.ui.monitorTooltip.popover({
content : content,
html : true,
trigger : 'hover',
title : 'Episode Monitoring Options',
placement: 'right',
container: this.$el
});
},
_configureTemplateHelpers: function () {
var existingSeries = SeriesCollection.where({tvdbId: this.model.get('tvdbId')});
if (existingSeries.length > 0) {
this.templateHelpers.existing = existingSeries[0].toJSON();
}
this.templateHelpers.profiles = Profiles.toJSON();
if (!this.model.get('isExisting')) {
this.templateHelpers.rootFolders = RootFolders.toJSON();
}
},
_onConfigUpdated: function (options) {
if (options.key === Config.Keys.DefaultProfileId) {
this.ui.profile.val(options.value);
}
else if (options.key === Config.Keys.DefaultRootFolderId) {
this.ui.rootFolder.val(options.value);
}
else if (options.key === Config.Keys.UseSeasonFolder) {
this.ui.seasonFolder.prop('checked', options.value);
}
else if (options.key === Config.Keys.DefaultSeriesType) {
this.ui.seriesType.val(options.value);
}
else if (options.key === Config.Keys.MonitorEpisodes) {
this.ui.monitor.val(options.value);
}
},
_profileChanged: function () {
Config.setValue(Config.Keys.DefaultProfileId, this.ui.profile.val());
},
_seasonFolderChanged: function () {
Config.setValue(Config.Keys.UseSeasonFolder, this.ui.seasonFolder.prop('checked'));
},
_rootFolderChanged: function () {
var rootFolderValue = this.ui.rootFolder.val();
if (rootFolderValue === 'addNew') {
var rootFolderLayout = new RootFolderLayout();
this.listenToOnce(rootFolderLayout, 'folderSelected', this._setRootFolder);
AppLayout.modalRegion.show(rootFolderLayout);
}
else {
Config.setValue(Config.Keys.DefaultRootFolderId, rootFolderValue);
}
},
_seriesTypeChanged: function () {
Config.setValue(Config.Keys.DefaultSeriesType, this.ui.seriesType.val());
},
_monitorChanged: function () {
Config.setValue(Config.Keys.MonitorEpisodes, this.ui.monitor.val());
},
_setRootFolder: function (options) {
vent.trigger(vent.Commands.CloseModalCommand);
this.ui.rootFolder.val(options.model.id);
this._rootFolderChanged();
},
_addWithoutSearch: function () {
this._addSeries(false);
},
_addAndSearch: function() {
this._addSeries(true);
},
_addSeries: function (searchForMissingEpisodes) {
var addButton = this.ui.addButton;
var addSearchButton = this.ui.addSearchButton;
addButton.addClass('disabled');
addSearchButton.addClass('disabled');
var profile = this.ui.profile.val();
var rootFolderPath = this.ui.rootFolder.children(':selected').text();
var seriesType = this.ui.seriesType.val();
var seasonFolder = this.ui.seasonFolder.prop('checked');
var options = this._getAddSeriesOptions();
options.searchForMissingEpisodes = searchForMissingEpisodes;
this.model.set({
profileId : profile,
rootFolderPath : rootFolderPath,
seasonFolder : seasonFolder,
seriesType : seriesType,
addOptions : options
}, { silent: true });
var self = this;
var promise = this.model.save();
if (searchForMissingEpisodes) {
this.ui.addSearchButton.spinForPromise(promise);
}
else {
this.ui.addButton.spinForPromise(promise);
}
promise.always(function () {
addButton.removeClass('disabled');
addSearchButton.removeClass('disabled');
});
promise.done(function () {
SeriesCollection.add(self.model);
self.close();
Messenger.show({
message: 'Added: ' + self.model.get('title'),
actions : {
goToSeries: {
label: 'Go to Series',
action: function() {
Backbone.history.navigate('/series/' + self.model.get('titleSlug'), { trigger: true });
}
}
},
hideAfter: 8,
hideOnNavigate: true
});
vent.trigger(vent.Events.SeriesAdded, { series: self.model });
});
},
_rootFoldersUpdated: function () {
this._configureTemplateHelpers();
this.render();
},
_getAddSeriesOptions: function () {
var monitor = this.ui.monitor.val();
var lastSeason = _.max(this.model.get('seasons'), 'seasonNumber');
var firstSeason = _.min(_.reject(this.model.get('seasons'), { seasonNumber: 0 }), 'seasonNumber');
this.model.setSeasonPass(firstSeason.seasonNumber);
var options = {
ignoreEpisodesWithFiles: false,
ignoreEpisodesWithoutFiles: false
};
if (monitor === 'all') {
return options;
}
else if (monitor === 'future') {
options.ignoreEpisodesWithFiles = true;
options.ignoreEpisodesWithoutFiles = true;
}
else if (monitor === 'latest') {
this.model.setSeasonPass(lastSeason.seasonNumber);
}
else if (monitor === 'first') {
this.model.setSeasonPass(lastSeason.seasonNumber + 1);
this.model.setSeasonMonitored(firstSeason.seasonNumber);
}
else if (monitor === 'missing') {
options.ignoreEpisodesWithFiles = true;
}
else if (monitor === 'existing') {
options.ignoreEpisodesWithoutFiles = true;
}
else if (monitor === 'none') {
this.model.setSeasonPass(lastSeason.seasonNumber + 1);
}
return options;
}
}); });
AsValidatedView.apply(view); this.templateFunction = Marionette.TemplateCache.get('AddSeries/MonitoringTooltipTemplate');
var content = this.templateFunction();
return view; this.ui.monitorTooltip.popover({
}); content : content,
html : true,
trigger : 'hover',
title : 'Episode Monitoring Options',
placement: 'right',
container: this.$el
});
},
_configureTemplateHelpers: function () {
var existingSeries = SeriesCollection.where({tvdbId: this.model.get('tvdbId')});
if (existingSeries.length > 0) {
this.templateHelpers.existing = existingSeries[0].toJSON();
}
this.templateHelpers.profiles = Profiles.toJSON();
if (!this.model.get('isExisting')) {
this.templateHelpers.rootFolders = RootFolders.toJSON();
}
},
_onConfigUpdated: function (options) {
if (options.key === Config.Keys.DefaultProfileId) {
this.ui.profile.val(options.value);
}
else if (options.key === Config.Keys.DefaultRootFolderId) {
this.ui.rootFolder.val(options.value);
}
else if (options.key === Config.Keys.UseSeasonFolder) {
this.ui.seasonFolder.prop('checked', options.value);
}
else if (options.key === Config.Keys.DefaultSeriesType) {
this.ui.seriesType.val(options.value);
}
else if (options.key === Config.Keys.MonitorEpisodes) {
this.ui.monitor.val(options.value);
}
},
_profileChanged: function () {
Config.setValue(Config.Keys.DefaultProfileId, this.ui.profile.val());
},
_seasonFolderChanged: function () {
Config.setValue(Config.Keys.UseSeasonFolder, this.ui.seasonFolder.prop('checked'));
},
_rootFolderChanged: function () {
var rootFolderValue = this.ui.rootFolder.val();
if (rootFolderValue === 'addNew') {
var rootFolderLayout = new RootFolderLayout();
this.listenToOnce(rootFolderLayout, 'folderSelected', this._setRootFolder);
AppLayout.modalRegion.show(rootFolderLayout);
}
else {
Config.setValue(Config.Keys.DefaultRootFolderId, rootFolderValue);
}
},
_seriesTypeChanged: function () {
Config.setValue(Config.Keys.DefaultSeriesType, this.ui.seriesType.val());
},
_monitorChanged: function () {
Config.setValue(Config.Keys.MonitorEpisodes, this.ui.monitor.val());
},
_setRootFolder: function (options) {
vent.trigger(vent.Commands.CloseModalCommand);
this.ui.rootFolder.val(options.model.id);
this._rootFolderChanged();
},
_addWithoutSearch: function () {
this._addSeries(false);
},
_addAndSearch: function() {
this._addSeries(true);
},
_addSeries: function (searchForMissingEpisodes) {
var addButton = this.ui.addButton;
var addSearchButton = this.ui.addSearchButton;
addButton.addClass('disabled');
addSearchButton.addClass('disabled');
var profile = this.ui.profile.val();
var rootFolderPath = this.ui.rootFolder.children(':selected').text();
var seriesType = this.ui.seriesType.val();
var seasonFolder = this.ui.seasonFolder.prop('checked');
var options = this._getAddSeriesOptions();
options.searchForMissingEpisodes = searchForMissingEpisodes;
this.model.set({
profileId : profile,
rootFolderPath : rootFolderPath,
seasonFolder : seasonFolder,
seriesType : seriesType,
addOptions : options
}, { silent: true });
var self = this;
var promise = this.model.save();
if (searchForMissingEpisodes) {
this.ui.addSearchButton.spinForPromise(promise);
}
else {
this.ui.addButton.spinForPromise(promise);
}
promise.always(function () {
addButton.removeClass('disabled');
addSearchButton.removeClass('disabled');
});
promise.done(function () {
SeriesCollection.add(self.model);
self.close();
Messenger.show({
message: 'Added: ' + self.model.get('title'),
actions : {
goToSeries: {
label: 'Go to Series',
action: function() {
Backbone.history.navigate('/series/' + self.model.get('titleSlug'), { trigger: true });
}
}
},
hideAfter: 8,
hideOnNavigate: true
});
vent.trigger(vent.Events.SeriesAdded, { series: self.model });
});
},
_rootFoldersUpdated: function () {
this._configureTemplateHelpers();
this.render();
},
_getAddSeriesOptions: function () {
var monitor = this.ui.monitor.val();
var lastSeason = _.max(this.model.get('seasons'), 'seasonNumber');
var firstSeason = _.min(_.reject(this.model.get('seasons'), { seasonNumber: 0 }), 'seasonNumber');
this.model.setSeasonPass(firstSeason.seasonNumber);
var options = {
ignoreEpisodesWithFiles: false,
ignoreEpisodesWithoutFiles: false
};
if (monitor === 'all') {
return options;
}
else if (monitor === 'future') {
options.ignoreEpisodesWithFiles = true;
options.ignoreEpisodesWithoutFiles = true;
}
else if (monitor === 'latest') {
this.model.setSeasonPass(lastSeason.seasonNumber);
}
else if (monitor === 'first') {
this.model.setSeasonPass(lastSeason.seasonNumber + 1);
this.model.setSeasonMonitored(firstSeason.seasonNumber);
}
else if (monitor === 'missing') {
options.ignoreEpisodesWithFiles = true;
}
else if (monitor === 'existing') {
options.ignoreEpisodesWithoutFiles = true;
}
else if (monitor === 'none') {
this.model.setSeasonPass(lastSeason.seasonNumber + 1);
}
return options;
}
});
AsValidatedView.apply(view);
module.exports = view;
Loading…
Cancel
Save