var _selectHeight = 23;

var inputs = new Array();
var selects = new Array();
var labels = new Array();
var radios = new Array();
var radioLabels = new Array();
var checkboxes = new Array();
var checkboxLabels = new Array();
var buttons = new Array();
var selects = new Array();
var all_selects = false;
var active_select = null;
var selectText = "please select";

function is_mac() {
	if (navigator.appVersion.indexOf("Safari") != -1)
	{
		if(!window.getComputedStyle)
		{
			return true;
		}
	}
	
	return false;
}

function initCastomForms() {
	if(!document.getElementById) {return false;}
	getElements();
	separateElements();
	replaceRadios();
	//replaceCheckboxes();
	//replaceSelects();

	var _selects = document.getElementsByTagName('select');
	var _SelctClassName = [];
	if (_selects) {
		for (var i = 0; i < _selects.length; i++) {
			if (_selects[i].className != '' && _selects[i].className != 'outtaHere')
				_SelctClassName[i] = ' drop-'+_selects[i].className;
		}
		for (var i = 0; i < _SelctClassName.length; i++) {
			var _selectDrop = document.getElementById('optionsDiv'+i);
			if (_selectDrop) {
				if (_SelctClassName[i]) 
					_selectDrop.className += _SelctClassName[i];
			}
		}
	}
}


// getting all the required elements
function getElements() {
	var _frms = document.getElementsByTagName("form");
	for (var nf = 0; nf < _frms.length; nf++) {
		if(_frms[nf].className.indexOf("default") == -1) {
			var a = document.forms[nf].getElementsByTagName("input");
			for(var nfi = 0; nfi < a.length; nfi++) {
				inputs.push(a[nfi]);
			}
			var b = document.forms[nf].getElementsByTagName("label");
			for(var nfl = 0; nfl < b.length; nfl++) {
				labels.push(b[nfl]);
			}
			var c = document.forms[nf].getElementsByTagName("select");
			for(var nfs = 0; nfs < c.length; nfs++) {
				selects.push(c[nfs]);
			}
		}
	}
}

// separating all the elements in their respective arrays
function separateElements() {
	var r = 0; var c = 0; var t = 0; var rl = 0; var cl = 0; var tl = 0; var b = 0;
	for (var q = 0; q < inputs.length; q++) {
		if(inputs[q].type == "radio") {
			radios[r] = inputs[q]; ++r;
			for(var w = 0; w < labels.length; w++) {
				if((inputs[q].id) && labels[w].htmlFor == inputs[q].id)
				{
					radioLabels[rl] = labels[w];
				}
			}
			++rl;
		}
		if(inputs[q].type == "checkbox") {
			checkboxes[c] = inputs[q]; ++c;
			for(var w = 0; w < labels.length; w++) {
				if((inputs[q].id) && (labels[w].htmlFor == inputs[q].id))
				{
					checkboxLabels[cl] = labels[w];
				}
			}
			++cl;
		}
		if((inputs[q].type == "submit") || (inputs[q].type == "button")) {
			buttons[b] = inputs[q]; ++b;
		}
	}
}

//replacing radio buttons
function replaceRadios() {
	for (var q = 0; q < radios.length; q++) {
		radios[q].className += " outtaHere";
		var radioArea = document.createElement("div");
		if(radios[q].checked) {
			radioArea.className = "radioAreaChecked";
			if (radioLabels[q])
			{
				radioLabels[q].className += "radioAreaCheckedLabel"
			}
			
		}
		else
		{
			radioArea.className = "radioArea";
		}
		radioArea.id = "myRadio" + q;
		radios[q].parentNode.insertBefore(radioArea, radios[q]);
		radios[q]._ra = radioArea;

		radioArea.onclick = new Function('rechangeRadios('+q+')');
		if (radioLabels[q])
		{
			radioLabels[q].onclick = new Function('rechangeRadios('+q+')');
		}
	}
	return true;
}

//checking radios
function checkRadios(who) {
	var what = radios[who]._ra;
	for(var q = 0; q < radios.length; q++) {
		if((radios[q]._ra.className == "radioAreaChecked")&&(radios[q]._ra.nextSibling.name == radios[who].name))
		{
			radios[q]._ra.className = "radioArea";
			if (radioLabels[q])
			{
				radioLabels[q].className = radioLabels[q].className.replace("radioAreaCheckedLabel", "");
			}
		}
	}
	what.className = "radioAreaChecked";
	if(radioLabels[who])
		radioLabels[who].className += " radioAreaCheckedLabel";
}

//changing radios
function changeRadios(who) {
	if(radios[who].checked) {
		for(var q = 0; q < radios.length; q++) {
			if(radios[q].name == radios[who].name) {
				radios[q].checked = false;
			} 
			radios[who].checked = true; 
			checkRadios(who);
		}
	}
}

//rechanging radios
function rechangeRadios(who) {
	if(!radios[who].checked) {
		for(var q = 0; q < radios.length; q++) {
			if(radios[q].name == radios[who].name)	{
				radios[q].checked = false; 
			}
			radios[who].checked = true; 
			checkRadios(who);
		}
	}
}

//replacing checkboxes
function replaceCheckboxes() {
	for (var q = 0; q < checkboxes.length; q++) {
		checkboxes[q].className += " outtaHere";
		var checkboxArea = document.createElement("div");
		if(checkboxes[q].checked) {
			checkboxArea.className = "checkboxAreaChecked";
			if(checkboxLabels[q])
				checkboxLabels[q].className += "checkboxAreaCheckedLabel"
		}
		else {
			checkboxArea.className = "checkboxArea";
		}
		checkboxArea.id = "myCheckbox" + q;
		checkboxes[q].parentNode.insertBefore(checkboxArea, checkboxes[q]);
		checkboxes[q]._ca = checkboxArea;
		checkboxArea.onclick = checkboxArea.onclick2 = new Function('rechangeCheckboxes('+q+')');
		if (checkboxLabels[q])
		{
			checkboxLabels[q].onclick = new Function('changeCheckboxes('+q+')');
		}
		
		checkboxes[q].onkeydown = checkEvent;
	}
	return true;
}

