mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-23 01:43:43 +00:00
Merge pull request #344 from JackDandy/feature/FixCustomShowList
Fix issue changing a custom show list group name that is in use.
This commit is contained in:
commit
1feb7a73d0
11 changed files with 746 additions and 737 deletions
12
CHANGES.md
12
CHANGES.md
|
@ -25,12 +25,22 @@
|
||||||
* Fix display of search status for an alternative release after episode is manually set to "Failed" on the Display Show page
|
* Fix display of search status for an alternative release after episode is manually set to "Failed" on the Display Show page
|
||||||
* Change handle more varieties of media quality
|
* Change handle more varieties of media quality
|
||||||
* Change to prevent another scheduled search when one of the same type is already running
|
* Change to prevent another scheduled search when one of the same type is already running
|
||||||
* Add custom show lists to home page
|
|
||||||
* Change travis to new container builds for faster unit testing
|
* Change travis to new container builds for faster unit testing
|
||||||
* Add handling for shows that do not have a total number of episodes
|
* Add handling for shows that do not have a total number of episodes
|
||||||
* Add support for country network image files to the Show List view
|
* Add support for country network image files to the Show List view
|
||||||
|
* Add General Config/Interface/"Group show list shows into:"... to divide shows into groups on the Show List page
|
||||||
|
* Change Show List progress bar code, smaller page load, efficient use of js render engine
|
||||||
* Change values used for date sorting on home page and episode view for improved compatibility with posix systems
|
* Change values used for date sorting on home page and episode view for improved compatibility with posix systems
|
||||||
|
|
||||||
|
[develop changelog]
|
||||||
|
Fix issue changing a custom show list group name that is in use. The bug resulted in the db containing stale group names
|
||||||
|
but worse, orphaned shows disappeared from the Show List page entirely. Changed texts to describe this feature more
|
||||||
|
clearly from tag to group names. Repositioned this feature on the add show, edit show, and config pages. Change the drop
|
||||||
|
down select to dynamically hide/show the list of group names and change the respectively selected help texts. Change
|
||||||
|
insert space between items in the list of group names for readability. Notify user if an attempt to remove an in use
|
||||||
|
group name is prevented. PEP8 and code cleanup to SG conventions. Removed fixed column widths, this means multiple groups
|
||||||
|
have different column widths, but the original approach is preferred because fixed widths look bad with long show titles.
|
||||||
|
|
||||||
|
|
||||||
### 0.8.3 (2015-04-25 08:48:00 UTC)
|
### 0.8.3 (2015-04-25 08:48:00 UTC)
|
||||||
|
|
||||||
|
|
|
@ -350,6 +350,14 @@ inc_top.tmpl
|
||||||
-moz-osx-font-smoothing:grayscale
|
-moz-osx-font-smoothing:grayscale
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.dropdown [class^="sgicon-"], .dropdown [class*=" sgicon-"]{
|
||||||
|
margin-right:6px
|
||||||
|
}
|
||||||
|
|
||||||
|
#SubMenu [class^="sgicon-"], #SubMenu [class*=" sgicon-"]{
|
||||||
|
margin-right:3px
|
||||||
|
}
|
||||||
|
|
||||||
.sgicon-rss:before{
|
.sgicon-rss:before{
|
||||||
content:"\e622"
|
content:"\e622"
|
||||||
}
|
}
|
||||||
|
@ -1591,12 +1599,6 @@ td.col-subtitles{
|
||||||
text-align:center
|
text-align:center
|
||||||
}
|
}
|
||||||
|
|
||||||
th.col-simple,
|
|
||||||
td.col-simple{
|
|
||||||
width: 150px;
|
|
||||||
text-align: center
|
|
||||||
}
|
|
||||||
|
|
||||||
th.col-status,
|
th.col-status,
|
||||||
td.col-status{
|
td.col-status{
|
||||||
width:200px;
|
width:200px;
|
||||||
|
@ -2084,7 +2086,7 @@ config*.tmpl
|
||||||
|
|
||||||
.component-group-desc{
|
.component-group-desc{
|
||||||
float:left;
|
float:left;
|
||||||
width:250px;
|
width:240px;
|
||||||
padding-right:10px
|
padding-right:10px
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2164,7 +2166,7 @@ config*.tmpl
|
||||||
.stepDiv span.component-title,
|
.stepDiv span.component-title,
|
||||||
#config span.component-title{
|
#config span.component-title{
|
||||||
float:left;
|
float:left;
|
||||||
width:172px;
|
width:182px;
|
||||||
margin-right:10px;
|
margin-right:10px;
|
||||||
font-size:13px;
|
font-size:13px;
|
||||||
font-weight:bold
|
font-weight:bold
|
||||||
|
@ -2180,7 +2182,7 @@ config*.tmpl
|
||||||
font-weight:normal;
|
font-weight:normal;
|
||||||
display:block;
|
display:block;
|
||||||
width:475px;
|
width:475px;
|
||||||
margin-left:182px
|
margin-left:192px
|
||||||
}
|
}
|
||||||
|
|
||||||
#config label.space-right{
|
#config label.space-right{
|
||||||
|
|
|
@ -174,14 +174,14 @@
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<input type="checkbox" name="auto_update" id="auto_update"#echo ('', $checked)[$sickbeard.AUTO_UPDATE]#>
|
<input type="checkbox" name="auto_update" id="auto_update"#echo ('', $checked)[$sickbeard.AUTO_UPDATE]#>
|
||||||
<p>fetch and install software updates.
|
<p>fetch and install software updates.
|
||||||
Updates are run on startup and in the background at the frequency set below*</p>
|
Updates are run on startup and in the background at the frequency set below<sup>1</sup></p>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="field-pair">
|
<div class="field-pair">
|
||||||
<label>
|
<label>
|
||||||
<span class="component-title">Check the server every*</span>
|
<span class="component-title">Check the server every<sup>1</sup></span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<input type="text" name="update_frequency" id="update_frequency" value="$sickbeard.UPDATE_FREQUENCY" class="form-control input-sm input75">
|
<input type="text" name="update_frequency" id="update_frequency" value="$sickbeard.UPDATE_FREQUENCY" class="form-control input-sm input75">
|
||||||
<p>hours for software updates (default:12)</p>
|
<p>hours for software updates (default:12)</p>
|
||||||
|
@ -244,33 +244,28 @@
|
||||||
|
|
||||||
<div class="field-pair">
|
<div class="field-pair">
|
||||||
<label for="showlist_tagview">
|
<label for="showlist_tagview">
|
||||||
<span class="component-title">Show list split view style:</span>
|
<span class="component-title">Group show list shows into:</span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<select id="showlist_tagview" name="showlist_tagview" class="form-control input-sm">
|
<select id="showlist_tagview" name="showlist_tagview" class="form-control input-sm">
|
||||||
<option value="standard"#echo ('', $selected)['standard' == $sickbeard.SHOWLIST_TAGVIEW]#>No Lists</option>
|
<option value="standard"#echo ('', $selected)['standard' == $sickbeard.SHOWLIST_TAGVIEW]#>One Show List</option>
|
||||||
<option value="anime"#echo ('', $selected)['anime' == $sickbeard.SHOWLIST_TAGVIEW]#>Show / Anime Lists</option>
|
<option value="anime"#echo ('', $selected)['anime' == $sickbeard.SHOWLIST_TAGVIEW]#>Show / Anime Lists</option>
|
||||||
<option value="custom"#echo ('', $selected)['custom' == $sickbeard.SHOWLIST_TAGVIEW]#>Custom Lists</option>
|
<option value="custom"#echo ('', $selected)['custom' == $sickbeard.SHOWLIST_TAGVIEW]#>Custom Lists</option>
|
||||||
</select>
|
</select>
|
||||||
|
#set $hidden = ' class="hidden"'
|
||||||
|
<span id="showlist_tagview_standard"#echo ('', $hidden)['standard' not in $sickbeard.SHOWLIST_TAGVIEW]#>that contains all shows (default)</span>
|
||||||
|
<span id="showlist_tagview_anime"#echo ('', $hidden)['anime' not in $sickbeard.SHOWLIST_TAGVIEW]#>two groups, the show list and anime</span>
|
||||||
|
<span id="showlist_tagview_custom"#echo ('', $hidden)['custom' not in $sickbeard.SHOWLIST_TAGVIEW]#>multiple custom<sup>1</sup> named groups and a "Show List"</span>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="field-pair #if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then 'hidden' else ''#">
|
<div id="showlist_tagview_custom_config" class="field-pair#if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then ' hidden' else ''#">
|
||||||
<label for="show_tags">
|
<label for="show_tags">
|
||||||
<span class="component-title">Show tags:</span>
|
<span class="component-title">Group names for show list<sup>1</sup></span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<input type="text" name="show_tags" id="show_tags" value="$show_tags" class="form-control input-sm input300">
|
<input type="text" name="show_tags" id="show_tags" value="$show_tags" class="form-control input-sm input300">
|
||||||
<p class="clear-left note">show tags are to be selected from these comma seperated words</p>
|
<span>comma separated names</span>
|
||||||
</span>
|
<p class="clear-left note">group shows to the order of this custom list (add shows to groups with <a href="/manage/">mass edit</a>)</p>
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="field-pair">
|
|
||||||
<label for="use_imdb_info">
|
|
||||||
<span class="component-title">Enable IMDb info</span>
|
|
||||||
<span class="component-desc">
|
|
||||||
<input type="checkbox" name="use_imdb_info" id="use_imdb_info"#echo ('', $checked)[$sickbeard.USE_IMDB_INFO]#>
|
|
||||||
<p>for ui links, display show; ratings, country flag, year, runtime, and genre tags</p>
|
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
@ -285,6 +280,16 @@
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="field-pair">
|
||||||
|
<label for="use_imdb_info">
|
||||||
|
<span class="component-title">Enable IMDb info</span>
|
||||||
|
<span class="component-desc">
|
||||||
|
<input type="checkbox" name="use_imdb_info" id="use_imdb_info"#echo ('', $checked)[$sickbeard.USE_IMDB_INFO]#>
|
||||||
|
<p>for ui links, display show; ratings, country flag, year, runtime, and genre tags</p>
|
||||||
|
</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="field-pair">
|
<div class="field-pair">
|
||||||
<label for="sort_article">
|
<label for="sort_article">
|
||||||
<span class="component-title">Sort with "The", "A", "An"</span>
|
<span class="component-title">Sort with "The", "A", "An"</span>
|
||||||
|
|
|
@ -50,7 +50,6 @@
|
||||||
}
|
}
|
||||||
\$('#indexerLangSelectEdit').html(resultStr)
|
\$('#indexerLangSelectEdit').html(resultStr)
|
||||||
|
|
||||||
$('tag')
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
//-->
|
//-->
|
||||||
|
@ -67,20 +66,6 @@
|
||||||
|
|
||||||
<div id="editShow" class="stepDiv linefix">
|
<div id="editShow" class="stepDiv linefix">
|
||||||
|
|
||||||
<div class="field-pair #if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then 'hidden' else ''#" style="margin-bottom:10px">
|
|
||||||
<label for="tag">
|
|
||||||
<span class="component-title">Tag</span>
|
|
||||||
<span class="component-desc">
|
|
||||||
<select name="tag" id="tag" class="form-control form-control-inline input-sm">
|
|
||||||
#for $tag in $sickbeard.SHOW_TAGS:
|
|
||||||
<option value="$tag" #if $tag == $show.tag then "selected=\"selected\"" else ""#>$tag</option>
|
|
||||||
#end for
|
|
||||||
</select>
|
|
||||||
<span>used for show list page split view</span>
|
|
||||||
</span>
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="field-pair">
|
<div class="field-pair">
|
||||||
<label for="paused">
|
<label for="paused">
|
||||||
<span class="component-title">Paused</span>
|
<span class="component-title">Paused</span>
|
||||||
|
@ -247,6 +232,20 @@
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="field-pair#if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then ' hidden' else ''#" style="margin-bottom:10px">
|
||||||
|
<label for="tag">
|
||||||
|
<span class="component-title">Show is grouped in</span>
|
||||||
|
<span class="component-desc">
|
||||||
|
<select name="tag" id="tag" class="form-control form-control-inline input-sm">
|
||||||
|
#for $tag in $sickbeard.SHOW_TAGS:
|
||||||
|
<option value="$tag" #if $tag == $show.tag then 'selected="selected"' else ''#>$tag#echo ('', ' (default)')['Show List' == $tag]#</option>
|
||||||
|
#end for
|
||||||
|
</select>
|
||||||
|
<span>and displays on the show list page under this section</span>
|
||||||
|
</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
#if $show.is_anime:
|
#if $show.is_anime:
|
||||||
#import sickbeard.blackandwhitelist
|
#import sickbeard.blackandwhitelist
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_blackwhitelist.tmpl')
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_blackwhitelist.tmpl')
|
||||||
|
|
|
@ -2,16 +2,14 @@
|
||||||
#import datetime
|
#import datetime
|
||||||
#from sickbeard.common import *
|
#from sickbeard.common import *
|
||||||
#from sickbeard import sbdatetime, network_timezones
|
#from sickbeard import sbdatetime, network_timezones
|
||||||
|
##
|
||||||
#set global $title="Home"
|
#set global $title = 'Home'
|
||||||
#set global $header="Show List"
|
#set global $header = 'Show List'
|
||||||
|
#set global $sbPath = '..'
|
||||||
#set global $sbPath = ".."
|
#set global $topmenu = 'home'
|
||||||
|
##
|
||||||
#set global $topmenu="home"#
|
|
||||||
#import os.path
|
#import os.path
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, "gui/slick/interfaces/default/inc_top.tmpl")
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_top.tmpl')
|
||||||
|
|
||||||
|
|
||||||
<script type="text/javascript" charset="utf-8">
|
<script type="text/javascript" charset="utf-8">
|
||||||
<!--
|
<!--
|
||||||
|
@ -23,11 +21,11 @@
|
||||||
},
|
},
|
||||||
format: function(s) {
|
format: function(s) {
|
||||||
if (s.indexOf('Loading...') == 0)
|
if (s.indexOf('Loading...') == 0)
|
||||||
return s.replace('Loading...','000');
|
return s.replace('Loading...', '000');
|
||||||
else
|
else
|
||||||
#if not $sickbeard.SORT_ARTICLE:
|
#if not $sickbeard.SORT_ARTICLE
|
||||||
return (s || '').replace(/^(?:(?:A(?!\s+to)n?)|The)\s(\w)/i, '$1');
|
return (s || '').replace(/^(?:(?:A(?!\s+to)n?)|The)\s(\w)/i, '$1');
|
||||||
#else:
|
#else
|
||||||
return (s || '');
|
return (s || '');
|
||||||
#end if
|
#end if
|
||||||
},
|
},
|
||||||
|
@ -46,18 +44,19 @@
|
||||||
});
|
});
|
||||||
|
|
||||||
\$(document).ready(function(){
|
\$(document).ready(function(){
|
||||||
|
#slurp
|
||||||
#for $curShowlist in $showlists
|
#for $curShowlist in $showlists
|
||||||
#set $curListID = $curShowlist[0]
|
#set $curListID = $curShowlist[0]
|
||||||
#if $layout != 'poster'
|
#if 'poster' != $layout
|
||||||
\$("#$curListID:has(tbody tr)").tablesorter({
|
|
||||||
|
\$('#$curListID:has(tbody tr)').tablesorter({
|
||||||
sortList: [[5,1],[1,0]],
|
sortList: [[5,1],[1,0]],
|
||||||
textExtraction: {
|
textExtraction: {
|
||||||
0: function(node) { return \$(node).find("span").text().toLowerCase(); },
|
0: function(node) { return \$(node).find('span').text().toLowerCase(); },
|
||||||
2: function(node) { return \$(node).find("span").text().toLowerCase(); },
|
2: function(node) { return \$(node).find('span').text().toLowerCase(); },
|
||||||
3: function(node) { return \$(node).find("span").text().toLowerCase(); },
|
3: function(node) { return \$(node).find('span').text().toLowerCase(); },
|
||||||
4: function(node) { return \$(node).find("span").text(); },
|
4: function(node) { return \$(node).find('span').attr('data-progress'); },
|
||||||
5: function(node) { return \$(node).find("img").attr("alt"); }
|
5: function(node) { return \$(node).find('img').attr('alt'); }
|
||||||
},
|
},
|
||||||
widgets: ['saveSort', 'zebra', 'stickyHeaders', 'filter'],
|
widgets: ['saveSort', 'zebra', 'stickyHeaders', 'filter'],
|
||||||
headers: {
|
headers: {
|
||||||
|
@ -73,7 +72,7 @@
|
||||||
sortStable: true
|
sortStable: true
|
||||||
});
|
});
|
||||||
|
|
||||||
\$.tablesorter.filter.bindSearch( "#$curListID", \$('.search') );
|
\$.tablesorter.filter.bindSearch( '#$curListID', \$('.search') );
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
|
@ -92,31 +91,33 @@
|
||||||
getSortData: {
|
getSortData: {
|
||||||
name: function( itemElem ) {
|
name: function( itemElem ) {
|
||||||
var name = \$( itemElem ).attr('data-name');
|
var name = \$( itemElem ).attr('data-name');
|
||||||
#if not $sickbeard.SORT_ARTICLE:
|
#if not $sickbeard.SORT_ARTICLE
|
||||||
return (name || '').replace(/^(?:(?:A(?!\s+to)n?)|The)\s(\w)/i, '$1');
|
return (name || '').replace(/^(?:(?:A(?!\s+to)n?)|The)\s(\w)/i, '$1');
|
||||||
#else:
|
#else
|
||||||
return (name || '');
|
return (name || '');
|
||||||
#end if
|
#end if
|
||||||
},
|
},
|
||||||
network: '[data-network]',
|
|
||||||
date: function( itemElem ) {
|
date: function( itemElem ) {
|
||||||
var date = \$( itemElem ).attr('data-date');
|
var date = \$( itemElem ).attr('data-date');
|
||||||
return date.length && parseInt( date, 10 ) || Number.POSITIVE_INFINITY;
|
return date.length && parseInt( date, 10 ) || Number.POSITIVE_INFINITY;
|
||||||
},
|
},
|
||||||
|
network: '[data-network]',
|
||||||
progress: function( itemElem ) {
|
progress: function( itemElem ) {
|
||||||
var progress = \$( itemElem ).attr('data-progress');
|
var progress = \$( itemElem ).children('.item-data').attr('data-progress');
|
||||||
return progress.length && parseInt( progress, 10 ) || Number.NEGATIVE_INFINITY;
|
return progress.length && parseInt( progress, 10 ) || Number.NEGATIVE_INFINITY;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
\$('#postersort').on( 'change', function() {
|
\$('#postersort').on( 'change', function() {
|
||||||
var sortValue = this.value;
|
var sortValue = this.value;
|
||||||
\$('#$curListID').isotope({ sortBy: sortValue });
|
\$('#$curListID').isotope({ sortBy: sortValue });
|
||||||
\$.get(this.options[this.selectedIndex].getAttribute('data-sort'));
|
\$.get(this.options[this.selectedIndex].getAttribute('data-sort'));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
\$('#postersortdirection').on( 'change', function() {
|
\$('#postersortdirection').on( 'change', function() {
|
||||||
var sortDirection = this.value;
|
var sortDirection = this.value;
|
||||||
sortDirection = sortDirection == 'true';
|
sortDirection = sortDirection == 'true';
|
||||||
|
@ -126,26 +127,29 @@
|
||||||
#end if
|
#end if
|
||||||
#end for
|
#end for
|
||||||
|
|
||||||
\$("img#network").on('error', function(){
|
#raw
|
||||||
\$(this).parent().text(\$(this).attr('alt'));
|
$('img#network').on('error', function(){
|
||||||
\$(this).remove();
|
$(this).parent().text($(this).attr('alt'));
|
||||||
|
$(this).remove();
|
||||||
});
|
});
|
||||||
|
#end raw
|
||||||
|
|
||||||
|
#set $fuzzydate = 'airdate'
|
||||||
|
#if $sickbeard.FUZZY_DATING
|
||||||
|
|
||||||
#set $fuzzydate = 'airdate'
|
|
||||||
#if $sickbeard.FUZZY_DATING:
|
|
||||||
fuzzyMoment({
|
fuzzyMoment({
|
||||||
dtInline : #if $layout == 'poster' then "true" else "false"#,
|
dtInline : #if $layout == 'poster' then 'true' else 'false'#,
|
||||||
containerClass : '.${fuzzydate}',
|
containerClass : '.${fuzzydate}',
|
||||||
dateHasTime : false,
|
dateHasTime : false,
|
||||||
dateFormat : '${sickbeard.DATE_PRESET}',
|
dateFormat : '${sickbeard.DATE_PRESET}',
|
||||||
timeFormat : '${sickbeard.TIME_PRESET}',
|
timeFormat : '${sickbeard.TIME_PRESET}',
|
||||||
trimZero : #if $sickbeard.TRIM_ZERO then "true" else "false"#
|
trimZero : #if $sickbeard.TRIM_ZERO then 'true' else 'false'#
|
||||||
});
|
});
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
|
|
||||||
#if $sickbeard.HOME_SEARCH_FOCUS
|
#if $sickbeard.HOME_SEARCH_FOCUS
|
||||||
|
|
||||||
\$('#search_show_name').focus();
|
\$('#search_show_name').focus();
|
||||||
|
|
||||||
#end if
|
#end if
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -153,74 +157,81 @@
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
#if $varExists('header')
|
#if $varExists('header')
|
||||||
|
|
||||||
<h1 class="header" style="margin-bottom:0">$showlists[0][1]</h1>
|
<h1 class="header" style="margin-bottom:0">$showlists[0][1]</h1>
|
||||||
#else
|
#else
|
||||||
|
|
||||||
<h1 class="title" style="margin-bottom:0">$title</h1>
|
<h1 class="title" style="margin-bottom:0">$title</h1>
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#set $tab = 1
|
#set $tab = 1
|
||||||
|
#if 'poster' != $layout
|
||||||
|
|
||||||
#if $layout != 'poster':
|
<div id="HomeLayout" class="pull-right not-poster">
|
||||||
<div id="HomeLayout" class="pull-right not-poster">
|
|
||||||
<div class="not-poster">
|
<div class="not-poster">
|
||||||
<input id="search_show_name" class="search form-control form-control-inline input-sm input200" type="search" data-column="1" placeholder="Search Show Name" tabindex="$tab#set $tab += 1#">
|
<input id="search_show_name" class="search form-control form-control-inline input-sm input200" type="search" data-column="1" placeholder="Search Show Name" tabindex="$tab#set $tab += 1#">
|
||||||
<button type="button" class="resetshows resetanime btn btn-inline" tabindex="$tab#set $tab += 1#">Reset Search</button>
|
<button type="button" class="resetshows resetanime btn btn-inline" tabindex="$tab#set $tab += 1#">Reset Search</button>
|
||||||
</div>
|
</div>
|
||||||
<span class="pull-right not-poster"> Layout:
|
<span class="pull-right not-poster">Layout:
|
||||||
#else
|
#else
|
||||||
<div id="HomeLayout" class="pull-right poster">
|
|
||||||
|
<div id="HomeLayout" class="pull-right poster">
|
||||||
<span class="pull-right poster">Layout:
|
<span class="pull-right poster">Layout:
|
||||||
#end if
|
#end if
|
||||||
|
#set $selected = ' selected="selected"'
|
||||||
<select name="layout" class="form-control form-control-inline input-sm" onchange="location = this.options[this.selectedIndex].value;" tabindex="$tab#set $tab += 1#">
|
<select name="layout" class="form-control form-control-inline input-sm" onchange="location = this.options[this.selectedIndex].value;" tabindex="$tab#set $tab += 1#">
|
||||||
<option value="$sbRoot/setHomeLayout/?layout=poster" #if $sickbeard.HOME_LAYOUT == "poster" then "selected=\"selected\"" else ""#>Poster</option>
|
<option value="$sbRoot/setHomeLayout/?layout=poster"#echo $selected if 'poster' == sickbeard.HOME_LAYOUT else ''#>Poster</option>
|
||||||
<option value="$sbRoot/setHomeLayout/?layout=small" #if $sickbeard.HOME_LAYOUT == "small" then "selected=\"selected\"" else ""#>Small Poster</option>
|
<option value="$sbRoot/setHomeLayout/?layout=small"#echo $selected if 'small' == sickbeard.HOME_LAYOUT else ''#>Small Poster</option>
|
||||||
<option value="$sbRoot/setHomeLayout/?layout=banner" #if $sickbeard.HOME_LAYOUT == "banner" then "selected=\"selected\"" else ""#>Banner</option>
|
<option value="$sbRoot/setHomeLayout/?layout=banner"#echo $selected if 'banner' == sickbeard.HOME_LAYOUT else ''#>Banner</option>
|
||||||
<option value="$sbRoot/setHomeLayout/?layout=simple" #if $sickbeard.HOME_LAYOUT == "simple" then "selected=\"selected\"" else ""#>Simple</option>
|
<option value="$sbRoot/setHomeLayout/?layout=simple"#echo $selected if 'simple' == sickbeard.HOME_LAYOUT else ''#>Simple</option>
|
||||||
</select>
|
</select>
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
#if $layout == 'poster':
|
#if 'poster' == $layout
|
||||||
|
|
||||||
<span>Sort By:
|
<span>Sort By:
|
||||||
<select id="postersort" class="form-control form-control-inline input-sm" tabindex="$tab#set $tab += 1#">
|
<select id="postersort" class="form-control form-control-inline input-sm" tabindex="$tab#set $tab += 1#">
|
||||||
<option value="name" data-sort="$sbRoot/setPosterSortBy/?sort=name" #if $sickbeard.POSTER_SORTBY == "name" then "selected=\"selected\"" else ""#>Name</option>
|
<option value="name" data-sort="$sbRoot/setPosterSortBy/?sort=name"#echo $selected if 'name' == sickbeard.POSTER_SORTBY else ''#>Name</option>
|
||||||
<option value="date" data-sort="$sbRoot/setPosterSortBy/?sort=date" #if $sickbeard.POSTER_SORTBY == "date" then "selected=\"selected\"" else ""#>Next Episode</option>
|
<option value="date" data-sort="$sbRoot/setPosterSortBy/?sort=date"#echo $selected if 'date' == sickbeard.POSTER_SORTBY else ''#>Next Episode</option>
|
||||||
<option value="network" data-sort="$sbRoot/setPosterSortBy/?sort=network" #if $sickbeard.POSTER_SORTBY == "network" then "selected=\"selected\"" else ""#>Network</option>
|
<option value="network" data-sort="$sbRoot/setPosterSortBy/?sort=network"#echo $selected if 'network' == sickbeard.POSTER_SORTBY else ''#>Network</option>
|
||||||
<option value="progress" data-sort="$sbRoot/setPosterSortBy/?sort=progress" #if $sickbeard.POSTER_SORTBY == "progress" then "selected=\"selected\"" else ""#>Progress</option>
|
<option value="progress" data-sort="$sbRoot/setPosterSortBy/?sort=progress"#echo $selected if 'progress' == sickbeard.POSTER_SORTBY else ''#>Progress</option>
|
||||||
</select>
|
</select>
|
||||||
</span>
|
</span>
|
||||||
<span style="margin:0 0 0 5px">Sort Order:
|
<span style="margin:0 0 0 5px">Sort Order:
|
||||||
<select id="postersortdirection" class="form-control form-control-inline input-sm" tabindex="$tab#set $tab += 1#">
|
<select id="postersortdirection" class="form-control form-control-inline input-sm" tabindex="$tab#set $tab += 1#">
|
||||||
<option value="true" data-sort="$sbRoot/setPosterSortDir/?direction=1" #if $sickbeard.POSTER_SORTDIR == 1 then "selected=\"selected\"" else ""#>Asc</option>
|
<option value="true" data-sort="$sbRoot/setPosterSortDir/?direction=1"#echo $selected if 1 == sickbeard.POSTER_SORTDIR else ''#>Asc</option>
|
||||||
<option value="false" data-sort="$sbRoot/setPosterSortDir/?direction=0" #if $sickbeard.POSTER_SORTDIR == 0 then "selected=\"selected\"" else ""#>Desc</option>
|
<option value="false" data-sort="$sbRoot/setPosterSortDir/?direction=0"#echo $selected if 0 == sickbeard.POSTER_SORTDIR else ''#>Desc</option>
|
||||||
</select>
|
</select>
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
#end if
|
||||||
|
</div><!-- /HomeLayout -->
|
||||||
|
|
||||||
|
#for $curShowlist in $showlists
|
||||||
|
#set $curListID = $curShowlist[0]
|
||||||
|
#set $curListName = $curShowlist[1]
|
||||||
|
#set $myShowList = $list($curShowlist[2])
|
||||||
|
#if $curShowlist != $showlists[0]
|
||||||
|
|
||||||
|
<h1 class="header">$curListName</h1>
|
||||||
|
|
||||||
#end if
|
#end if
|
||||||
</div>
|
|
||||||
|
|
||||||
|
#if 'poster' == $layout
|
||||||
|
|
||||||
#for $curShowlist in $showlists:
|
<div id="$curListID" class="clearfix container">
|
||||||
#set $curListID = $curShowlist[0]
|
<div class="posterview">
|
||||||
#set $curListName = $curShowlist[1]
|
|
||||||
#set $myShowList = $list($curShowlist[2])
|
|
||||||
#if $curShowlist != $showlists[0]:
|
|
||||||
<h1 class="header">$curListName</h1>
|
|
||||||
#end if
|
|
||||||
|
|
||||||
#if $layout == 'poster':
|
#for $curLoadingShow in $sickbeard.showQueueScheduler.action.loadingShowList
|
||||||
<div id="$curListID" class="clearfix container">
|
|
||||||
<div class="posterview">
|
|
||||||
#for $curLoadingShow in $sickbeard.showQueueScheduler.action.loadingShowList:
|
|
||||||
|
|
||||||
#if $curLoadingShow.show != None and $curLoadingShow.show in $sickbeard.showList:
|
#if $curLoadingShow.show != None and $curLoadingShow.show in $sickbeard.showList
|
||||||
#continue
|
#continue
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#if $curLoadingShow.show == None:
|
#if None is $curLoadingShow.show
|
||||||
<div class="show" data-name="0" data-date="010101" data-network="0" data-progress="101">
|
|
||||||
<img alt="" title="$curLoadingShow.show_name" class="show-image" style="border-bottom: 1px solid #111;" src="$sbRoot/images/poster.png" />
|
<div class="show" data-name="0" data-date="010101" data-network="0">
|
||||||
|
<span class="item-data" data-progress="101" style="display:none"></span>
|
||||||
|
<img alt="" title="$curLoadingShow.show_name" class="show-image" style="border-bottom:1px solid #111" src="$sbRoot/images/poster.png" />
|
||||||
<div class="show-details">
|
<div class="show-details">
|
||||||
<div class="show-add">Loading... ($curLoadingShow.show_name)</div>
|
<div class="show-add">Loading... ($curLoadingShow.show_name)</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -228,10 +239,10 @@
|
||||||
|
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#end for
|
#end for
|
||||||
|
|
||||||
$myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
$myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
#for $curShow in $myShowList:
|
#for $curShow in $myShowList
|
||||||
|
|
||||||
#set $cur_airs_next = ''
|
#set $cur_airs_next = ''
|
||||||
#set $cur_snatched = 0
|
#set $cur_snatched = 0
|
||||||
|
@ -247,51 +258,51 @@ $myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#if $curShow.indexerid in $show_stat:
|
#if $curShow.indexerid in $show_stat
|
||||||
#set $cur_airs_next = $show_stat[$curShow.indexerid]['ep_airs_next']
|
#set $cur_airs_next = $show_stat[$curShow.indexerid]['ep_airs_next']
|
||||||
|
|
||||||
#set $cur_snatched = $show_stat[$curShow.indexerid]['ep_snatched']
|
#set $cur_snatched = $show_stat[$curShow.indexerid]['ep_snatched']
|
||||||
#if not $cur_snatched:
|
#if not $cur_snatched
|
||||||
#set $cur_snatched = 0
|
#set $cur_snatched = 0
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#set $cur_downloaded = $show_stat[$curShow.indexerid]['ep_downloaded']
|
#set $cur_downloaded = $show_stat[$curShow.indexerid]['ep_downloaded']
|
||||||
#if not $cur_downloaded:
|
#if not $cur_downloaded
|
||||||
#set $cur_downloaded = 0
|
#set $cur_downloaded = 0
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#set $cur_total = $show_stat[$curShow.indexerid]['ep_total']
|
#set $cur_total = $show_stat[$curShow.indexerid]['ep_total']
|
||||||
#if not $cur_total:
|
#if not $cur_total
|
||||||
#set $cur_total = 0
|
#set $cur_total = 0
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#if $cur_total != 0:
|
#if $cur_total != 0
|
||||||
#set $download_stat = str($cur_downloaded)
|
#set $download_stat = str($cur_downloaded)
|
||||||
#set $download_stat_tip = "Downloaded: " + str($cur_downloaded)
|
#set $download_stat_tip = 'Downloaded: ' + str($cur_downloaded)
|
||||||
#if $cur_snatched > 0:
|
#if $cur_snatched > 0
|
||||||
#set $download_stat = download_stat
|
#set $download_stat = download_stat
|
||||||
#set $download_stat_tip = download_stat_tip + "
" + "Snatched: " + str($cur_snatched)
|
#set $download_stat_tip = download_stat_tip + '
' + 'Snatched: ' + str($cur_snatched)
|
||||||
#end if
|
#end if
|
||||||
#set $download_stat = download_stat + " / " + str($cur_total)
|
#set $download_stat = download_stat + ' / ' + str($cur_total)
|
||||||
#set $download_stat_tip = download_stat_tip + "
" + "Total: " + str($cur_total)
|
#set $download_stat_tip = download_stat_tip + '
' + 'Total: ' + str($cur_total)
|
||||||
#else
|
#else
|
||||||
#set $download_stat = '?'
|
#set $download_stat = '?'
|
||||||
#set $download_stat_tip = "no data"
|
#set $download_stat_tip = 'no data'
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#set $nom = $cur_downloaded
|
#set $nom = $cur_downloaded
|
||||||
#set $den = $cur_total
|
#set $den = $cur_total
|
||||||
#if $den == 0:
|
#if $den == 0
|
||||||
#set $den = 1
|
#set $den = 1
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#set $progressbar_percent = $nom * 100 / $den
|
#set $progressbar_percent = $nom * 100 / $den
|
||||||
|
|
||||||
#set $data_date = '600000000000'
|
#set $data_date = '600000000000'
|
||||||
#if $cur_airs_next:
|
#if $cur_airs_next
|
||||||
#set $data_date = $sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($cur_airs_next, $curShow.airs, $curShow.network)).strftime('%Y%m%d%H%M')
|
#set $data_date = $sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($cur_airs_next, $curShow.airs, $curShow.network)).strftime('%Y%m%d%H%M')
|
||||||
#else if None is not $display_status
|
#else if None is not $display_status
|
||||||
#if 'nded' not in $display_status and 1 == int($curShow.paused)
|
#if 'nded' not in $display_status and 1 == int($curShow.paused)
|
||||||
#set $data_date = '500000000500'
|
#set $data_date = '500000000500'
|
||||||
#else if 'ontinu' in $display_status
|
#else if 'ontinu' in $display_status
|
||||||
|
@ -299,45 +310,25 @@ $myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
#else if 'nded' in $display_status
|
#else if 'nded' in $display_status
|
||||||
#set $data_date = '500000000100'
|
#set $data_date = '500000000100'
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
<div class="show" id="show$curShow.indexerid" data-name="$curShow.name" data-date="$data_date" data-network="$curShow.network" data-progress="$progressbar_percent">
|
|
||||||
|
<div id="show$curShow.indexerid" class="show" data-name="$curShow.name" data-date="$data_date" data-network="$curShow.network">
|
||||||
|
<span class="item-data" data-progress="$progressbar_percent" style="display:none"></span>
|
||||||
<div class="show-image">
|
<div class="show-image">
|
||||||
<a href="$sbRoot/home/displayShow?show=$curShow.indexerid"><img alt="" class="show-image" src="$sbRoot/showPoster/?show=$curShow.indexerid&which=poster_thumb" /></a>
|
<a href="$sbRoot/home/displayShow?show=$curShow.indexerid"><img alt="" class="show-image" src="$sbRoot/showPoster/?show=$curShow.indexerid&which=poster_thumb" /></a>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="progressbar$curShow.indexerid"></div>
|
<div id="progressbar$curShow.indexerid"></div>
|
||||||
<script type="text/javascript">
|
|
||||||
<!--
|
|
||||||
\$(function() {
|
|
||||||
\$("\#progressbar$curShow.indexerid").progressbar({
|
|
||||||
value: $progressbar_percent });
|
|
||||||
classvalue = $progressbar_percent
|
|
||||||
if (classvalue<20) {
|
|
||||||
classtoadd = "progress-20"
|
|
||||||
}
|
|
||||||
if (classvalue>=20 && classvalue<60) {
|
|
||||||
classtoadd = "progress-40"
|
|
||||||
}
|
|
||||||
if (classvalue>=40 && classvalue<80) {
|
|
||||||
classtoadd = "progress-60"
|
|
||||||
}
|
|
||||||
if (classvalue>=80) {
|
|
||||||
classtoadd = "progress-80"
|
|
||||||
}
|
|
||||||
\$("\#progressbar$curShow.indexerid > .ui-progressbar-value").addClass(classtoadd);
|
|
||||||
});
|
|
||||||
//-->
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<div class="show-title">
|
<div class="show-title">
|
||||||
$curShow.name
|
$curShow.name
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="show-date">
|
<div class="show-date">
|
||||||
#if $cur_airs_next
|
#if $cur_airs_next
|
||||||
#set $ldatetime = $sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($cur_airs_next,$curShow.airs,$curShow.network))
|
#set $ldatetime = $sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($cur_airs_next,$curShow.airs,$curShow.network))
|
||||||
<span class="${fuzzydate}">$sbdatetime.sbdatetime.sbfdate($ldatetime)</span>
|
<span class="${fuzzydate}">$sbdatetime.sbdatetime.sbfdate($ldatetime)</span>
|
||||||
#else
|
#else
|
||||||
#set $output_html = '?'
|
#set $output_html = '?'
|
||||||
#if None is not $display_status
|
#if None is not $display_status
|
||||||
#if 'nded' not in $display_status and 1 == int($curShow.paused)
|
#if 'nded' not in $display_status and 1 == int($curShow.paused)
|
||||||
|
@ -347,8 +338,8 @@ $myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
$output_html
|
$output_html
|
||||||
#end if
|
#end if
|
||||||
</div>
|
</div><!-- /show-date -->
|
||||||
|
|
||||||
<table width="100%" cellspacing="1" border="0" cellpadding="0">
|
<table width="100%" cellspacing="1" border="0" cellpadding="0">
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -357,44 +348,46 @@ $myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td class="show-table">
|
<td class="show-table">
|
||||||
#if 'simple' != $layout:
|
#if 'simple' != $layout
|
||||||
#set $img_text = ($curShow.network, 'No Network')[None is $curShow.network]
|
#set $img_text = ($curShow.network, 'No Network')[None is $curShow.network]
|
||||||
<img class="show-network-image" src="$sbRoot/images/network/$network_images[$curShow.indexerid]" alt="#echo '%s" title="%s' % ($img_text, $img_text)#" />
|
<img class="show-network-image" src="$sbRoot/images/network/$network_images[$curShow.indexerid]" alt="#echo '%s" title="%s' % ($img_text, $img_text)#" />
|
||||||
#else:
|
#else
|
||||||
$curShow.network
|
$curShow.network
|
||||||
#end if
|
#end if
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td class="show-table">
|
<td class="show-table">
|
||||||
#if $curShow.quality in $qualityPresets:
|
#if $curShow.quality in $qualityPresets
|
||||||
<span class="show-quality">$qualityPresetStrings[$curShow.quality]</span>
|
<span class="show-quality">$qualityPresetStrings[$curShow.quality]</span>
|
||||||
#else:
|
#else
|
||||||
<span class="show-quality">Custom</span>
|
<span class="show-quality">Custom</span>
|
||||||
#end if
|
#end if
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
</div><!-- /show$curShow.indexerid -->
|
||||||
|
|
||||||
|
#end for
|
||||||
</div>
|
</div>
|
||||||
|
</div><!-- /$curListID -->
|
||||||
|
|
||||||
|
########################
|
||||||
|
## end of poster layout
|
||||||
|
########################
|
||||||
|
#else
|
||||||
|
|
||||||
#end for
|
<table id="$curListID" class="tablesorter" cellspacing="1" border="0" cellpadding="0">
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
<table id="$curListID" class="tablesorter" cellspacing="1" border="0" cellpadding="0">
|
|
||||||
|
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="col-airdate">Next Ep</th>
|
<th>Next Ep</th>
|
||||||
<th class="col-name">Show</th>
|
<th>Show</th>
|
||||||
<th class="col-simple">Network</th>
|
<th>Network</th>
|
||||||
<th class="col-simple">Quality</th>
|
<th>Quality</th>
|
||||||
<th class="col-simple">Downloads</th>
|
<th>Downloads</th>
|
||||||
<th class="col-simple">Active</th>
|
<th>Active</th>
|
||||||
<th class="col-simple">Status</th>
|
<th>Status</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
|
|
||||||
|
@ -406,19 +399,17 @@ $myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
</tfoot>
|
</tfoot>
|
||||||
|
|
||||||
<tbody>
|
<tbody>
|
||||||
|
#for $curLoadingShow in $sickbeard.showQueueScheduler.action.loadingShowList
|
||||||
#for $curLoadingShow in $sickbeard.showQueueScheduler.action.loadingShowList:
|
#if $curLoadingShow.show != None and $curLoadingShow.show in $sickbeard.showList
|
||||||
|
|
||||||
#if $curLoadingShow.show != None and $curLoadingShow.show in $sickbeard.showList:
|
|
||||||
#continue
|
#continue
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center">(loading)</td>
|
<td align="center">(loading)</td>
|
||||||
<td>
|
<td>
|
||||||
#if $curLoadingShow.show == None:
|
#if None is $curLoadingShow.show
|
||||||
Loading... ($curLoadingShow.show_name)
|
Loading... ($curLoadingShow.show_name)
|
||||||
#else:
|
#else
|
||||||
<a href="displayShow?show=$curLoadingShow.show.indexerid">$curLoadingShow.show.name</a>
|
<a href="displayShow?show=$curLoadingShow.show.indexerid">$curLoadingShow.show.name</a>
|
||||||
#end if
|
#end if
|
||||||
</td>
|
</td>
|
||||||
|
@ -428,156 +419,158 @@ $myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
<td></td>
|
<td></td>
|
||||||
<td></td>
|
<td></td>
|
||||||
</tr>
|
</tr>
|
||||||
#end for
|
#end for
|
||||||
|
|
||||||
$myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
|
||||||
#for $curShow in $myShowList:
|
|
||||||
|
|
||||||
|
$myShowList.sort(lambda x, y: cmp(x.name, y.name))
|
||||||
|
#for $curShow in $myShowList
|
||||||
|
#slurp
|
||||||
#set $cur_airs_next = ''
|
#set $cur_airs_next = ''
|
||||||
#set $cur_snatched = 0
|
#set $cur_snatched = 0
|
||||||
#set $cur_downloaded = 0
|
#set $cur_downloaded = 0
|
||||||
#set $cur_total = 0
|
#set $cur_total = 0
|
||||||
#set $download_stat_tip = ''
|
#set $download_stat_tip = ''
|
||||||
|
#slurp
|
||||||
#if $curShow.indexerid in $show_stat:
|
#if $curShow.indexerid in $show_stat
|
||||||
#set $cur_airs_next = $show_stat[$curShow.indexerid]['ep_airs_next']
|
#set $cur_airs_next = $show_stat[$curShow.indexerid]['ep_airs_next']
|
||||||
|
#slurp
|
||||||
#set $cur_snatched = $show_stat[$curShow.indexerid]['ep_snatched']
|
#set $cur_snatched = $show_stat[$curShow.indexerid]['ep_snatched']
|
||||||
#if not $cur_snatched:
|
#if not $cur_snatched
|
||||||
#set $cur_snatched = 0
|
#set $cur_snatched = 0
|
||||||
#end if
|
#end if
|
||||||
|
#slurp
|
||||||
#set $cur_downloaded = $show_stat[$curShow.indexerid]['ep_downloaded']
|
#set $cur_downloaded = $show_stat[$curShow.indexerid]['ep_downloaded']
|
||||||
#if not $cur_downloaded:
|
#if not $cur_downloaded
|
||||||
#set $cur_downloaded = 0
|
#set $cur_downloaded = 0
|
||||||
#end if
|
#end if
|
||||||
|
#slurp
|
||||||
#set $cur_total = $show_stat[$curShow.indexerid]['ep_total']
|
#set $cur_total = $show_stat[$curShow.indexerid]['ep_total']
|
||||||
#if not $cur_total:
|
#if not $cur_total
|
||||||
#set $cur_total = 0
|
#set $cur_total = 0
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
|
#slurp
|
||||||
#if $cur_total != 0:
|
#if $cur_total != 0
|
||||||
#set $download_stat = str($cur_downloaded)
|
#set $download_stat = str($cur_downloaded)
|
||||||
#set $download_stat_tip = "Downloaded: " + str($cur_downloaded)
|
#set $download_stat_tip = 'Downloaded: ' + str($cur_downloaded)
|
||||||
#if $cur_snatched > 0:
|
#if $cur_snatched > 0
|
||||||
#set $download_stat = download_stat + "+" + str($cur_snatched)
|
#set $download_stat = download_stat + '+' + str($cur_snatched)
|
||||||
#set $download_stat_tip = download_stat_tip + "
" + "Snatched: " + str($cur_snatched)
|
#set $download_stat_tip = download_stat_tip + '
' + 'Snatched: ' + str($cur_snatched)
|
||||||
#end if
|
#end if
|
||||||
#set $download_stat = download_stat + " / " + str($cur_total)
|
#set $download_stat = download_stat + ' / ' + str($cur_total)
|
||||||
#set $download_stat_tip = download_stat_tip + "
" + "Total: " + str($cur_total)
|
#set $download_stat_tip = download_stat_tip + '
' + 'Total: ' + str($cur_total)
|
||||||
#else
|
#else
|
||||||
#set $download_stat = '?'
|
#set $download_stat = '?'
|
||||||
#set $download_stat_tip = "no data"
|
#set $download_stat_tip = 'no data'
|
||||||
#end if
|
#end if
|
||||||
|
#slurp
|
||||||
#set $nom = $cur_downloaded
|
#set $nom = $cur_downloaded
|
||||||
#set $den = $cur_total
|
#set $den = $cur_total
|
||||||
#if $den == 0:
|
#if $den == 0
|
||||||
#set $den = 1
|
#set $den = 1
|
||||||
#end if
|
#end if
|
||||||
|
#slurp
|
||||||
#set $progressbar_percent = $nom * 100 / $den
|
#set $progressbar_percent = $nom * 100 / $den
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
|
|
||||||
#if $cur_airs_next
|
#if $cur_airs_next
|
||||||
#set $ldatetime = $sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($cur_airs_next,$curShow.airs,$curShow.network))
|
#set $ldatetime = $sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($cur_airs_next,$curShow.airs,$curShow.network))
|
||||||
|
|
||||||
<td align="center" class="nowrap"><div class="${fuzzydate}">$sbdatetime.sbdatetime.sbfdate($ldatetime)</div><span class="sort_data">$ldatetime.strftime('%Y%m%d%H%M')</span></td>
|
<td align="center" class="nowrap"><div class="${fuzzydate}">$sbdatetime.sbdatetime.sbfdate($ldatetime)</div><span class="sort_data">$ldatetime.strftime('%Y%m%d%H%M')</span></td>
|
||||||
#else:
|
#else
|
||||||
|
|
||||||
<td align="center" class="nowrap"></td>
|
<td align="center" class="nowrap"></td>
|
||||||
#end if
|
#end if
|
||||||
|
#if 'small' == $layout
|
||||||
|
|
||||||
#if $layout == 'small':
|
|
||||||
<td class="tvShow">
|
<td class="tvShow">
|
||||||
<div class="imgsmallposter $layout">
|
<div class="imgsmallposter $layout">
|
||||||
<a href="$sbRoot/showPoster/?show=$curShow.indexerid&which=poster" rel="dialog" title="$curShow.name">
|
<a href="$sbRoot/showPoster/?show=$curShow.indexerid&which=poster" rel="dialog" title="$curShow.name">
|
||||||
<img src="$sbRoot/showPoster/?show=$curShow.indexerid&which=poster_thumb" class="$layout" alt="$curShow.indexerid"/>
|
<img src="$sbRoot/showPoster/?show=$curShow.indexerid&which=poster_thumb" class="$layout" alt="$curShow.indexerid"/>
|
||||||
</a>
|
</a>
|
||||||
<a href="$sbRoot/home/displayShow?show=$curShow.indexerid" style="vertical-align: middle;">$curShow.name</a>
|
<a href="$sbRoot/home/displayShow?show=$curShow.indexerid" style="vertical-align:middle">$curShow.name</a>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
#else if $layout == 'banner':
|
#else if 'banner' == $layout
|
||||||
|
|
||||||
<td>
|
<td>
|
||||||
<span style="display: none;">$curShow.name</span>
|
<span style="display:none">$curShow.name</span>
|
||||||
<div class="imgbanner $layout">
|
<div class="imgbanner $layout">
|
||||||
<a href="$sbRoot/home/displayShow?show=$curShow.indexerid">
|
<a href="$sbRoot/home/displayShow?show=$curShow.indexerid">
|
||||||
<img src="$sbRoot/showPoster/?show=$curShow.indexerid&which=banner" class="$layout" alt="$curShow.indexerid" title="$curShow.name"/>
|
<img src="$sbRoot/showPoster/?show=$curShow.indexerid&which=banner" class="$layout" alt="$curShow.indexerid" title="$curShow.name"/>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
#else if $layout == 'simple':
|
#else if 'simple' == $layout
|
||||||
|
|
||||||
<td class="tvShow"><a href="$sbRoot/home/displayShow?show=$curShow.indexerid">$curShow.name</a></td>
|
<td class="tvShow"><a href="$sbRoot/home/displayShow?show=$curShow.indexerid">$curShow.name</a></td>
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#if 'simple' != $layout:
|
#if 'simple' != $layout
|
||||||
#set $img_text = ($curShow.network, 'No Network')[None is $curShow.network]
|
#set $img_text = ($curShow.network, 'No Network')[None is $curShow.network]
|
||||||
|
|
||||||
<td align="center">
|
<td align="center">
|
||||||
<span style="display: none;">$curShow.network</span>
|
<span style="display:none">$curShow.network</span>
|
||||||
<img width="54" height="27" src="$sbRoot/images/network/$network_images[$curShow.indexerid]" alt="#echo '%s" title="%s' % ($img_text, $img_text)#" />
|
<img width="54" height="27" src="$sbRoot/images/network/$network_images[$curShow.indexerid]" alt="#echo '%s" title="%s' % ($img_text, $img_text)#" />
|
||||||
</td>
|
</td>
|
||||||
#else:
|
#else
|
||||||
|
|
||||||
<td>
|
<td>
|
||||||
<span>$curShow.network</span>
|
<span>$curShow.network</span>
|
||||||
</td>
|
</td>
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
#if $curShow.quality in $qualityPresets:
|
#if $curShow.quality in $qualityPresets
|
||||||
|
|
||||||
<td align="center"><span class="quality $qualityPresetStrings[$curShow.quality]">$qualityPresetStrings[$curShow.quality]</span></td>
|
<td align="center"><span class="quality $qualityPresetStrings[$curShow.quality]">$qualityPresetStrings[$curShow.quality]</span></td>
|
||||||
#else:
|
#else
|
||||||
|
|
||||||
<td align="center"><span class="quality Custom">Custom</span></td>
|
<td align="center"><span class="quality Custom">Custom</span></td>
|
||||||
#end if
|
#end if
|
||||||
|
|
||||||
<td align="center"><span style="display: none;">$progressbar_percent</span><div id="progressbar$curShow.indexerid" style="position:relative;"></div>
|
<td align="center">
|
||||||
<script type="text/javascript">
|
<span class="item-data" data-progress="$progressbar_percent" style="display:none"></span>
|
||||||
<!--
|
<div id="progressbar$curShow.indexerid" style="position:relative">
|
||||||
\$(function() {
|
<div class="progressbarText" title="$download_stat_tip">$download_stat</div>
|
||||||
\$("\#progressbar$curShow.indexerid").progressbar({
|
</div>
|
||||||
value: $progressbar_percent });
|
|
||||||
\$("\#progressbar$curShow.indexerid").append( "<div class='progressbarText' title='$download_stat_tip'>$download_stat</div>" )
|
|
||||||
classvalue = $progressbar_percent
|
|
||||||
if (classvalue<20) {
|
|
||||||
classtoadd = "progress-20"
|
|
||||||
}
|
|
||||||
if (classvalue>=20 && classvalue<60) {
|
|
||||||
classtoadd = "progress-40"
|
|
||||||
}
|
|
||||||
if (classvalue>=40 && classvalue<80) {
|
|
||||||
classtoadd = "progress-60"
|
|
||||||
}
|
|
||||||
if (classvalue>=80) {
|
|
||||||
classtoadd = "progress-80"
|
|
||||||
}
|
|
||||||
\$("\#progressbar$curShow.indexerid > .ui-progressbar-value").addClass(classtoadd);
|
|
||||||
});
|
|
||||||
//-->
|
|
||||||
</script>
|
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td align="center">
|
<td align="center">
|
||||||
<img src="$sbRoot/images/#if int($curShow.paused) == 0 and $curShow.status != "Ended" then "yes16.png\" alt=\"Y\"" else "no16.png\" alt=\"N\""# width="16" height="16" />
|
<img src="$sbRoot/images/#if int($curShow.paused) == 0 and $curShow.status != 'Ended' then 'yes16.png" alt="Y"' else 'no16.png" alt="N"'# width="16" height="16" />
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td align="center">
|
<td align="center">
|
||||||
|
#set $display_status = $curShow.status
|
||||||
#set $display_status = $curShow.status
|
#if None is not $display_status
|
||||||
#if None is not $display_status
|
|
||||||
#if re.search(r'(?i)(?:new|returning)\s*series', $curShow.status)
|
#if re.search(r'(?i)(?:new|returning)\s*series', $curShow.status)
|
||||||
#set $display_status = 'Continuing'
|
#set $display_status = 'Continuing'
|
||||||
#else if re.search(r'(?i)(?:nded)', $curShow.status)
|
#else if re.search(r'(?i)(?:nded)', $curShow.status)
|
||||||
#set $display_status = 'Ended'
|
#set $display_status = 'Ended'
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
$display_status
|
$display_status
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
</tr>
|
</tr>
|
||||||
|
#end for
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
|
||||||
#end for
|
#end if
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
#end if
|
|
||||||
#end for
|
#end for
|
||||||
|
|
||||||
#include $os.path.join($sickbeard.PROG_DIR,"gui/slick/interfaces/default/inc_bottom.tmpl")
|
<script type="text/javascript">
|
||||||
|
<!--
|
||||||
|
#raw
|
||||||
|
$(document).ready(function(){
|
||||||
|
$('div[id^="progressbar"]').each(function(k, v){
|
||||||
|
var progress = parseInt($(this).siblings('span[class="item-data"]').attr('data-progress'), 10) , elId = '#' + $(this).attr('id'), v = 80;
|
||||||
|
$(elId).progressbar({value:progress});
|
||||||
|
if (progress < 80) {
|
||||||
|
v = progress >= 40 ? 60 : (progress >= 20 ? 40 : 20);
|
||||||
|
}
|
||||||
|
$(elId + ' > .ui-progressbar-value').addClass('progress-' + v);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
#end raw
|
||||||
|
//-->
|
||||||
|
</script>
|
||||||
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_bottom.tmpl')
|
|
@ -27,21 +27,6 @@
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_qualityChooser.tmpl')
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_qualityChooser.tmpl')
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="field-pair #if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then 'hidden' else ''#" style="margin-bottom:10px">
|
|
||||||
<label for="tag">
|
|
||||||
<span class="component-title">Tag</span>
|
|
||||||
<span class="component-desc">
|
|
||||||
<select name="tag" id="tag" class="form-control form-control-inline input-sm">
|
|
||||||
#for $tag in $sickbeard.SHOW_TAGS:
|
|
||||||
<option value="$tag" #if $tag == $sickbeard.DEFAULT_SHOW_TAG then "selected=\"selected\"" else ""#>$tag</option>
|
|
||||||
#end for
|
|
||||||
</select>
|
|
||||||
<span>used for show list page split view</span>
|
|
||||||
</span>
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
|
||||||
#try:
|
#try:
|
||||||
#if True == $enable_default_wanted:
|
#if True == $enable_default_wanted:
|
||||||
<div class="field-pair alt">
|
<div class="field-pair alt">
|
||||||
|
@ -65,6 +50,20 @@
|
||||||
#pass
|
#pass
|
||||||
#end try
|
#end try
|
||||||
|
|
||||||
|
<div class="field-pair #if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then 'hidden' else ''#" style="margin-top:10px">
|
||||||
|
<label for="tag">
|
||||||
|
<span class="component-title">Place show in group</span>
|
||||||
|
<span class="component-desc">
|
||||||
|
<select name="tag" id="tag" class="form-control form-control-inline input-sm">
|
||||||
|
#for $tag in $sickbeard.SHOW_TAGS:
|
||||||
|
<option value="$tag" #if $tag == $sickbeard.DEFAULT_SHOW_TAG then 'selected="selected"' else ''#>$tag</option>
|
||||||
|
#end for
|
||||||
|
</select>
|
||||||
|
<span>and display on the show list page under this section</span>
|
||||||
|
</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="field-pair alt">
|
<div class="field-pair alt">
|
||||||
<label for="flatten_folders">
|
<label for="flatten_folders">
|
||||||
<span class="component-title">Flat folder structure</span>
|
<span class="component-title">Flat folder structure</span>
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
#import sickbeard
|
#import sickbeard
|
||||||
#import urllib
|
#import urllib
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8">
|
<meta charset="utf-8">
|
||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
@ -33,7 +32,6 @@
|
||||||
<meta name="msapplication-TileColor" content="#2b5797">
|
<meta name="msapplication-TileColor" content="#2b5797">
|
||||||
<meta name="msapplication-TileImage" content="$sbRoot/images/ico/mstile-144x144.png">
|
<meta name="msapplication-TileImage" content="$sbRoot/images/ico/mstile-144x144.png">
|
||||||
<meta name="msapplication-config" content="$sbRoot/css/browserconfig.xml">
|
<meta name="msapplication-config" content="$sbRoot/css/browserconfig.xml">
|
||||||
|
|
||||||
<link rel="stylesheet" type="text/css" href="$sbRoot/css/lib/bootstrap.css?$sbPID"/>
|
<link rel="stylesheet" type="text/css" href="$sbRoot/css/lib/bootstrap.css?$sbPID"/>
|
||||||
<link rel="stylesheet" type="text/css" href="$sbRoot/css/browser.css?$sbPID" />
|
<link rel="stylesheet" type="text/css" href="$sbRoot/css/browser.css?$sbPID" />
|
||||||
<link rel="stylesheet" type="text/css" href="$sbRoot/css/lib/jquery-ui-1.10.4.custom.css?$sbPID" />
|
<link rel="stylesheet" type="text/css" href="$sbRoot/css/lib/jquery-ui-1.10.4.custom.css?$sbPID" />
|
||||||
|
@ -60,17 +58,14 @@
|
||||||
<script type="text/javascript" src="$sbRoot/js/lib/imagesloaded.pkgd.min.js?$sbPID"></script>
|
<script type="text/javascript" src="$sbRoot/js/lib/imagesloaded.pkgd.min.js?$sbPID"></script>
|
||||||
<script type="text/javascript" src="$sbRoot/js/lib/jquery.confirm.js?$sbPID"></script>
|
<script type="text/javascript" src="$sbRoot/js/lib/jquery.confirm.js?$sbPID"></script>
|
||||||
<script type="text/javascript" src="$sbRoot/js/script.js?$sbPID"></script>
|
<script type="text/javascript" src="$sbRoot/js/script.js?$sbPID"></script>
|
||||||
#if $sickbeard.FUZZY_DATING:
|
#if $sickbeard.FUZZY_DATING
|
||||||
<script type="text/javascript" src="$sbRoot/js/moment/moment.min.js?$sbPID"></script>
|
<script type="text/javascript" src="$sbRoot/js/moment/moment.min.js?$sbPID"></script>
|
||||||
<script type="text/javascript" src="$sbRoot/js/fuzzyMoment.js?$sbPID"></script>
|
<script type="text/javascript" src="$sbRoot/js/fuzzyMoment.js?$sbPID"></script>
|
||||||
#end if
|
#end if
|
||||||
<script type="text/javascript" charset="utf-8">
|
<script type="text/javascript" charset="utf-8">
|
||||||
<!--
|
<!--
|
||||||
sbRoot = '$sbRoot'; // needed for browser.js & ajaxNotifications.js
|
var sbRoot = '$sbRoot', anonURL = '$sickbeard.ANON_REDIRECT', themeSpinner = '#echo ('', '-dark')['dark' == $sickbeard.THEME_NAME]#'
|
||||||
//HTML for scrolltopcontrol, which is auto wrapped in DIV w/ ID="topcontrol"
|
|
||||||
top_image_html = '<img src="$sbRoot/images/top.gif" width="31" height="11" alt="Jump to top" />';
|
top_image_html = '<img src="$sbRoot/images/top.gif" width="31" height="11" alt="Jump to top" />';
|
||||||
themeSpinner = <%= '\'\'' if 'dark' != sickbeard.THEME_NAME else '\'-dark\'' %>;
|
|
||||||
anonURL = '<%= sickbeard.ANON_REDIRECT %>'
|
|
||||||
//-->
|
//-->
|
||||||
</script>
|
</script>
|
||||||
<script type="text/javascript" src="$sbRoot/js/lib/jquery.scrolltopcontrol-1.1.js"></script>
|
<script type="text/javascript" src="$sbRoot/js/lib/jquery.scrolltopcontrol-1.1.js"></script>
|
||||||
|
@ -78,53 +73,52 @@
|
||||||
<script type="text/javascript" src="$sbRoot/js/ajaxNotifications.js"></script>
|
<script type="text/javascript" src="$sbRoot/js/ajaxNotifications.js"></script>
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
<!--
|
<!--
|
||||||
|
#raw
|
||||||
function initActions() {
|
function initActions() {
|
||||||
\$("#SubMenu a[href*='/home/restart/']").addClass('btn restart').html('<i class="sgicon-restart"></i> Restart');
|
$('#SubMenu a[href*="/home/restart/"]').addClass('btn restart').html('<i class="sgicon-restart"></i>Restart');
|
||||||
\$("#SubMenu a[href*='/home/shutdown/']").addClass('btn shutdown').html('<i class="sgicon-shutdown"></i> Shutdown');
|
$('#SubMenu a[href*="/home/shutdown/"]').addClass('btn shutdown').html('<i class="sgicon-shutdown"></i>Shutdown');
|
||||||
\$("#SubMenu a[href*='/home/logout/']").addClass('btn').html('<i class="sgicon-logout"></i> Logout');
|
$('#SubMenu a[href*="/home/logout/"]').addClass('btn').html('<i class="sgicon-logout"></i>Logout');
|
||||||
\$("#SubMenu a:contains('Edit')").addClass('btn').html('<i class="sgicon-edit"></i> Edit');
|
$('#SubMenu a:contains("Edit")').addClass('btn').html('<i class="sgicon-edit"></i>Edit');
|
||||||
\$("#SubMenu a:contains('Remove')").addClass('btn remove').html('<i class="sgicon-delete"></i> Remove');
|
$('#SubMenu a:contains("Remove")').addClass('btn remove').html('<i class="sgicon-delete"></i>Remove');
|
||||||
\$("#SubMenu a:contains('Clear History')").addClass('btn clearhistory').html('<i class="sgicon-delete"></i> Clear History');
|
$('#SubMenu a:contains("Clear History")').addClass('btn clearhistory').html('<i class="sgicon-delete"></i>Clear History');
|
||||||
\$("#SubMenu a:contains('Trim History')").addClass('btn trimhistory').html('<i class="sgicon-trim"></i> Trim History');
|
$('#SubMenu a:contains("Trim History")').addClass('btn trimhistory').html('<i class="sgicon-trim"></i>Trim History');
|
||||||
\$("#SubMenu a[href$='/errorlogs/clearerrors/']").addClass('btn').html('<i class="sgicon-delete"></i> Clear Errors');
|
$('#SubMenu a[href$="/errorlogs/clearerrors/"]').addClass('btn').html('<i class="sgicon-delete"></i>Clear Errors');
|
||||||
\$("#SubMenu a:contains('Re-scan')").addClass('btn').html('<i class="sgicon-refresh"></i> Re-scan');
|
$('#SubMenu a:contains("Re-scan")').addClass('btn').html('<i class="sgicon-refresh"></i>Re-scan');
|
||||||
\$("#SubMenu a:contains('Backlog Overview')").addClass('btn').html('<i class="sgicon-backlog"></i> Backlog Overview');
|
$('#SubMenu a:contains("Backlog Overview")').addClass('btn').html('<i class="sgicon-backlog"></i>Backlog Overview');
|
||||||
\$("#SubMenu a[href$='/home/updatePLEX/']").addClass('btn').html('<i class="sgicon-plex"></i>Update PLEX');
|
$('#SubMenu a[href$="/home/updatePLEX/"]').addClass('btn').html('<i class="sgicon-plex"></i>Update PLEX');
|
||||||
\$("#SubMenu a:contains('Force')").addClass('btn').html('<i class="sgicon-fullupdate"></i> Force Full Update');
|
$('#SubMenu a:contains("Force")').addClass('btn').html('<i class="sgicon-fullupdate"></i>Force Full Update');
|
||||||
\$("#SubMenu a:contains('Rename')").addClass('btn').html('<i class="sgicon-rename"></i> Preview Rename');
|
$('#SubMenu a:contains("Rename")').addClass('btn').html('<i class="sgicon-rename"></i>Preview Rename');
|
||||||
\$("#SubMenu a[href$='/config/subtitles/']").addClass('btn').html('<i class="sgicon-subtitles"></i> Search Subtitles');
|
$('#SubMenu a[href$="/config/subtitles/"]').addClass('btn').html('<i class="sgicon-subtitles"></i>Search Subtitles');
|
||||||
\$("#SubMenu a[href*='/home/subtitleShow']").addClass('btn').html('<i class="sgicon-subtitles"></i> Download Subtitles');
|
$('#SubMenu a[href*="/home/subtitleShow"]').addClass('btn').html('<i class="sgicon-subtitles"></i>Download Subtitles');
|
||||||
\$("#SubMenu a:contains('Anime')").addClass('btn').html('<i class="sgicon-anime"></i> Anime');
|
$('#SubMenu a:contains("Anime")').addClass('btn').html('<i class="sgicon-anime"></i>Anime');
|
||||||
\$("#SubMenu a:contains('Settings')").addClass('btn').html('<i class="sgicon-search"></i> Search Settings');
|
$('#SubMenu a:contains("Settings")').addClass('btn').html('<i class="sgicon-search"></i>Search Settings');
|
||||||
\$("#SubMenu a:contains('Provider')").addClass('btn').html('<i class="sgicon-search"></i> Search Providers');
|
$('#SubMenu a:contains("Provider")').addClass('btn').html('<i class="sgicon-search"></i>Search Providers');
|
||||||
\$("#SubMenu a:contains('General')").addClass('btn').html('<i class="sgicon-config"></i> General');
|
$('#SubMenu a:contains("General")').addClass('btn').html('<i class="sgicon-config"></i>General');
|
||||||
\$("#SubMenu a:contains('Episode Status')").addClass('btn').html('<i class="sgicon-episodestatus"></i> Episode Status Management');
|
$('#SubMenu a:contains("Episode Status")').addClass('btn').html('<i class="sgicon-episodestatus"></i>Episode Status Management');
|
||||||
\$("#SubMenu a:contains('Missed Subtitle')").addClass('btn').html('<i class="sgicon-subtitles"></i> Missed Subtitles');
|
$('#SubMenu a:contains("Missed Subtitle")').addClass('btn').html('<i class="sgicon-subtitles"></i>Missed Subtitles');
|
||||||
\$("#SubMenu a[href$='/home/addShows/']").addClass('btn').html('<i class="sgicon-addshow"></i> Add Show');
|
$('#SubMenu a[href$="/home/addShows/"]').addClass('btn').html('<i class="sgicon-addshow"></i>Add Show');
|
||||||
\$("#SubMenu a:contains('Processing')").addClass('btn').html('<i class="sgicon-postprocess"></i> Post-Processing');
|
$('#SubMenu a:contains("Processing")').addClass('btn').html('<i class="sgicon-postprocess"></i>Post-Processing');
|
||||||
\$("#SubMenu a:contains('Manage Searches')").addClass('btn').html('<i class="sgicon-search"></i> Manage Searches');
|
$('#SubMenu a:contains("Manage Searches")').addClass('btn').html('<i class="sgicon-search"></i>Manage Searches');
|
||||||
\$("#SubMenu a:contains('Manage Torrents')").addClass('btn').html('<i class="sgicon-bittorrent"></i> Manage Torrents');
|
$('#SubMenu a:contains("Manage Torrents")').addClass('btn').html('<i class="sgicon-bittorrent"></i>Manage Torrents');
|
||||||
\$("#SubMenu a[href$='/manage/failedDownloads/']").addClass('btn').html('<i class="sgicon-failed"></i> Failed Downloads');
|
$('#SubMenu a[href$="/manage/failedDownloads/"]').addClass('btn').html('<i class="sgicon-failed"></i>Failed Downloads');
|
||||||
\$("#SubMenu a:contains('Notification')").addClass('btn').html('<i class="sgicon-notification"></i> Notifications');
|
$('#SubMenu a:contains("Notification")').addClass('btn').html('<i class="sgicon-notification"></i>Notifications');
|
||||||
\$("#SubMenu a:contains('Update show in XBMC')").addClass('btn').html('<i class="sgicon-xbmc"></i> Update show in XBMC');
|
$('#SubMenu a:contains("Update show in XBMC")').addClass('btn').html('<i class="sgicon-xbmc"></i>Update show in XBMC');
|
||||||
\$("#SubMenu a[href$='/home/updateXBMC/']").addClass('btn').html('<i class="sgicon-xbmc"></i> Update XBMC');
|
$('#SubMenu a[href$="/home/updateXBMC/"]').addClass('btn').html('<i class="sgicon-xbmc"></i>Update XBMC');
|
||||||
\$("#SubMenu a:contains('Update show in Kodi')").addClass('btn').html('<i class="sgicon-kodi"></i> Update show in Kodi');
|
$('#SubMenu a:contains("Update show in Kodi")').addClass('btn').html('<i class="sgicon-kodi"></i>Update show in Kodi');
|
||||||
\$("#SubMenu a[href$='/home/updateKODI/']").addClass('btn').html('<i class="sgicon-kodi"></i> Update Kodi');
|
$('#SubMenu a[href$="/home/updateKODI/"]').addClass('btn').html('<i class="sgicon-kodi"></i>Update Kodi');
|
||||||
}
|
}
|
||||||
|
#end raw
|
||||||
\$(document).ready(function() {
|
\$(document).ready(function() {
|
||||||
|
|
||||||
initActions();
|
initActions();
|
||||||
|
|
||||||
\$("#NAV$topmenu").addClass("active");
|
\$("#NAV$topmenu").addClass("active");
|
||||||
|
|
||||||
\$('.dropdown-toggle').dropdownHover();
|
\$('.dropdown-toggle').dropdownHover();
|
||||||
|
|
||||||
});
|
});
|
||||||
//-->
|
//-->
|
||||||
</script>
|
</script>
|
||||||
<script type="text/javascript" src="$sbRoot/js/confirmations.js?$sbPID"></script>
|
<script type="text/javascript" src="$sbRoot/js/confirmations.js?$sbPID"></script>
|
||||||
</head>
|
</head>
|
||||||
#set $tab = 4
|
#set $tab = 4
|
||||||
#set $body_attr = ''
|
#set $body_attr = ''
|
||||||
#try
|
#try
|
||||||
|
@ -132,9 +126,10 @@
|
||||||
#except
|
#except
|
||||||
#pass
|
#pass
|
||||||
#end try
|
#end try
|
||||||
<body$body_attr>
|
<body$body_attr>
|
||||||
<nav class="navbar navbar-default navbar-fixed-top" role="navigation">
|
<nav class="navbar navbar-default navbar-fixed-top" role="navigation">
|
||||||
<div class="container-fluid">
|
<div class="container-fluid">
|
||||||
|
|
||||||
<div class="navbar-header">
|
<div class="navbar-header">
|
||||||
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
|
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1">
|
||||||
<span class="sr-only">Toggle navigation</span>
|
<span class="sr-only">Toggle navigation</span>
|
||||||
|
@ -150,9 +145,9 @@
|
||||||
<li id="NAVhome" class="dropdown">
|
<li id="NAVhome" class="dropdown">
|
||||||
<a href="$sbRoot/home/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#">Shows <b class="caret"></b></a>
|
<a href="$sbRoot/home/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#">Shows <b class="caret"></b></a>
|
||||||
<ul class="dropdown-menu">
|
<ul class="dropdown-menu">
|
||||||
<li><a href="$sbRoot/home/showlistView/" tabindex="$tab#set $tab += 1#"><i class="sgicon-home"></i> Show List</a></li>
|
<li><a href="$sbRoot/home/showlistView/" tabindex="$tab#set $tab += 1#"><i class="sgicon-home"></i>Show List</a></li>
|
||||||
<li><a href="$sbRoot/home/addShows/" tabindex="$tab#set $tab += 1#"><i class="sgicon-addshow"></i> Add Shows</a></li>
|
<li><a href="$sbRoot/home/addShows/" tabindex="$tab#set $tab += 1#"><i class="sgicon-addshow"></i>Add Shows</a></li>
|
||||||
<li><a href="$sbRoot/home/postprocess/" tabindex="$tab#set $tab += 1#"><i class="sgicon-postprocess"></i> Manual Post-Processing</a></li>
|
<li><a href="$sbRoot/home/postprocess/" tabindex="$tab#set $tab += 1#"><i class="sgicon-postprocess"></i>Manual Post-Processing</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
@ -167,29 +162,29 @@
|
||||||
<li id="NAVmanage" class="dropdown">
|
<li id="NAVmanage" class="dropdown">
|
||||||
<a href="$sbRoot/manage/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#">Manage <b class="caret"></b></a>
|
<a href="$sbRoot/manage/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#">Manage <b class="caret"></b></a>
|
||||||
<ul class="dropdown-menu">
|
<ul class="dropdown-menu">
|
||||||
<li><a href="$sbRoot/manage/" tabindex="$tab#set $tab += 1#"><i class="sgicon-massupdate"></i> Mass Update</a></li>
|
<li><a href="$sbRoot/manage/" tabindex="$tab#set $tab += 1#"><i class="sgicon-massupdate"></i>Mass Update</a></li>
|
||||||
<li><a href="$sbRoot/manage/backlogOverview/" tabindex="$tab#set $tab += 1#"><i class="sgicon-backlog"></i> Backlog Overview</a></li>
|
<li><a href="$sbRoot/manage/backlogOverview/" tabindex="$tab#set $tab += 1#"><i class="sgicon-backlog"></i>Backlog Overview</a></li>
|
||||||
<li><a href="$sbRoot/manage/manageSearches/" tabindex="$tab#set $tab += 1#"><i class="sgicon-search"></i> Manage Searches</a></li>
|
<li><a href="$sbRoot/manage/manageSearches/" tabindex="$tab#set $tab += 1#"><i class="sgicon-search"></i>Manage Searches</a></li>
|
||||||
<li><a href="$sbRoot/manage/episodeStatuses/" tabindex="$tab#set $tab += 1#"><i class="sgicon-episodestatus"></i> Episode Status Management</a></li>
|
<li><a href="$sbRoot/manage/episodeStatuses/" tabindex="$tab#set $tab += 1#"><i class="sgicon-episodestatus"></i>Episode Status Management</a></li>
|
||||||
#if $sickbeard.USE_PLEX and $sickbeard.PLEX_SERVER_HOST != '':
|
#if $sickbeard.USE_PLEX and $sickbeard.PLEX_SERVER_HOST != ''
|
||||||
<li><a href="$sbRoot/home/updatePLEX/" tabindex="$tab#set $tab += 1#"><i class="sgicon-plex"></i> Update PLEX</a></li>
|
<li><a href="$sbRoot/home/updatePLEX/" tabindex="$tab#set $tab += 1#"><i class="sgicon-plex"></i>Update PLEX</a></li>
|
||||||
#end if
|
#end if
|
||||||
#if $sickbeard.USE_XBMC and $sickbeard.XBMC_HOST != '':
|
#if $sickbeard.USE_XBMC and $sickbeard.XBMC_HOST != ''
|
||||||
<li><a href="$sbRoot/home/updateXBMC/" tabindex="$tab#set $tab += 1#"><i class="sgicon-xbmc"></i> Update XBMC</a></li>
|
<li><a href="$sbRoot/home/updateXBMC/" tabindex="$tab#set $tab += 1#"><i class="sgicon-xbmc"></i>Update XBMC</a></li>
|
||||||
#end if
|
#end if
|
||||||
#if $sickbeard.USE_KODI and $sickbeard.KODI_HOST != '':
|
#if $sickbeard.USE_KODI and $sickbeard.KODI_HOST != ''
|
||||||
<li><a href="$sbRoot/home/updateKODI/" tabindex="$tab#set $tab += 1#"><i class="sgicon-kodi"></i> Update Kodi</a></li>
|
<li><a href="$sbRoot/home/updateKODI/" tabindex="$tab#set $tab += 1#"><i class="sgicon-kodi"></i>Update Kodi</a></li>
|
||||||
#end if
|
#end if
|
||||||
#if $sickbeard.USE_TORRENTS and $sickbeard.TORRENT_METHOD != 'blackhole' \
|
#if $sickbeard.USE_TORRENTS and $sickbeard.TORRENT_METHOD != 'blackhole' \
|
||||||
and ($sickbeard.ENABLE_HTTPS and $sickbeard.TORRENT_HOST[:5] == 'https' \
|
and ($sickbeard.ENABLE_HTTPS and $sickbeard.TORRENT_HOST[:5] == 'https' \
|
||||||
or not $sickbeard.ENABLE_HTTPS and $sickbeard.TORRENT_HOST[:5] == 'http:'):
|
or not $sickbeard.ENABLE_HTTPS and $sickbeard.TORRENT_HOST[:5] == 'http:')
|
||||||
<li><a href="$sbRoot/manage/manageTorrents/" tabindex="$tab#set $tab += 1#"><i class="sgicon-bittorrent"></i> Manage Torrents</a></li>
|
<li><a href="$sbRoot/manage/manageTorrents/" tabindex="$tab#set $tab += 1#"><i class="sgicon-bittorrent"></i>Manage Torrents</a></li>
|
||||||
#end if
|
#end if
|
||||||
#if $sickbeard.USE_FAILED_DOWNLOADS:
|
#if $sickbeard.USE_FAILED_DOWNLOADS
|
||||||
<li><a href="$sbRoot/manage/failedDownloads/" tabindex="$tab#set $tab += 1#"><i class="sgicon-failed"></i> Failed Downloads</a></li>
|
<li><a href="$sbRoot/manage/failedDownloads/" tabindex="$tab#set $tab += 1#"><i class="sgicon-failed"></i>Failed Downloads</a></li>
|
||||||
#end if
|
#end if
|
||||||
#if $sickbeard.USE_SUBTITLES:
|
#if $sickbeard.USE_SUBTITLES
|
||||||
<li><a href="$sbRoot/manage/subtitleMissed/" tabindex="$tab#set $tab += 1#"><i class="sgicon-subtitles"></i> Missed Subtitle Management</a></li>
|
<li><a href="$sbRoot/manage/subtitleMissed/" tabindex="$tab#set $tab += 1#"><i class="sgicon-subtitles"></i>Missed Subtitle Management</a></li>
|
||||||
#end if
|
#end if
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
|
@ -197,58 +192,62 @@
|
||||||
<li id="NAVerrorlogs" class="dropdown">
|
<li id="NAVerrorlogs" class="dropdown">
|
||||||
<a href="$sbRoot/errorlogs/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#">$logPageTitle <b class="caret"></b></a>
|
<a href="$sbRoot/errorlogs/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#">$logPageTitle <b class="caret"></b></a>
|
||||||
<ul class="dropdown-menu">
|
<ul class="dropdown-menu">
|
||||||
<li><a href="$sbRoot/errorlogs/" tabindex="$tab#set $tab += 1#"><i class="sgicon-errorlog"></i> View Log (Errors)</a></li>
|
<li><a href="$sbRoot/errorlogs/" tabindex="$tab#set $tab += 1#"><i class="sgicon-errorlog"></i>View Log (Errors)</a></li>
|
||||||
<li><a href="$sbRoot/errorlogs/viewlog/" tabindex="$tab#set $tab += 1#"><i class="sgicon-log"></i> View Log</a></li>
|
<li><a href="$sbRoot/errorlogs/viewlog/" tabindex="$tab#set $tab += 1#"><i class="sgicon-log"></i>View Log</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
<li id="NAVconfig" class="dropdown">
|
<li id="NAVconfig" class="dropdown">
|
||||||
<a href="$sbRoot/config/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#"><img src="$sbRoot/images/menu/system18.png" class="navbaricon hidden-xs" /><b class="caret hidden-xs"></b><span class="visible-xs">Config <b class="caret"></b></span></a>
|
<a href="$sbRoot/config/" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#"><img src="$sbRoot/images/menu/system18.png" class="navbaricon hidden-xs" /><b class="caret hidden-xs"></b><span class="visible-xs">Config <b class="caret"></b></span></a>
|
||||||
<ul class="dropdown-menu">
|
<ul class="dropdown-menu">
|
||||||
<li><a href="$sbRoot/config/" tabindex="$tab#set $tab += 1#"><i class="sgicon-info"></i> Help & Info</a></li>
|
<li><a href="$sbRoot/config/" tabindex="$tab#set $tab += 1#"><i class="sgicon-info"></i>Help & Info</a></li>
|
||||||
<li><a href="$sbRoot/config/general/" tabindex="$tab#set $tab += 1#"><i class="sgicon-config"></i> General</a></li>
|
<li><a href="$sbRoot/config/general/" tabindex="$tab#set $tab += 1#"><i class="sgicon-config"></i>General</a></li>
|
||||||
<li><a href="$sbRoot/config/search/" tabindex="$tab#set $tab += 1#"><i class="sgicon-search"></i> Search Settings</a></li>
|
<li><a href="$sbRoot/config/search/" tabindex="$tab#set $tab += 1#"><i class="sgicon-search"></i>Search Settings</a></li>
|
||||||
<li><a href="$sbRoot/config/providers/" tabindex="$tab#set $tab += 1#"><i class="sgicon-search"></i> Search Providers</a></li>
|
<li><a href="$sbRoot/config/providers/" tabindex="$tab#set $tab += 1#"><i class="sgicon-search"></i>Search Providers</a></li>
|
||||||
<li><a href="$sbRoot/config/subtitles/" tabindex="$tab#set $tab += 1#"><i class="sgicon-subtitles"></i> Subtitles Settings</a></li>
|
<li><a href="$sbRoot/config/providers/" tabindex="$tab#set $tab += 1#"><i class="sgicon-search"></i>Search Providers</a></li>
|
||||||
<li><a href="$sbRoot/config/postProcessing/" tabindex="$tab#set $tab += 1#"><i class="sgicon-postprocess"></i> Post Processing</a></li>
|
<li><a href="$sbRoot/config/subtitles/" tabindex="$tab#set $tab += 1#"><i class="sgicon-subtitles"></i>Subtitles Settings</a></li>
|
||||||
<li><a href="$sbRoot/config/notifications/" tabindex="$tab#set $tab += 1#"><i class="sgicon-notification"></i> Notifications</a></li>
|
<li><a href="$sbRoot/config/postProcessing/" tabindex="$tab#set $tab += 1#"><i class="sgicon-postprocess"></i>Post Processing</a></li>
|
||||||
<li><a href="$sbRoot/config/anime/" tabindex="$tab#set $tab += 1#"><i class="sgicon-anime"></i> Anime</a></li>
|
<li><a href="$sbRoot/config/notifications/" tabindex="$tab#set $tab += 1#"><i class="sgicon-notification"></i>Notifications</a></li>
|
||||||
|
<li><a href="$sbRoot/config/anime/" tabindex="$tab#set $tab += 1#"><i class="sgicon-anime"></i>Anime</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
<li class="dropdown">
|
<li class="dropdown">
|
||||||
<a href="#" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#"><img src="$sbRoot/images/menu/system18-2.png" class="navbaricon hidden-xs" /><b class="caret hidden-xs"></b><span class="visible-xs">System <b class="caret"></b></span></a>
|
<a href="#" class="dropdown-toggle" data-toggle="dropdown" data-delay="0" tabindex="$tab#set $tab += 1#"><img src="$sbRoot/images/menu/system18-2.png" class="navbaricon hidden-xs" /><b class="caret hidden-xs"></b><span class="visible-xs">System <b class="caret"></b></span></a>
|
||||||
<ul class="dropdown-menu">
|
<ul class="dropdown-menu">
|
||||||
<li><a href="$sbRoot/manage/manageSearches/forceVersionCheck" tabindex="$tab#set $tab += 1#"><i class="sgicon-updatecheck"></i> Force Version Check</a></li>
|
<li><a href="$sbRoot/manage/manageSearches/forceVersionCheck" tabindex="$tab#set $tab += 1#"><i class="sgicon-updatecheck"></i>Force Version Check</a></li>
|
||||||
#if $sickbeard.WEB_USERNAME or $sickbeard.WEB_PASSWORD:
|
#if $sickbeard.WEB_USERNAME or $sickbeard.WEB_PASSWORD
|
||||||
<li><a href="$sbRoot/logout" class="confirm logout" tabindex="$tab#set $tab += 1#"><i class="sgicon-logout"></i> Logout</a></li>
|
<li><a href="$sbRoot/logout" class="confirm logout" tabindex="$tab#set $tab += 1#"><i class="sgicon-logout"></i>Logout</a></li>
|
||||||
#end if
|
#end if
|
||||||
<li><a href="$sbRoot/home/restart/?pid=$sbPID" class="confirm restart" tabindex="$tab#set $tab += 1#"><i class="sgicon-restart"></i> Restart</a></li>
|
<li><a href="$sbRoot/home/restart/?pid=$sbPID" class="confirm restart" tabindex="$tab#set $tab += 1#"><i class="sgicon-restart"></i>Restart</a></li>
|
||||||
<li><a href="$sbRoot/home/shutdown/?pid=$sbPID" class="confirm shutdown" tabindex="$tab#set $tab += 1#"><i class="sgicon-shutdown"></i> Shutdown</a></li>
|
<li><a href="$sbRoot/home/shutdown/?pid=$sbPID" class="confirm shutdown" tabindex="$tab#set $tab += 1#"><i class="sgicon-shutdown"></i>Shutdown</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
</div><!-- /.navbar-collapse -->
|
</div><!-- /.navbar-collapse -->
|
||||||
|
|
||||||
</div><!-- /.container-fluid -->
|
</div><!-- /.container-fluid -->
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
#if $varExists('submenu'):
|
#if $varExists('submenu')
|
||||||
<div id="SubMenu">
|
<div id="SubMenu">
|
||||||
<span>
|
<span>
|
||||||
#set $first = True
|
#set $first = True
|
||||||
#for $menuItem in $submenu:
|
#for $menuItem in $submenu
|
||||||
#if 'requires' not in $menuItem or $menuItem.requires():
|
#if 'requires' not in $menuItem or $menuItem.requires()
|
||||||
#if type($menuItem.path) == dict:
|
#if type($menuItem.path) == dict
|
||||||
#if $first then "" else "</span><span>"#<b>$menuItem.title</b>
|
#if $first then '' else '</span><span>'#<b>$menuItem.title</b>
|
||||||
#set $first = False
|
#set $first = False
|
||||||
#set $inner_first = True
|
#set $inner_first = True
|
||||||
#for $cur_link in $menuItem.path:
|
#for $cur_link in $menuItem.path
|
||||||
#if $inner_first then "" else "· "#<a class="inner" href="$sbRoot/$menuItem.path[$cur_link]">$cur_link</a>
|
#if $inner_first then '' else '· '
|
||||||
|
#slurp
|
||||||
|
<a class="inner" href="$sbRoot/$menuItem.path[$cur_link]">$cur_link</a>
|
||||||
#set $inner_first = False
|
#set $inner_first = False
|
||||||
#end for
|
#end for
|
||||||
#else
|
#else
|
||||||
#if $first then "" else ""#<a href="$sbRoot/$menuItem.path" #if 'confirm' in $menuItem then "class=\"confirm\"" else "" # tabindex="$tab#set $tab += 1#">$menuItem.title</a>
|
#slurp
|
||||||
|
<a href="$sbRoot/$menuItem.path"#if 'confirm' in $menuItem then ' class="confirm"' else ''# tabindex="$tab#set $tab += 1#">$menuItem.title</a>
|
||||||
#set $first = False
|
#set $first = False
|
||||||
#end if
|
#end if
|
||||||
#end if
|
#end if
|
||||||
|
@ -256,22 +255,22 @@
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
#end if
|
#end if
|
||||||
|
##
|
||||||
#if $sickbeard.NEWEST_VERSION_STRING:
|
#if $sickbeard.NEWEST_VERSION_STRING
|
||||||
<div class="alert alert-success upgrade-notification" role="alert">
|
<div class="alert alert-success upgrade-notification" role="alert">
|
||||||
<span>$sickbeard.NEWEST_VERSION_STRING</span>
|
<span>$sickbeard.NEWEST_VERSION_STRING</span>
|
||||||
</div>
|
</div>
|
||||||
#end if
|
#end if
|
||||||
|
##
|
||||||
#set $items = []
|
#set $items = []
|
||||||
#try
|
#try
|
||||||
$items.append($topmenu)
|
$items.append($topmenu)
|
||||||
#except (NameError, NotFound):
|
#except (NameError, NotFound)
|
||||||
#pass
|
#pass
|
||||||
#end try
|
#end try
|
||||||
#try
|
#try
|
||||||
$items.append($layout)
|
$items.append($layout)
|
||||||
#except (NameError, NotFound):
|
#except (NameError, NotFound)
|
||||||
#pass
|
#pass
|
||||||
#end try
|
#end try
|
||||||
#set $page_class = ('', ' class="%s"' % '_'.join($items).lower().replace(' ', '-').replace('_', '-'))[0 < len($items)]
|
#set $page_class = ('', ' class="%s"' % '_'.join($items).lower().replace(' ', '-').replace('_', '-'))[0 < len($items)]
|
||||||
|
|
|
@ -165,12 +165,12 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="optionWrapper #if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then 'hidden' else ''#">
|
<div class="optionWrapper #if $sickbeard.SHOWLIST_TAGVIEW != 'custom' then 'hidden' else ''#">
|
||||||
<span class="selectTitle">Tag</span>
|
<span class="selectTitle">Show is grouped in</span>
|
||||||
<div class="selectChoices">
|
<div class="selectChoices">
|
||||||
<select id="edit_tag" name="tag" class="form-control form-control-inline input-sm">
|
<select id="edit_tag" name="tag" class="form-control form-control-inline input-sm">
|
||||||
<option value="keep">< keep ></option>
|
<option value="keep">< keep ></option>
|
||||||
#for $tag in $sickbeard.SHOW_TAGS:
|
#for $tag in $sickbeard.SHOW_TAGS:
|
||||||
<option value="$tag" #if $tag_value == $tag then $selected else ''#>$tag</option>
|
<option value="$tag" #if $tag_value == $tag then $selected else ''#>$tag#echo ('', ' (default)')['Show List' == $tag]#</option>
|
||||||
#end for
|
#end for
|
||||||
</select>
|
</select>
|
||||||
</div><br />
|
</div><br />
|
||||||
|
|
|
@ -121,6 +121,15 @@ $(document).ready(function () {
|
||||||
|
|
||||||
fetch_branches();
|
fetch_branches();
|
||||||
fetch_pullrequests();
|
fetch_pullrequests();
|
||||||
|
|
||||||
|
$('#showlist_tagview').on('change', function() {
|
||||||
|
var selected = '#showlist_tagview_', target = $(selected + 'custom_config');
|
||||||
|
target.removeClass('hidden');
|
||||||
|
if ('custom' !== $(this).val())
|
||||||
|
target.addClass('hidden');
|
||||||
|
$(selected + 'standard,' + selected + 'anime,' + selected + 'custom').removeClass('hidden').addClass('hidden');
|
||||||
|
$(selected + $(this).val()).removeClass('hidden');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
function config_success(response) {
|
function config_success(response) {
|
||||||
|
|
|
@ -743,6 +743,7 @@ class ConfigMigrator():
|
||||||
def _migrate_v10(self):
|
def _migrate_v10(self):
|
||||||
# reset backlog frequency to default
|
# reset backlog frequency to default
|
||||||
sickbeard.BACKLOG_FREQUENCY = sickbeard.DEFAULT_BACKLOG_FREQUENCY
|
sickbeard.BACKLOG_FREQUENCY = sickbeard.DEFAULT_BACKLOG_FREQUENCY
|
||||||
|
|
||||||
def _migrate_v11(self):
|
def _migrate_v11(self):
|
||||||
if check_setting_int(self.config_obj, 'ANIME', 'anime_split_home', ''):
|
if check_setting_int(self.config_obj, 'ANIME', 'anime_split_home', ''):
|
||||||
sickbeard.SHOWLIST_TAGVIEW = 'anime'
|
sickbeard.SHOWLIST_TAGVIEW = 'anime'
|
||||||
|
|
|
@ -59,11 +59,6 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from lib import simplejson as json
|
from lib import simplejson as json
|
||||||
|
|
||||||
try:
|
|
||||||
from collections import OrderedDict
|
|
||||||
except ImportError:
|
|
||||||
from requests.packages.urllib3.packages.ordered_dict import OrderedDict
|
|
||||||
|
|
||||||
|
|
||||||
class PageTemplate(Template):
|
class PageTemplate(Template):
|
||||||
def __init__(self, headers, *args, **KWs):
|
def __init__(self, headers, *args, **KWs):
|
||||||
|
@ -3025,7 +3020,6 @@ class Manage(MainHandler):
|
||||||
else:
|
else:
|
||||||
new_tag = tag
|
new_tag = tag
|
||||||
|
|
||||||
|
|
||||||
if anime == 'keep':
|
if anime == 'keep':
|
||||||
new_anime = showObj.anime
|
new_anime = showObj.anime
|
||||||
else:
|
else:
|
||||||
|
@ -3429,7 +3423,7 @@ class ConfigGeneral(Config):
|
||||||
|
|
||||||
t = PageTemplate(headers=self.request.headers, file='config_general.tmpl')
|
t = PageTemplate(headers=self.request.headers, file='config_general.tmpl')
|
||||||
t.submenu = self.ConfigMenu
|
t.submenu = self.ConfigMenu
|
||||||
t.show_tags = ','.join(sickbeard.SHOW_TAGS)
|
t.show_tags = ', '.join(sickbeard.SHOW_TAGS)
|
||||||
return t.respond()
|
return t.respond()
|
||||||
|
|
||||||
def saveRootDirs(self, rootDirString=None):
|
def saveRootDirs(self, rootDirString=None):
|
||||||
|
@ -3512,20 +3506,19 @@ class ConfigGeneral(Config):
|
||||||
sickbeard.FILE_LOGGING_PRESET = file_logging_preset
|
sickbeard.FILE_LOGGING_PRESET = file_logging_preset
|
||||||
sickbeard.SHOWLIST_TAGVIEW = showlist_tagview
|
sickbeard.SHOWLIST_TAGVIEW = showlist_tagview
|
||||||
|
|
||||||
# Convert csv to list, must always contain Show List as a default fallback and strip leading/trailing spaces
|
# 'Show List' is the must have default fallback. Tags in use that are removed from config ui are restored, not deleted.
|
||||||
show_tags = show_tags.split(',')
|
# Deduped list order preservation is key to feature function.
|
||||||
if 'Show List' not in show_tags:
|
myDB = db.DBConnection()
|
||||||
show_tags.append('Show List')
|
|
||||||
show_tags = [x.strip() for x in show_tags if x]
|
|
||||||
|
|
||||||
# Don't allow deletion of tags that are still assigned to shows
|
|
||||||
myDB = db.DBConnection('sickbeard.db')
|
|
||||||
sql_results = myDB.select('SELECT DISTINCT tag FROM tv_shows')
|
sql_results = myDB.select('SELECT DISTINCT tag FROM tv_shows')
|
||||||
if sql_results:
|
new_names = [u'' + v.strip() for v in (show_tags.split(u','), [])[None is show_tags] if v.strip()]
|
||||||
for tag in sql_results[0]:
|
orphans = [item for item in [v['tag'] for v in sql_results or []] if item not in new_names]
|
||||||
show_tags.append(tag)
|
cleanser = []
|
||||||
|
if 0 < len(orphans):
|
||||||
sickbeard.SHOW_TAGS = list(OrderedDict.fromkeys(show_tags)) # remove dupes
|
cleanser = [item for item in sickbeard.SHOW_TAGS if item in orphans or item in new_names]
|
||||||
|
results += [u'An attempt was prevented to remove a show list group name still in use']
|
||||||
|
dedupe = {}
|
||||||
|
sickbeard.SHOW_TAGS = [dedupe.setdefault(item, item) for item in (cleanser + new_names + [u'Show List'])
|
||||||
|
if item not in dedupe]
|
||||||
|
|
||||||
logger.log_set_level()
|
logger.log_set_level()
|
||||||
|
|
||||||
|
@ -3557,7 +3550,6 @@ class ConfigGeneral(Config):
|
||||||
|
|
||||||
if date_preset:
|
if date_preset:
|
||||||
sickbeard.DATE_PRESET = date_preset
|
sickbeard.DATE_PRESET = date_preset
|
||||||
discarded_na_data = date_preset_na
|
|
||||||
|
|
||||||
if indexer_default:
|
if indexer_default:
|
||||||
sickbeard.INDEXER_DEFAULT = config.to_int(indexer_default)
|
sickbeard.INDEXER_DEFAULT = config.to_int(indexer_default)
|
||||||
|
@ -3595,8 +3587,8 @@ class ConfigGeneral(Config):
|
||||||
sickbeard.save_config()
|
sickbeard.save_config()
|
||||||
|
|
||||||
if len(results) > 0:
|
if len(results) > 0:
|
||||||
for x in results:
|
for v in results:
|
||||||
logger.log(x, logger.ERROR)
|
logger.log(v, logger.ERROR)
|
||||||
ui.notifications.error('Error(s) Saving Configuration',
|
ui.notifications.error('Error(s) Saving Configuration',
|
||||||
'<br />\n'.join(results))
|
'<br />\n'.join(results))
|
||||||
else:
|
else:
|
||||||
|
|
Loading…
Reference in a new issue