1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-12-16 11:37:58 +02:00
Sonarr/UI/Cells/EpisodeStatusCell.js

59 lines
1.8 KiB
JavaScript
Raw Normal View History

2013-06-22 09:24:24 +03:00
'use strict';
define(
[
'backgrid',
'moment'
], function (Backgrid, Moment) {
return Backgrid.Cell.extend({
className: 'episode-status-cell',
2013-05-21 00:42:20 +03:00
render: function () {
this.$el.empty();
2013-05-21 00:05:48 +03:00
if (this.model) {
2013-05-21 00:05:48 +03:00
var icon;
2013-07-05 23:26:50 +03:00
var tooltip;
2013-05-21 00:05:48 +03:00
var hasAired = Moment(this.model.get('airDate')).isBefore(Moment());
2013-07-17 06:25:42 +03:00
var hasFile = this.model.get('hasFile');
2013-07-17 02:54:45 +03:00
2013-07-17 06:25:42 +03:00
if (hasFile) {
var quality = this.model.get('episodeFile').quality;
if (quality.proper) {
this.$el.html('<span class="badge badge-info" title="Episode downloaded [PROPER]">{0}</span>'.format(quality.quality.name));
}
else {
this.$el.html('<span class="badge badge-inverse" title="Episode downloaded">{0}</span>'.format(quality.quality.name));
}
return this;
2013-05-21 00:06:01 +03:00
}
else {
if (!this.model.get('airDate')) {
icon = 'icon-question-sign';
tooltip = 'TBA';
}
else if (hasAired) {
icon = 'icon-warning-sign';
2013-07-05 23:26:50 +03:00
tooltip = 'Episode missing from disk';
}
else {
icon = 'icon-time';
2013-07-05 23:26:50 +03:00
tooltip = 'Episode has not aired';
}
2013-05-21 00:06:01 +03:00
}
2013-07-05 23:26:50 +03:00
this.$el.html('<i class="{0}" title="{1}"/>'.format(icon, tooltip));
2013-05-21 00:06:01 +03:00
}
2013-05-21 00:05:48 +03:00
return this;
2013-05-21 00:05:48 +03:00
}
});
});