|
|
@ -8,95 +8,121 @@ var Messenger = require('../Shared/Messenger');
|
|
|
|
module.exports = Marionette.Layout.extend({
|
|
|
|
module.exports = Marionette.Layout.extend({
|
|
|
|
className : 'modal-lg',
|
|
|
|
className : 'modal-lg',
|
|
|
|
template : 'Episode/EpisodeDetailsLayoutTemplate',
|
|
|
|
template : 'Episode/EpisodeDetailsLayoutTemplate',
|
|
|
|
|
|
|
|
|
|
|
|
regions : {
|
|
|
|
regions : {
|
|
|
|
summary : '#episode-summary',
|
|
|
|
summary : '#episode-summary',
|
|
|
|
activity : '#episode-activity',
|
|
|
|
activity : '#episode-activity',
|
|
|
|
search : '#episode-search'
|
|
|
|
search : '#episode-search'
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
ui : {
|
|
|
|
ui : {
|
|
|
|
summary : '.x-episode-summary',
|
|
|
|
summary : '.x-episode-summary',
|
|
|
|
activity : '.x-episode-activity',
|
|
|
|
activity : '.x-episode-activity',
|
|
|
|
search : '.x-episode-search',
|
|
|
|
search : '.x-episode-search',
|
|
|
|
monitored : '.x-episode-monitored'
|
|
|
|
monitored : '.x-episode-monitored'
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
events : {
|
|
|
|
events : {
|
|
|
|
"click .x-episode-summary" : '_showSummary',
|
|
|
|
|
|
|
|
"click .x-episode-activity" : '_showActivity',
|
|
|
|
'click .x-episode-summary' : '_showSummary',
|
|
|
|
"click .x-episode-search" : '_showSearch',
|
|
|
|
'click .x-episode-activity' : '_showActivity',
|
|
|
|
"click .x-episode-monitored" : '_toggleMonitored'
|
|
|
|
'click .x-episode-search' : '_showSearch',
|
|
|
|
|
|
|
|
'click .x-episode-monitored' : '_toggleMonitored'
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
templateHelpers : {},
|
|
|
|
templateHelpers : {},
|
|
|
|
|
|
|
|
|
|
|
|
initialize : function(options) {
|
|
|
|
initialize : function(options) {
|
|
|
|
this.templateHelpers.hideSeriesLink = options.hideSeriesLink;
|
|
|
|
this.templateHelpers.hideSeriesLink = options.hideSeriesLink;
|
|
|
|
|
|
|
|
|
|
|
|
this.series = SeriesCollection.get(this.model.get('seriesId'));
|
|
|
|
this.series = SeriesCollection.get(this.model.get('seriesId'));
|
|
|
|
this.templateHelpers.series = this.series.toJSON();
|
|
|
|
this.templateHelpers.series = this.series.toJSON();
|
|
|
|
this.openingTab = options.openingTab || 'summary';
|
|
|
|
this.openingTab = options.openingTab || 'summary';
|
|
|
|
|
|
|
|
|
|
|
|
this.listenTo(this.model, 'sync', this._setMonitoredState);
|
|
|
|
this.listenTo(this.model, 'sync', this._setMonitoredState);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
onShow : function() {
|
|
|
|
onShow : function() {
|
|
|
|
this.searchLayout = new SearchLayout({ model : this.model });
|
|
|
|
this.searchLayout = new SearchLayout({ model : this.model });
|
|
|
|
|
|
|
|
|
|
|
|
if (this.openingTab === 'search') {
|
|
|
|
if (this.openingTab === 'search') {
|
|
|
|
this.searchLayout.startManualSearch = true;
|
|
|
|
this.searchLayout.startManualSearch = true;
|
|
|
|
this._showSearch();
|
|
|
|
this._showSearch();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
else {
|
|
|
|
else {
|
|
|
|
this._showSummary();
|
|
|
|
this._showSummary();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
this._setMonitoredState();
|
|
|
|
this._setMonitoredState();
|
|
|
|
|
|
|
|
|
|
|
|
if (this.series.get('monitored')) {
|
|
|
|
if (this.series.get('monitored')) {
|
|
|
|
this.$el.removeClass('series-not-monitored');
|
|
|
|
this.$el.removeClass('series-not-monitored');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
else {
|
|
|
|
else {
|
|
|
|
this.$el.addClass('series-not-monitored');
|
|
|
|
this.$el.addClass('series-not-monitored');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
_showSummary : function(e) {
|
|
|
|
_showSummary : function(e) {
|
|
|
|
if (e) {
|
|
|
|
if (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
this.ui.summary.tab('show');
|
|
|
|
this.ui.summary.tab('show');
|
|
|
|
this.summary.show(new SummaryLayout({
|
|
|
|
this.summary.show(new SummaryLayout({
|
|
|
|
model : this.model,
|
|
|
|
model : this.model,
|
|
|
|
series : this.series
|
|
|
|
series : this.series
|
|
|
|
}));
|
|
|
|
}));
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
_showActivity : function(e) {
|
|
|
|
_showActivity : function(e) {
|
|
|
|
if (e) {
|
|
|
|
if (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
this.ui.activity.tab('show');
|
|
|
|
this.ui.activity.tab('show');
|
|
|
|
this.activity.show(new EpisodeActivityLayout({
|
|
|
|
this.activity.show(new EpisodeActivityLayout({
|
|
|
|
model : this.model,
|
|
|
|
model : this.model,
|
|
|
|
series : this.series
|
|
|
|
series : this.series
|
|
|
|
}));
|
|
|
|
}));
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
_showSearch : function(e) {
|
|
|
|
_showSearch : function(e) {
|
|
|
|
if (e) {
|
|
|
|
if (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
this.ui.search.tab('show');
|
|
|
|
this.ui.search.tab('show');
|
|
|
|
this.search.show(this.searchLayout);
|
|
|
|
this.search.show(this.searchLayout);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
_toggleMonitored : function() {
|
|
|
|
_toggleMonitored : function() {
|
|
|
|
if (!this.series.get('monitored')) {
|
|
|
|
if (!this.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;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var name = 'monitored';
|
|
|
|
var name = 'monitored';
|
|
|
|
this.model.set(name, !this.model.get(name), { silent : true });
|
|
|
|
this.model.set(name, !this.model.get(name), { silent : true });
|
|
|
|
|
|
|
|
|
|
|
|
this.ui.monitored.addClass('icon-spinner icon-spin');
|
|
|
|
this.ui.monitored.addClass('icon-spinner icon-spin');
|
|
|
|
this.model.save();
|
|
|
|
this.model.save();
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
_setMonitoredState : function() {
|
|
|
|
_setMonitoredState : function() {
|
|
|
|
this.ui.monitored.removeClass('icon-spin icon-spinner');
|
|
|
|
this.ui.monitored.removeClass('icon-spin icon-spinner');
|
|
|
|
|
|
|
|
|
|
|
|
if (this.model.get('monitored')) {
|
|
|
|
if (this.model.get('monitored')) {
|
|
|
|
this.ui.monitored.addClass('icon-bookmark');
|
|
|
|
this.ui.monitored.addClass('icon-bookmark');
|
|
|
|
this.ui.monitored.removeClass('icon-bookmark-empty');
|
|
|
|
this.ui.monitored.removeClass('icon-bookmark-empty');
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
else {
|
|
|
|
|
|
|
|
this.ui.monitored.addClass('icon-bookmark-empty');
|
|
|
|
this.ui.monitored.addClass('icon-bookmark-empty');
|
|
|
|
this.ui.monitored.removeClass('icon-bookmark');
|
|
|
|
this.ui.monitored.removeClass('icon-bookmark');
|
|
|
|
}
|
|
|
|
}
|
|
|
|