refresh series details after rename/refresh

Fixed: Refresh series details after series refresh and rename
This commit is contained in:
Mark McDowall 2013-09-29 01:48:47 -07:00
parent c2129054a0
commit bd1a9db0ef
4 changed files with 64 additions and 38 deletions

View File

@ -1,11 +1,14 @@
'use strict'; 'use strict';
define( define(
[ [
'app',
'Commands/CommandModel', 'Commands/CommandModel',
'Commands/CommandCollection', 'Commands/CommandCollection',
'underscore', 'underscore',
'jQuery/jquery.spin' 'jQuery/jquery.spin'
], function (CommandModel, CommandCollection, _) { ], function (App, CommandModel, CommandCollection, _) {
var singleton = function () {
return { return {
@ -47,10 +50,17 @@ define(
model.bind('change:state', function (model) { model.bind('change:state', function (model) {
if (!model.isActive()) { if (!model.isActive()) {
options.element.stopSpin(); options.element.stopSpin();
if (model.isComplete()) {
App.vent.trigger(App.Events.CommandComplete, { command: model, model: options.model });
}
} }
}); });
options.element.startSpin(); options.element.startSpin();
} }
}; };
};
return singleton();
}); });

View File

@ -11,13 +11,9 @@ define(
return response; return response;
}, },
isActive: function () {
return this.get('state') !== 'completed' && this.get('state') !== 'failed';
},
isSameCommand: function (command) { isSameCommand: function (command) {
if (command.name.toLocaleLowerCase() != this.get('name').toLocaleLowerCase()) { if (command.name.toLocaleLowerCase() !== this.get('name').toLocaleLowerCase()) {
return false; return false;
} }
@ -28,6 +24,14 @@ define(
} }
return true; return true;
},
isActive: function () {
return this.get('state') !== 'completed' && this.get('state') !== 'failed';
},
isComplete: function () {
return this.get('state') === 'completed';
} }
}); });
}); });

View File

@ -44,6 +44,8 @@ define(
this.listenTo(this.model, 'change:monitored', this._setMonitoredState); this.listenTo(this.model, 'change:monitored', this._setMonitoredState);
this.listenTo(App.vent, App.Events.SeriesDeleted, this._onSeriesDeleted); this.listenTo(App.vent, App.Events.SeriesDeleted, this._onSeriesDeleted);
this.listenTo(App.vent, App.Events.SeasonRenamed, this._onSeasonRenamed); this.listenTo(App.vent, App.Events.SeasonRenamed, this._onSeasonRenamed);
App.vent.on(App.Events.CommandComplete, this._commandComplete, this);
}, },
onShow: function () { onShow: function () {
@ -195,6 +197,16 @@ define(
if (this.model.get('id') === event.series.get('id')) { if (this.model.get('id') === event.series.get('id')) {
this.episodeFileCollection.fetch(); this.episodeFileCollection.fetch();
} }
},
_commandComplete: function (options) {
if (options.command.get('name') === 'refreshseries' || options.command.get('name') === 'renameseries') {
if (options.command.get('seriesId') === this.model.get('id')) {
this._showSeasons();
this._setMonitoredState();
this._showInfo();
}
}
} }
}); });
}); });

View File

@ -25,7 +25,6 @@ require.config({
'jquery.knob' : 'JsLibraries/jquery.knob', 'jquery.knob' : 'JsLibraries/jquery.knob',
'jquery.dotdotdot' : 'JsLibraries/jquery.dotdotdot', 'jquery.dotdotdot' : 'JsLibraries/jquery.dotdotdot',
'libs' : 'JsLibraries/' 'libs' : 'JsLibraries/'
}, },
shim: { shim: {
@ -193,7 +192,8 @@ define(
app.Events = { app.Events = {
SeriesAdded : 'series:added', SeriesAdded : 'series:added',
SeriesDeleted : 'series:deleted', SeriesDeleted : 'series:deleted',
SeasonRenamed: 'season:renamed' SeasonRenamed : 'season:renamed',
CommandComplete: 'command:complete'
}; };
app.Commands = { app.Commands = {