Your IP : 18.217.141.236


Current Path : /var/www/www-root/data/www/monolith-realty.ru/bitrix/modules/fileman/js/
Upload File :
Current File : /var/www/www-root/data/www/monolith-realty.ru/bitrix/modules/fileman/js/controls.js

var BXConst =
{
	'arColor': ["000000", "993300", "333300", "003300", "003366", "000080", "333399", "333333",
		"800000", "FF6600", "808000", "008000", "008080", "0000FF", "666699", "808080",
		"FF0000", "FF9900", "99CC00", "339966", "33CCCC", "3366FF", "800080", "999999",
		"FF00FF", "FFCC00", "FFFF00", "00FF00", "00FFFF", "00CCFF", "993366", "C0C0C0",
		"FF99CC", "FFCC99", "FFFF99", "CCFFCC", "CCFFFF", "99CCFF", "CC99FF", "FFFFFF"],

	'arColorName': [BX_MESS.CPickClr1, BX_MESS.CPickClr2, BX_MESS.CPickClr3, BX_MESS.CPickClr4, BX_MESS.CPickClr5, BX_MESS.CPickClr6, BX_MESS.CPickClr7, BX_MESS.CPickClr8,
		BX_MESS.CPickClr9, BX_MESS.CPickClr10, BX_MESS.CPickClr11, BX_MESS.CPickClr12, BX_MESS.CPickClr13, BX_MESS.CPickClr14, BX_MESS.CPickClr15, BX_MESS.CPickClr16,
		BX_MESS.CPickClr17, BX_MESS.CPickClr18, BX_MESS.CPickClr19, BX_MESS.CPickClr20, BX_MESS.CPickClr21, BX_MESS.CPickClr22, BX_MESS.CPickClr23, BX_MESS.CPickClr24,
		BX_MESS.CPickClr25, BX_MESS.CPickClr26, BX_MESS.CPickClr27, BX_MESS.CPickClr28, BX_MESS.CPickClr29, BX_MESS.CPickClr30, BX_MESS.CPickClr31, BX_MESS.CPickClr32,
		BX_MESS.CPickClr33, BX_MESS.CPickClr34, BX_MESS.CPickClr35, BX_MESS.CPickClr36, BX_MESS.CPickClr37, BX_MESS.CPickClr38, BX_MESS.CPickClr39, BX_MESS.CPickClr1]
};


/**************************************************************************************
BXButton - class
**************************************************************************************/
function BXButton()
{
	BXButton.prototype._Create = function ()
	{
		var pElement, i, j, obj = this;
		this.className = 'BXButton';

		this.pWnd = this.CreateElement("IMG", {'src': this.src, 'alt': (this.title?this.title:this.name), 'title': (this.title?this.title:this.name), 'width': '20', 'height': '20'});
		this.pWnd.className = 'bxedtbutton';
		if(!this.no_actions || this.no_actions != true) // for context menu
		{
			this.pWnd.onmouseover = this.onMouseOver;
			this.pWnd.onmouseout = this.onMouseOut;
			//addCustomElementEvent(this.pWnd, 'mouseover', this.onMouseOver, this);
			//addCustomElementEvent(this.pWnd, 'mouseout', this.onMouseOut, this);
			addCustomElementEvent(this.pWnd, 'click', this.onClick, this);
			this.pMainObj.AddEventHandler("OnSelectionChange", this._OnSelectionChange, this);
			this.pMainObj.AddEventHandler("OnChangeView", this.OnChangeView, this);
		}
	}

	BXButton.prototype._OnChangeView = function (mode, split_mode)
	{
		mode = (mode=='split'?split_mode:mode);
		if(mode=='code' && !this.codeEditorMode)
		{
			this._prevDisabledState = this.pWnd.disabled;
			this.Disable(true);
		}
		else if(mode=='code' && this.codeEditorMode)
			this.Disable(false);
		else if(!this.codeEditorMode)
			this.Disable(this._prevDisabledState);
	}

	BXButton.prototype.OnChangeView = function (mode, split_mode)
	{
		this._OnChangeView(mode, split_mode);
	}

	BXButton.prototype.Disable = function (bFlag)
	{
		if(bFlag == this.pWnd.disabled)
			return false;
		this.pWnd.disabled = bFlag;
		if(bFlag)
			this.pWnd.className = 'bxedtbuttondisabled';
		else
		{
			if(this.pWnd.checked)
				this.pWnd.className = 'bxedtbuttonset';
			else
				this.pWnd.className = 'bxedtbutton';
		}
	}

	BXButton.prototype.Check = function (bFlag)
	{
		if(bFlag == this.pWnd.checked)
			return false;
		this.pWnd.checked = bFlag;
		if(!this.pWnd.disabled)
		{
			if(this.pWnd.checked)
				this.pWnd.className = 'bxedtbuttonset';
			else
				this.pWnd.className = 'bxedtbutton';
		}
	}

	BXButton.prototype.onMouseOver = function (e)
	{
		if(!this.disabled)
		{
			if(this.checked)
				this.className = 'bxedtbuttonsetover';
			else
				this.className = 'bxedtbuttonover';
		}
	}

	BXButton.prototype.onMouseOut = function (e)
	{
		if(!this.disabled)
		{
			if(this.checked)
				this.className = 'bxedtbuttonset';
			else
				this.className = 'bxedtbutton';
		}
	}

	BXButton.prototype.onClick = function (e)
	{
		if(this.pWnd.disabled) return false;
		this.pMainObj.SetFocus();
		var res = false;
		if(this.handler)
			if(this.handler()!==false)
				res = true;

		if(!res)
			res = this.pMainObj.executeCommand(this.cmd);

		if(!this.bNotFocus)
			this.pMainObj.SetFocus();
		return res;
	}

	BXButton.prototype._OnSelectionChange = function()
	{
		if(this.OnSelectionChange)
			this.OnSelectionChange();
		else if(this.cmd)
		{
			var res;

			if(this.cmd=='Unlink' && !BXFindParentByTagName(this.pMainObj.GetSelectionObject(), 'A'))
				res = 'DISABLED';
			else
				res = this.pMainObj.queryCommandState(this.cmd);

			if(res == 'DISABLED')
				this.Disable(true);
			else if(res == 'CHECKED')
			{
				this.Disable(false);
				this.Check(true);
			}
			else
			{
				this.Disable(false);
				this.Check(false);
			}
		}
	}
}

