mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-07 10:33:38 +00:00
Change fuzzyMoment to handle air dates before ~1970 on display show page.
Change ensure sbdatetime functions return formatted string instead of tuple. Change limit availability of fuzzy date functions on General Config/Interface to English locale systems. Update moment.js 2.6 to 2.15.1
This commit is contained in:
parent
c789c8a14c
commit
05956804df
6 changed files with 541 additions and 50 deletions
|
@ -16,6 +16,7 @@
|
||||||
* Update Hachoir library 1.3.4 (r1383) to 1.3.4 (r1435)
|
* Update Hachoir library 1.3.4 (r1383) to 1.3.4 (r1435)
|
||||||
* Update html5lib 0.999 to 0.99999999/1.0b9 (46dae3d)
|
* Update html5lib 0.999 to 0.99999999/1.0b9 (46dae3d)
|
||||||
* Update IMDb 5.0 to 5.1dev20160106
|
* Update IMDb 5.0 to 5.1dev20160106
|
||||||
|
* Update moment.js 2.6 to 2.15.1
|
||||||
* Update PNotify library 2.0.1 to 2.1.0
|
* Update PNotify library 2.0.1 to 2.1.0
|
||||||
* Update profilehooks 1.4 to 1.8.2.dev0 (ee3f1a8)
|
* Update profilehooks 1.4 to 1.8.2.dev0 (ee3f1a8)
|
||||||
* Update Requests library 2.7.0 (5d6d1bc) to 2.9.1 (a1c9b84)
|
* Update Requests library 2.7.0 (5d6d1bc) to 2.9.1 (a1c9b84)
|
||||||
|
@ -181,6 +182,8 @@
|
||||||
* Change hachoir_parser to close input stream if no parser is found e.g. due to file corruption
|
* Change hachoir_parser to close input stream if no parser is found e.g. due to file corruption
|
||||||
* Change reduce time taken to parse avi RIFF metadata during post processing and other times
|
* Change reduce time taken to parse avi RIFF metadata during post processing and other times
|
||||||
* Change avi metadata extraction is more fault tolerant and the chance of hanging due to corrupt avi files is reduced
|
* Change avi metadata extraction is more fault tolerant and the chance of hanging due to corrupt avi files is reduced
|
||||||
|
* Change fuzzyMoment to handle air dates before ~1970 on display show page
|
||||||
|
* Change limit availability of fuzzy date functions on General Config/Interface to English locale systems
|
||||||
|
|
||||||
[develop changelog]
|
[develop changelog]
|
||||||
* Change send nzb data to NZBGet for Anizb instead of url
|
* Change send nzb data to NZBGet for Anizb instead of url
|
||||||
|
@ -205,6 +208,7 @@
|
||||||
* Change add helper function to validate acceptable image file extension
|
* Change add helper function to validate acceptable image file extension
|
||||||
* Change make sure avi files are closed if an error occurs
|
* Change make sure avi files are closed if an error occurs
|
||||||
* Change refactor hachoir scan_index for non RIFF file processing
|
* Change refactor hachoir scan_index for non RIFF file processing
|
||||||
|
* Change ensure sbdatetime functions return formatted string instead of tuple
|
||||||
|
|
||||||
|
|
||||||
### 0.11.16 (2016-10-16 17:30:00 UTC)
|
### 0.11.16 (2016-10-16 17:30:00 UTC)
|
||||||
|
|
|
@ -332,6 +332,10 @@
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
#if not $sbdatetime.is_locale_eng()
|
||||||
|
<input type="hidden" name="fuzzy_dating" id="fuzzy_dating" value="false">
|
||||||
|
<input type="hidden" name="trim_zero" id="trim_zero" value="false">
|
||||||
|
#else
|
||||||
<div class="field-pair">
|
<div class="field-pair">
|
||||||
<label for="fuzzy_dating">
|
<label for="fuzzy_dating">
|
||||||
<span class="component-title">Display fuzzy dates</span>
|
<span class="component-title">Display fuzzy dates</span>
|
||||||
|
@ -350,7 +354,7 @@
|
||||||
</span>
|
</span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
#end if
|
||||||
<div class="field-pair">
|
<div class="field-pair">
|
||||||
<label for="date_presets">
|
<label for="date_presets">
|
||||||
<span class="component-title">Date style:</span>
|
<span class="component-title">Date style:</span>
|
||||||
|
|
|
@ -548,7 +548,7 @@
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
<td class="col-airdate">
|
<td class="col-airdate">
|
||||||
<span class="${fuzzydate}">#if 1 == int($epResult['airdate']) then 'never' else $sbdatetime.sbdatetime.sbfdate($sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($epResult['airdate'], $network_time, $network_timezone)))#</span>
|
<span class="${fuzzydate}"#if $sickbeard.FUZZY_DATING# data-fulldate="$sbdatetime.sbdatetime.sbfdate(dt=$datetime.date.fromordinal($epResult['airdate']), d_preset='%A, %B %d, %Y')"#end if#>#if 1 == int($epResult['airdate']) then 'never' else $sbdatetime.sbdatetime.sbfdate($sbdatetime.sbdatetime.convert_to_setting($network_timezones.parse_date_time($epResult['airdate'], $network_time, $network_timezone)))#</span>
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
#if $sickbeard.USE_SUBTITLES and $show.subtitles
|
#if $sickbeard.USE_SUBTITLES and $show.subtitles
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
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 = ['d', 'DD', 'a', 'ddd', 'A', 'dddd', 'b', 'MMM', 'B', 'MMMM', 'm', 'MM', 'y', 'YY', 'Y', 'YYYY', 'x', 'L',
|
||||||
'H', 'HH', 'I', 'hh', 'M', 'mm', 'S', 'ss', 'p', 'A', 'P', 'a'],
|
'H', 'HH', 'I', 'hh', 'M', 'mm', 'S', 'ss', 'p', 'A', 'P', 'a'],
|
||||||
result = '';
|
result = '';
|
||||||
|
|
||||||
|
@ -36,8 +36,6 @@
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}),
|
}),
|
||||||
dateTemplate = jd(dateFormat),
|
|
||||||
timeTemplate = jd(timeFormat),
|
|
||||||
|
|
||||||
addQTip = (function() {
|
addQTip = (function() {
|
||||||
$(this).css('cursor', 'help');
|
$(this).css('cursor', 'help');
|
||||||
|
@ -48,10 +46,7 @@
|
||||||
position: {
|
position: {
|
||||||
viewport: $(window),
|
viewport: $(window),
|
||||||
my: 'left center',
|
my: 'left center',
|
||||||
adjust: {
|
adjust: { y: -10, x: 2 }
|
||||||
y: -10,
|
|
||||||
x: 2
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
style: {
|
style: {
|
||||||
classes: 'qtip-dark qtip-rounded qtip-shadow'
|
classes: 'qtip-dark qtip-rounded qtip-shadow'
|
||||||
|
@ -59,18 +54,18 @@
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
if (trimZero) {
|
|
||||||
timeTemplate = timeTemplate.replace(/hh/g, 'h');
|
|
||||||
timeTemplate = timeTemplate.replace(/HH/g, 'H');
|
|
||||||
dateTemplate = dateTemplate.replace(/\bDD\b/g, 'D');
|
|
||||||
}
|
|
||||||
|
|
||||||
$(containerClass).each(function() {
|
$(containerClass).each(function() {
|
||||||
var input = $(this).text(),
|
var attrFullDate = $(this).data('fulldate'),
|
||||||
|
useTextDate = /undefined/i.test(typeof(attrFullDate)),
|
||||||
|
input = useTextDate ? $(this).text() : attrFullDate,
|
||||||
|
inputDateTemplate = jd(useTextDate ? dateFormat : '%A, %B %d, %Y'),
|
||||||
|
inDateTemplate = trimZero ? inputDateTemplate.replace(/\bDD\b/g, 'D') : inputDateTemplate,
|
||||||
|
outDateTemplate = trimZero ? jd(dateFormat).replace(/\bDD\b/g, 'D') : jd(dateFormat),
|
||||||
|
timeTemplate = trimZero ? jd(timeFormat).replace(/hh/g, 'h').replace(/HH/g, 'H') : jd(timeFormat),
|
||||||
|
timeToken = timeTemplate,
|
||||||
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(/([,\s]+)(\d{1,2})(?:(.)(\d\d)(?:(.)(\d\d))?)?(?:\s?([ap]m))?$/im);
|
var timeMeta = input.match(/([,\s]+)(\d{1,2})(?:(.)(\d\d)(?:(.)(\d\d))?)?(?:\s?([ap]m))?$/im);
|
||||||
|
@ -103,12 +98,13 @@
|
||||||
timeB = '[</span>' + dtGlue + '<span class="ft">]' + timeToken + timeB;
|
timeB = '[</span>' + dtGlue + '<span class="ft">]' + timeToken + timeB;
|
||||||
}
|
}
|
||||||
|
|
||||||
var inputTokens = dateTemplate + dtSeparator + (dateWithTime ? timeToken : 'HH:mm:ss');
|
var inputTokens = inDateTemplate + dtSeparator + (dateWithTime ? timeToken : 'HH:mm:ss'),
|
||||||
|
outTokens = outDateTemplate + dtSeparator + (dateWithTime ? timeToken : 'HH:mm:ss');
|
||||||
|
|
||||||
if (! moment(input + (dateWithTime ? '' : dtSeparator + '00:00:00'), inputTokens).isValid())
|
if (! (moment(input + (dateWithTime ? '' : dtSeparator + '00:00:00'), inputTokens).isValid()
|
||||||
|
&& moment(input + (dateWithTime ? '' : dtSeparator + '00:00:00'), outTokens).isValid()))
|
||||||
return;
|
return;
|
||||||
|
moment.updateLocale('en', {
|
||||||
moment.lang('en', {
|
|
||||||
calendar: {
|
calendar: {
|
||||||
lastDay:dateA + 'Yesterday' + timeA, sameDay:dateA + 'Today' + timeA, nextDay:dateA + 'Tomorrow' + timeA,
|
lastDay:dateA + 'Yesterday' + timeA, sameDay:dateA + 'Today' + timeA, nextDay:dateA + 'Tomorrow' + timeA,
|
||||||
lastWeek:dateA + 'last] ddd' + timeB, nextWeek:dateA + 'on] ddd' + timeB,
|
lastWeek:dateA + 'last] ddd' + timeB, nextWeek:dateA + 'on] ddd' + timeB,
|
||||||
|
@ -155,7 +151,7 @@
|
||||||
titleThis = true;
|
titleThis = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
var n = false; // disable for prod
|
var n = !1; // disable for prod
|
||||||
$(this).html(result);
|
$(this).html(result);
|
||||||
if (dateWithTime && /(yester|to)day/i.test(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);
|
$(this).find('.fd').attr('title',(n?'1) ':'') + moment.duration(airdatetime.diff(moment(),'seconds'),'seconds').humanize(true)).each(addQTip);
|
||||||
|
@ -168,13 +164,13 @@
|
||||||
|
|
||||||
if (titleThis)
|
if (titleThis)
|
||||||
if (dateWithTime && qTipTime)
|
if (dateWithTime && qTipTime)
|
||||||
$(this).attr('title',(n?'4) ':'') + airdatetime.format(inputTokens)).each(addQTip);
|
$(this).attr('title',(n?'4) ':'') + airdatetime.format(outTokens)).each(addQTip);
|
||||||
else
|
else
|
||||||
$(this).attr('title',(n?'5) ':'') + airdate.format(dateTemplate)).each(addQTip);
|
$(this).attr('title',(n?'5) ':'') + airdate.format(outDateTemplate)).each(addQTip);
|
||||||
else
|
else
|
||||||
if (dateWithTime && qTipTime)
|
if (dateWithTime && qTipTime)
|
||||||
$(this).find('.ft').attr('title',(n?'6) ':'') + airdatetime.format(inputTokens)).each(addQTip);
|
$(this).find('.ft').attr('title',(n?'6) ':'') + airdatetime.format(outTokens)).each(addQTip);
|
||||||
else
|
else
|
||||||
$(this).find('.ft').attr('title',(n?'7) ':'') + airdate.format(dateTemplate)).each(addQTip);
|
$(this).find('.ft').attr('title',(n?'7) ':'') + airdate.format(outDateTemplate)).each(addQTip);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
493
gui/slick/js/moment/moment.min.js
vendored
493
gui/slick/js/moment/moment.min.js
vendored
File diff suppressed because one or more lines are too long
|
@ -106,9 +106,9 @@ class sbdatetime(datetime.datetime):
|
||||||
|
|
||||||
@static_or_instance
|
@static_or_instance
|
||||||
def is_locale_eng(self):
|
def is_locale_eng(self):
|
||||||
return (sbdatetime.sbdatetime.sbfdate(datetime.datetime.now(), '%A').lower() in [
|
today = sbdatetime.sbfdate(sbdatetime.now(), '%A').lower()
|
||||||
'sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday'] and
|
return ('day' == today[-3::] and today[0:-3:] in ['sun', 'mon', 'tues', 'wednes', 'thurs', 'fri', 'satur']
|
||||||
sbdatetime.sbdatetime.sbfdate(datetime.datetime.now(), '%B').lower() in [
|
and sbdatetime.sbfdate(sbdatetime.now(), '%B').lower() in [
|
||||||
'january', 'february', 'march', 'april', 'may', 'june',
|
'january', 'february', 'march', 'april', 'may', 'june',
|
||||||
'july', 'august', 'september', 'october', 'november', 'december'])
|
'july', 'august', 'september', 'october', 'november', 'december'])
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ class sbdatetime(datetime.datetime):
|
||||||
try:
|
try:
|
||||||
if 'local' == sickbeard.TIMEZONE_DISPLAY:
|
if 'local' == sickbeard.TIMEZONE_DISPLAY:
|
||||||
return obj.astimezone(sb_timezone)
|
return obj.astimezone(sb_timezone)
|
||||||
except:
|
except (StandardError, Exception):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
return obj
|
return obj
|
||||||
|
@ -148,11 +148,7 @@ class sbdatetime(datetime.datetime):
|
||||||
t_preset)[None is not t_preset]
|
t_preset)[None is not t_preset]
|
||||||
tmpl = (tmpl.replace(':%S', ''), tmpl)[show_seconds]
|
tmpl = (tmpl.replace(':%S', ''), tmpl)[show_seconds]
|
||||||
|
|
||||||
pm_token = tmpl.replace('%P', '%p')
|
strt = sbdatetime.sbstrftime(obj, tmpl.replace('%P', '%p'))
|
||||||
try:
|
|
||||||
strt = obj.strftime(pm_token)
|
|
||||||
except ValueError:
|
|
||||||
strt = obj.replace(tzinfo=None).strftime(pm_token)
|
|
||||||
|
|
||||||
if sickbeard.TRIM_ZERO:
|
if sickbeard.TRIM_ZERO:
|
||||||
strt = re.sub(r'^0(\d:\d\d)', r'\1', strt)
|
strt = re.sub(r'^0(\d:\d\d)', r'\1', strt)
|
||||||
|
@ -190,11 +186,7 @@ class sbdatetime(datetime.datetime):
|
||||||
try:
|
try:
|
||||||
obj = (dt, self)[self is not None]
|
obj = (dt, self)[self is not None]
|
||||||
if None is not obj:
|
if None is not obj:
|
||||||
preset = (sickbeard.DATE_PRESET, d_preset)[None is not d_preset]
|
strd = sbdatetime.sbstrftime(obj, (sickbeard.DATE_PRESET, d_preset)[None is not d_preset])
|
||||||
try:
|
|
||||||
strd = obj.strftime(preset)
|
|
||||||
except ValueError:
|
|
||||||
strd = obj.replace(tzinfo=None).strftime(preset)
|
|
||||||
|
|
||||||
finally:
|
finally:
|
||||||
sbdatetime.setlocale(setlocale=setlocale)
|
sbdatetime.setlocale(setlocale=setlocale)
|
||||||
|
@ -210,17 +202,23 @@ class sbdatetime(datetime.datetime):
|
||||||
obj = (dt, self)[self is not None]
|
obj = (dt, self)[self is not None]
|
||||||
try:
|
try:
|
||||||
if None is not obj:
|
if None is not obj:
|
||||||
preset = (sickbeard.DATE_PRESET, d_preset)[None is not d_preset]
|
strd = u'%s, %s' % (
|
||||||
try:
|
sbdatetime.sbstrftime(obj, (sickbeard.DATE_PRESET, d_preset)[None is not d_preset]),
|
||||||
strd = obj.strftime(preset),
|
sbdatetime.sbftime(dt, show_seconds, t_preset, False, markup))
|
||||||
except ValueError:
|
|
||||||
strd = obj.replace(tzinfo=None).strftime(preset)
|
|
||||||
strd = u'%s, %s' % (strd, sbdatetime.sbftime(dt, show_seconds, t_preset, False, markup))
|
|
||||||
|
|
||||||
finally:
|
finally:
|
||||||
sbdatetime.setlocale(use_has_locale=sbdatetime.has_locale)
|
sbdatetime.setlocale(use_has_locale=sbdatetime.has_locale)
|
||||||
return strd
|
return strd
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def sbstrftime(obj, str_format):
|
||||||
|
try:
|
||||||
|
result = obj.strftime(str_format),
|
||||||
|
except ValueError:
|
||||||
|
result = obj.replace(tzinfo=None).strftime(str_format)
|
||||||
|
return result if isinstance(result, basestring) else \
|
||||||
|
isinstance(result, tuple) and 1 == len(result) and '%s' % result[0] or ''
|
||||||
|
|
||||||
@static_or_instance
|
@static_or_instance
|
||||||
def totimestamp(self, dt=None, default=None):
|
def totimestamp(self, dt=None, default=None):
|
||||||
obj = (dt, self)[self is not None]
|
obj = (dt, self)[self is not None]
|
||||||
|
@ -228,4 +226,4 @@ class sbdatetime(datetime.datetime):
|
||||||
try:
|
try:
|
||||||
timestamp = time.mktime(obj.timetuple())
|
timestamp = time.mktime(obj.timetuple())
|
||||||
finally:
|
finally:
|
||||||
return (default, timestamp)[isinstance(timestamp, float)]
|
return (default, timestamp)[isinstance(timestamp, float)]
|
||||||
|
|
Loading…
Reference in a new issue