//checking checkboxes
function checkCheckboxes(who, action) {
	var what = checkboxes[who]._ca;
	if(action == true) {
		what.className = "checkboxAreaChecked";
		what.checked = true;
		if(checkboxLabels[who])
			checkboxLabels[who].className += " checkboxAreaCheckedLabel";
	}
	if(action == false) {
		what.className = "checkboxArea";
		what.checked = false;
		if(checkboxLabels[who])
			checkboxLabels[who].className = checkboxLabels[who].className.replace("checkboxAreaCheckedLabel", "");
	}
}

//changing checkboxes
function changeCheckboxes(who) {
	if(checkboxes[who].checked) {
		checkCheckboxes(who, false);
	}
	else {
		checkCheckboxes(who, true);
	} 
}

//rechanging checkboxes
function rechangeCheckboxes(who) {
	var tester = false;
	if(checkboxes[who].checked == true) {
		tester = false;
	}
	else {
		tester = true;
	}
	checkboxes[who].checked = tester;
	checkCheckboxes(who, tester);
}

//check event
function checkEvent(e) {
	if (!e) var e = window.event;
	if(e.keyCode == 32) {for (var q = 0; q < checkboxes.length; q++) {if(this == checkboxes[q]) {changeCheckboxes(q);}}} //check if space is pressed
}


function replaceSelects() {
	for(var q = 0; q < selects.length; q++) {
	if (!selects[q].replaced && selects[q].offsetWidth && selects[q].className.indexOf("default") == -1)
	{
		selects[q]._number = q;
		//create and build div structure
		var selectArea = document.createElement("div");
		var left = document.createElement("span");
		left.className = "left";
		selectArea.appendChild(left);
		
		var disabled = document.createElement("span");
		disabled.className = "disabled";
		selectArea.appendChild(disabled);
		
		selects[q]._disabled = disabled;
		var center = document.createElement("span");
		var button = document.createElement("a");
		var text = document.createTextNode(selectText);
		center.id = "mySelectText"+q;
		
		var stWidth = selects[q].offsetWidth;
		selectArea.style.width = stWidth + "px";
		if (selects[q].parentNode.className.indexOf("type2") != -1){
			button.href = "javascript:showOptions("+q+",true)";
		} else {
			button.href = "javascript:showOptions("+q+",false)";
		}
		button.className = "selectButton";
		selectArea.className = "selectArea";

		selectArea.className += " " + selects[q].className;
		selectArea.id = "sarea"+q;
		center.className = "center";
		center.appendChild(text);
		selectArea.appendChild(center);
		selectArea.appendChild(button);
		
		//hide the select field
		selects[q].className += " outtaHere";
		//insert select div
		selects[q].parentNode.insertBefore(selectArea, selects[q]);
		//build & place options div

		var optionsDiv = document.createElement("div");
		var optionsListParent = document.createElement("div");
		optionsListParent.className = "select-center";
		var optionsListParent2 = document.createElement("div");
		optionsListParent2.className = "select-center-right";
		var optionsList = document.createElement("ul");
		optionsDiv.innerHTML += "<div class='select-top'><div class='select-top-left'></div><div class='select-top-right'></div></div>";
		optionsListParent.appendChild(optionsListParent2);
		optionsListParent.appendChild(optionsList);
		optionsDiv.appendChild(optionsListParent);
		
		selects[q]._options = optionsList;
		
		optionsDiv.style.width = stWidth + "px";
		optionsDiv._parent = selectArea;
		
		optionsDiv.className = "optionsDivInvisible";
		optionsDiv.id = "optionsDiv"+q;
		
	
		populateSelectOptions(selects[q]);
		optionsDiv.innerHTML += "<div class='select-bottom'><div class='select-bottom-left'></div><div class='select-bottom-right'></div></div>";
		document.getElementsByTagName("body")[0].appendChild(optionsDiv);
		selects[q].replaced = true;
		}
	all_selects = true;
	}
}

//collecting select options
function populateSelectOptions(me) {
	me._options.innerHTML = "";
	
	for(var w = 0; w < me.options.length; w++) {
		if(me.options[w].title.indexOf("title") == -1) {
			var optionHolder = document.createElement('li');
			var optionLink = document.createElement('a');
			var optionTxt;
			if (me.options[w].title.indexOf('image') != -1) {
				optionTxt = document.createElement('img');
				optionSpan = document.createElement('span');
				optionTxt.src = me.options[w].title;
				optionSpan = document.createTextNode(me.options[w].text);
			} else {
				optionTxt = document.createTextNode(me.options[w].text);
			}
			
			optionLink.href = "javascript:showOptions("+me._number+"); selectMe('"+me.id+"',"+w+","+me._number+");";
			if (me.options[w].title.indexOf('image') != -1) {
				optionLink.appendChild(optionTxt);
				optionLink.appendChild(optionSpan);
			} else {
				optionLink.appendChild(optionTxt);
			}
			optionHolder.appendChild(optionLink);
			me._options.appendChild(optionHolder);
			//check for pre-selected items
			if(me.options[w].selected) {
				selectMe(me.id,w,me._number);
			}
		}
		else if(me.options[w].selected)
			selectMe(me.id,w,me._number);
	}
	if (me.disabled) {
		me._disabled.style.display = "block";
	}
	else {
		me._disabled.style.display = "none";
	}
}