function BXButtonSeparator()
{
	BXButtonSeparator.prototype._Create = function ()
	{
		var pElement, i, j;
		this.className = 'BXButtonSeparator';
		this.pWnd = this.CreateElement("IMG", {'src': '/bitrix/images/fileman/htmledit2/separator.gif', 'width': '2', 'height': '20'});
		this.pWnd.className = 'bxseparator';
	}

	BXButtonSeparator.prototype.onToolbarChangeDirection = function (bVertical)
	{
		if(bVertical)
		{
			this.pWnd.src='/bitrix/images/fileman/htmledit2/separator-v.gif';
			this.pWnd.style.width = "20px";
			this.pWnd.style.height = "2px";
		}
		else
		{
			this.pWnd.src='/bitrix/images/fileman/htmledit2/separator.gif';
			this.pWnd.style.width = "2px";
			this.pWnd.style.height = "24px";
		}
	}
}

/**************************************************************************************
BXList - class
**************************************************************************************/
function BXList()
{
	this.className = 'BXList';
	this.iSelectedIndex = -1;
}

BXList.prototype._Create = function ()
{
	if(this.onCreate && this.onCreate()==false)
		return false;

	if(this.OnSelectionChange)
	{
		this.pMainObj.AddEventHandler("OnSelectionChange", this.OnSelectionChange, this);
	}

	if(this.disableOnCodeView)
		this.pMainObj.AddEventHandler("OnChangeView", this.OnChangeView, this);

	this._PreCreate();
	this.SetValues(this.values);

	if(this.onInit && this.onInit()==false)
		return false;

	//alert(this.pDropDownList.innerHTML);
	return true;
}

BXList.prototype._OnChangeView = function (mode, split_mode)
{
	mode = (mode=='split'?split_mode:mode);
	this.Disable(mode=='code');
}

BXList.prototype.OnChangeView = function (mode, split_mode)
{
	this._OnChangeView(mode, split_mode);
}

BXList.prototype.Disable = function(flag)
{
	if(this.disabled==flag) return false;
	this.disabled=flag;
	if(flag)
	{
		this.pWnd.className = 'bxlistdisabled';
	}
	else
	{
		this.pWnd.className = 'bxlist';
	}
}

BXList.prototype.SetValues = function (values)
{
	this.values = values;
	while(this.pDropDownList.childNodes.length>0)
		this.pDropDownList.removeChild(this.pDropDownList.childNodes[0]);

	for(var i=0; i<this.values.length; i++)
	{
		var r = this.pDropDownList.insertRow(-1);
		var c = r.insertCell(-1);

		var t1 = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'cellSpacing': '0', 'width': '100%', 'cellPadding': '1', 'className': 'bxedlistitem'});
		var r1 = t1.insertRow(-1);
		var c1 = r1.insertCell(-1);
		c1.style.height = "16px";
		c1.style.cursor = "default";
		c1.noWrap = true;
		this.values[i].index = i;
		c1.title = this.values[i].name;
		c1.value = this.values[i];

		c1.style.border = '1px solid #FFFFFF';
		c1.onmouseover = function (e){this.style.border = '1px solid #4B4B6F';};
		c1.onmouseout = function (e){this.style.border = '1px solid #FFFFFF';};
		c1.obj = this;
		c1.onclick = function ()
			{
				BXPopupWindow.Hide();
				this.obj._onChange(this.value);
				this.obj.FireChangeEvent();
				//this.style.border = '1px solid #CCCCCC';
			};

		if(this.onDrawItem)
			c1.innerHTML = this.onDrawItem(this.values[i]);
		else
			c1.innerHTML = this.values[i].name;

		t1.unselectable = "on";
		c.appendChild(t1);
	}
}

BXList.prototype.FireChangeEvent = function()
{
	//alert(this.onChange);
	if(this.onChange)
		this.onChange(this.arSelected);
}

BXList.prototype._onChange = function (selected)
{
	this.Select(selected["index"]);
}


