var curent_action_confirm = "";

//Функция используется всеми частями интер



/**
 * Эмитирует клик по левому пункту меню (с подтверждением).
 *
 * Аналогично jspub_click, но перед тем как осуществить переход выводится сообщение
 * и переход осуществиться только в том случае, если пользователь подтвердит это 
 * сообщение (тоесть ответит "Yes")
 * @param string dialog_action URL, на который осуществляем переход
 * @param string dialog_message Сообщение, которое нужно подтвердить, прежде чем будет осуществлён переход
 */

function jspub_confirm(dialog_action, dialog_message)
{
	curent_action_confirm = dialog_action;
	Ext.MessageBox.confirm('', dialog_message, dialog_confirm_action);
	return false;

}

/**
 * Сохраняеи значение в куках пользователя под определённым именем
 *
 */
function jspub_cookie_set(cookieName, cookieValue, expires, path, domain, secure) 
{
	document.cookie =
		escape(cookieName) + '=' + escape(cookieValue)
		+ (expires ? '; expires=' + expires.toGMTString() : '')
		+ (path ? '; path=' + path : '')
		+ (domain ? '; domain=' + domain : '')
		+ (secure ? '; secure' : '');
}

/**
 * Возвращает из Кук значение по его имени
 *
 */

function jspub_cookie_get(cookieName) 
{
	var cookieValue = '';
	var posName = document.cookie.indexOf(escape(cookieName) + '=');
	
	if (posName != -1) 
	{
		var posValue = posName + (escape(cookieName) + '=').length;
		var endPos = document.cookie.indexOf(';', posValue);
		if (endPos != -1) 
			cookieValue = unescape(document.cookie.substring(posValue, endPos));
		else 
			cookieValue = unescape(document.cookie.substring(posValue));
	}
	return (cookieValue);
}



/**
 * Эмитирует клик по левому пункту меню.
 *
 * Функция используется для отправки любых GET (и только их) запросов модулю
 * в качестве параметра используется URL для перехода, который должен начинаться с 
 * идентификатора пугкта левого меню.
 * @param string lnk URL, на который осуществляем переход
 */

function jspub_click(lnk)
{
	start_interface.link_go(lnk);
	return false;
}


//Вызывается из яваскрипта. В качестве elem_check в зависиомсти от значения 
//параметра "checked" которой либы выключаются, либо включаются элементы, 
//переданные в массиве arr_elem

/**
 * Включает или выключает элементы HTML элементы административного интерфейса.
 * 
 * Функция производит выключение (или включение) заданных элметов в зависимости от того
 * отмечена или не отмечена галочка, переданная в качестве переданного параметра.
 * @param string|Object elem_check Передаётся идентификатор чекбокса или сам объект чекбокса (если он Ext)
 * @param array dialog_message Массив идентификаторов (или объектов Ext`а) которые нужно включить или выключить.
 */

function jspub_disabled_change(elem_check, arr_elem)
{
	//В качестве параметра arr_elem может быть переданна
	//либо строка с ID объекта, сам объект, либо массмв
	//и того и другого. 
	//Прежде всего всего пройдёмся по arr_element, и сделаем так,
	//что бы это всегда был массив объектов, в независимости от того
	//что было на входе
	
	var elements = new Array();
	if (typeof(arr_elem) == "string")
	{
		elements[elements.length] = arr_elem;
	}
	else
	{
		//Значит передаётся	либо массив, либо объект
		if (arr_elem.length > 0)
			elements = arr_elem;
		else
			elements[elements.length] = arr_elem;
	}
	
	//Теперь у нас всегда массив, пройдёмся по нему и сделаем 
	//строки - объектами.
	for (i = 0; i < elements.length; i ++)
	{
		if (typeof(elements[i]) == "string")
			elements[i] = document.getElementById(elements[i]);
	}
	
	//Теперь в массиве только объекты 
	
	//Определим, нам надо выключить или включить	
	if (typeof(elem_check) == "string")
	{
		var chk_value = document.getElementById(elem_check).checked;
	}
	else
	{
		var chk_value = elem_check.getValue();
	}
		
	for (i = 0; i < elements.length; i ++)
	{
		var el = elements[i];
		//Теперь надо как-то определить что это за объект, потому что в этом случае нам его нужно будет по
		// разному выключать
		//alert(Ext.type(el));
		
		if (Ext.type(el) == "element")
		{
			el.disabled = chk_value;			
		} else 
		{
			if (chk_value)
				elements[i].disable();
			else
				elements[i].enable();				
		}
	}
}