//selecting me
function selectMe(selectFieldId,linkNo,selectNo) {
	selectField = selects[selectNo];
	for(var k = 0; k < selectField.options.length; k++) {
		if(k==linkNo) {
			selectField.options[k].selected = true;
		}
		else {
			selectField.options[k].selected = false;
		}
	}
	
	//show selected option
	textVar = document.getElementById("mySelectText"+selectNo);
	var newText;
	var optionSpan;
	if (selectField.options[linkNo].title.indexOf('image') != -1) {
		newText = document.createElement('img');
		newText.src = selectField.options[linkNo].title;
		optionSpan = document.createElement('span');
		optionSpan = document.createTextNode(selectField.options[linkNo].text);
	} else {
		newText = document.createTextNode(selectField.options[linkNo].text);
	}
	if (selectField.options[linkNo].title.indexOf('image') != -1) {
		if (textVar.childNodes.length > 1) textVar.removeChild(textVar.childNodes[0]);
		textVar.replaceChild(newText, textVar.childNodes[0]);	
		textVar.appendChild(optionSpan);	
	} else {
		if (textVar.childNodes.length > 1) textVar.removeChild(textVar.childNodes[0]);
		textVar.replaceChild(newText, textVar.childNodes[0]);	
	}
	if (selectField.onchange && all_selects)
		{
			eval(selectField.onchange());
		}
}
//showing options
function showOptions(g) {
		_elem = document.getElementById("optionsDiv"+g);
		var divArea = document.getElementById("sarea"+g);
		if (active_select && active_select != _elem) {
			active_select.className = active_select.className.replace('optionsDivVisible','optionsDivInvisible');
			active_select.style.height = "auto";
			_active.className = _active.className.replace('selectAreaActive','');
		}
		if(_elem.className.indexOf("optionsDivInvisible") != -1) {
			_elem.style.left = "-9999px";
			_elem.style.top = findPosY(divArea) + _selectHeight + 'px';
			_elem.className = _elem.className.replace('optionsDivInvisible','');
			_elem.className += " optionsDivVisible";
			/*if (_elem.offsetHeight > 200)
			{
				_elem.style.height = "200px";
			}*/
			_elem.style.left = findPosX(divArea) + 'px';
			divArea.className += ' selectAreaActive';
			_active = divArea;
			
			active_select = _elem;
			if(document.documentElement)
			{
				document.documentElement.onclick = hideSelectOptions;
			}
			else
			{
				window.onclick = hideSelectOptions;
			}
		}
		else if(_elem.className.indexOf("optionsDivVisible") != -1) {
			_elem.style.height = "auto";
			_elem.className = _elem.className.replace('optionsDivVisible','');
			_elem.className += " optionsDivInvisible";
			divArea.className = divArea.className.replace('selectAreaActive','');
		}
		
		// for mouseout
		/*_elem.timer = false;
		_elem.onmouseover = function() {
			if (this.timer) clearTimeout(this.timer);
		}
		_elem.onmouseout = function() {
			var _this = this;
			this.timer = setTimeout(function(){
				_this.style.height = "auto";
				_this.className = _this.className.replace('optionsDivVisible','');
				if (_elem.className.indexOf('optionsDivInvisible') == -1)
					_this.className += " optionsDivInvisible";
			},200);
		}*/
}
_active = false;
function hideSelectOptions(e)
{
	if(active_select)
	{
		if(!e) e = window.event;
		var _target = (e.target || e.srcElement);
		if(isElementBefore(_target,'selectArea') == 0 && isElementBefore(_target,'optionsDiv') == 0)
		{
			active_select.className = active_select.className.replace('optionsDivVisible', '');
			active_select.className = active_select.className.replace('optionsDivInvisible', '');
			active_select.className += " optionsDivInvisible";
			_active.className = _active.className.replace('selectAreaActive','');
			active_select = false;

			if(document.documentElement)
			{
				document.documentElement.onclick = function(){};
			}
			else
			{
				window.onclick = null;
			}
		}
	}
}

function isElementBefore(_el,_class)
{
	var _parent = _el;	
	do
	{
		_parent = _parent.parentNode;
	}
	while(_parent && _parent.className != null && _parent.className.indexOf(_class) == -1)
	
	if(_parent.className && _parent.className.indexOf(_class) != -1)
	{
		return 1;
	}
	else
	{
		return 0;
	}
	
}

function findPosY(obj) {
	var posTop = 0;
	while (obj.offsetParent) {posTop += obj.offsetTop; obj = obj.offsetParent;}
	return posTop;
}
function findPosX(obj) {
	var posLeft = 0;
	while (obj.offsetParent) {posLeft += obj.offsetLeft; obj = obj.offsetParent;}
	return posLeft;
}
window.onload = initCastomForms;

faces = new Object();
faces.nextStep = function() {
	$('div#step1').hide();
	$('div#step2').show();
	
	var faces_fiz = $('input#faces0').attr("checked");
	var faces_ur = $('input#faces1').attr("checked");
	
	switch(faces_fiz) {
		case true:
			$('input#faces_select').val(0);
			$('span#faces').html('Физическим лицом');
		break
		default:
			$('input#faces_select').val(1);
			$('span#faces').html('Юридическим лицом');
			$('div#step2 table tr#autosalon').show();
			$('div#step2 table tr td#autosalon').show();
		break
	}
	
	getMarks();
}
faces.step1 = function() {
	$('div#step0').hide();
	$('div#step1').show();
}

review = new Object();
review.nextStep = function() {
	$('div#step1').hide();
	$('div#step2').show();
	
	var faces_fiz = $('input#review0').attr("checked");
	var faces_ur = $('input#review1').attr("checked");
	
	switch(faces_fiz) {
		case true:
			$('select#mark_id').change(review.formModels);
			review.formMarks(0);
			$('input#review_select').val(0);
			$('div#step2 div#auto_none').hide();
		break
		default:
			$('select#mark_id').change(review.formCities);
			$('select#city_id').change(review.formAutosalones);
			review.formMarks(1);
			$('input#review_select').val(1);
			$('div#step2 div#autosalones_none').hide();
		break
	}
	
	getMarks();
}
review.step1 = function() {
	$('div#step0').hide();
	$('div#step1').show();
}

function getMarks() {
	$.post('api.php', {'method':'getMarks', 'face':$('input#faces_select').val()},
	function(data) {
		var content = '<option>-</option>';
		count_marks = data.response.marks.length;
		for(i=0; i<count_marks; i++) {
			content += '<option value="'+data.response.marks[i].id+'">'+data.response.marks[i].name+'</option>';
		}
		$('select#marks').html(content);
	}, 'json');
}

function editCatalogMenu() {
	$('div#header div.replSpan td.replCenter center').prepend('<img style="vertical-align: middle;" alt="bullet" src="/e107_themes/reline/images/bullet2.gif"> <a href="/catalog/edit.html">Каталог</a><br><br>');
	$('div#header div.replSpan td.replCenter center').prepend('<img style="vertical-align: middle;" alt="bullet" src="/e107_themes/reline/images/bullet2.gif"> <a href="/catalog_as/edit.html">Автосалоны</a><br><br>');
}