BXList.prototype.SetValue = function(val)
{
	if(this.pTitle)
	{
		if(val.length<=0)
			this.pTitle.innerHTML = (this.title?this.title:'');
		else
			this.pTitle.innerHTML = val;
	}
}

BXList.prototype.onMouseOver = function (e)
{
	if(this.disabled) return false;
	this.pWnd.className = 'bxlist bxlistover';
}

BXList.prototype.onMouseOut = function (e)
{
	if(this.disabled) return false;
	this.pWnd.className = 'bxlist';
}

BXList.prototype._PreCreate = function ()
{
	this.pWnd = this.pMainObj.CreateElement("DIV", {'className': 'bxlist', 'border': '0'});
	this.pWnd.style.width = this.field_size;
	this.pTable = this.pWnd.appendChild(this.pMainObj.CreateElement("TABLE", {'cellPadding': 0, 'cellSpacing': 0, 'border': 0, 'width':'100%'}));
	this.pTable.style.tableLayout = "fixed";
	//this.pTable.onmouseover = function (e){this.className = 'bxlistover'; return false;};
	//this.pTable.onmouseout = function (e){this.className = 'bxlist';return false;};
	var row = this.pTable.insertRow(-1), cell = row.insertCell(-1);

	this.pTitle = this.pMainObj.CreateElement("DIV", {'className': 'bxlisttitle', 'border': '0'});
	this.pTitle.innerHTML = (this.title?this.title:'');
	this.pTitle.unselectable = "on";
	cell.appendChild(this.pTitle);
	this.pTitleCell = cell;

	cell = row.insertCell(-1);
	cell.className = 'bxlistbutton';
	cell.innerHTML = '&nbsp;';
	cell.unselectable = "on";

	addCustomElementEvent(this.pWnd, 'mouseover', this.onMouseOver, this);
	addCustomElementEvent(this.pWnd, 'mouseout', this.onMouseOut, this);
	addCustomElementEvent(this.pWnd, 'click', this.onClick, this);

	BXPopupWindow.Create();

	this.pPopupNode = BXPopupWindow.CreateElement("DIV", {'border': "0"});
	this.pPopupNode.style.border = "1px solid #A0A0A0";
	this.pPopupNode.style.overflow = "auto";
	this.pPopupNode.style.width = (this.width?this.width:"150px");
	this.pPopupNode.style.overflowX = "hidden";
	this.pPopupNode.style.height = (this.height?this.height:"200px");
	this.pPopupNode.style.overflowY = "auto";
	this.pPopupNode.style.textOverflow = "ellipsis";
	//this.onclick = function (e){BXPopupWindow.Hide();};

	this.pDropDownList = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'width': '100%', 'cellSpacing': '0', 'cellPadding': '0', 'unselectable': 'on'});
	//this.pDropDownList.onclick = function (e){BXPopupWindow.Hide();};

	/*
	var r = this.pDropDownList.insertRow(-1);
	var c = r.insertCell(-1);
	c.innerHTML = this.title;
	c.val = "";
	c.style.cssText = "border: 1px solid #CCCCCC; height: 17px; font-size: 11px; font-family: Tahoma, Courier New; cursor: default; white-space: nowrap;";

	c.onmouseover = function (e){this.style.border = '1px solid #000000';};
	c.onmouseout = function (e){this.style.border = '1px solid #C0C0C0';};
	addCustomElementEvent(c, 'click', function (e) {this._onChange(''); BXPopupWindow.Hide();}, this);
	*/

	this.pPopupNode.appendChild(this.pDropDownList);
}


BXList.prototype.onClick = function (e)
{
	if(this.disabled) return false;
	//this.pWnd.className = 'bxedtbutton';
	var arPos = GetRealPos(this.pWnd);
	if(this.bSetGlobalStyles)
		BXPopupWindow.SetCurStyles();
	else
		this.pMainObj.oStyles.SetToDocument(BXPopupWindow.GetDocument());
	BXPopupWindow.Show([arPos["left"], arPos["right"]], [arPos["top"], arPos["bottom"]], this.pPopupNode);
}

BXList.prototype.Select = function(v)
{
	if(this.iSelectedIndex==v)
		return;
	var sel = this.values[v];
	this.iSelectedIndex = v;
	this.arSelected = sel;
	/*
	if(this.onChange)this.onChange(this.arSelected);
	*/
	this.SetValue(sel["name"]);
}



BXList.prototype.SelectByVal = function(val)
{
	//alert(val);
	if(val)
	{
		for(var i=0; i<this.values.length; i++)
		{
			if(this.values[i].value == val)
			{
				this.Select(i);
				return;
			}
		}
	}

	if(this.title)
		this.SetValue(this.title);
	else
		this.SetValue('');

	this.iSelectedIndex = -1;
}

BXList.prototype.onToolbarChangeDirection = function (bVertical)
{
	if(bVertical)
	{
		this.pWnd.style.width = "18px";
		this.pTitleCell.style.visibility = "hidden";
	}
	else
	{
		this.pWnd.style.width = this.field_size;
		this.pTitleCell.style.visibility = "inherit";
	}

	this.pWnd.className = 'bxlist';
}

/**************************************************************************************
BXTemplateList - class
**************************************************************************************/
function BXTemplateList()
{
}

BXTemplateList.prototype = new BXList;