/**
 * Производит отправку формы
 *
 *  
 * @param Object form Обхект Form (Ext) или ID HTML объекта FORM, которую отправляем
 * @param string url URL, на который осуществляем отсылку
 */

function jspub_form_submit(form, url)
{
	//Обшие параметры
	if (window.XMLHttpRequest) { // Mozilla, Safari,...
		http_request = new XMLHttpRequest();
		if (http_request.overrideMimeType) {
			// set type accordingly to anticipated content type
			//http_request.overrideMimeType('text/xml');
			http_request.overrideMimeType('text/html');
		}
		} else if (window.ActiveXObject) { // IE
			try {
				http_request = new ActiveXObject("Msxml2.XMLHTTP");
			} catch (e) {
			try {
				http_request = new ActiveXObject("Microsoft.XMLHTTP");
			} catch (e) {}
		}
	}
	
	if (!http_request) {
		alert('Cannot create XMLHTTP instance');
		return false;
	}
	
	var parameters = new Array();
	var i = 0;

	//Необходимо закодировать нужные нам параметры и передать их
	//при этом в зависиомсти от того, что нам туда передали в form
	if (typeof(form) == "string")
	{
		//Это обычная форма.  
		var post_form = document.getElementById(form);
		for (i = 0; i < post_form.elements.length; i++)
		{
			var tmp_val = encodeURI(post_form.elements[i].value);
			//Галочку превратив вот такое
			if (post_form.elements[i].type == "checkbox")
			{
				tmp_val = 0;
				if (post_form.elements[i].checked)
					tmp_val = 1;
			}
			//Нужно обработать и текстареа
			//if (post_form.elements[i].type == "textarea")
			//{
			//	tmp_val = encodeURI("Обработали");
			//}
			
			parameters[i] = post_form.elements[i].name + "=" + tmp_val;
		}		  
	} else
	{
		//Это объект Ext  
		var fields = form.getValues();
		for (key in fields)
		{
			if (Ext.get(key) === null)
			{
				parameters[i] = key + "=";
			} else
			{
				parameters[i] = key + "="+encodeURI(Ext.get(key).getValue());
			}
			i++;
		}
			
	}
	//Добавим в форму параметр, который будет указывать ядру на то, что 
	//данные были отправлены таким образом и их нужно перекодировать
	parameters[parameters.length] = '_kernel_form_code=cp1251';
	//Теперь непосредственно отсылка формы 	  
	http_request.open('POST', url, false);
	http_request.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
	http_request.setRequestHeader("Content-length", parameters.length);
	http_request.setRequestHeader("Connection", "close");
	http_request.send(parameters.join("&"));
	//Теперь получим результат (если его вернули правильно)
	//Обработаем и предпримим соответсвующие меры
	var post_res = Ext.util.JSON.decode(http_request.responseText);
	if (typeof(post_res) == "object")
	{
		//Обрабатываем ответ
		//сначала проверка на наличие ошибок
		if (parseInt(post_res.errore_count) > 0)
		{
			Ext.MessageBox.alert('Errore', Base64.decode(post_res.errore_text));
		} else
		{
			//Значит ошибок небыло и нужно вывести сообщение с результатом...
			var msg_label = Base64.decode(post_res.result_label);
			var msg = Base64.decode(post_res.result_message);
			if (msg != "")
				Ext.example.msg(msg_label, msg);
			//...и возможно перейти на другой пункт меню
			var id_link =  post_res.redirect;
			if (id_link != "")
			{
				jspub_click(id_link);
			}
		}
	}
	//
	//if (Ext.get(id_insert))
	//	Ext.get(id_insert).update(result, true);
}






/* Функции, используемые только в административном интерфейсе*/