catalog = new Object();

catalog.getMarks = function() {
	$.post('/api.php', {'method':'catalogGetMarks'},
	function(data) {
		if(data.response.status == 'ok') {
			var content = '<div id="add_mark">Добавить марку</div><ul>';
			var marks = data.response.marks;
			marks_count = data.response.marks.length;
			for(i=0; i<marks_count; i++) {
				content += '<li id="'+marks[i].id+'">'+marks[i].short_name+' <span id="menu2"><span id="edit">Редактировать</span> | <span id="delete">Удалить</span></span></li>';
			}
			content += '</ul>';
			
			$('div#catalog_edit div#content').html(content);
			
			$('div#catalog_edit div#content ul li').hover(
			function(){
				$($(this).find('span#menu2')).show();
			},
			function() {
				$($(this).find('span#menu2')).hide();
			});
			
			$('div#catalog_edit div#content ul li span#menu2 span#edit').click(catalog.editMark);
			$('div#catalog_edit div#content ul li span#menu2 span#delete').click(catalog.deleteMark);
			$('div#catalog_edit div#content div#add_mark').click(catalog.addMark);
		}
	}, 'json');
};

catalog.editMark = function() {
	var id = $(this).parent().parent().attr('id');
	$.post('/api.php', {'method':'catalogGetMark', 'id':id},
	function(data) {
		if(data.response.status == 'ok') {
			var mark = data.response.mark;
			var type = new Array();
			var image = '';
			
			if(mark.type == 0)
				type[0] = 'checked';
			else
				type[1] = 'checked';
			
			if(mark.image != '')
				image = '<div><img src="/uploads_catalog/'+mark.image+'" height="50" /></div>';
			
			content = '<form method="post" action="/m_Request.php" enctype="multipart/form-data">'
					+'<input type="hidden" name="id" value="'+mark.id+'" />'
					+'<input type="hidden" name="method" value="catalog_save_edit_mark" />'
					+'<table class="form1">'
					+'<tr><td>Короткое название</td><td><input type="text" name="short_name" value="'+mark.short_name+'" /></td></tr>'
					+'<tr><td>Полное название</td><td><input type="text" name="name" value="'+mark.name+'" /></td></tr>'
					+'<tr><td>Изображение</td><td><input type="file" name="image" /> '+image+'</td></tr>'
					+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE">'+mark.description+'</textarea></td></tr>'
					+'<tr><td>Локация</td><td><input type="radio" name="location" value="0" '+type[0]+' class="radio" />Иномарка <input type="radio" name="location" value="1" '+type[1]+' class="radio" />Отечественный</td></tr>'
					+'<tr><td>Дескрипшен</td><td><textarea name="head_description" class="meta_textarea">'+mark.head_description+'</textarea></td></tr>'
					+'<tr><td>Ключевые слова</td><td><textarea name="head_keywords" class="meta_textarea">'+mark.head_keywords+'</textarea></td></tr>'
					+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
					+'</table></form>';
			$('div#catalog_edit div#content').html(content);
			
			initTinyMCE();
		}
	}, 'json');
}
catalog.addMark = function() {
	content = '<form method="post" action="/m_Request.php" enctype="multipart/form-data">'
			+'<input type="hidden" name="method" value="catalog_save_add_mark" />'
			+'<table class="form1">'
			+'<tr><td>Короткое название</td><td><input type="text" name="short_name" /></td></tr>'
			+'<tr><td>Полное название</td><td><input type="text" name="name" /></td></tr>'
			+'<tr><td>Изображение</td><td><input type="file" name="image" /></td></tr>'
			+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE"></textarea></td></tr>'
			+'<tr><td>Локация</td><td><input type="radio" name="location" value="0" checked class="radio" />Иномарка <input type="radio" name="location" value="1" class="radio" />Отечественный</td></tr>'
			+'<tr><td>Дескрипшен</td><td><textarea name="head_description" class="meta_textarea"></textarea></td></tr>'
			+'<tr><td>Ключевые слова</td><td><textarea name="head_keywords" class="meta_textarea"></textarea></td></tr>'
			+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
			+'</table></form>';
	$('div#catalog_edit div#content').html(content);
	
	initTinyMCE();
}
catalog.deleteMark = function() {
	var id = $(this).parent().parent().attr('id');
	location.href = '/m_Request.php?request=catalog&method=delete_mark&id='+id;
}