BXTemplateList.prototype._Create = function ()
{
	var pElement, i, j, obj = this;
	this.className = 'BXTemplateList';
	this._PreCreate();

	var arStyles;
	var r1, c1, t1, r, c;

	/*
	this.values = [];
	for(i=0; i<this.filter.length; i++)
	{
		arStyles = this.pMainObj.oStyles.GetStyles(this.filter[i]);
		for(j=0; j<arStyles.length; j++)
		{
			if(arStyles[j].className.length<=0)
				continue;

			r = this.pDropDownList.insertRow(-1);
			c = r.insertCell(-1);

			t1 = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'cellSpacing': '0', 'width': '100%', 'cellPadding': '1'});
			r1 = t1.insertRow(-1);
			c1 = r1.insertCell(-1);
			c1.style.height = "16px";
			c1.style.cursor = "default";
			c1.innerHTML = arStyles[j].className;
			if(!this.tag_name)
				this.tag_name = '';

			switch(this.tag_name.toUpperCase())
			{
				case "TD":
					c1.className = arStyles[j].className;
					break;
				case "TABLE":
					t1.className = arStyles[j].className;
					break;
				case "TR":
					r1.className = arStyles[j].className;
					break;
				default:
					c1.innerHTML = '<span class="'+arStyles[j].className+'">'+arStyles[j].className+'</span>';
			}
			c1.style.border = '1px solid #CCCCCC';
			c1.val = arStyles[j].className;
			c1.onmouseover = function (e){this.style.border = '1px solid #000000';};
			c1.onmouseout = function (e){this.style.border = '1px solid #CCCCCC';};
			c1.onclick = function (e){obj._onChange(this.value); BXPopupWindow.Hide(); this.style.border = '1px solid #CCCCCC'; return false;};
			c1.title = arStyles[j].className;
			t1.unselectable = "on";
			c.appendChild(t1);

			var value = {'index': this.values.length, 'value': arStyles[j].className, 'name': arStyles[j].className};
			c1.value = value;
			c1.obj = this;
			this.values.push(value);
		}
	}
	*/
}

BXTemplateList.prototype.onClick = function (e)
{
	var arPos = GetRealPos(this.pWnd);
	this.pMainObj.oStyles.SetToDocument(BXPopupWindow.GetDocument());
	BXPopupWindow.Show([arPos["left"], arPos["right"]], [arPos["top"], arPos["bottom"]], this.pPopupNode);
}


/**************************************************************************************
BXStyleList - class
**************************************************************************************/
function BXStyleList()
{
}

BXStyleList.prototype = new BXList;

BXStyleList.prototype._Create = function ()
{
	this.className = 'BXStyleList';
	this._PreCreate();

	if(this.OnSelectionChange)
		this.pMainObj.AddEventHandler("OnSelectionChange", this.OnSelectionChange, this);

	this.pMainObj.AddEventHandler("OnTemplateChanged", this.FillList, this);

	if(this.disableOnCodeView)
		this.pMainObj.AddEventHandler("OnChangeView", this.OnChangeView, this);

	this.FillList();
}

BXStyleList.prototype.FillList = function()
{
	var i, j, arStyles;

	if(!this.filter)
		this._SetFilter();

	while(this.pDropDownList.rows.length>0)
		this.pDropDownList.deleteRow(0);

	this.values = [];
	if(!this.tag_name)
		this.tag_name = '';

	//"clear style" item
	this.__CreateRow('', BX_MESS.DeleteStyleOpt, {'index': this.values.length, 'value': '', 'name': BX_MESS.DeleteStyleOptTitle});

	var style_title;
	// other styles
	for(i=0; i<this.filter.length; i++)
	{
		arStyles = this.pMainObj.oStyles.GetStyles(this.filter[i]);
		for(j=0; j<arStyles.length; j++)
		{
			if(arStyles[j].className.length<=0)
				continue;

			style_title = null;
			if(this.pMainObj.arTemplateParams && this.pMainObj.arTemplateParams["STYLES_TITLE"] && this.pMainObj.arTemplateParams["STYLES_TITLE"][arStyles[j].className])
				style_title = this.pMainObj.arTemplateParams["STYLES_TITLE"][arStyles[j].className];
			if(!style_title)
			{
				if(this.pMainObj.arConfig["bUseOnlyDefinedStyles"]==true)
			 		continue;
			 	style_title = arStyles[j].className;
			}

			this.__CreateRow(arStyles[j].className, style_title, {'index': this.values.length, 'value': arStyles[j].className, 'name': style_title});
		}
	}
}

