/**
* Load XMLDoc function
* Здесь в качестве параметра url при вызове мы должны указать
* backend-скрипт, который, собственно, и получит данные с сервера
*/
var timer_photo, abortRequest;
var id_el="";
function doLoadVotes(url) {
	if (window.XMLHttpRequest) {
		request = new XMLHttpRequest();
		request.onreadystatechange = processRequestChange_Content;
		request.open("GET", url, true);
		request.send(null);
	} 
	else if (window.ActiveXObject) {
		request = new ActiveXObject("Microsoft.XMLHTTP");
		if (request) {
			request.onreadystatechange = processRequestChange_Content;
			request.open("GET", url, true);
			request.send();
		}
	}
}
/**
* Event on request change
* Собственно, обработчик события onreadystatechange.
* Здесь мы, в зависимости от состояния запроса,
* будем скрывать / показывать слои "Загрузка данных",
* само поле данных и т.д.
*/
function processRequestChange_Content() {	
	abortRequest = window.setTimeout("request.abort();", 120000);
	var el = id_el;
	// если выполнен
	if (request.readyState == 4){
		clearTimeout(abortRequest);
		// если успешно
		if (request.status == 200) {
			$(el).html(request.responseText);
		} 
		else alert("Не удалось получить данные:n" + request.statusText);
	}
}

function getVotes(id, number){
    id_el = '#id_'+id;
    //отправляем данные через AJAX
/*    .post(
        '/votes_jx.php',
        {
            act: "vote",
            div_id: <'id_'+id>,
            'id':id,
            'number':number
        },
        drawDivVote //функция перерисовка дива
*/
    doLoadVotes('/votes_jx.php?id='+id+'&number='+number);
}

function CloseTip() {
	//clearTimeout(timer_photo);
	//document.getElementById("indicator").src='/img/indicator.gif';
}