//Функция открывает слой для выбора страницы сайта
//во всех свойствах с типом (страница сайта)
function get_properes_page(EventElement, Object)
{

    if (Object.disabled)
        return true;
	//Очистим содержимое слоя на всяк случай
    Ext.get("ext_layout").dom.innerHTML = "";

    //Сформируем окно
	start_interface.dialog = new Ext.LayoutDialog("ext_layout", {
		modal:false,
		autoScroll: true,
		autoCreate: true,
		shadow:false,
		proxyDrag: false,
		resizable: true,
		width: 200,
		height: 300,
        center:{
            alwaysShowTabs: false,
            autoScroll:true
        }

	});

	start_interface.dialog.setTitle('Выбор страницы');
	start_interface.dialog.anchorTo(EventElement.getTarget());

	start_interface.select_element = Object;

	start_interface.dialog.addKeyListener(27, start_interface.dialog.hide, start_interface.dialog);

	//Теперь обновим контент внтури окна
	start_interface.dialog.getLayout().getRegion('center').bodyEl.getUpdateManager().update({
						url: "index.php?action=select_page"
						, scope: this
						, discardUrl: false
						, nocache: false
						, timeout: 30
						, scripts: true
					});
	start_interface.dialog.show();
}



//Открывает новое окно для загрухки туда редактора контента
//Используется в свойствах страницы, для вызова редактора контента для конкретной
function go_edit_content(name_file, no_redactor)
{
	//if (!event.srcElement.disabled)
	//{
		var name_edit = 'edit_';
		var left=parseInt(100);
		var top=parseInt(50);
		var width = parseInt(screen.width - 600);
		var height = parseInt(screen.height - 300);

		if (width < 600)
			width = 600;
		
		if (no_redactor)
			var newWin=window.open('/admin/index.php?action=edit_content&file='+name_file+'&edit='+name_edit+'&no_redactor=1', '_blank', 'alwaysRaised=yes,dependent=yes,resizable=yes,titlebar=no,toolbar=no,menubar=no,location=no,status=no,scrollbars=no,left=' + left + ',top=' + top + ',width=' + width +',height='+height,'Content');
		else
			var newWin=window.open('/admin/index.php?action=edit_content&file='+name_file+'&edit='+name_edit, '_blank', 'alwaysRaised=yes,dependent=yes,resizable=yes,titlebar=no,toolbar=no,menubar=no,location=no,status=no,scrollbars=no,left=' + left + ',top=' + top + ',width=' + width +',height='+height,'Content');
		newWin.focus();
		//return 0;
	//}

}







//Скрывает или показывает иконку возможности редактирования
//контента у определённой метки
function show_icon_go_edit_content(obj, id_image)
{
	if (obj == null)
		return

	var id_action = 0;
	if (parseInt(obj.getValue()) > 0 )
		id_action = parseInt(obj.getValue());

	if (document.getElementById(id_image) == null)
		return

	if ((id_action == 1) && (!obj.disabled))
		Ext.get(id_image).setVisible(true, false);
	else
		Ext.get(id_image).setVisible(false, false);
		
}





//Служебная функция для jspub_confirm()
function dialog_confirm_action(btn)
{
	if (btn != 'no')
	{
		start_interface.link_go(curent_action_confirm);
	}
}


//Открывает окно для редактирования или создания нового действия
function show_action_edit(strlink, name)
{

    Ext.get("action_edit").dom.innerHTML = "";

    //Сформируем окно
	start_interface.actiondialog = new Ext.LayoutDialog("action_edit",{
		modal:true,
		autoScroll: true,
		autoCreate: true,
		shadow:false,
		proxyDrag: false,
		resizable: true,
		width: 600,
		height: 400,
        center:{
            alwaysShowTabs: false,
            autoScroll:true
        }
	});

	start_interface.actiondialog.setTitle(name);
	//start_interface.dialog.anchorTo(EventElement.getTarget());

	//start_interface.select_element = Object;
	start_interface.actiondialog.on('hide', update_action_list);
	start_interface.actiondialog.addKeyListener(27, start_interface.actiondialog.hide, start_interface.actiondialog);

	//Теперь обновим контент внтури окна
	start_interface.actiondialog.getLayout().getRegion('center').bodyEl.getUpdateManager().update({
						url: start_interface.global_link + strlink
						, scope: this
						, discardUrl: false
						, nocache: false
						, timeout: 30
						, scripts: true
					});
	//alert(start_interface.global_link + strlink);
	start_interface.actiondialog.show();

}