BXStyleList.prototype.__CreateRow = function(className, Name, value)
{
	var r1, c1, t1, r, c;

	r = this.pDropDownList.insertRow(-1);
	c = r.insertCell(-1);

	t1 = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'cellSpacing': '0', 'width': '100%', 'cellPadding': '1'});
	r1 = t1.insertRow(-1);
	c1 = r1.insertCell(-1);
	c1.style.height = "16px";
	c1.style.cursor = "default";
	c1.innerHTML = Name;

	switch(this.tag_name.toUpperCase())
	{
		case "TD":
			c1.className = className;
			break;
		case "TABLE":
			t1.className = className;
			break;
		case "TR":
			r1.className = className;
			break;
		default:
			c1.innerHTML = '<span class="'+className+'">'+Name+'</span>';
	}
	c1.style.border = '1px solid #CCCCCC';
	c1.val = className;
	c1.onmouseover = function (e){this.style.border = '1px solid #000000';};
	c1.onmouseout = function (e){this.style.border = '1px solid #CCCCCC';};
	c1.onclick = function (e){this.obj._onChange(this.value); this.obj.FireChangeEvent(); BXPopupWindow.Hide(); this.style.border = '1px solid #CCCCCC'; if(this.value.value=='')this.obj.SelectByVal(); /*return false;*/};
	c1.title = Name;
	t1.unselectable = "on";
	c.appendChild(t1);
	c1.value = value;
	c1.obj = this;
	this.values.push(value);
}

BXStyleList.prototype.onChange = function(arSelected)
{
	//
	this.pMainObj.WrapSelectionWith("span", {"class":arSelected["value"]});
	//this.pMainObj.pEditorDocument.execCommand("fontsize", false, "0");
	//alert(this.pMainObj.pEditorDocument.body.innerHTML);
}

BXStyleList.prototype._SetFilter = function()
{
	this.filter = ["DEFAULT"];
}

BXStyleList.prototype.onClick = function (e)
{
	//this.pWnd.className = 'bxedtbutton';
	var arPos = GetRealPos(this.pWnd);
	this.pMainObj.oStyles.SetToDocument(BXPopupWindow.GetDocument());
	BXPopupWindow.Show([arPos["left"], arPos["right"]], [arPos["top"], arPos["bottom"]], this.pPopupNode);
}


/**************************************************************************************
BXColorPicker - class
**************************************************************************************/
function _BXColorPicker()
{
	_BXColorPicker.prototype._Create = function ()
	{
		var pElement, i, j, obj = this;
		this.className = 'BXColorPicker';

		this.pWnd = this.pMainObj.CreateElement("TABLE", {'cellPadding': 0, 'cellSpacing': 0, 'border': 0});
		var row = this.pWnd.insertRow(-1), cell = row.insertCell(-1);

		if(this.OnSelectionChange)
			this.pMainObj.AddEventHandler("OnSelectionChange", this.OnSelectionChange, this);

		if(this.with_input)
		{
			this.pInput = this.pMainObj.CreateElement("INPUT", {'type': 'text', 'size': 7});
			cell.appendChild(this.pInput);
			cell = row.insertCell(-1);
			this.pInput.onchange = function (){obj._onChange(this.value);};
		}

		this.pIcon = this.pMainObj.CreateElement("IMG", {'src': (this.icon?this.icon:'/bitrix/images/fileman/htmledit2/bgcolor.gif'), 'width': '20', 'height': '20', 'alt': this.title});
		this.pIcon.className = 'bxedtbutton';
		cell.appendChild(this.pIcon);
		addCustomElementEvent(this.pIcon, 'mouseover', this.onMouseOver, this);
		addCustomElementEvent(this.pIcon, 'mouseout', this.onMouseOut, this);
		addCustomElementEvent(this.pIcon, 'click', this.onClick, this);


		BXPopupWindow.Create();

		this.pPopupNode = BXPopupWindow.CreateElement("DIV", {'border': "0"});
		this.pPopupNode.style.border = "1px solid #A0A0A0";
		this.onclick = function (e){BXPopupWindow.Hide();};
		var t = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'width': '160', 'cellSpacing': '1', 'cellPadding': '2'});
		t.onclick = function (e){BXPopupWindow.Hide();};
		var r = t.insertRow(-1);
		var c = r.insertCell(-1);
		t.className = 'bxedcolorpicker';
		c.style.height = "0%";
		c.innerHTML = BX_MESS.CPickDef;
		c.style.border = '1px solid #C0C0C0';
		c.onmouseover = function (e){this.style.border = '1px solid #000000';};
		c.onmouseout = function (e){this.style.border = '1px solid #C0C0C0';};
		c.onclick = function (e){obj._onChange(''); BXPopupWindow.Hide();};

		r = t.insertRow(-1);
		c = r.insertCell(-1);
		c.style.height = "100%";

		var iColumnCount = 8;

		var r1, c1, t1 = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'cellSpacing': '3', 'cellPadding': '0'});

		for(i=0; i<BXConst.arColor.length/iColumnCount; i++)
		{
			r1 = t1.insertRow(-1);
			for(j=0; j<iColumnCount; j++)
			{
				c1 = r1.insertCell(-1);
				c1.style.height = "16px";
				c1.style.width = "16px";
				c1.style.backgroundColor = "#" + BXConst.arColor[i*iColumnCount + j];
				c1.style.border = '1px solid #C0C0C0';
				c1.val = "#" + BXConst.arColor[i*iColumnCount + j];
				c1.onmouseover = function (e){this.style.border = '1px solid #000000';};
				c1.onmouseout = function (e){this.style.border = '1px solid #C0C0C0';};
				c1.onclick = function (e){BXPopupWindow.Hide(); obj._onChange(this.val); this.style.border = '1px solid #C0C0C0'; /*return false;*/};
				c1.innerHTML = '<img src="/bitrix/images/1.gif" width="1" height="1"/>';
				c1.title = BXConst.arColorName[i*iColumnCount + j];
			}
		}

		c.appendChild(t1);
		this.pPopupNode.appendChild(t);
	}

	_BXColorPicker.prototype._onChange = function (color)
	{
		if(this.with_input)
			this.pInput.value = color;

		if(this.onChange)
			this.onChange(color);
	}

	_BXColorPicker.prototype.SetValue = function(val)
	{
		if(this.pInput)
			this.pInput.value = val;
	}

	_BXColorPicker.prototype.onMouseOver = function (e)
	{
		this.pIcon.className = 'bxedtbuttonover';
	}

	_BXColorPicker.prototype.onMouseOut = function (e)
	{
		this.pIcon.className = 'bxedtbutton';
	}

	_BXColorPicker.prototype.onClick = function (e)
	{
		//this.pWnd.className = 'bxedtbutton';
		var arPos = GetRealPos(this.pIcon);
		BXPopupWindow.SetCurStyles();
		BXPopupWindow.Show([arPos["left"], arPos["right"]], [arPos["top"], arPos["bottom"]], this.pPopupNode);
	}
}