catalog.getModelsDesc = function() {
	$.post('/api.php', {'method':'catalogGetModelsDesc'},
	function(data) {
		if(data.response.status == 'ok') {
			var content = '<div id="add_modelDesc">Добавить модель (описание)</div><ul>';
			var models = data.response.models;
			models_count = data.response.models.length;
			for(i=0; i<models_count; i++) {
				content += '<li id="'+models[i].id+'">'+models[i].short_name+' <span id="menu2"><span id="edit">Редактировать</span> | <span id="delete">Удалить</span></span></li>';
			}
			content += '</ul>';
			
			$('div#catalog_edit div#content').html(content);
			
			$('div#catalog_edit div#content ul li').hover(
			function(){
				$($(this).find('span#menu2')).show();
			},
			function() {
				$($(this).find('span#menu2')).hide();
			});
			
			$('div#catalog_edit div#content ul li span#menu2 span#edit').click(catalog.editModelDesc);
			$('div#catalog_edit div#content ul li span#menu2 span#delete').click(catalog.deleteModelDesc);
			$('div#catalog_edit div#content div#add_modelDesc').click(catalog.addModelDesc);
		}
	}, 'json');
};
catalog.addModelDesc = function() {
	$.post('/api.php', {'method':'catalogGetModelMarks'},
	function(data) {
		var marks = '';
		var model = data.response.model;
		count_marks = model.marks.length;
		
		for(i=0; i<count_marks; i++) {
			marks += '<option value="'+model.marks[i].id+'">'+model.marks[i].short_name+'</option>';
		}
		
		content = '<form method="post" action="/m_Request.php" enctype="multipart/form-data">'
				+'<input type="hidden" name="method" value="catalog_save_add_model_desc" />'
				+'<table class="form1">'
				+'<tr><td>Марка</td><td><select name="mark">'+marks+'</select></td></tr>'
				+'<tr><td>Короткое название</td><td><input type="text" name="short_name" /></td></tr>'
				+'<tr><td>Полное название</td><td><input type="text" name="name" /></td></tr>'
				+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE"></textarea></td></tr>'
				+'<tr><td>Дескрипшен</td><td><textarea name="head_description" class="meta_textarea"></textarea></td></tr>'
				+'<tr><td>Ключевые слова</td><td><textarea name="head_keywords" class="meta_textarea"></textarea></td></tr>'
				+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
				+'</table></form>';
		$('div#catalog_edit div#content').html(content);
		
		initTinyMCE();
	}, 'json');
}
catalog.editModelDesc = function() {
	var id = $(this).parent().parent().attr('id');
	$.post('/api.php', {'method':'catalogGetModelDesc', 'id':id},
	function(data) {
		if(data.response.status == 'ok') {
			var marks = '';
			var model = data.response.model;
			count_marks = model.marks.length;
			
			for(i=0; i<count_marks; i++) {
				marks += '<option value="'+model.marks[i].id+'" '+(model.mark_select == model.marks[i].id ? 'selected="selected"' : '')+'>'+model.marks[i].short_name+'</option>';
			}
			
			content = '<form method="post" action="/m_Request.php" enctype="multipart/form-data">'
					+'<input type="hidden" name="id" value="'+model.id+'" />'
					+'<input type="hidden" name="method" value="catalog_save_edit_model_desc" />'
					+'<table class="form1">'
					+'<tr><td>Марка</td><td><select name="mark">'+marks+'</select></td></tr>'
					+'<tr><td>Короткое название</td><td><input type="text" name="short_name" value="'+model.short_name+'" /></td></tr>'
					+'<tr><td>Полное название</td><td><input type="text" name="name" value="'+model.name+'" /></td></tr>'
					+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE">'+model.description+'</textarea></td></tr>'
					+'<tr><td>Дескрипшен</td><td><textarea name="head_description" class="meta_textarea">'+model.head_description+'</textarea></td></tr>'
					+'<tr><td>Ключевые слова</td><td><textarea name="head_keywords" class="meta_textarea">'+model.head_keywords+'</textarea></td></tr>'
					+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
					+'</table></form>';
			$('div#catalog_edit div#content').html(content);
			
			initTinyMCE();
		}
	}, 'json');
}
catalog.deleteModelDesc = function() {
	var id = $(this).parent().parent().attr('id');
	location.href = '/m_Request.php?request=catalog&method=delete_model_desc&id='+id;
}

catalog.getModels = function() {
	$.post('/api.php', {'method':'catalogGetModels'},
	function(data) {
		if(data.response.status == 'ok') {
			var content = '<div id="add_model">Добавить модель</div><ul>';
			var models = data.response.models;
			models_count = data.response.models.length;
			for(i=0; i<models_count; i++) {
				content += '<li id="'+models[i].id+'">'+models[i].name+' <span id="menu2"><span id="edit">Редактировать</span> | <span id="delete">Удалить</span></span></li>';
			}
			content += '</ul>';
			
			$('div#catalog_edit div#content').html(content);
			
			$('div#catalog_edit div#content ul li').hover(
			function(){
				$($(this).find('span#menu2')).show();
			},
			function() {
				$($(this).find('span#menu2')).hide();
			});
			
			$('div#catalog_edit div#content ul li span#menu2 span#edit').click(catalog.editModels);
			$('div#catalog_edit div#content ul li span#menu2 span#delete').click(catalog.deleteModels);
			$('div#catalog_edit div#content div#add_model').click(catalog.addModels);
		}
	}, 'json');
};
catalog.addModels = function() {
	$.post('/api.php', {'method':'catalogGetModelMarks'},
	function(data) {
		var marks = '';
		var model = data.response.model;
		count_marks = model.marks.length;
		
		for(i=0; i<count_marks; i++) {
			marks += '<option value="'+model.marks[i].id+'">'+model.marks[i].name+'</option>';
		}
		
		content = '<form method="post" action="/m_Request.php" enctype="multipart/form-data">'
				+'<input type="hidden" name="method" value="catalog_save_add_model" />'
				+'<table class="form1">'
				+'<tr><td>Марка</td><td><select name="mark">'+marks+'</select></td></tr>'
				+'<tr><td>Название</td><td><input type="text" name="name" /></td></tr>'
				+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE"></textarea></td></tr>'
				+'<tr><td>Изображение 1</td><td><input type="file" name="image1" /></td></tr>'
				+'<tr><td>Изображение 2</td><td><input type="file" name="image2" /></td></tr>'
				+'<tr><td>Изображение 3</td><td><input type="file" name="image3" /></td></tr>'
				+'<tr><td>Изображение 4</td><td><input type="file" name="image4" /></td></tr>'
				+'<tr><td>Дескрипшен</td><td><textarea name="head_description" class="meta_textarea"></textarea></td></tr>'
				+'<tr><td>Ключевые слова</td><td><textarea name="head_keywords" class="meta_textarea"></textarea></td></tr>'
				+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
				+'</table></form>';
		$('div#catalog_edit div#content').html(content);
		initTinyMCE();
	}, 'json');
}
catalog.editModels = function() {
	var id = $(this).parent().parent().attr('id');
	$.post('/api.php', {'method':'catalogGetModel', 'id':id},
	function(data) {
		if(data.response.status == 'ok') {
			var images = Array('','','','');
			var marks = '';
			var model = data.response.model;
			count_marks = model.marks.length;
			
			if(model.images1 != '')
				images[0] = '<div><img src="/uploads_catalog/'+model.images1+'" height="50" /></div>';
			if(model.images2 != '')
				images[1] = '<div><img src="/uploads_catalog/'+model.images2+'" height="50" /></div>';
			if(model.images3 != '')
				images[2] = '<div><img src="/uploads_catalog/'+model.images3+'" height="50" /></div>';
			if(model.images4 != '')
				images[3] = '<div><img src="/uploads_catalog/'+model.images4+'" height="50" /></div>';
			
			for(i=0; i<count_marks; i++) {
				marks += '<option value="'+model.marks[i].id+'" '+(model.mark_select == model.marks[i].id ? 'selected="selected"' : '')+'>'+model.marks[i].name+'</option>';
			}
			
			content = '<form method="post" action="/m_Request.php" enctype="multipart/form-data">'
					+'<input type="hidden" name="id" value="'+model.id+'" />'
					+'<input type="hidden" name="method" value="catalog_save_edit_model" />'
					+'<table class="form1">'
					+'<tr><td>Марка</td><td><select name="mark">'+marks+'</select></td></tr>'
					+'<tr><td>Название</td><td><input type="text" name="name" value="'+model.name+'" /></td></tr>'
					+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE">'+model.description+'</textarea></td></tr>'
					+'<tr><td>Изображение 1</td><td><input type="file" name="image1" /> '+images[0]+'</td></tr>'
					+'<tr><td>Изображение 2</td><td><input type="file" name="image2" /> '+images[1]+'</td></tr>'
					+'<tr><td>Изображение 3</td><td><input type="file" name="image3" /> '+images[2]+'</td></tr>'
					+'<tr><td>Изображение 4</td><td><input type="file" name="image4" /> '+images[3]+'</td></tr>'
					+'<tr><td>Дескрипшен</td><td><textarea name="head_description" class="meta_textarea">'+model.head_description+'</textarea></td></tr>'
					+'<tr><td>Ключевые слова</td><td><textarea name="head_keywords" class="meta_textarea">'+model.head_keywords+'</textarea></td></tr>'
					+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
					+'</table></form>';
			$('div#catalog_edit div#content').html(content);
			initTinyMCE();
		}
	}, 'json');
}
catalog.deleteModels = function() {
	var id = $(this).parent().parent().attr('id');
	location.href = '/m_Request.php?request=catalog&method=delete_model&id='+id;
}

