88 lines
2.6 KiB
JavaScript
88 lines
2.6 KiB
JavaScript
var Ajax = {
|
|
loadArtistData: function(name) {
|
|
$('#search-container input').attr('disabled', 'disabled').blur();
|
|
$('#search-container img').show();
|
|
name = name.split(' ').join('+');
|
|
Ajax.setArchor('/artist/'+ name +'/');
|
|
$.get('/artist/'+ name +'/', function(data){
|
|
if (typeof data.error != 'undefined') {
|
|
if (data.error == 'loading') {
|
|
Ajax.loadArtistData(name);
|
|
} else if (data.error == 404) {
|
|
Ajax.load404Page();
|
|
}
|
|
return false;
|
|
}
|
|
Pages.renderArtist(data);
|
|
beathaven.redrawScrollbar();
|
|
})
|
|
},
|
|
|
|
loadSearchPage: function() {
|
|
Ajax.setArchor('/search/');
|
|
$.get('/demo/search.html', function(data){
|
|
$('#data-container .inner').html(data);
|
|
beathaven.redrawScrollbar();
|
|
$('#search_field').autocomplete({
|
|
serviceUrl: '/artist/autocomplete', // Страница для обработки запросов автозаполнения
|
|
minChars: 2, // Минимальная длина запроса для срабатывания автозаполнения
|
|
delimiter: /(,|;)\s*/, // Разделитель для нескольких запросов, символ или регулярное выражение
|
|
maxHeight: 400, // Максимальная высота списка подсказок, в пикселях
|
|
width: 415, // Ширина списка
|
|
zIndex: 9999, // z-index списка
|
|
deferRequestBy: 150, // Задержка запроса (мсек)
|
|
onSelect: Ajax.loadArtistData
|
|
});
|
|
$('#search_field').focus();
|
|
})
|
|
},
|
|
|
|
loadWheePage: function() {
|
|
$.get('/demo/whee.html', function(data){
|
|
$('#data-container .inner').html(data);
|
|
})
|
|
},
|
|
|
|
load404Page: function() {
|
|
$.get('/demo/404.html', function(data){
|
|
$('#data-container .inner').html(data);
|
|
beathaven.redrawScrollbar();
|
|
})
|
|
},
|
|
|
|
setArchor: function(anchor) {
|
|
window.location.hash = '#'+ anchor;
|
|
},
|
|
|
|
getAnchor: function() {
|
|
return window.location.hash.substring(1);
|
|
},
|
|
|
|
detectPage: function() {
|
|
if (m = Ajax.getAnchor().match(/\/artist\/(.+)\//)) {
|
|
Ajax.loadArtistData(m[1]);
|
|
} else if (Ajax.getAnchor() === '' || Ajax.getAnchor().match(/\/search\//)) {
|
|
Ajax.loadSearchPage();
|
|
} else {
|
|
Ajax.load404Page();
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
$(function(){
|
|
$('a.data.artist').live('click', function(){
|
|
Ajax.loadArtistData($(this).html());
|
|
return false;
|
|
});
|
|
$('.search').live('click', function(){
|
|
Ajax.loadSearchPage();
|
|
return false;
|
|
});
|
|
$('#search_form').live('submit', function(){
|
|
$('.autocomplete-container').remove();
|
|
Ajax.loadArtistData($('#search_field').val());
|
|
return false;
|
|
});
|
|
$(window).bind('hashchange', Ajax.detectPage);
|
|
}) |