var pBXColorPicker = new _BXColorPicker();
function BXColorPicker()
{
	return new _BXColorPicker();
	//return pBXColorPicker;
}

/**************************************************************************************
BXTAlignPicker - class
**************************************************************************************/
function _BXTAlignPicker()
{
	this.arIcon = ["tl", "tc", "tr", "cl", "cc", "cr", "bl", "bc", "br"];
	this.arIconH = ["left", "center", "right"];
	this.arIconV = ["top", "middle", "bottom"];
	this.arIconName = [
		BX_MESS.TAlign1, BX_MESS.TAlign2, BX_MESS.TAlign3,
		BX_MESS.TAlign4, BX_MESS.TAlign5, BX_MESS.TAlign6,
		BX_MESS.TAlign7, BX_MESS.TAlign8, BX_MESS.TAlign9];

	_BXTAlignPicker.prototype._Create = function ()
	{
		var pElement, i, j, obj = this;
		this.className = 'BXTAlignPicker';

		this.pWnd = this.pMainObj.CreateElement("TABLE", {'cellPadding': 0, 'cellSpacing': 0, 'border': 0});
		var row = this.pWnd.insertRow(-1), cell = row.insertCell(-1);

		this.pIcon = this.pMainObj.CreateElement("IMG", {'src': '/bitrix/images/fileman/htmledit2/talign-tl.gif', 'width': '20', 'height': '20', 'alt': this.title});
		this.pIcon.className = 'bxedtbutton';
		cell.appendChild(this.pIcon);
		addCustomElementEvent(this.pIcon, 'mouseover', this.onMouseOver, this);
		addCustomElementEvent(this.pIcon, 'mouseout', this.onMouseOut, this);
		addCustomElementEvent(this.pIcon, 'click', this.onClick, this);

		BXPopupWindow.Create();

		this.pPopupNode = BXPopupWindow.CreateElement("DIV", {'border': "0"});
		this.pPopupNode.style.border = "1px solid #A0A0A0";
		this.onclick = function (e){BXPopupWindow.Hide();};
		var t = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'width': '80', 'cellSpacing': '1', 'cellPadding': '2'});
		t.onclick = function (e){BXPopupWindow.Hide();};
		var r = t.insertRow(-1);
		var c = r.insertCell(-1);
		t.className = 'bxedtalignpicker';
		//c.style.height = "0%";
		c.innerHTML = '<nobr>'+BX_MESS.TAlignDef+'</nobr>';
		c.className = 'bxedtbutton';
		c.noWrap = true;
		c.onmouseover = function (e){this.className = 'bxedtbuttonover';};
		c.onmouseout = function (e){this.className = 'bxedtbutton';};
		c.onclick = function (e){obj._onChange('', ''); BXPopupWindow.Hide();};

		r = t.insertRow(-1);
		c = r.insertCell(-1);
		c.style.height = "100%";
		if(!this.type)
			this.type = "default";

		var r1, c1, t1 = BXPopupWindow.CreateElement("TABLE", {'border': '0', 'cellSpacing': '3', 'cellPadding': '0'});
		for(i=0; i<3; i++)
		{
			r1 = t1.insertRow(-1);
			if(this.type == 'table')
				i = 1;
			for(j=0; j<3; j++)
			{
				c1 = r1.insertCell(-1);
				if(this.type == 'image' && i!=1 && j!=1)
				{
					c1 = c1.appendChild(BXPopupWindow.CreateElement("IMG", {"src": "/bitrix/images/fileman/htmledit2/1.gif", "border": 0, "alt": "", "title": ""}));
					c1.className = 'bxedtbutton';
				}
				else
				{
					c1 = c1.appendChild(BXPopupWindow.CreateElement("IMG", {"src": "/bitrix/images/fileman/htmledit2/talign-"+this.arIcon[i*3+j]+".gif", "border": 0, "alt": this.arIconName[i*3 + j], "title": this.arIconName[i*3 + j]}));
					c1.className = 'bxedtbutton';
					if(this.type == 'image')
					{
						if(j==1)
							c1.val = this.arIconV[i];
						else
							c1.val = this.arIconH[j];
						c1.onclick = function (e){obj._onChangeI(this.val); BXPopupWindow.Hide(); this.className = 'bxedtbutton'; /*return false;*/};
					}
					else
					{
						c1.valH = this.arIconH[j];
						c1.valV = this.arIconV[i];
						c1.onclick = function (e){obj._onChange(this.valH, this.valV); BXPopupWindow.Hide(); this.className = 'bxedtbutton'; /*return false;*/};
					}
					c1.onmouseover = function (e){this.className = 'bxedtbuttonover';};
					c1.onmouseout = function (e){this.className = 'bxedtbutton';};
				}
			}
			if(this.type == 'table')
				break;
		}

		c.appendChild(t1);
		this.pPopupNode.appendChild(t);
	}

	_BXTAlignPicker.prototype._onChange = function (valH, valV)
	{
			if(this.onChange)
				this.onChange(valH, valV);

			this.SetValue(valH, valV);
	}

	_BXTAlignPicker.prototype._onChangeI = function (val)
	{
			if(this.onChange)
				this.onChange(val);

			this.SetValueI(val);
	}

	_BXTAlignPicker.prototype.SetValue = function(valH, valV)
	{
		if(this.type=='image')
			return this.SetValueI(valH);

		for(var j=0; j<3; j++)
			if(this.arIconH[j] == valH)
				break;

		for(var i=0; i<3; i++)
			if(this.arIconV[i] == valV)
				break;

		if(i>2)i=1;
		if(j>2)j=0;

		this.pIcon.src = "/bitrix/images/fileman/htmledit2/talign-"+this.arIcon[i*3+j]+".gif";
		this.pIcon.alt = this.arIconName[i*3 + j];
		this.pIcon.title = this.pIcon.alt;
		return i*3 + j;
	}

	_BXTAlignPicker.prototype.SetValueI = function(val)
	{
		var i, j = 0;
		for(i=0; i<3; i++)
			if(this.arIconV[i] == val)
			{
				j = 1;
				break;
			}
		if(j!=1)
			for(j=0; j<3; j++)
				if(this.arIconH[j] == val)
				{
					i = 1;
					break;
				}

		if(i>2)i=1;
		if(j>2)j=0;

		this.pIcon.src = "/bitrix/images/fileman/htmledit2/talign-"+this.arIcon[i*3+j]+".gif";
		this.pIcon.alt = this.arIconName[i*3 + j];
		this.pIcon.title = this.pIcon.alt;
		return i*3 + j;
	}

	_BXTAlignPicker.prototype.onMouseOver = function (e)
	{
		this.pIcon.className = 'bxedtbuttonover';
	}

	_BXTAlignPicker.prototype.onMouseOut = function (e)
	{
		this.pIcon.className = 'bxedtbutton';
	}

	_BXTAlignPicker.prototype.onClick = function (e)
	{
		//this.pWnd.className = 'bxedtbutton';
		var arPos = GetRealPos(this.pIcon);
		BXPopupWindow.SetCurStyles();
		BXPopupWindow.Show([arPos["left"], arPos["right"]], [arPos["top"], arPos["bottom"]], this.pPopupNode);
	}
}