listPhotosCatalog = function(e) {
	var img = $(this).attr('class');
	$('#photo_oneCatalog img').attr({'src':'/uploads_catalog/'+img});
}

catalog.getMarksAs = function() {
	$.post('/api.php', {'method':'catalogGetMarksAs'},
	function(data) {
		if(data.response.status == 'ok') {
			var content = '<div id="add_mark">Добавить марку</div><ul>';
			var marks = data.response.marks;
			marks_count = data.response.marks.length;
			for(i=0; i<marks_count; i++) {
				content += '<li id="'+marks[i].id+'">'+marks[i].name+' <span id="menu2"><span id="edit">Редактировать</span> | <span id="delete">Удалить</span></span></li>';
			}
			content += '</ul>';
			
			$('div#catalog_edit div#content').html(content);
			
			$('div#catalog_edit div#content ul li').hover(
			function(){
				$($(this).find('span#menu2')).show();
			},
			function() {
				$($(this).find('span#menu2')).hide();
			});
			
			$('div#catalog_edit div#content ul li span#menu2 span#edit').click(catalog.editMarkAs);
			$('div#catalog_edit div#content ul li span#menu2 span#delete').click(catalog.deleteMarkAs);
			$('div#catalog_edit div#content div#add_mark').click(catalog.addMarkAs);
		}
	}, 'json');
};

catalog.editMarkAs = function() {
	var id = $(this).parent().parent().attr('id');
	$.post('/api.php', {'method':'catalogGetMarkAs', 'id':id},
	function(data) {
		if(data.response.status == 'ok') {
			var mark = data.response.mark;
			var type = new Array();
			var image = '';
			
			if(mark.type == 0)
				type[0] = 'checked';
			else
				type[1] = 'checked';
			
			if(mark.image != '')
				image = '<div><img src="/uploads_catalog/'+mark.image+'" height="50" /></div>';
			
			content = '<form method="post" action="/m_RequestV2.php" enctype="multipart/form-data">'
					+'<input type="hidden" name="id" value="'+mark.id+'" />'
					+'<input type="hidden" name="method" value="catalog_save_edit_mark_as" />'
					+'<table class="form1">'
					+'<tr><td>Название</td><td><input type="text" name="name" value="'+mark.name+'" /></td></tr>'
					+'<tr><td>Локация</td><td><input type="radio" name="location" value="0" '+type[0]+' class="radio" />Иномарка <input type="radio" name="location" value="1" '+type[1]+' class="radio" />Отечественный</td></tr>'
					+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
					+'</table></form>';
			$('div#catalog_edit div#content').html(content);
			
			initTinyMCE();
		}
	}, 'json');
}
catalog.addMarkAs = function() {
	content = '<form method="post" action="/m_RequestV2.php" enctype="multipart/form-data">'
			+'<input type="hidden" name="method" value="catalog_save_add_mark_as" />'
			+'<table class="form1">'
			+'<tr><td>Название</td><td><input type="text" name="name" /></td></tr>'
			+'<tr><td>Локация</td><td><input type="radio" name="location" value="0" checked class="radio" />Иномарка <input type="radio" name="location" value="1" class="radio" />Отечественный</td></tr>'
			+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
			+'</table></form>';
	$('div#catalog_edit div#content').html(content);
	
	initTinyMCE();
}
catalog.deleteMarkAs = function() {
	var id = $(this).parent().parent().attr('id');
	location.href = '/m_RequestV2.php?request=catalog&method=delete_mark_as&id='+id;
}

catalog.getCitiesAs = function() {
	$.post('/api.php', {'method':'catalogGetCitiesAs'},
	function(data) {
		if(data.response.status == 'ok') {
			var content = '<div id="add_mark">Добавить Город</div><ul>';
			var cities = data.response.cities;
			cities_count = data.response.cities.length;
			for(i=0; i<cities_count; i++) {
				content += '<li id="'+cities[i].id+'">'+cities[i].name+' <span id="menu2"><span id="edit">Редактировать</span> | <span id="delete">Удалить</span></span></li>';
			}
			content += '</ul>';
			
			$('div#catalog_edit div#content').html(content);
			
			$('div#catalog_edit div#content ul li').hover(
			function(){
				$($(this).find('span#menu2')).show();
			},
			function() {
				$($(this).find('span#menu2')).hide();
			});
			
			$('div#catalog_edit div#content ul li span#menu2 span#edit').click(catalog.editCityAs);
			$('div#catalog_edit div#content ul li span#menu2 span#delete').click(catalog.deleteCityAs);
			$('div#catalog_edit div#content div#add_mark').click(catalog.addCityAs);
		}
	}, 'json');
};

