mirror of
https://github.com/SickGear/SickGear.git
synced 2025-01-21 17:13:42 +00:00
278 lines
8 KiB
JavaScript
278 lines
8 KiB
JavaScript
$(document).ready(function () {
|
|
|
|
function populateSelect() {
|
|
if (!$('#nameToSearch').length)
|
|
return;
|
|
|
|
if (1 >= $('#indexerLangSelect').find('option').length) {
|
|
|
|
$.getJSON(sbRoot + '/home/addShows/getIndexerLanguages', {}, function (data) {
|
|
|
|
var resultStr = '',
|
|
selected = ' selected="selected"',
|
|
elIndexerLang = $('#indexerLangSelect');
|
|
|
|
if (0 === data.results.length) {
|
|
resultStr = '<option value="en"' + selected + '>en</option>';
|
|
} else {
|
|
$.each(data.results, function (index, obj) {
|
|
resultStr += '<option value="' + obj + '"'
|
|
+ ('' == resultStr ? selected : '')
|
|
+ '>' + obj + '</option>';
|
|
});
|
|
}
|
|
|
|
elIndexerLang.html(resultStr);
|
|
elIndexerLang.change(function () {
|
|
searchIndexers();
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
var searchRequestXhr = null;
|
|
|
|
function searchIndexers() {
|
|
var elNameToSearch = $('#nameToSearch');
|
|
|
|
if (!elNameToSearch.val().length)
|
|
return;
|
|
|
|
if (searchRequestXhr)
|
|
searchRequestXhr.abort();
|
|
|
|
var elTvDatabase = $('#providedIndexer'),
|
|
elIndexerLang = $('#indexerLangSelect'),
|
|
searchingFor = elNameToSearch.val() + ' on ' + elTvDatabase.find('option:selected').text() + ' in ' + elIndexerLang.val();
|
|
|
|
$('#searchResults').empty().html('<img id="searchingAnim" src="' + sbRoot + '/images/loading32' + themeSpinner + '.gif" height="32" width="32" /> searching ' + searchingFor + '...');
|
|
|
|
searchRequestXhr = $.ajax({
|
|
url: sbRoot + '/home/addShows/searchIndexersForShowName',
|
|
data: {
|
|
'search_term': elNameToSearch.val(),
|
|
'lang': elIndexerLang.val(),
|
|
'indexer': elTvDatabase.val()
|
|
},
|
|
timeout: parseInt($('#indexer_timeout').val(), 10) * 1000,
|
|
dataType: 'json',
|
|
error: function () {
|
|
$('#searchResults').empty().html('search timed out, try again or try another database');
|
|
},
|
|
success: function (data) {
|
|
var resultStr = '', checked = '', rowType, row = 0;
|
|
|
|
if (0 === data.results.length) {
|
|
resultStr += '<span class="boldest">Sorry, no results found. Try a different search.</span>';
|
|
} else {
|
|
$.each(data.results, function (index, obj) {
|
|
checked = (0 == row ? ' checked' : '');
|
|
rowType = (0 == row % 2 ? '' : ' class="alt"');
|
|
row++;
|
|
|
|
var whichSeries = obj.join('|'),
|
|
showstartdate = '';
|
|
|
|
if (null !== obj[5]) {
|
|
var startDate = new Date(obj[5]);
|
|
var today = new Date();
|
|
showstartdate = ' <span class="stepone-result-date">('
|
|
+ (startDate > today ? 'will debut' : 'started')
|
|
+ ' on ' + obj[5] + ')</span>';
|
|
}
|
|
|
|
resultStr += '<div' + rowType + '>'
|
|
+ '<input id="whichSeries" type="radio"'
|
|
+ ' class="stepone-result-radio"'
|
|
+ ' title="Add show <span style=\'color: rgb(66, 139, 202)\'>' + obj[4] + '</span>"'
|
|
+ ' name="whichSeries"'
|
|
+ ' value="' + whichSeries + '"'
|
|
+ checked
|
|
+ ' />'
|
|
+ '<a'
|
|
+ ' class="stepone-result-title"'
|
|
+ ' title="View detail for <span style=\'color: rgb(66, 139, 202)\'>' + obj[4] + '</span>"'
|
|
+ ' href="' + anonURL + obj[2] + obj[3] + ((data.langid && '' != data.langid) ? '&lid=' + data.langid : '') + '"'
|
|
+ ' onclick="window.open(this.href, \'_blank\'); return false;"'
|
|
+ '>' + obj[4] + '</a>'
|
|
+ showstartdate
|
|
+ (null == obj[0] ? ''
|
|
: ' <span class="stepone-result-db grey-text">' + '[' + obj[0] + ']' + '</span>')
|
|
+ '</div>' + "\n";
|
|
});
|
|
}
|
|
$('#searchResults').html(
|
|
'<fieldset>' + "\n" + '<legend class="legendStep" style="margin-bottom: 15px">'
|
|
+ (0 < row ? row : 'No')
|
|
+ ' search result' + (1 == row ? '' : 's') + '...</legend>' + "\n"
|
|
+ resultStr
|
|
+ '</fieldset>'
|
|
);
|
|
updateSampleText();
|
|
myform.loadsection(0);
|
|
$('.stepone-result-radio, .stepone-result-title').each(addQTip);
|
|
}
|
|
});
|
|
}
|
|
|
|
var elNameToSearch = $('#nameToSearch'),
|
|
elSearchName = $('#searchName');
|
|
|
|
elSearchName.click(function () { searchIndexers(); });
|
|
|
|
if (elNameToSearch.length && elNameToSearch.val().length) {
|
|
elSearchName.click();
|
|
}
|
|
|
|
$('#addShowButton').click(function () {
|
|
// if they haven't picked a show don't let them submit
|
|
if (!$('input:radio[name="whichSeries"]:checked').val()
|
|
&& !$('input:hidden[name="whichSeries"]').val().length) {
|
|
alert('You must choose a show to continue');
|
|
return false;
|
|
}
|
|
$('#addShowForm').submit();
|
|
});
|
|
|
|
$('#skipShowButton').click(function () {
|
|
$('#skipShow').val('1');
|
|
$('#addShowForm').submit();
|
|
});
|
|
|
|
$('#qualityPreset').change(function () {
|
|
myform.loadsection(2);
|
|
});
|
|
|
|
/***********************************************
|
|
* jQuery Form to Form Wizard- (c) Dynamic Drive (www.dynamicdrive.com)
|
|
* This notice MUST stay intact for legal use
|
|
* Visit http://www.dynamicdrive.com/ for this script and 100s more.
|
|
***********************************************/
|
|
|
|
var myform = new FormToWizard({
|
|
fieldsetborderwidth: 0,
|
|
formid: 'addShowForm',
|
|
revealfx: ['slide', 500],
|
|
oninit: function () {
|
|
populateSelect();
|
|
updateSampleText();
|
|
if ($('input:hidden[name="whichSeries"]').length && $('#fullShowPath').length) {
|
|
goToStep(3);
|
|
}
|
|
}
|
|
});
|
|
|
|
function goToStep(num) {
|
|
$('.step').each(function () {
|
|
if ($.data(this, 'section') + 1 == num) {
|
|
$(this).click();
|
|
}
|
|
});
|
|
}
|
|
|
|
elNameToSearch.focus();
|
|
|
|
function updateSampleText() {
|
|
// if something's selected then we have some behavior to figure out
|
|
|
|
var show_name,
|
|
sep_char,
|
|
elRadio = $('input:radio[name="whichSeries"]:checked'),
|
|
elInput = $('input:hidden[name="whichSeries"]'),
|
|
elRootDirs = $('#rootDirs'),
|
|
elFullShowPath = $('#fullShowPath');
|
|
|
|
// if they've picked a radio button then use that
|
|
if (elRadio.length) {
|
|
show_name = elRadio.val().split('|')[4];
|
|
}
|
|
// if we provided a show in the hidden field, use that
|
|
else if (elInput.length && elInput.val().length) {
|
|
show_name = $('#providedName').val();
|
|
} else {
|
|
show_name = '';
|
|
}
|
|
|
|
var sample_text = '<p>Adding show <span class="show-name">' + show_name + '</span>'
|
|
+ ('' == show_name ? 'into<br />' : '<br />into')
|
|
+ ' <span class="show-dest">';
|
|
|
|
// if we have a root dir selected, figure out the path
|
|
if (elRootDirs.find('option:selected').length) {
|
|
var root_dir_text = elRootDirs.find('option:selected').val();
|
|
if (root_dir_text.indexOf('/') >= 0) {
|
|
sep_char = '/';
|
|
} else if (root_dir_text.indexOf('\\') >= 0) {
|
|
sep_char = '\\';
|
|
} else {
|
|
sep_char = '';
|
|
}
|
|
|
|
if (root_dir_text.substr(sample_text.length - 1) != sep_char) {
|
|
root_dir_text += sep_char;
|
|
}
|
|
root_dir_text += '<i>||</i>' + sep_char;
|
|
|
|
sample_text += root_dir_text;
|
|
} else if (elFullShowPath.length && elFullShowPath.val().length) {
|
|
sample_text += elFullShowPath.val();
|
|
} else {
|
|
sample_text += 'unknown dir.';
|
|
}
|
|
|
|
sample_text += '</span></p>';
|
|
|
|
// if we have a show name then sanitize and use it for the dir name
|
|
if (show_name.length) {
|
|
$.get(sbRoot + '/home/addShows/sanitizeFileName', {name: show_name}, function (data) {
|
|
$('#displayText').html(sample_text.replace('||', data));
|
|
});
|
|
// if not then it's unknown
|
|
} else {
|
|
$('#displayText').html(sample_text.replace('||', '??'));
|
|
}
|
|
|
|
// also toggle the add show button
|
|
if ((elRootDirs.find('option:selected').length || (elFullShowPath.length && elFullShowPath.val().length)) &&
|
|
(elRadio.length) || (elInput.length && elInput.val().length)) {
|
|
$('#addShowButton').attr('disabled', false);
|
|
} else {
|
|
$('#addShowButton').attr('disabled', true);
|
|
}
|
|
}
|
|
|
|
$('#rootDirText').change(updateSampleText);
|
|
|
|
$('#searchResults').on('click', '.stepone-result-radio', updateSampleText);
|
|
|
|
elNameToSearch.keyup(function (event) {
|
|
if (event.keyCode == 13) {
|
|
elSearchName.click();
|
|
}
|
|
});
|
|
|
|
var addQTip = (function() {
|
|
$(this).css('cursor', 'help');
|
|
$(this).qtip({
|
|
show: {
|
|
solo: true
|
|
},
|
|
position: {
|
|
viewport: $(window),
|
|
my: 'left center',
|
|
adjust: {
|
|
y: -10,
|
|
x: 2
|
|
}
|
|
},
|
|
style: {
|
|
tip: {
|
|
corner: true,
|
|
method: 'polygon'
|
|
},
|
|
classes: 'qtip-rounded qtip-bootstrap qtip-shadow ui-tooltip-sb'
|
|
}
|
|
});
|
|
});
|
|
|
|
});
|