mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-07 10:33:38 +00:00
Merge pull request #121 from JackDandy/feature/AddTimeFormatLowerPM
Add lowercase PM to the General Config/Interface/Time style selection.
This commit is contained in:
commit
5cfb8b202b
8 changed files with 370 additions and 352 deletions
11
CHANGES.md
11
CHANGES.md
|
@ -1,10 +1,13 @@
|
||||||
### 0.x.x (2014-12-xx xx:xx:xx UTC)
|
### 0.x.x (2014-12-xx xx:xx:xx UTC)
|
||||||
|
|
||||||
* Add network logo's for BBC Canada, Crackle, El Rey Network, SKY Atlantic, and Watch
|
* Add network logos BBC Canada, Crackle, El Rey Network, SKY Atlantic, and Watch
|
||||||
* Change Yahoo! screen network logo
|
* Change Yahoo! screen network logo
|
||||||
* Change added and updated Discovery Network's channel logo's
|
* Add and update Discovery Network's channel logos
|
||||||
* Remove unrequired duplicate network logo's
|
* Add A&E Network International/Scripps Networks International channel logos
|
||||||
* Add Discovery Network International/A&E Network International/Scripps Networks International missing channel logos
|
* Remove non required duplicate network logos
|
||||||
|
* Add lowercase PM to the General Config/Interface/Time style selection
|
||||||
|
* Change General Config/Interface/Trim zero padding to Trim date and time, now handles 2:00 pm > 2 pm
|
||||||
|
* Fix trim zero of military time hour to not use 12 hr time
|
||||||
|
|
||||||
[develop changelog]
|
[develop changelog]
|
||||||
|
|
||||||
|
|
|
@ -1375,11 +1375,6 @@ config*.tmpl
|
||||||
padding: 12px 0px;
|
padding: 12px 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#config div.field-pair input {
|
|
||||||
float: left;
|
|
||||||
margin-right: 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#config .nocheck, #config div #customQuality, .metadataDiv {
|
#config .nocheck, #config div #customQuality, .metadataDiv {
|
||||||
padding-left: 20px;
|
padding-left: 20px;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1358,11 +1358,6 @@ config*.tmpl
|
||||||
padding: 12px 0px;
|
padding: 12px 0px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#config div.field-pair input {
|
|
||||||
float: left;
|
|
||||||
margin-right: 6px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#config .nocheck, #config div #customQuality, .metadataDiv {
|
#config .nocheck, #config div #customQuality, .metadataDiv {
|
||||||
padding-left: 20px;
|
padding-left: 20px;
|
||||||
}
|
}
|
||||||
|
|
|
@ -153,7 +153,7 @@ inc_top.tmpl
|
||||||
/* background: url("../images/bg.png") repeat 0 0 transparent; */
|
/* background: url("../images/bg.png") repeat 0 0 transparent; */
|
||||||
}
|
}
|
||||||
|
|
||||||
[class^="icon-"],
|
[class^="icon-"],
|
||||||
[class*=" icon-"] {
|
[class*=" icon-"] {
|
||||||
background-image: url("../images/glyphicons-halflings.png");
|
background-image: url("../images/glyphicons-halflings.png");
|
||||||
}
|
}
|
||||||
|
@ -1591,10 +1591,13 @@ config*.tmpl
|
||||||
padding: 12px 0
|
padding: 12px 0
|
||||||
}
|
}
|
||||||
|
|
||||||
.stepDiv .component-desc select,
|
|
||||||
.stepDiv .component-desc input,
|
|
||||||
#config div.field-pair select,
|
#config div.field-pair select,
|
||||||
#config div.field-pair input {
|
#config div.field-pair input {
|
||||||
|
margin-right: 6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.stepDiv .component-desc select,
|
||||||
|
.stepDiv .component-desc input {
|
||||||
margin-right: 15px;
|
margin-right: 15px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3153,6 +3156,11 @@ span.token-input-delete-token {
|
||||||
z-index: 0;
|
z-index: 0;
|
||||||
background-image: url(../images/poster-dark.jpg)
|
background-image: url(../images/poster-dark.jpg)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.time-am-pm {
|
||||||
|
margin-left: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
/* =======================================================================
|
/* =======================================================================
|
||||||
jquery.confirm.css
|
jquery.confirm.css
|
||||||
========================================================================== */
|
========================================================================== */
|
||||||
|
|
|
@ -103,9 +103,9 @@
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<select id="indexer_default" name="indexer_default" class="form-control input-sm">
|
<select id="indexer_default" name="indexer_default" class="form-control input-sm">
|
||||||
<option value="0" #if $indexer == 0 then 'selected="selected"' else ''#>All Indexers</option>
|
<option value="0" #if $indexer == 0 then 'selected="selected"' else ''#>All Indexers</option>
|
||||||
#for $indexer in $sickbeard.indexerApi().indexers
|
#for $indexer in $sickbeard.indexerApi().indexers
|
||||||
<option value="$indexer" #if $indexer == $sickbeard.INDEXER_DEFAULT then 'selected="selected"' else ''#>$sickbeard.indexerApi().indexers[$indexer]</option>
|
<option value="$indexer" #if $indexer == $sickbeard.INDEXER_DEFAULT then 'selected="selected"' else ''#>$sickbeard.indexerApi().indexers[$indexer]</option>
|
||||||
#end for
|
#end for
|
||||||
</select>
|
</select>
|
||||||
<span>as the default selection when adding new shows</span>
|
<span>as the default selection when adding new shows</span>
|
||||||
</span>
|
</span>
|
||||||
|
@ -127,7 +127,7 @@
|
||||||
<span class="component-title">Show root directories</span>
|
<span class="component-title">Show root directories</span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<p>where the files of shows are located</p>
|
<p>where the files of shows are located</p>
|
||||||
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_rootDirs.tmpl')
|
#include $os.path.join($sickbeard.PROG_DIR, 'gui/slick/interfaces/default/inc_rootDirs.tmpl')
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
@ -246,10 +246,10 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="field-pair show_if_fuzzy_dating#if True == $sickbeard.FUZZY_DATING then '' else ' metadataDiv'#">
|
<div class="field-pair show_if_fuzzy_dating#if True == $sickbeard.FUZZY_DATING then '' else ' metadataDiv'#">
|
||||||
<label for="trim_zero">
|
<label for="trim_zero">
|
||||||
<span class="component-title">Trim zero padding</span>
|
<span class="component-title">Trim date and time</span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<input type="checkbox" name="trim_zero" id="trim_zero" #if True == $sickbeard.TRIM_ZERO then 'checked="checked"' else ''#/>
|
<input type="checkbox" name="trim_zero" id="trim_zero" #if True == $sickbeard.TRIM_ZERO then 'checked="checked"' else ''#/>
|
||||||
<p>remove the leading number "0" shown on hour of day, and date of month</p>
|
<p>display minimalist date and time i.e. <del>02:00</del> = 2:00, <del>02:00pm</del> = 2pm, <del>03 Jan</del> = 3 Jan</p>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
@ -259,16 +259,16 @@
|
||||||
<span class="component-title">Date style:</span>
|
<span class="component-title">Date style:</span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<select class="form-control input-sm #if True == $sickbeard.FUZZY_DATING then '' else ' metadataDiv'#" id="date_presets#if True == $sickbeard.FUZZY_DATING then '' else '_na'#" name="date_preset#if True == $sickbeard.FUZZY_DATING then '' else '_na'#">
|
<select class="form-control input-sm #if True == $sickbeard.FUZZY_DATING then '' else ' metadataDiv'#" id="date_presets#if True == $sickbeard.FUZZY_DATING then '' else '_na'#" name="date_preset#if True == $sickbeard.FUZZY_DATING then '' else '_na'#">
|
||||||
#for $cur_preset in $date_presets:
|
#for $cur_preset in $date_presets:
|
||||||
<option value="$cur_preset" #if $cur_preset == $sickbeard.DATE_PRESET or ("%x" == $sickbeard.DATE_PRESET and "$cur_preset" == '%a, %b %d, %Y') then 'selected="selected"' else ''#>$datetime.datetime($datetime.datetime.now().year, 12, 31, 14, 30, 47).strftime($cur_preset)</option>
|
<option value="$cur_preset" #if $cur_preset == $sickbeard.DATE_PRESET or ("%x" == $sickbeard.DATE_PRESET and "$cur_preset" == '%a, %b %d, %Y') then 'selected="selected"' else ''#>$datetime.datetime($datetime.datetime.now().year, 12, 31, 14, 30, 47).strftime($cur_preset)</option>
|
||||||
#end for
|
#end for
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
<select class="form-control input-sm #if True != $sickbeard.FUZZY_DATING then '' else ' metadataDiv'#" id="date_presets#if True != $sickbeard.FUZZY_DATING then '' else '_na'#" name="date_preset#if True != $sickbeard.FUZZY_DATING then '' else '_na'#">
|
<select class="form-control input-sm #if True != $sickbeard.FUZZY_DATING then '' else ' metadataDiv'#" id="date_presets#if True != $sickbeard.FUZZY_DATING then '' else '_na'#" name="date_preset#if True != $sickbeard.FUZZY_DATING then '' else '_na'#">
|
||||||
<option value="%x" #if "%x" == $sickbeard.DATE_PRESET then 'selected="selected"' else ''#>Use System Default</option>
|
<option value="%x" #if "%x" == $sickbeard.DATE_PRESET then 'selected="selected"' else ''#>Use System Default</option>
|
||||||
#for $cur_preset in $date_presets:
|
#for $cur_preset in $date_presets:
|
||||||
<option value="$cur_preset" #if $cur_preset == $sickbeard.DATE_PRESET then 'selected="selected"' else ''#>$datetime.datetime($datetime.datetime.now().year, 12, 31, 14, 30, 47).strftime($cur_preset)</option>
|
<option value="$cur_preset" #if $cur_preset == $sickbeard.DATE_PRESET then 'selected="selected"' else ''#>$datetime.datetime($datetime.datetime.now().year, 12, 31, 14, 30, 47).strftime($cur_preset)</option>
|
||||||
#end for
|
#end for
|
||||||
</select>
|
</select>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
|
@ -279,11 +279,12 @@
|
||||||
<span class="component-title">Time style:</span>
|
<span class="component-title">Time style:</span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<select id="time_presets" name="time_preset" class="form-control input-sm">
|
<select id="time_presets" name="time_preset" class="form-control input-sm">
|
||||||
#for $cur_preset in $time_presets:
|
#for $cur_preset in $time_presets:
|
||||||
<option value="$cur_preset" #if $cur_preset == $sickbeard.TIME_PRESET_W_SECONDS then 'selected="selected"' else ''#>$sbdatetime.now().sbftime(show_seconds=True,t_preset=$cur_preset)</option>
|
#set $show_seconds = not $sickbeard.FUZZY_DATING
|
||||||
#end for
|
<option value="$cur_preset" #if $cur_preset == $sickbeard.TIME_PRESET_W_SECONDS then 'selected="selected"' else ''#>$sbdatetime.now().sbftime(show_seconds=$show_seconds, t_preset=$cur_preset)</option>
|
||||||
|
#end for
|
||||||
</select>
|
</select>
|
||||||
<span><b>note:</b> seconds are only shown on the History page</span>
|
<span id="trim_info_seconds"><b>note:</b> seconds are only shown on the History page</span>
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
@ -450,9 +451,9 @@
|
||||||
<span class="component-title">Branch version:</span>
|
<span class="component-title">Branch version:</span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<select id="branchVersion" class="form-control form-control-inline input-sm pull-left">
|
<select id="branchVersion" class="form-control form-control-inline input-sm pull-left">
|
||||||
#for $cur_branch in $sickbeard.versionCheckScheduler.action.list_remote_branches():
|
#for $cur_branch in $sickbeard.versionCheckScheduler.action.list_remote_branches():
|
||||||
<option value="$cur_branch" #if $cur_branch == $sickbeard.BRANCH then 'selected="selected"' else ''#>$cur_branch</option>
|
<option value="$cur_branch" #if $cur_branch == $sickbeard.BRANCH then 'selected="selected"' else ''#>$cur_branch</option>
|
||||||
#end for
|
#end for
|
||||||
</select>
|
</select>
|
||||||
<input class="btn btn-inline" style="margin-left: 6px;" type="button" id="branchCheckout" value="Checkout Branch">
|
<input class="btn btn-inline" style="margin-left: 6px;" type="button" id="branchCheckout" value="Checkout Branch">
|
||||||
<div class="clear-left"><p>select branch to use (restart required)</p></div>
|
<div class="clear-left"><p>select branch to use (restart required)</p></div>
|
||||||
|
@ -485,9 +486,9 @@
|
||||||
<span class="component-title">CPU throttling:</span>
|
<span class="component-title">CPU throttling:</span>
|
||||||
<span class="component-desc">
|
<span class="component-desc">
|
||||||
<select id="cpu_presets" name="cpu_preset" class="form-control input-sm">
|
<select id="cpu_presets" name="cpu_preset" class="form-control input-sm">
|
||||||
#for $cur_preset in $cpu_presets:
|
#for $cur_preset in $cpu_presets:
|
||||||
<option value="$cur_preset" #if $cur_preset == $sickbeard.CPU_PRESET then 'selected="selected"' else ''#>$cur_preset.capitalize()</option>
|
<option value="$cur_preset" #if $cur_preset == $sickbeard.CPU_PRESET then 'selected="selected"' else ''#>$cur_preset.capitalize()</option>
|
||||||
#end for
|
#end for
|
||||||
</select>
|
</select>
|
||||||
<span>Normal (default). High is lower and Low is higher CPU use</span>
|
<span>Normal (default). High is lower and Low is higher CPU use</span>
|
||||||
</span>
|
</span>
|
||||||
|
|
|
@ -1,85 +1,126 @@
|
||||||
$(document).ready(function(){
|
$(document).ready(function(){
|
||||||
$('.enabler').each(function(){
|
var enabler = $('.enabler'),
|
||||||
if (!$(this).prop('checked'))
|
viewIf = $('.viewIf');
|
||||||
$('#content_' + $(this).attr('id')).hide();
|
|
||||||
});
|
|
||||||
|
|
||||||
$('.enabler').click(function(){
|
enabler.each(function(){
|
||||||
if ($(this).prop('checked'))
|
if (!$(this).prop('checked'))
|
||||||
$('#content_' + $(this).attr('id')).fadeIn('fast', 'linear');
|
$('#content_' + $(this).attr('id')).hide();
|
||||||
else
|
});
|
||||||
$('#content_' + $(this).attr('id')).fadeOut('fast', 'linear');
|
|
||||||
});
|
|
||||||
|
|
||||||
$('.viewIf').click(function(){
|
enabler.click(function(){
|
||||||
if ($(this).prop('checked')) {
|
var content_id = $('#content_' + $(this).attr('id'));
|
||||||
$('.hide_if_' + $(this).attr('id')).css('display','none');
|
if ($(this).prop('checked'))
|
||||||
$('.show_if_' + $(this).attr('id')).fadeIn('fast', 'linear');
|
content_id.fadeIn('fast', 'linear');
|
||||||
} else {
|
else
|
||||||
$('.show_if_' + $(this).attr('id')).css('display','none');
|
content_id.fadeOut('fast', 'linear');
|
||||||
$('.hide_if_' + $(this).attr('id')).fadeIn('fast', 'linear');
|
});
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$('.datePresets').click(function(){
|
viewIf.each(function(){
|
||||||
var def = $('#date_presets').val()
|
$(($(this).prop('checked') ? '.hide_if_' : '.show_if_') + $(this).attr('id')).hide();
|
||||||
if ($(this).prop('checked') && '%x' == def) {
|
});
|
||||||
def = '%a, %b %d, %Y'
|
|
||||||
$('#date_use_system_default').html('1')
|
|
||||||
} else if (!$(this).prop('checked') && '1' == $('#date_use_system_default').html())
|
|
||||||
def = '%x'
|
|
||||||
|
|
||||||
$('#date_presets').attr('name', 'date_preset_old')
|
viewIf.click(function(){
|
||||||
$('#date_presets').attr('id', 'date_presets_old')
|
var if_id = '_if_' + $(this).attr('id');
|
||||||
|
if ($(this).prop('checked')) {
|
||||||
|
$('.hide' + if_id).fadeOut('fast', 'linear');
|
||||||
|
$('.show' + if_id).fadeIn('fast', 'linear');
|
||||||
|
} else {
|
||||||
|
$('.show' + if_id).fadeOut('fast', 'linear');
|
||||||
|
$('.hide' + if_id).fadeIn('fast', 'linear');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
$('#date_presets_na').attr('name', 'date_preset')
|
var ui_update_trim_zero = (function() {
|
||||||
$('#date_presets_na').attr('id', 'date_presets')
|
var secs = ('00' + new Date().getSeconds().toString()).slice(-2),
|
||||||
|
elSecs = $('#trim_info_seconds'),
|
||||||
|
elTrimZero = $('#trim_zero');
|
||||||
|
elTrimZero.each(function() {
|
||||||
|
var checked = $(this).prop('checked') && $('#fuzzy_dating').prop('checked');
|
||||||
|
|
||||||
$('#date_presets_old').attr('name', 'date_preset_na')
|
$('#time_presets').find('option').each(function() {
|
||||||
$('#date_presets_old').attr('id', 'date_presets_na')
|
var text = ($(this).text());
|
||||||
|
$(this).text(checked
|
||||||
|
? text.replace(/(\b\d+:\d\d):\d+/mg, '$1')
|
||||||
|
: text.replace(/(\b\d+:\d\d)(?:.\d+)?/mg, '$1:' + secs));
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
if (def)
|
if ($('#fuzzy_dating').prop('checked'))
|
||||||
$('#date_presets').val(def)
|
if (elTrimZero.prop('checked'))
|
||||||
});
|
elSecs.fadeOut('fast', 'linear');
|
||||||
|
else
|
||||||
|
elSecs.fadeIn('fast', 'linear');
|
||||||
|
else
|
||||||
|
elSecs.fadeIn('fast', 'linear');
|
||||||
|
});
|
||||||
|
|
||||||
// bind 'myForm' and provide a simple callback function
|
$('#trim_zero, #fuzzy_dating').click(function() {
|
||||||
$('#configForm').ajaxForm({
|
ui_update_trim_zero();
|
||||||
beforeSubmit: function(){
|
});
|
||||||
$('.config_submitter').each(function(){
|
|
||||||
$(this).attr('disabled', 'disabled');
|
|
||||||
$(this).after('<span><img src="' + sbRoot + '/images/loading16' + themeSpinner + '.gif"> Saving...</span>');
|
|
||||||
$(this).hide();
|
|
||||||
});
|
|
||||||
},
|
|
||||||
success: function(){
|
|
||||||
setTimeout('config_success()', 2000)
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#api_key').click(function(){ $('#api_key').select() });
|
ui_update_trim_zero();
|
||||||
$("#generate_new_apikey").click(function(){
|
|
||||||
$.get(sbRoot + '/config/general/generateKey',
|
|
||||||
function(data){
|
|
||||||
if (data.error != undefined) {
|
|
||||||
alert(data.error);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$('#api_key').val(data);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#branchCheckout').click(function(){
|
$('.datePresets').click(function(){
|
||||||
url = sbRoot + '/home/branchCheckout?branch=' + $('#branchVersion').val();
|
var elDatePresets = $('#date_presets'),
|
||||||
window.location.href = url;
|
defaultPreset = elDatePresets.val();
|
||||||
});
|
if ($(this).prop('checked') && '%x' == defaultPreset) {
|
||||||
|
defaultPreset = '%a, %b %d, %Y';
|
||||||
|
$('#date_use_system_default').html('1')
|
||||||
|
} else if (!$(this).prop('checked') && '1' == $('#date_use_system_default').html())
|
||||||
|
defaultPreset = '%x';
|
||||||
|
|
||||||
|
elDatePresets.attr('name', 'date_preset_old');
|
||||||
|
elDatePresets.attr('id', 'date_presets_old');
|
||||||
|
|
||||||
|
var elDatePresets_na = $('#date_presets_na');
|
||||||
|
elDatePresets_na.attr('name', 'date_preset');
|
||||||
|
elDatePresets_na.attr('id', 'date_presets');
|
||||||
|
|
||||||
|
var elDatePresets_old = $('#date_presets_old');
|
||||||
|
elDatePresets_old.attr('name', 'date_preset_na');
|
||||||
|
elDatePresets_old.attr('id', 'date_presets_na');
|
||||||
|
|
||||||
|
if (defaultPreset)
|
||||||
|
elDatePresets.val(defaultPreset)
|
||||||
|
});
|
||||||
|
|
||||||
|
// bind 'myForm' and provide a simple callback function
|
||||||
|
$('#configForm').ajaxForm({
|
||||||
|
beforeSubmit: function(){
|
||||||
|
$('.config_submitter').each(function(){
|
||||||
|
$(this).attr('disabled', 'disabled');
|
||||||
|
$(this).after('<span><img src="' + sbRoot + '/images/loading16' + themeSpinner + '.gif"> Saving...</span>');
|
||||||
|
$(this).hide();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
success: function(){
|
||||||
|
setTimeout('config_success()', 2000)
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#api_key').click(function(){ $('#api_key').select() });
|
||||||
|
$("#generate_new_apikey").click(function(){
|
||||||
|
$.get(sbRoot + '/config/general/generateKey',
|
||||||
|
function(data){
|
||||||
|
if (data.error != undefined) {
|
||||||
|
alert(data.error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
$('#api_key').val(data);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#branchCheckout').click(function(){
|
||||||
|
window.location.href = sbRoot + '/home/branchCheckout?branch=' + $('#branchVersion').val();
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
function config_success(){
|
function config_success(){
|
||||||
$('.config_submitter').each(function(){
|
$('.config_submitter').each(function(){
|
||||||
$(this).removeAttr('disabled');
|
$(this).removeAttr('disabled');
|
||||||
$(this).next().remove();
|
$(this).next().remove();
|
||||||
$(this).show();
|
$(this).show();
|
||||||
});
|
});
|
||||||
$('#email_show').trigger('notify');
|
$('#email_show').trigger('notify');
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,152 +11,170 @@
|
||||||
*/
|
*/
|
||||||
function fuzzyMoment(fmConfig) {
|
function fuzzyMoment(fmConfig) {
|
||||||
|
|
||||||
var containerClass = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.containerClass)) ? '.fuzzydate' : fmConfig.containerClass),
|
var containerClass = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.containerClass)) ? '.fuzzydate' : fmConfig.containerClass),
|
||||||
dateWithTime = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dateHasTime)) ? false : !!fmConfig.dateHasTime),
|
dateWithTime = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dateHasTime)) ? false : !!fmConfig.dateHasTime),
|
||||||
dateFormat = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dateFormat)) ? '' : fmConfig.dateFormat),
|
dateFormat = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dateFormat)) ? '' : fmConfig.dateFormat),
|
||||||
timeFormat = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.timeFormat)) ? '' : fmConfig.timeFormat),
|
timeFormat = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.timeFormat)) ? '' : fmConfig.timeFormat),
|
||||||
trimZero = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.trimZero)) ? false : !!fmConfig.trimZero),
|
trimZero = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.trimZero)) ? false : !!fmConfig.trimZero),
|
||||||
dtGlue = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dtGlue)) ? '<br />' : fmConfig.dtGlue),
|
dtGlue = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dtGlue)) ? '<br />' : fmConfig.dtGlue),
|
||||||
dtInline = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dtInline)) ? false : fmConfig.dtInline),
|
dtInline = (/undefined/i.test(typeof(fmConfig)) || /undefined/i.test(typeof(fmConfig.dtInline)) ? false : fmConfig.dtInline),
|
||||||
|
|
||||||
jd = (function (str) {
|
jd = (function (str) {
|
||||||
var token_map = ['a', 'ddd', 'A', 'dddd', 'b', 'MMM', 'B', 'MMMM', 'd', 'DD', 'm', 'MM', 'y', 'YY', 'Y', 'YYYY', 'x', 'L',
|
var token_map = ['a', 'ddd', 'A', 'dddd', 'b', 'MMM', 'B', 'MMMM', 'd', 'DD', 'm', 'MM', 'y', 'YY', 'Y', 'YYYY', 'x', 'L',
|
||||||
'H', 'HH', 'I', 'hh', 'M', 'mm', 'S', 'ss', 'p', 'A'],
|
'H', 'HH', 'I', 'hh', 'M', 'mm', 'S', 'ss', 'p', 'A', 'P', 'a'],
|
||||||
result = '';
|
result = '';
|
||||||
|
|
||||||
for (var i = 0; i < str.length; i++)
|
for (var i = 0; i < str.length; i++)
|
||||||
if (/[aAbBdmyYxHIMSp]/.test(str[i])) {
|
if (/[aAbBdmyYxHIMSpP]/.test(str[i])) {
|
||||||
for (var t = 0; t < token_map.length; t = t + 2)
|
for (var t = 0; t < token_map.length; t = t + 2)
|
||||||
if (str[i] == token_map[t]) {
|
if (str[i] == token_map[t]) {
|
||||||
result += token_map[t + 1];
|
result += token_map[t + 1];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if ('%' != str[i])
|
} else if ('%' != str[i])
|
||||||
result += str[i];
|
result += str[i];
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}),
|
}),
|
||||||
dateToken = jd(dateFormat),
|
dateTemplate = jd(dateFormat),
|
||||||
timeToken = jd(timeFormat),
|
timeTemplate = jd(timeFormat),
|
||||||
|
|
||||||
addQTip = (function() {
|
addQTip = (function() {
|
||||||
$(this).css('cursor', 'help');
|
$(this).css('cursor', 'help');
|
||||||
$(this).qtip({
|
$(this).qtip({
|
||||||
show: {
|
show: {
|
||||||
solo: true
|
solo: true
|
||||||
},
|
},
|
||||||
position: {
|
position: {
|
||||||
viewport: $(window),
|
viewport: $(window),
|
||||||
my: 'left center',
|
my: 'left center',
|
||||||
adjust: {
|
adjust: {
|
||||||
y: -10,
|
y: -10,
|
||||||
x: 2
|
x: 2
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
style: {
|
style: {
|
||||||
classes: 'qtip-dark qtip-rounded qtip-shadow'
|
classes: 'qtip-dark qtip-rounded qtip-shadow'
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
if (trimZero) {
|
if (trimZero) {
|
||||||
timeToken = timeToken.replace(/hh/ig, 'h');
|
timeTemplate = timeTemplate.replace(/hh/g, 'h');
|
||||||
dateToken = dateToken.replace(/\bDD\b/g, 'D');
|
timeTemplate = timeTemplate.replace(/HH/g, 'H');
|
||||||
}
|
dateTemplate = dateTemplate.replace(/\bDD\b/g, 'D');
|
||||||
|
}
|
||||||
|
|
||||||
$(containerClass).each(function() {
|
$(containerClass).each(function() {
|
||||||
var input = $(this).text(),
|
var input = $(this).text(),
|
||||||
dateA = '[<span class="fd">',
|
dateA = '[<span class="fd">',
|
||||||
dtSeparator = ' ',
|
dtSeparator = ' ',
|
||||||
timeA = '</span>]', timeB = '[' + timeA;
|
timeA = '</span>]', timeB = '[' + timeA,
|
||||||
|
timeToken = timeTemplate;
|
||||||
|
|
||||||
if (dateWithTime) {
|
if (dateWithTime) {
|
||||||
var timeMeta = input.match(/^.{6,}?([,\s]+)(\d{1,2}).(?:\d{2,2})(?:.(\d{2,2}))?(?:\s([ap]m))?$/im);
|
var timeMeta = input.match(/([,\s]+)(\d{1,2})(?:(.)(\d\d)(?:(.)(\d\d))?)?(?:\s?([ap]m))?$/im);
|
||||||
if (null != timeMeta) {
|
if (null != timeMeta) {
|
||||||
dtSeparator = (! /undefined/i.test(typeof(timeMeta[1])) ? timeMeta[1] : dtSeparator);
|
dtSeparator = (! /undefined/i.test(typeof(timeMeta[1])) ? timeMeta[1] : dtSeparator);
|
||||||
// adjust timeToken to num digits of input hours
|
// adjust timeToken to num digits of input hours
|
||||||
timeToken = (! /undefined/i.test(typeof(timeMeta[2])) && 1 == timeMeta[2].length ? timeToken.replace(/hh/ig, 'h') : timeToken);
|
timeToken = (! /undefined/i.test(typeof(timeMeta[2])) && 1 == timeMeta[2].length ? timeToken.replace(/hh/ig, 'h') : timeToken);
|
||||||
// adjust timeToken to use seconds if input has them
|
// adjust timeToken to remove min if input has one and there is a pm
|
||||||
timeToken = (! /undefined/i.test(typeof(timeMeta[3])) && 2 == timeMeta[3].length ? timeToken : timeToken.replace(/.ss/, ''));
|
timeToken = (trimZero && ! /undefined/i.test(typeof(timeMeta[7]))
|
||||||
// adjust timeToken to am/pm or AM/PM if input has it
|
&& (/undefined/i.test(typeof(timeMeta[4]))
|
||||||
timeToken = (! /undefined/i.test(typeof(timeMeta[4])) && 2 == timeMeta[4].length ? timeToken.replace(/A$/, (/[ap]m/.test(timeMeta[4]) ? 'a' : 'A')) : timeToken);
|
|| '00' == timeMeta[4]) ? timeToken.replace(/.mm/ig, '') : timeToken);
|
||||||
}
|
// adjust timeToken to use seconds if input has them
|
||||||
timeA = '</span>' + dtGlue + '<span class="ft">]' + timeToken + '[' + timeA;
|
timeToken = (! /undefined/i.test(typeof(timeMeta[5])) && 2 == timeMeta[5].length ? timeToken : timeToken.replace(/.ss/, ''));
|
||||||
timeB = '[</span>' + dtGlue + '<span class="ft">]' + timeToken + timeB;
|
// adjust timeToken to am/pm or AM/PM if input has it
|
||||||
}
|
timeToken = (! /undefined/i.test(typeof(timeMeta[7])) && 2 == timeMeta[7].length ? timeToken.replace(/A$/, (/[ap]m/.test(timeMeta[7]) ? 'a' : 'A')) : timeToken);
|
||||||
|
}
|
||||||
|
|
||||||
var inputTokens = dateToken + dtSeparator + (dateWithTime ? timeToken : 'HH:mm:ss');
|
var token_build = (/h+/i.test(timeToken) ? timeToken.replace(/^(h+).*/i, '[<span class="time-hr">]$1[</span>]') : '');
|
||||||
|
if (/m+/i.test(timeToken)) {
|
||||||
|
token_build += (! /undefined/i.test(typeof(timeMeta[3])) ? '[<span class="time-hr-min">]' + timeMeta[3] + '[</span>]' : '')
|
||||||
|
+ (! /undefined/i.test(typeof(timeMeta[4])) ? timeToken.replace(/.*?(m+).*/i, '[<span class="time-min">]$1[</span>]') : '');
|
||||||
|
if (/s+/i.test(timeToken)) {
|
||||||
|
token_build += (! /undefined/i.test(typeof(timeMeta[5])) ? '[<span class="time-min-sec">]' + timeMeta[5] + '[</span>]' : '')
|
||||||
|
+ (! /undefined/i.test(typeof(timeMeta[6])) ? timeToken.replace(/.*?(s+).*/i, '[<span class="time-sec">]$1[</span>]') : '');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
timeToken = token_build + (! /undefined/i.test(typeof(timeMeta[7])) ? timeToken.replace(/.*?[\s0-9](a).*/i, '[<span class="time-am-pm">]$1[</span>]') : '');
|
||||||
|
|
||||||
if (! moment(input + (dateWithTime ? '' : dtSeparator + '00:00:00'), inputTokens).isValid())
|
timeA = '</span>' + dtGlue + '<span class="ft">]' + timeToken + '[' + timeA;
|
||||||
return;
|
timeB = '[</span>' + dtGlue + '<span class="ft">]' + timeToken + timeB;
|
||||||
|
}
|
||||||
|
|
||||||
moment.lang('en', {
|
var inputTokens = dateTemplate + dtSeparator + (dateWithTime ? timeToken : 'HH:mm:ss');
|
||||||
calendar: {
|
|
||||||
lastDay:dateA + 'Yesterday' + timeA, sameDay:dateA + 'Today' + timeA, nextDay:dateA + 'Tomorrow' + timeA,
|
|
||||||
lastWeek:dateA + 'last] ddd' + timeB, nextWeek:dateA + 'on] ddd' + timeB,
|
|
||||||
sameElse:dateA + ']ddd, MMM D YYYY[' + timeA
|
|
||||||
},
|
|
||||||
relativeTime: {
|
|
||||||
future:'in %s', past:'%s ago', s:'seconds', m:'a minute', mm:'%d minutes', h:'an hour', hh:'%d hours',
|
|
||||||
d:'a day', dd:'%d days', M:'a month', MM:'%d months', y:'a year', yy:'%d years'
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
var airdatetime = moment(input + (dateWithTime ? '' : dtSeparator + '00:00:00'), inputTokens),
|
if (! moment(input + (dateWithTime ? '' : dtSeparator + '00:00:00'), inputTokens).isValid())
|
||||||
airdate = airdatetime.clone().hour(0).minute(0).second(0).millisecond(0),
|
return;
|
||||||
today = moment({}),
|
|
||||||
day = Math.abs(airdate.diff(today, 'days')),
|
|
||||||
week = Math.abs(weekdiff = airdate.diff(today, 'week')), isPast = weekdiff < 0,
|
|
||||||
titleThis = false, qTipTime = false,
|
|
||||||
result = (0 == week ? airdatetime.calendar() : '');
|
|
||||||
|
|
||||||
if (/\bOn\b/i.test(result)) {
|
moment.lang('en', {
|
||||||
var fuzzer = false, weekday = today.day();
|
calendar: {
|
||||||
if (3 == weekday)
|
lastDay:dateA + 'Yesterday' + timeA, sameDay:dateA + 'Today' + timeA, nextDay:dateA + 'Tomorrow' + timeA,
|
||||||
fuzzer = (5 <= day);
|
lastWeek:dateA + 'last] ddd' + timeB, nextWeek:dateA + 'on] ddd' + timeB,
|
||||||
else if (4 == weekday || 5 == weekday)
|
sameElse:dateA + ']ddd, MMM D YYYY[' + timeA
|
||||||
fuzzer = (4 <= day);
|
},
|
||||||
else
|
relativeTime: {
|
||||||
fuzzer = (6 == day);
|
future:'in %s', past:'%s ago', s:'seconds', m:'a minute', mm:'%d minutes', h:'an hour', hh:'%d hours',
|
||||||
if (fuzzer)
|
d:'a day', dd:'%d days', M:'a month', MM:'%d months', y:'a year', yy:'%d years'
|
||||||
result = result.replace(/\bOn\b/i, 'Next');
|
}
|
||||||
|
});
|
||||||
|
|
||||||
} else if (! /\b((yester|to)day\b|tomo|last\b)/i.test(result)) {
|
var airdatetime = moment(input + (dateWithTime ? '' : dtSeparator + '00:00:00'), inputTokens),
|
||||||
if (14 > day)
|
airdate = airdatetime.clone().hour(0).minute(0).second(0).millisecond(0),
|
||||||
result = airdate.from(today) + (dateWithTime ? dtGlue + airdatetime.format(timeToken) : '');
|
today = moment({}),
|
||||||
else if (4 > week) {
|
day = Math.abs(airdate.diff(today, 'days')),
|
||||||
result = (isPast ? '' : 'in ') + (1 == week ? 'a' : week) + ' week' + (1 == week ? '' : 's') + (isPast ? ' ago' : '');
|
week = Math.abs(weekdiff = airdate.diff(today, 'week')), isPast = weekdiff < 0,
|
||||||
qTipTime = true;
|
titleThis = false, qTipTime = false,
|
||||||
} else {
|
result = (0 == week ? airdatetime.calendar() : '');
|
||||||
result = airdate.from(today);
|
|
||||||
qTipTime = true;
|
|
||||||
var month = airdate.diff(today, 'month');
|
|
||||||
if (1 == parseInt(airdate.year() - today.year()))
|
|
||||||
result += (dtInline ? ' ' : '<br />') + '(Next Year)';
|
|
||||||
}
|
|
||||||
titleThis = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
var n = false; // disable for prod
|
if (/\bOn\b/i.test(result)) {
|
||||||
$(this).html(result);
|
var fuzzer = false, weekday = today.day();
|
||||||
if (dateWithTime && /(yester|to)day/i.test(result))
|
if (3 == weekday)
|
||||||
$(this).find('.fd').attr('title',(n?'1) ':'') + moment.duration(airdatetime.diff(moment(),'seconds'),'seconds').humanize(true)).each(addQTip);
|
fuzzer = (5 <= day);
|
||||||
else if (dateWithTime)
|
else if (4 == weekday || 5 == weekday)
|
||||||
$(this).find('.fd').attr('title',(n?'2) ':'') + airdate.from(today)).each(addQTip);
|
fuzzer = (4 <= day);
|
||||||
else if (! /today/i.test(result))
|
else
|
||||||
$(this).find('.fd').attr('title',(n?'3) ':'') + airdate.from(today)).each(addQTip);
|
fuzzer = (6 == day);
|
||||||
else
|
if (fuzzer)
|
||||||
titleThis = false;
|
result = result.replace(/\bOn\b/i, 'Next');
|
||||||
|
|
||||||
if (titleThis)
|
} else if (! /\b((yester|to)day\b|tomo|last\b)/i.test(result)) {
|
||||||
if (dateWithTime && qTipTime)
|
if (14 > day)
|
||||||
$(this).attr('title',(n?'4) ':'') + airdatetime.format(inputTokens)).each(addQTip);
|
result = airdate.from(today) + (dateWithTime ? dtGlue + airdatetime.format(timeToken) : '');
|
||||||
else
|
else if (4 > week) {
|
||||||
$(this).attr('title',(n?'5) ':'') + airdate.format(dateToken)).each(addQTip);
|
result = (isPast ? '' : 'in ') + (1 == week ? 'a' : week) + ' week' + (1 == week ? '' : 's') + (isPast ? ' ago' : '');
|
||||||
else
|
qTipTime = true;
|
||||||
if (dateWithTime && qTipTime)
|
} else {
|
||||||
$(this).find('.ft').attr('title',(n?'6) ':'') + airdatetime.format(inputTokens)).each(addQTip);
|
result = airdate.from(today);
|
||||||
else
|
qTipTime = true;
|
||||||
$(this).find('.ft').attr('title',(n?'7) ':'') + airdate.format(dateToken)).each(addQTip);
|
var month = airdate.diff(today, 'month');
|
||||||
});
|
if (1 == parseInt(airdate.year() - today.year()))
|
||||||
|
result += (dtInline ? ' ' : '<br />') + '(Next Year)';
|
||||||
|
}
|
||||||
|
titleThis = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
var n = false; // disable for prod
|
||||||
|
$(this).html(result);
|
||||||
|
if (dateWithTime && /(yester|to)day/i.test(result))
|
||||||
|
$(this).find('.fd').attr('title',(n?'1) ':'') + moment.duration(airdatetime.diff(moment(),'seconds'),'seconds').humanize(true)).each(addQTip);
|
||||||
|
else if (dateWithTime)
|
||||||
|
$(this).find('.fd').attr('title',(n?'2) ':'') + airdate.from(today)).each(addQTip);
|
||||||
|
else if (! /today/i.test(result))
|
||||||
|
$(this).find('.fd').attr('title',(n?'3) ':'') + airdate.from(today)).each(addQTip);
|
||||||
|
else
|
||||||
|
titleThis = false;
|
||||||
|
|
||||||
|
if (titleThis)
|
||||||
|
if (dateWithTime && qTipTime)
|
||||||
|
$(this).attr('title',(n?'4) ':'') + airdatetime.format(inputTokens)).each(addQTip);
|
||||||
|
else
|
||||||
|
$(this).attr('title',(n?'5) ':'') + airdate.format(dateTemplate)).each(addQTip);
|
||||||
|
else
|
||||||
|
if (dateWithTime && qTipTime)
|
||||||
|
$(this).find('.ft').attr('title',(n?'6) ':'') + airdatetime.format(inputTokens)).each(addQTip);
|
||||||
|
else
|
||||||
|
$(this).find('.ft').attr('title',(n?'7) ':'') + airdate.format(dateTemplate)).each(addQTip);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
import datetime
|
import datetime
|
||||||
import locale
|
import locale
|
||||||
import functools
|
import functools
|
||||||
|
import re
|
||||||
|
|
||||||
import sickbeard
|
import sickbeard
|
||||||
from sickbeard.network_timezones import sb_timezone
|
from sickbeard.network_timezones import sb_timezone
|
||||||
|
@ -82,12 +83,12 @@ date_presets = ('%Y-%m-%d',
|
||||||
'%A, %b %d, %Y',
|
'%A, %b %d, %Y',
|
||||||
'%B %d, %Y',
|
'%B %d, %Y',
|
||||||
'%a, %B %d, %Y',
|
'%a, %B %d, %Y',
|
||||||
'%A, %B %d, %Y'
|
'%A, %B %d, %Y')
|
||||||
)
|
|
||||||
|
|
||||||
time_presets = ('%I:%M:%S %p',
|
time_presets = ('%I:%M:%S %p',
|
||||||
'%H:%M:%S'
|
'%I:%M:%S %P',
|
||||||
)
|
'%H:%M:%S')
|
||||||
|
|
||||||
|
|
||||||
# helper class
|
# helper class
|
||||||
class static_or_instance(object):
|
class static_or_instance(object):
|
||||||
|
@ -104,142 +105,98 @@ class sbdatetime(datetime.datetime):
|
||||||
|
|
||||||
@static_or_instance
|
@static_or_instance
|
||||||
def convert_to_setting(self, dt=None):
|
def convert_to_setting(self, dt=None):
|
||||||
|
obj = (dt, self)[self is not None]
|
||||||
try:
|
try:
|
||||||
if sickbeard.TIMEZONE_DISPLAY == 'local':
|
if 'local' == sickbeard.TIMEZONE_DISPLAY:
|
||||||
if self is None:
|
return obj.astimezone(sb_timezone)
|
||||||
return dt.astimezone(sb_timezone)
|
|
||||||
else:
|
|
||||||
return self.astimezone(sb_timezone)
|
|
||||||
else:
|
|
||||||
if self is None:
|
|
||||||
return dt
|
|
||||||
else:
|
|
||||||
return self
|
|
||||||
except:
|
except:
|
||||||
if self is None:
|
pass
|
||||||
return dt
|
|
||||||
else:
|
return obj
|
||||||
return self
|
|
||||||
|
@static_or_instance
|
||||||
|
def setlocale(self, setlocale=True, use_has_locale=None, locale_str=''):
|
||||||
|
if setlocale:
|
||||||
|
try:
|
||||||
|
if None is use_has_locale or use_has_locale:
|
||||||
|
locale.setlocale(locale.LC_TIME, locale_str)
|
||||||
|
except:
|
||||||
|
if None is not use_has_locale:
|
||||||
|
sbdatetime.has_locale = False
|
||||||
|
pass
|
||||||
|
|
||||||
# display Time in SickGear Format
|
# display Time in SickGear Format
|
||||||
@static_or_instance
|
@static_or_instance
|
||||||
def sbftime(self, dt=None, show_seconds=False, t_preset=None):
|
def sbftime(self, dt=None, show_seconds=False, t_preset=None, setlocale=True, markup=False):
|
||||||
|
|
||||||
try:locale.setlocale(locale.LC_TIME, '')
|
sbdatetime.setlocale(setlocale=setlocale, use_has_locale=sbdatetime.has_locale, locale_str='us_US')
|
||||||
except:pass
|
|
||||||
|
|
||||||
try:
|
|
||||||
if sbdatetime.has_locale:
|
|
||||||
locale.setlocale(locale.LC_TIME, 'us_US')
|
|
||||||
except:
|
|
||||||
sbdatetime.has_locale = False
|
|
||||||
|
|
||||||
strt = ''
|
strt = ''
|
||||||
try:
|
try:
|
||||||
if self is None:
|
obj = (dt, self)[self is not None]
|
||||||
if dt is not None:
|
if None is not obj:
|
||||||
if t_preset is not None:
|
tmpl = (((sickbeard.TIME_PRESET, sickbeard.TIME_PRESET_W_SECONDS)[show_seconds]),
|
||||||
strt = dt.strftime(t_preset)
|
t_preset)[None is not t_preset]
|
||||||
elif show_seconds:
|
tmpl = (tmpl.replace(':%S', ''), tmpl)[show_seconds]
|
||||||
strt = dt.strftime(sickbeard.TIME_PRESET_W_SECONDS)
|
|
||||||
else:
|
|
||||||
strt = dt.strftime(sickbeard.TIME_PRESET)
|
|
||||||
else:
|
|
||||||
if t_preset is not None:
|
|
||||||
strt = self.strftime(t_preset)
|
|
||||||
elif show_seconds:
|
|
||||||
strt = self.strftime(sickbeard.TIME_PRESET_W_SECONDS)
|
|
||||||
else:
|
|
||||||
strt = self.strftime(sickbeard.TIME_PRESET)
|
|
||||||
finally:
|
|
||||||
try:
|
|
||||||
if sbdatetime.has_locale:
|
|
||||||
locale.setlocale(locale.LC_TIME, '')
|
|
||||||
except:
|
|
||||||
sbdatetime.has_locale = False
|
|
||||||
|
|
||||||
|
strt = obj.strftime(tmpl.replace('%P', '%p'))
|
||||||
|
|
||||||
|
if sickbeard.TRIM_ZERO:
|
||||||
|
strt = re.sub(r'^0(\d:\d\d)', r'\1', strt)
|
||||||
|
|
||||||
|
if re.search(r'(?im)%p$', tmpl):
|
||||||
|
if '%p' in tmpl:
|
||||||
|
strt = strt.upper()
|
||||||
|
elif '%P' in tmpl:
|
||||||
|
strt = strt.lower()
|
||||||
|
|
||||||
|
if sickbeard.TRIM_ZERO:
|
||||||
|
strt = re.sub(r'(?im)^(\d+)(?::00)?(\s?[ap]m)', r'\1\2', strt)
|
||||||
|
|
||||||
|
if markup:
|
||||||
|
match = re.search(r'(?im)(\d{1,2})(?:(.)(\d\d)(?:(.)(\d\d))?)?(?:\s?([ap]m))?$', strt)
|
||||||
|
if match:
|
||||||
|
strt = ('%s%s%s%s%s%s' % (
|
||||||
|
('<span class="time-hr">%s</span>' % match.group(1), '')[None is match.group(1)],
|
||||||
|
('<span class="time-hr-min">%s</span>' % match.group(2), '')[None is match.group(2)],
|
||||||
|
('<span class="time-min">%s</span>' % match.group(3), '')[None is match.group(3)],
|
||||||
|
('<span class="time-min-sec">%s</span>' % match.group(4), '')[None is match.group(4)],
|
||||||
|
('<span class="time-sec">%s</span>' % match.group(5), '')[None is match.group(5)],
|
||||||
|
('<span class="time-am-pm">%s</span>' % match.group(6), '')[None is match.group(6)]))
|
||||||
|
|
||||||
|
finally:
|
||||||
|
sbdatetime.setlocale(setlocale=setlocale, use_has_locale=sbdatetime.has_locale)
|
||||||
return strt
|
return strt
|
||||||
|
|
||||||
# display Date in SickGear Format
|
# display Date in SickGear Format
|
||||||
@static_or_instance
|
@static_or_instance
|
||||||
def sbfdate(self, dt=None, d_preset=None):
|
def sbfdate(self, dt=None, d_preset=None, setlocale=True):
|
||||||
|
|
||||||
try:
|
sbdatetime.setlocale(setlocale=setlocale)
|
||||||
locale.setlocale(locale.LC_TIME, '')
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
strd = ''
|
strd = ''
|
||||||
try:
|
try:
|
||||||
if self is None:
|
obj = (dt, self)[self is not None]
|
||||||
if dt is not None:
|
if None is not obj:
|
||||||
if d_preset is not None:
|
strd = obj.strftime((sickbeard.DATE_PRESET, d_preset)[None is not d_preset])
|
||||||
strd = dt.strftime(d_preset)
|
|
||||||
else:
|
|
||||||
strd = dt.strftime(sickbeard.DATE_PRESET)
|
|
||||||
else:
|
|
||||||
if d_preset is not None:
|
|
||||||
strd = self.strftime(d_preset)
|
|
||||||
else:
|
|
||||||
strd = self.strftime(sickbeard.DATE_PRESET)
|
|
||||||
finally:
|
finally:
|
||||||
|
sbdatetime.setlocale(setlocale=setlocale)
|
||||||
try:
|
|
||||||
locale.setlocale(locale.LC_TIME, '')
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
return strd
|
return strd
|
||||||
|
|
||||||
# display Datetime in SickGear Format
|
# display Datetime in SickGear Format
|
||||||
@static_or_instance
|
@static_or_instance
|
||||||
def sbfdatetime(self, dt=None, show_seconds=False, d_preset=None, t_preset=None):
|
def sbfdatetime(self, dt=None, show_seconds=False, d_preset=None, t_preset=None, markup=False):
|
||||||
|
|
||||||
try:
|
sbdatetime.setlocale()
|
||||||
locale.setlocale(locale.LC_TIME, '')
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
strd = ''
|
strd = ''
|
||||||
|
obj = (dt, self)[self is not None]
|
||||||
try:
|
try:
|
||||||
if self is None:
|
if None is not obj:
|
||||||
if dt is not None:
|
strd = u'%s, %s' % (obj.strftime((sickbeard.DATE_PRESET, d_preset)[None is not d_preset]),
|
||||||
if d_preset is not None:
|
sbdatetime.sbftime(dt, show_seconds, t_preset, False, markup))
|
||||||
strd = dt.strftime(d_preset)
|
|
||||||
else:
|
|
||||||
strd = dt.strftime(sickbeard.DATE_PRESET)
|
|
||||||
try:
|
|
||||||
if sbdatetime.has_locale:
|
|
||||||
locale.setlocale(locale.LC_TIME, 'us_US')
|
|
||||||
except:
|
|
||||||
sbdatetime.has_locale = False
|
|
||||||
if t_preset is not None:
|
|
||||||
strd += u', ' + dt.strftime(t_preset)
|
|
||||||
elif show_seconds:
|
|
||||||
strd += u', ' + dt.strftime(sickbeard.TIME_PRESET_W_SECONDS)
|
|
||||||
else:
|
|
||||||
strd += u', ' + dt.strftime(sickbeard.TIME_PRESET)
|
|
||||||
else:
|
|
||||||
if d_preset is not None:
|
|
||||||
strd = self.strftime(d_preset)
|
|
||||||
else:
|
|
||||||
strd = self.strftime(sickbeard.DATE_PRESET)
|
|
||||||
try:
|
|
||||||
if sbdatetime.has_locale:
|
|
||||||
locale.setlocale(locale.LC_TIME, 'us_US')
|
|
||||||
except:
|
|
||||||
sbdatetime.has_locale = False
|
|
||||||
if t_preset is not None:
|
|
||||||
strd += u', ' + self.strftime(t_preset)
|
|
||||||
elif show_seconds:
|
|
||||||
strd += u', ' + self.strftime(sickbeard.TIME_PRESET_W_SECONDS)
|
|
||||||
else:
|
|
||||||
strd += u', ' + self.strftime(sickbeard.TIME_PRESET)
|
|
||||||
finally:
|
|
||||||
try:
|
|
||||||
if sbdatetime.has_locale:
|
|
||||||
locale.setlocale(locale.LC_TIME, '')
|
|
||||||
except:
|
|
||||||
sbdatetime.has_locale = False
|
|
||||||
|
|
||||||
|
finally:
|
||||||
|
sbdatetime.setlocale(use_has_locale=sbdatetime.has_locale)
|
||||||
return strd
|
return strd
|
||||||
|
|
Loading…
Reference in a new issue