catalog.editCityAs = function() {
	var id = $(this).parent().parent().attr('id');
	$.post('/api.php', {'method':'catalogGetCityAs', 'id':id},
	function(data) {
		if(data.response.status == 'ok') {
			var city = data.response.city;
			
			content = '<form method="post" action="/m_RequestV2.php" enctype="multipart/form-data">'
					+'<input type="hidden" name="id" value="'+city.id+'" />'
					+'<input type="hidden" name="method" value="catalog_save_edit_city_as" />'
					+'<table class="form1">'
					+'<tr><td>Название</td><td><input type="text" name="name" value="'+city.name+'" /></td></tr>'
					+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
					+'</table></form>';
			$('div#catalog_edit div#content').html(content);
			
			initTinyMCE();
		}
	}, 'json');
}
catalog.addCityAs = function() {
	content = '<form method="post" action="/m_RequestV2.php" enctype="multipart/form-data">'
			+'<input type="hidden" name="method" value="catalog_save_add_city_as" />'
			+'<table class="form1">'
			+'<tr><td>Название</td><td><input type="text" name="name" /></td></tr>'
			+'<tr><td colspan="2"><input type="submit" class="btn" value="Сохранить" /></td></tr>'
			+'</table></form>';
	$('div#catalog_edit div#content').html(content);
	
	initTinyMCE();
}
catalog.deleteCityAs = function() {
	var id = $(this).parent().parent().attr('id');
	location.href = '/m_RequestV2.php?request=catalog_as&method=delete_city_as&id='+id;
}


catalog.getAs = function() {
	$.post('/api.php', {'method':'catalogGetAs'},
	function(data) {
		if(data.response.status == 'ok') {
			var content = '<div id="add_mark">Добавить Автосалон</div><ul>';
			var as = data.response.as;
			var as_count = as.length;
			
			for(i=0; i<as_count; i++) {
				content += '<li id="'+as[i].id+'">'+as[i].name+' <span id="menu2"><span id="edit">Редактировать</span> | <span id="delete">Удалить</span></span></li>';
			}
			
			content += '</ul>';
			
			$('div#catalog_edit div#content').html(content);
			
			$('div#catalog_edit div#content ul li').hover(
			function(){
				$($(this).find('span#menu2')).show();
			},
			function() {
				$($(this).find('span#menu2')).hide();
			});
			
			$('div#catalog_edit div#content ul li span#menu2 span#edit').click(catalog.editAs);
			$('div#catalog_edit div#content ul li span#menu2 span#delete').click(catalog.deleteAs);
			$('div#catalog_edit div#content div#add_mark').click(catalog.addAs);
		}
	}, 'json');
};
catalog.editAs = function() {
	var id = $(this).parent().parent().attr('id');
	
	$.post('/api.php', {'method':'catalogGetAsOne', 'id':id},
	function(data) {
		tmp = data;
		$.post('/api.php', {'method':'citiesAndMarks'},
		function(data) {
			data2 = tmp.response;
			if(data.response.status == 'ok') {
				var cities = data.response.cities;
				var cities_html = '';
				for(var key in cities) {
					cities_html += '<option value="'+cities[key].id+'" '+(data2.as.city_id == cities[key].id ? 'selected' : '')+'>'+cities[key].name+'</option>';
				}
				
				var marks = data.response.marks;
				var marks_html = '';
				for(var key in marks) {
					marks_html += '<li><input type="checkbox" name="mark_'+marks[key].id+'" value="'+marks[key].id+'" '+(data2.as.marks[marks[key].id] ? 'checked' : '')+' />'+marks[key].name+'</li>';
				}
				
				content = '<form method="post" action="/m_RequestV2.php" enctype="multipart/form-data">'
						+'<input type="hidden" name="method" value="catalog_save_edit_as" />'
						+'<input type="hidden" name="id" value="'+data2.as.id+'" />'
						+'<table class="form1">'
						+'<tr><td>Название</td><td><input type="text" name="name" value="'+data2.as.name+'" /></td></tr>'
						+'<tr><td>Марки</td><td class="marks"><ul>'+marks_html+'</ul></td></tr>'
						+'<tr><td>Город</td><td><select name="city">'+cities_html+'</select></td></tr>'
						+'<tr><td>Адрес</td><td><input type="text" name="address" value="'+data2.as.address+'" /></td></tr>'
						+'<tr><td>Сайт</td><td><input type="text" name="site" value="'+data2.as.site+'" /></td></tr>'
						+'<tr><td>Email</td><td><input type="text" name="email" value="'+data2.as.email+'" /></td></tr>'
						+'<tr><td>Телефоны</td><td><input type="text" name="phones" value="'+data2.as.phones+'" /></td></tr>'
						+'<tr><td>Факс</td><td><input type="text" name="fax" value="'+data2.as.fax+'" /></td></tr>'
						+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE">'+data2.as.description+'</textarea></td></tr>'
						+'<tr><td colspan="2"><input type="submit" class="btn" name="submit" value="Сохранить" /></td></tr>'
						+'</table></form>';
				$('div#catalog_edit div#content').html(content);
				
				initTinyMCE();
			}
		}, 'json');
	}, 'json');
}
catalog.addAs = function() {
	$.post('/api.php', {'method':'citiesAndMarks'},
	function(data) {
		if(data.response.status == 'ok') {
			var cities = data.response.cities;
			var cities_html = '';
			for(var key in cities) {
				cities_html += '<option value="'+cities[key].id+'">'+cities[key].name+'</option>';
			}
			
			var marks = data.response.marks;
			var marks_html = '';
			for(var key in marks) {
				marks_html += '<li><input type="checkbox" name="mark_'+marks[key].id+'" value="'+marks[key].id+'">'+marks[key].name+'</li>';
			}
			
			content = '<form method="post" action="/m_RequestV2.php" enctype="multipart/form-data">'
					+'<input type="hidden" name="method" value="catalog_save_add_as" />'
					+'<table class="form1">'
					+'<tr><td>Название</td><td><input type="text" name="name" /></td></tr>'
					+'<tr><td>Марки</td><td class="marks"><ul>'+marks_html+'</ul></td></tr>'
					+'<tr><td>Город</td><td><select name="city">'+cities_html+'</select></td></tr>'
					+'<tr><td>Адрес</td><td><input type="text" name="address" /></td></tr>'
					+'<tr><td>Сайт</td><td><input type="text" name="site" /></td></tr>'
					+'<tr><td>Email</td><td><input type="text" name="email" /></td></tr>'
					+'<tr><td>Телефоны</td><td><input type="text" name="phones" /></td></tr>'
					+'<tr><td>Факс</td><td><input type="text" name="fax" /></td></tr>'
					+'<tr><td>Описание</td><td><textarea name="description" id="tinyMCE"></textarea></td></tr>'
					+'<tr><td colspan="2"><input type="submit" class="btn" name="submit" value="Сохранить" /></td></tr>'
					+'</table></form>';
			$('div#catalog_edit div#content').html(content);
			
			initTinyMCE();
		}
	}, 'json');
}
catalog.deleteAs = function() {
	var id = $(this).parent().parent().attr('id');
	location.href = '/m_RequestV2.php?request=catalog_as&method=delete_as&id='+id;
}