//Обновляет список выбранных текущих дейсвтвий при редактировании настроек модуля
function update_action_list()
{
	//actions_list_table
	if (Ext.get('actions_list_table') != null)
	{
		Ext.get('actions_list_table').getUpdateManager().update({
						url: start_interface.global_link + 'action_update_list'
						, scope: this
						, discardUrl: false
						, nocache: false
						, timeout: 30
						, scripts: true
					});
	}
}



/**
* Класс для кодирования, декодировния по основанию 64. Используются
* при передаче данных по Ajax
* Base64 encode / decode
* http://www.webtoolkit.info/
*
**/

var Base64 = {

    // private property
    _keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",

    // public method for encoding
    encode : function (input) {
        var output = "";
        var chr1, chr2, chr3, enc1, enc2, enc3, enc4;
        var i = 0;

        input = Base64._utf8_encode(input);

        while (i < input.length) {

            chr1 = input.charCodeAt(i++);
            chr2 = input.charCodeAt(i++);
            chr3 = input.charCodeAt(i++);

            enc1 = chr1 >> 2;
            enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
            enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
            enc4 = chr3 & 63;

            if (isNaN(chr2)) {
                enc3 = enc4 = 64;
            } else if (isNaN(chr3)) {
                enc4 = 64;
            }

            output = output +
            this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) +
            this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4);

        }

        return output;
    },

    // public method for decoding
    decode : function (input) {
        var output = "";
        var chr1, chr2, chr3;
        var enc1, enc2, enc3, enc4;
        var i = 0;
        
        if (input == undefined)
            return "";
            
        input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");

        while (i < input.length) {

            enc1 = this._keyStr.indexOf(input.charAt(i++));
            enc2 = this._keyStr.indexOf(input.charAt(i++));
            enc3 = this._keyStr.indexOf(input.charAt(i++));
            enc4 = this._keyStr.indexOf(input.charAt(i++));

            chr1 = (enc1 << 2) | (enc2 >> 4);
            chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
            chr3 = ((enc3 & 3) << 6) | enc4;

            output = output + String.fromCharCode(chr1);

            if (enc3 != 64) {
                output = output + String.fromCharCode(chr2);
            }
            if (enc4 != 64) {
                output = output + String.fromCharCode(chr3);
            }

        }

        output = Base64._utf8_decode(output);

        return output;

    },

    // private method for UTF-8 encoding
    _utf8_encode : function (string) {
        string = string.replace(/\r\n/g,"\n");
        var utftext = "";

        for (var n = 0; n < string.length; n++) {

            var c = string.charCodeAt(n);

            if (c < 128) {
                utftext += String.fromCharCode(c);
            }
            else if((c > 127) && (c < 2048)) {
                utftext += String.fromCharCode((c >> 6) | 192);
                utftext += String.fromCharCode((c & 63) | 128);
            }
            else {
                utftext += String.fromCharCode((c >> 12) | 224);
                utftext += String.fromCharCode(((c >> 6) & 63) | 128);
                utftext += String.fromCharCode((c & 63) | 128);
            }

        }

        return utftext;
    },

    // private method for UTF-8 decoding
    _utf8_decode : function (utftext) {
        var string = "";
        var i = 0;
        var c = c1 = c2 = 0;

        while ( i < utftext.length ) {

            c = utftext.charCodeAt(i);

            if (c < 128) {
                string += String.fromCharCode(c);
                i++;
            }
            else if((c > 191) && (c < 224)) {
                c2 = utftext.charCodeAt(i+1);
                string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
                i += 2;
            }
            else {
                c2 = utftext.charCodeAt(i+1);
                c3 = utftext.charCodeAt(i+2);
                string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
                i += 3;
            }

        }

        return string;
    }

}