var pBXTAlignPicker = new _BXTAlignPicker();
function BXTAlignPicker()
{
	return new _BXTAlignPicker();
	//return pBXColorPicker;
}




/*************************************************************************************
**************************************************************************************
**************************************************************************************
**************************************************************************************
**************************************************************************************
*************************************************************************************/
function BXCombo(pMainObj, id, pHandler)
{
	this.className = "BXCombo";
	this.id = id;
	this.items = Array();
	this.pHandler = pHandler;
	this.pMainObj = pMainObj;

	BXCombo.prototype.AddRow = function(id, value, title, handler)
	{
		this.items[id] = new Object;
		this.items[id].id = id;
		this.items[id].value = value;
		if(handler)
			this.items[id].handler = handler;
		if(title)
			this.items[id].title = title;
		else
			this.items[id].title = value;
	}

	BXCombo.prototype.Show = function()
	{
		var obj = this;
		this.dx = this.params[1];
		this.dy = this.params[2];
		this.title_size = this.params[3];
		this.title_name = this.params[4];

		this.pWnd = this.pMainObj.pDocument.createElement("TABLE");
		this.pWnd.cellPadding = 0;
		this.pWnd.cellSpacing = 0;
		this.pWnd.className = 'bxcombo';
		this.pWnd.unselectable = "on";
		var obwnd = this.pWnd;
		this.pWnd.onmouseover = function (e){obj.pWnd.className = 'bxcomboover'; return false;};
		this.pWnd.onmouseout = function (e){obj.pWnd.className = 'bxcombo';return false;};
		var r  = this.pWnd.insertRow(0);
		var c = r.insertCell(0);
		this.title = c.appendChild(this.pMainObj.pDocument.createElement("DIV"));
		this.title.className = 'bxcombotitle';
		this.title.style.width = this.title_size;
		this.title.innerHTML = this.title_name;
		this.title.unselectable = "on";

		var c2 = r.insertCell(1);
		c2.appendChild(this.pMainObj.CreateElement('IMG', {'src':'/bitrix/images/fileman/htmledit2/combo_arr.gif', 'border':'0', 'width':'11', 'height':'17'}));

		this.pWnd.onclick = function e(){obj.Drop(true)};
		this.pDropDown = new BXPopup(this.pMainObj, this.pWnd, this.pMainObj.pDocument);

		var itemstable = this.pDropDown.pDocument.createElement("TABLE");
		itemstable.style.width = "100%";
		for(var it_id in this.items)
		{
			var item = itemstable.insertRow(-1).insertCell(0);
			item.unselectable = "on";
			item.style.border = "1px #CCCCCC solid";
			item.style.cursor = "default";
			item.onmousemove = function (e)
			{
				this.style.border = "1px #0000FF solid";
			}
			item.onmouseout = function (e)
			{
				this.style.border = "1px #CCCCCC solid";
			}
			item.onclick = function (e)
			{
				this.style.border = "1px #CCCCCC solid";
				obj.title.innerText = this.title;
				obj.Drop(false);
				var id = it_id;
				obj.selectedItem = this.id;
				if(item.handler)
					item.handler();
				else
					obj.OnSelect();
			}
			item.innerHTML = this.items[it_id].value;
			item.title = this.items[it_id].title;
			item.id = this.items[it_id].id;
			item.handler = this.items[it_id].handler;
		}

		this.pDropDown.AddContent(itemstable);
	}

	BXCombo.prototype.Drop = function(bDrop)
	{
		if(bDrop)
		{
			var pos = GetRealPos(this.pWnd);
			this.pDropDown.Show(pos["left"], pos["bottom"], this.dx, this.dy)
		}
		else
			this.pDropDown.Hide();
		this.pMainObj.SetFocus();
	}

	BXCombo.prototype.onToolbarChangeDirection = function (bVertical)
	{
		if(bVertical)
			this.title.style.width = "0px";
		else
			this.title.style.width = this.title_size;
		this.pWnd.className = 'bxcombo';
	}
}