catalog.selectCity = function(id) {
	tmp = id;
	$.post('/api.php', {'method':'catalogGetCitiesAs'},
	function(data) {
		data = data.response;
		if(data.status == 'ok') {
			$('body').append('<div id="opacity_modal"></div>');
			$('body').append('<div id="modal_select_city"></div>');
			
			var option = '';
			var selectedCity = '';
			
			for(var key in data.cities) {
				if(option == '')
					selectedCity = data.cities[key].id;
				
				option += '<option value="'+data.cities[key].id+'">'+data.cities[key].name+'</option>';
			}
			
			$('div#modal_select_city').html('<div style="font-weight:bold;">Выберите город:</div><form name="select_city_form"><select name="modal_select_citySelect" id="modal_select_citySelect">'+option+'</select> <span id="selectedCity" class="'+selectedCity+'"><input type="button" value="OK"></span></form>');
			var margin_left = $('div#modal_select_city').width() / 2;
			$('div#modal_select_city').css({'margin-left':'-'+margin_left+'px'});
			
			$('div#opacity_modal').height($(document).height());
			
			$('#modal_select_citySelect').change(function(){
				var option_value = document.select_city_form.modal_select_citySelect.value;
				$('#selectedCity').attr({'class':option_value});
			});
			
			//$('#modal_select_citySelect option').click(function(){
			//	var option_value = $(this).attr('value');
			//	$('#selectedCity').attr({'class':option_value});
			//	console.log(option_value);
			//});
			
			$('#selectedCity').click(function(){
				var url = 'http://'+location.host+'/catalog_as/autosalones_'+tmp+'_'+$(this).attr('class')+'.html';
				location.href = url;
			});
		}
	}, 'json');
	return false;
}

review.selectCity = function(id) {
	tmp = id;
	$.post('/api.php', {'method':'catalogGetCitiesAs'},
	function(data) {
		data = data.response;
		if(data.status == 'ok') {
			$('body').append('<div id="opacity_modal"></div>');
			$('body').append('<div id="modal_select_city"></div>');
			
			var option = '';
			var selectedCity = '';
			
			for(var key in data.cities) {
				if(option == '')
					selectedCity = data.cities[key].id;
				
				option += '<option value="'+data.cities[key].id+'">'+data.cities[key].name+'</option>';
			}
			
			$('div#modal_select_city').html('<div style="font-weight:bold;">Выберите город:</div><form name="select_city_form"><select name="modal_select_citySelect" id="modal_select_citySelect">'+option+'</select> <span id="selectedCity" class="'+selectedCity+'"><input type="button" value="OK"></span></form>');
			var margin_left = $('div#modal_select_city').width() / 2;
			$('div#modal_select_city').css({'margin-left':'-'+margin_left+'px'});
			
			$('div#opacity_modal').height($(document).height());
			
			$('#modal_select_citySelect').change(function(){
				var option_value = document.select_city_form.modal_select_citySelect.value;
				$('#selectedCity').attr({'class':option_value});
			});
			
			//$('#modal_select_citySelect option').click(function(){
			//	var option_value = $(this).attr('value');
			//	$('#selectedCity').attr({'class':option_value});
			//	console.log(option_value);
			//});
			
			$('#selectedCity').click(function(){
				var url = 'http://'+location.host+'/otzivi_as/autosalones_'+tmp+'_'+$(this).attr('class')+'.html';
				location.href = url;
			});
		}
	}, 'json');
	return false;
}

function nav_submenu() {
	$($(this).parent()).find('ul').show();
	return false;
}


$(document).ready(function() {
	$('input#next_step').click(faces.nextStep);
	$('div#step0 a#btn2').click(faces.step1);
	$('input#review_next_step').click(review.nextStep);
	$('div#step0 a#btn3').click(review.step1);
	$('div#catalog_edit ul#menu li#marks').click(catalog.getMarks);
	$('div#catalog_edit ul#menu li#models_desc').click(catalog.getModelsDesc);
	$('div#catalog_edit ul#menu li#models').click(catalog.getModels);
	
	$('div#catalog_edit ul#menu li#marks_as').click(catalog.getMarksAs);
	$('div#catalog_edit ul#menu li#cities_as').click(catalog.getCitiesAs);
	$('div#catalog_edit ul#menu li#as').click(catalog.getAs);
	
	$('div#listPhotosCatalog span#list').click(listPhotosCatalog);
	
	$('ul.nav li a#submenu').click(nav_submenu);
});