//Функция используется только интерфейсом подсистемы статистики, в 
//дальнейшем нужно перейти на стандартную
function admin_form_submit(url, id_insert, form)
{
	//Обшие параметры
	if (window.XMLHttpRequest) { // Mozilla, Safari,...
		http_request = new XMLHttpRequest();
		if (http_request.overrideMimeType) {
			// set type accordingly to anticipated content type
			//http_request.overrideMimeType('text/xml');
			http_request.overrideMimeType('text/html');
		}
		} else if (window.ActiveXObject) { // IE
			try {
				http_request = new ActiveXObject("Msxml2.XMLHTTP");
			} catch (e) {
			try {
				http_request = new ActiveXObject("Microsoft.XMLHTTP");
			} catch (e) {}
		}
	}
	
	if (!http_request) {
		alert('Cannot create XMLHTTP instance');
		return false;
	}
	
	var parameters = new Array();
	var i = 0;

	//Необходимо закодировать нужные нам параметры и передать их
	//при этом в зависиомсти от того, что нам туда передали в form
	if (typeof(form) == "string")
	{
		//Это обычная форма.  
		var post_form = document.getElementById(form);
		for (i = 0; i < post_form.elements.length; i++)
		{
			parameters[i] = post_form.elements[i].name + "="+encodeURI(post_form.elements[i].value);
		}		  
	} else
	{
		//Это объект Ext  
		var fields = form.getValues();
		for (key in fields)
		{
			if (Ext.get(key) === null)
			{
				parameters[i] = key + "=";
			} else
			{
				parameters[i] = key + "="+encodeURI(Ext.get(key).getValue());
			}
			i++;
		}
			
	}
	
	//Теперь непосредственно отсылка формы 	  
	http_request.open('POST', url, false);
	http_request.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
	http_request.setRequestHeader("Content-length", parameters.length);
	http_request.setRequestHeader("Connection", "close");
	http_request.send(parameters.join("&"));
	result = http_request.responseText;
	if (Ext.get(id_insert))
		Ext.get(id_insert).update(result, true);
}




//Функция выполняет подсвтеку строки с сдействием в настройках модуля, пока не уневерсальна
//Из ней нужно сделать функцию, которой смогли бы пользоваться все модули.
function mouse_select_element(obj, del_class)
{
	var str = Ext.get(obj);
	if (del_class)
		str.removeClass('table_action_select');
	else
		str.addClass('table_action_select');
}


//Обновляет левое меню, в случаях когда необходимо перестроить какой-то блок, или обновить какие-то данные
function update_left_menu(url)
{
	start_interface.innerLayout.getRegion('west').getActivePanel().getUpdateManager().update({
		url: "index.php?action=get_left_menu&"+url
		, scope: start_interface
		, discardUrl: false
		, nocache: false
		, timeout: 30
		, scripts: true
	});
}




function form_submit_include_content_auto()
{
	//Запишем в массив названия, что бы потом перенести из них контент
	for (var i=0; i < start_interface.array_name_edit_content.length; i++)
	{
		form_submit_include_content(start_interface.array_name_edit_content[i])		
	}
	return false;
	//start_interface.array_name_edit_content[] = name_area;
}

//Вызвается в старых модулях, для сабмита формы с редактором контента
//Всего скорей может быть удалена в дальнейшем
function form_submit_include_content(name_area)
{
	if (!name_area)
		name_area = 'content_html';

	//Закрываем редакттор контента в этой области, почле чего всё и сабмититься
	tinyMCE.execCommand('mceRemoveControl', false, name_area);
	return true;
}




// Функция используется в шаблоне main.html активации редактора контента 
function start_include_content(name_area)
{
	if (!name_area)
		name_area = 'content_html';

	//Запишем в массив названия, что бы потом перенести из них контент
	start_interface.array_name_edit_content[start_interface.array_name_edit_content.length] = name_area;
	//alert(start_interface.array_name_edit_content.count)
	
	//Закрываем редакттор контента в этой области, почле чего всё и сабмититься
	tinyMCE.execCommand('mceAddControl', false, name_area);
	return true;
}




//Добовляет к строкам функцию по их образанию
String.prototype.ellipse = function(maxLength){
    if(this.length > maxLength){
        return this.substr(0, maxLength-3) + '...';
    }
    return this;
};
