mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-21 00:53:37 +00:00
0d81453c1f
Add sort by quality to Poster layout. Change +n snatches to links on all Show List layouts.
209 lines
5.6 KiB
JavaScript
209 lines
5.6 KiB
JavaScript
/** @namespace config.sortArticle */
|
|
/** @namespace config.homeSearchFocus */
|
|
/** @namespace config.fuzzyDating */
|
|
/** @namespace config.fuzzydate */
|
|
/** @namespace config.datePreset */
|
|
/** @namespace config.timePreset */
|
|
/** @namespace config.isPoster */
|
|
/** @namespace config.posterSortby */
|
|
/** @namespace config.posterSortdir */
|
|
$.tablesorter.addParser({
|
|
id: 'loadingNames',
|
|
is: function (s) {
|
|
return !1;
|
|
},
|
|
format: function (s) {
|
|
var name = (s.toLowerCase() || '');
|
|
return (0 == name.indexOf('loading...')) ? name.replace('loading...', '000')
|
|
: config.sortArticle ? name : name.replace(/^(?:(?:A(?!\s+to)n?)|The)\s(\w)/i, '$1');
|
|
},
|
|
type: 'text'
|
|
});
|
|
|
|
$.tablesorter.addParser({
|
|
id: 'quality',
|
|
is: function (s) {
|
|
return !1;
|
|
},
|
|
format: function (s) {
|
|
return s.replace('hd1080p', 22).replace('hd720p', 21).replace('hd', 20)
|
|
.replace('sd', 10).replace('any', 1).replace('custom', 50);
|
|
},
|
|
type: 'numeric'
|
|
});
|
|
|
|
$.tablesorter.addParser({
|
|
id: 'downloads',
|
|
is: function (s) {
|
|
return !1;
|
|
},
|
|
format: function(s) {
|
|
return valueDownloads(s);
|
|
},
|
|
type: 'numeric'
|
|
});
|
|
|
|
function valueDownloads(s) {
|
|
var match = s.match(/^(\?|\d+)(?:[^/]+[^\d]+(\d+))?$/);
|
|
|
|
if (null == match || '?' == match[1])
|
|
return -10;
|
|
|
|
var dlCnt = parseInt(match[1], 10), epsCnt = parseInt(match[2], 10);
|
|
|
|
if (0 == dlCnt)
|
|
return epsCnt;
|
|
|
|
var perNum = parseInt(1000000000 * parseFloat(dlCnt / epsCnt), 10), finalNum = perNum;
|
|
if (0 < finalNum)
|
|
finalNum += dlCnt;
|
|
|
|
return finalNum;
|
|
}
|
|
|
|
$(document).ready(function () {
|
|
if (config.homeSearchFocus) {
|
|
$('#search_show_name').focus();
|
|
}
|
|
|
|
if (config.fuzzyDating) {
|
|
fuzzyMoment({
|
|
dtInline: config.isPoster,
|
|
containerClass: config.fuzzydate,
|
|
dateHasTime: !1,
|
|
dateFormat: config.datePreset,
|
|
timeFormat: config.timePreset,
|
|
trimZero: config.trimZero
|
|
});
|
|
}
|
|
|
|
$('div[id^="progressbar"]').each(function (k, v) {
|
|
var progress = parseInt($(this).siblings('span[class="sort-data"]').attr('data-progress'), 10),
|
|
elId = '#' + $(this).attr('id');
|
|
v = 80;
|
|
$(elId).progressbar({value: progress});
|
|
if (progress < v) {
|
|
v = progress >= 40 ? 60 : (progress >= 20 ? 40 : 20);
|
|
}
|
|
$(elId + ' > .ui-progressbar-value').addClass('progress-' + v);
|
|
});
|
|
|
|
if (config.isPoster) {
|
|
$('.container').each(function (i, obj) {
|
|
var sortCriteria;
|
|
switch (config.posterSortby) {
|
|
case 'date':
|
|
sortCriteria = ['date', 'name', 'network', 'progress'];
|
|
break;
|
|
case 'network':
|
|
sortCriteria = ['network', 'name', 'date', 'progress'];
|
|
break;
|
|
case 'progress':
|
|
sortCriteria = ['progress', 'name', 'date', 'network'];
|
|
break;
|
|
case 'quality':
|
|
sortCriteria = ['quality', 'name', 'date', 'network', 'progress'];
|
|
break;
|
|
default:
|
|
sortCriteria = ['name', 'date', 'network', 'progress'];
|
|
break;
|
|
}
|
|
|
|
$(obj).isotope({
|
|
itemSelector: '.show-card',
|
|
sortBy: sortCriteria,
|
|
sortAscending: config.posterSortdir,
|
|
layoutMode: 'masonry',
|
|
masonry: {
|
|
columnWidth: 188,
|
|
isFitWidth: !0,
|
|
gutter: 12
|
|
},
|
|
getSortData: {
|
|
name: function (itemElem) {
|
|
var name = $(itemElem).attr('data-name').toLowerCase() || '';
|
|
return config.sortArticle ? name : name.replace(/^(?:(?:A(?!\s+to)n?)|The)\s(\w)/i, '$1');
|
|
},
|
|
date: function (itemElem) {
|
|
var date = $(itemElem).attr('data-date');
|
|
return date.length && parseInt(date, 10) || Number.POSITIVE_INFINITY;
|
|
},
|
|
network: function (itemElem) {
|
|
return $(itemElem).attr('data-network').toLowerCase()
|
|
.replace(/^(.*?)\W*[(]\w{2,3}[)]|1$/i, '$1') || '';
|
|
},
|
|
progress: function (itemElem) {
|
|
var progress = $(itemElem).find('.show-dlstats').text();
|
|
return valueDownloads(progress);
|
|
},
|
|
quality: function (itemElem) {
|
|
return $(itemElem).find('.show-quality').text().toLowerCase();
|
|
}
|
|
}
|
|
});
|
|
|
|
$('#postersort').on('change', function () {
|
|
var sortValue = this.value;
|
|
$(obj).isotope({sortBy: sortValue});
|
|
$.get(this.options[this.selectedIndex].getAttribute('data-sort'));
|
|
});
|
|
|
|
$('#postersortdirection').on('change', function () {
|
|
var sortDirection = this.value;
|
|
sortDirection = sortDirection == 'true';
|
|
$(obj).isotope({sortAscending: sortDirection});
|
|
$.get(this.options[this.selectedIndex].getAttribute('data-sort'));
|
|
});
|
|
});
|
|
$('#search_show_name').on('input', function() {
|
|
$('.container').isotope({
|
|
filter: function () {
|
|
return 0 <= $(this).attr('data-name').toLowerCase().indexOf(
|
|
$('#search_show_name').val().toLowerCase());
|
|
}
|
|
});
|
|
});
|
|
} else {
|
|
$('.tablesorter').each(function (i, obj) {
|
|
$(obj).has('tbody tr').tablesorter({
|
|
sortList: [[5, 1], [1, 0]],
|
|
textExtraction: {
|
|
0: function (node) {
|
|
return $(node).find('span.sort-data').text();
|
|
},
|
|
2: function (node) {
|
|
return $(node).find('span.sort-data').text().toLowerCase();
|
|
},
|
|
3: function (node) {
|
|
return $(node).find('span').text().toLowerCase();
|
|
},
|
|
4: function (node) {
|
|
return $(node).find('.progressbarText').text();
|
|
},
|
|
5: function (node) {
|
|
return $(node).find('i').attr('alt');
|
|
}
|
|
},
|
|
widgets: ['saveSort', 'zebra', 'stickyHeaders', 'filter'],
|
|
headers: {
|
|
1: {sorter: 'loadingNames'},
|
|
3: {sorter: 'quality'},
|
|
4: {sorter: 'downloads'}
|
|
},
|
|
widgetOptions: {
|
|
filter_columnFilters: !1
|
|
},
|
|
sortStable: !0
|
|
});
|
|
$.tablesorter.filter.bindSearch($(obj), $('.search'));
|
|
});
|
|
}
|
|
$('.resetshows').click(function() {
|
|
var input = $('#search_show_name');
|
|
if ('' !== input.val()){
|
|
input.val('').trigger('input').change();
|
|
if (config.homeSearchFocus)
|
|
input.focus();
|
|
}
|
|
});
|
|
});
|