function BXTBSelect()
{

}

//BXCombo.prototype = new BXToolbarItem;
BXTBSelect.prototype = new BXCombo;
//BXTBSelect.prototype = new BXCombo;

function FontStyleListSelect()
{
	var obj = this;
	obj.className = 'FontStyleListSelect';
	obj.items = Array();
	obj.__Show = obj.Show;
	obj.Show = function ()
	{
		//this.arStyles
		//
		//for(var ix=0; ix<obj.params[5].length; ix++)
		//	obj.AddRow(ix, '<span style="font-name:' + obj.params[5][ix] + ';">' + obj.params[5][ix] + '</span>');
		obj.__Show();
	}
	obj.OnSelect = function (val)
	{
		alert(val.id);
	}
}
FontStyleListSelect.prototype = new BXTBSelect;

function FontSizeListSelect()
{
	var obj = this;
	obj.className = 'FontSizeListSelect';
	obj.items = Array();
	obj.__Show = obj.Show;
	obj.Show = function ()
	{
		for(var ix=0; ix<obj.params[5].length; ix++)
			obj.AddRow(ix, '<span style="font-size:' + obj.params[5][ix] + ';">' + obj.params[5][ix] + '</span>', obj.params[5][ix]);
		obj.__Show();
	}

	FontSizeListSelect.prototype.OnSelect = function ()
	{
		var item_id = this.selectedItem;
		//this.pMainObj.executeCommand('FontSize', this.items[item_id].title);
		this.pMainObj.WrapSelectionWith('span', {'style': 'font-size:'+this.items[item_id].title+';'});
		return true;
	}
}

//**************************************************************************************/
function BXDialog()
{
	BXDialog.prototype._Create = function ()
	{
		if(!this.params || typeof(this.params)!="object")
			this.params = {};

		this.params.pMainObj = this.pMainObj;
		if(window.showModalDialog)
			window.showModalDialog('/bitrix/admin/fileman_editor_dialog.php?lang='+BXLang+'&site='+BXSite+'&name='+this.name+'&not_use_default='+this.not_use_default, this.params, "dialogWidth:"+this.width+"px;dialogHeight:"+this.height+"px;help:no;scroll:no;status:no;center:yes;");
		else
		{
			this.pWnd = window.open('/bitrix/admin/fileman_editor_dialog.php?lang='+BXLang+'&site='+BXSite+'&name='+this.name+'&not_use_default='+this.not_use_default, 'BXDialog'+Math.random.toString().substring(2), 'height='+this.height+',width='+this.width+',toolbar=no,directories=no,status=no,menubar=no,scrollbars=no,resizable=no,modal=yes,alwaysRaised=yes,dialog=yes');
			this.pWnd.resizeTo(this.width, this.height);
			this.pWnd.moveTo((screen.width-this.width)/2, (screen.height-this.height)/2);
			this.pWnd.dialogArguments = this.params;

			addCustomElementEvent(window.top.parent, 'focus', this.CheckFocus, this);

			this.pWnd.focus();
		}
	}

	BXDialog.prototype.CheckFocus = function()
	{
		if(this.pWnd && !this.pWnd.closed)
		{
			this.pWnd.focus();
			return false;
		}
		else
		{
			delCustomElementEvent(window.top.parent, 'focus', this.CheckFocus);
		}
	}
}