Your IP : 3.143.254.28


Current Path : /var/www/www-root/data/webdav/webdav/www/monolith-realty.ru/bitrix/admin/htmleditor2/
Upload File :
Current File : /var/www/www-root/data/webdav/webdav/www/monolith-realty.ru/bitrix/admin/htmleditor2/bars.js

function BXTaskbarSet(pColumn, pMainObj, iNum)
{
	if (typeof SETTINGS[pMainObj.name].arTBSetsSettings != 'object' )
		SETTINGS[pMainObj.name].arTBSetsSettings = arTBSetsSettings_default;

	var
		arTBSetsSet = SETTINGS[pMainObj.name].arTBSetsSettings,
		_this = this,
		bVertical = (iNum == 1 || iNum==2);

	ar_BXTaskbarSetS.push(this);

	this.pParentWnd = pColumn;
	this.pParentWnd.unselectable = "on";
	this.pMainObj = pMainObj;
	this.bVertical = bVertical;
	this.iNum = iNum;
	this.bShowing = !!arTBSetsSet[iNum].show;
	this.bFirstDisplay = true;

	this.pWnd = BX.findChild(this.pParentWnd, {tagName: "TABLE"});
	this.sActiveTaskbar = '';

	this.pMoveColumn = this.pWnd.rows[0].cells[0];
	if (this.iNum == 2) //right
	{
		this.pTitleColumn = this.pWnd.rows[0].cells[1];
		this.pMainCell = this.pWnd.rows[1].cells[0];
		this.pBottomColumn = this.pWnd.rows[2].cells[0];
	}
	else //this.iNum == 3  - bottom
	{
		this.pTitleColumn = this.pWnd.rows[1].cells[0];
		this.pMainCell = this.pWnd.rows[2].cells[0];
		this.pBottomColumn = this.pWnd.rows[3].cells[0];
	}

	this.pDataColumn = this.pMainCell.appendChild(BX.create("DIV", {props: {className: "bxedtaskbar-scroll"}}));
	this.arTaskbars = [];

	this.pMoveColumn.style.display = "none";
	this.pMoveColumn.unselectable = "on";
	this.pMoveColumn.ondragstart = function (e){return BX.PreventDefault(e);};
	this.pMoveColumn.onmousedown = function(e){_this.MouseDown(e); return false;};

	if (!CACHE_DISPATCHER['TranspToggle'])
		CACHE_DISPATCHER['TranspToggle'] = document.body.appendChild(BX.create('IMG', {props: {src: one_gif_src}, styles: {display: 'none'}}));
}

BXTaskbarSet.prototype =
{
	// Start move toogle
	MouseDown: function (e)
	{
		var val, maxVal, minVal, bVertical, w, h;

		if (this.iNum == 2)  // Right
		{
			val = parseInt(this.pWnd.offsetWidth);
			maxVal = val + parseInt(this.pMainObj.cEditor.offsetWidth) - 155;
			minVal = 210;
			bVertical = false;
			w = false;
			h = this.pMoveColumn.offsetHeight;
		}
		else // Bottom
		{
			val = parseInt(this.pWnd.offsetHeight);
			maxVal = val + parseInt(this.pMainObj.cEditor.offsetHeight) - (BX.browser.IsIE() ? 50 : 155);
			minVal = 120;
			bVertical = true;
			w = this.pMoveColumn.offsetWidth;
			h = false;
		}

		this.pMainObj.ClearPosCache();

		showTranspToggle({
			e: e,
			bVertical: bVertical,
			pMainObj: this.pMainObj,
			pos: BX.pos(this.pMoveColumn),
			width: w,
			height: h,
			callbackFunc: this.Resize,
			callbackObj: this,
			value: val,
			maxValue: maxVal,
			minValue: minVal
		});
	},

	Resize: function (value, bSave, bSetTmpClass)
	{
		// Get value from saved settings resize
		if (value === false || typeof value == 'undefined')
		{
			value = SETTINGS[this.pMainObj.name].arTBSetsSettings[this.iNum].size;
			bSave = false;
		}

		if (!this.bShowing)
		{
			value = 0;
			bSave = false;
		}

		var maxVal, minVal;
		if (this.iNum == 2)  // Right
		{
			maxVal = parseInt(this.pMainObj.pWnd.offsetWidth) - 200;
			minVal = 210;
		}
		else // Bottom
		{
			maxVal = parseInt(this.pMainObj.pWnd.offsetHeight) - 250;
			minVal = 120;
		}

		if (value > maxVal && maxVal > minVal)
			value = maxVal;

		if (value < minVal && value !== 0 && minVal < maxVal)
			value = minVal;

		value = parseInt(value);
		var
			_this = this,
			rightTaskbar = this.pMainObj.arTaskbarSet[2],
			bottomTaskbar = this.pMainObj.arTaskbarSet[3],
			h = parseInt(this.pMainObj.pWnd.offsetHeight), // sceleton height
			h1 = parseInt(this.pMainObj.pTopToolbarset.offsetHeight), // top toolbarset
			h2 = 29; //taskbars tabs

		// If editor is invisible - try to resize it every 0.5 sec
		if (!h || !h1)
			return setTimeout(function(){_this.Resize(value, bSave, bSetTmpClass);}, 500);

		if (this.iNum == 2)  // Resize vertical taskbar set
		{
			var h4 = bottomTaskbar.pWnd.offsetHeight;
			this.pParentWnd.style.height = (h - h1 - h2 - h4) + "px";
			if (this.bShowing)
			{
				this.pWnd.style.width = value + 'px';
				this.pDataColumn.style.width = (value - 8) + 'px';
				this.pParentWnd.style.width = value + 'px';
			}

			var w = parseInt(this.pMainObj.pWnd.offsetWidth); // sceleton width
			this.pMainObj.cEditor.style.width = (w - value - 2) + 'px';
		}
		else // Resize horizontal taskbar set
		{
			this.pMainObj.cEditor.style.height = (h - h1 - h2 - value) + "px";
			rightTaskbar.pParentWnd.style.height = (h - h1 - h2 - value) + "px";

			if (this.bShowing)
			{
				this.pWnd.style.height = value + 'px';
				this.pDataColumn.style.height = (value - 34) + 'px';
			}
		}

		if (this.adjustTimeout)
			clearTimeout(this.adjustTimeout);

		this.adjustTimeout = setTimeout(function()
		{
			var
				h3 = rightTaskbar.pDataColumn.parentNode.offsetHeight,
				w3 = rightTaskbar.pDataColumn.parentNode.offsetWidth;

			h3 = BX.findParent(rightTaskbar.pDataColumn, {tagName: "TABLE"}).offsetHeight - 26 /*top title*/;
			if (rightTaskbar.arTaskbars.length > 1)
				h3 -= 26;


			if (h3 > 0)
				rightTaskbar.pDataColumn.style.height = h3 + "px";

			if (w3 > 0)
				rightTaskbar.pDataColumn.style.width = w3 + "px";

			if (BX.browser.IsIE())
				rightTaskbar.pWnd.parentNode.appendChild(rightTaskbar.pWnd); // IE needs to refresh DOM tree

			if (bSetTmpClass !== false)
				_this._SetTmpClass(false);
		}, 100);

		if (bSave !== false)
		{
			SETTINGS[this.pMainObj.name].arTBSetsSettings[this.iNum].size = value;
			this.SaveConfig();
		}
	},

	_SetTmpClass: function(bSet)
	{
		var
			d2 = this.pMainObj.arTaskbarSet[2].pDataColumn,
			d3 = this.pMainObj.arTaskbarSet[3].pDataColumn,
			c = "bxedtaskbar-scroll-tmp";

		if (bSet)
		{
			BX.addClass(d2, c);
			BX.addClass(d3, c);
		}
		else
		{
			BX.removeClass(d2, c);
			BX.removeClass(d3, c);
		}
	},

	SaveConfig: function ()
	{
		this.pMainObj.SaveConfig("taskbars", {
			tskbrsetset: SETTINGS[this.pMainObj.name].arTBSetsSettings,
			tskbrset: SETTINGS[this.pMainObj.name].arTaskbarSettings
		});
	},

	Show: function ()
	{
		this.bShowing = true;
		SETTINGS[this.pMainObj.name].arTBSetsSettings[this.iNum].show = true;

		var _this = this;
		var btt = this.pMainObj.oBXTaskTabs;

		if (this.pMainObj.visualEffects && btt)
			this.pMainObj.oBXVM.Show({
				sPos: btt.GetVPos(),
				ePos: this.GetVPos(),
				callback: function(){_this.Display(true);}
			});
		else
			this.Display(true);
	},

	Hide: function ()
	{
		this.bShowing = false;
		SETTINGS[this.pMainObj.name].arTBSetsSettings[this.iNum].show = false;

		this.Display(false);

		if (this.pMainObj.oBXTaskTabs)
		{
			if (this.pMainObj.visualEffects)
				this.pMainObj.oBXVM.Show({sPos: this.GetVPos(), ePos: this.pMainObj.oBXTaskTabs.GetVPos()});

			this.pMainObj.oBXTaskTabs.Refresh();
		}

		this.SaveConfig();
	},

	Display: function(bDisplay)
	{
		// It's first taskbarset opening - lets draw tabs for taskbars
		if (this.bFirstDisplay)
		{
			this.DrawTabs();
			this.bFirstDisplay = false;
		}

		this.bShowing = !!bDisplay && this.arTaskbars.length > 0;

		var dispStr = bDisplay ? '' : 'none';

		if (bDisplay)
			this._SetTmpClass(true);

		var _this = this;
		setTimeout(function()
		{
			_this.Resize();
			_this.pWnd.style.display = _this.pWnd.parentNode.style.display = dispStr;
			if (!_this.bVertical)
				_this.pWnd.parentNode.parentNode.style.display = dispStr;

		}, 10);
	},

	ShowToggle: function(e)
	{
		if(this.bShowing)
			this.Hide();
		else
			this.Show();

		SETTINGS[this.pMainObj.name].arTBSetsSettings[this.iNum].show = this.bShowing;
		this.SaveConfig();
		BX.PreventDefault(e);
	},

	AddTaskbar: function (pTaskbar, bDontRefresh)
	{
		var arTBSetsSet = SETTINGS[this.pMainObj.name].arTBSetsSettings;

		pTaskbar.pWnd.style.display = "";
		pTaskbar.pWnd.style.width = "100%";
		pTaskbar.pWnd.style.height = "100%";

		pTaskbar.pTaskbarSet = this;
		pTaskbar.parentCell = this.pWnd;
		//this.pWnd.style.height = '100%'; // ??????????????/

		this.arTaskbars.push(pTaskbar);
		this.pMoveColumn.style.display = "";

		if (this.bVertical)
		{
			this.pWnd.style.width = arTBSetsSet[this.iNum].size + "px";
			this.pWnd.style.height = "100%";
			this.pWnd.parentNode.style.height = "100%";
		}
		else
		{
			this.pWnd.style.width = "100%";
			this.pWnd.style.height = arTBSetsSet[this.iNum].size + "px";
		}

		if (this.arTaskbars.length > 0)
		{
			this.DrawTabs();

			// We add tab to taskbar set - need for resize right taskbar
			this._SetTmpClass(true);
			this.Resize();
		}

		pTaskbar.OnCreate();
	},

	GetVPos: function (pTaskbar, bDontRefresh)
	{
		var arVPos = [];
		var iNum = this.iNum;
		//var edPos = GetRealPos(this.pMainObj.pWnd);
		var edPos = BX.pos(this.pMainObj.pWnd);
		if (this.bVertical)
		{
			arVPos[iNum] = {
				t: parseInt(edPos.top) + 60,
				l: parseInt(edPos.right) - 200,
				w: 200,
				h: parseInt(this.pMainObj.pWnd.offsetHeight) - 150
			};
		}
		else
		{
			arVPos[iNum] = {
				t: parseInt(edPos.bottom) - 200,
				l: parseInt(edPos.left),
				w: parseInt(this.pMainObj.pWnd.offsetWidth),
				h: 200
			};
		}
		return arVPos[iNum];
	},

	DelTaskbar: function (pTaskbar, bRedrawTabs)
	{
		if (pTaskbar.pWnd && pTaskbar.pWnd.parentNode)
			pTaskbar.pWnd.parentNode.removeChild(pTaskbar.pWnd);

		//ar_BXTaskbarS[pTaskbar.name + "_" + this.pMainObj.name] = null;
		for(var i = 0; i < this.arTaskbars.length; i++)
		{
			if(pTaskbar.id == this.arTaskbars[i].id)
			{
				this.arTaskbars = BX.util.deleteFromArray(this.arTaskbars, i);
				this.DrawTabs();
				if(this.arTaskbars.length > 0)
					this.ActivateTaskbar(this.arTaskbars[0].id, false);
			}
		}

		if (bRedrawTabs !== false)
		{
			this.pMainObj.oBXTaskTabs.Draw();
			this.pMainObj.oBXTaskTabs.Refresh();
		}

		if(this.arTaskbars.length == 0)
			this.Display(false);
	},

	DrawTabs: function ()
	{
		this.pMoveColumn.style.display = this.arTaskbars.length == 0 ? "none" : "";
		if(this.arTaskbars.length <= 1)
		{
			//this.pBottomColumn.parentNode.style.display = this.pBottomColumn.style.display = 'none';
			this.pBottomColumn.style.display = 'none';
			return;
		}

		//If more than one taskbars for one taskbarsets
		//this.pBottomColumn.parentNode.style.display = this.pBottomColumn.style.display = "";
		this.pBottomColumn.style.display = "";
		BX.cleanNode(this.pBottomColumn);

		var
			_this = this,
			pIconTable = this.pBottomColumn.appendChild(BX.create("TABLE", {props: {className: "bx-taskbar-tabs", unselectable: "on"}})),
			r = pIconTable.insertRow(0), c,
			tabIsAct, cn, k, l = this.arTaskbars.length;

		BX.adjust(r.insertCell(-1), {style: {width: "9px"}}).appendChild(BX.create("DIV", {props: {className: 'tabs_common bx_btn_tabs_0a'}}));

		this.sActiveTaskbar = this.arTaskbars[0].id;

		for(k = 0; k < l; k++)
		{
			tabIsAct = true;
			if (k != 0)
			{
				BX.adjust(r.insertCell(-1), {style: {width: "9px"}}).appendChild(BX.create("DIV", {props: {className: 'tabs_common ' + (k==1 ? 'bx_btn_tabs_ad' : 'bx_btn_tabs_dd')}}));
				tabIsAct = false;
			}

			c = BX.adjust(r.insertCell(-1), {props: {className: tabIsAct ? 'bx-tsb-tab-act' : 'bx-tsb-tab'}, style:{width: "0%"}, html: '<span unselectable="on" class="bx-tsb-title">' + this.arTaskbars[k].title + '</span>'});
			c.tid = this.arTaskbars[k].id;
			c.onclick = function (e){_this.ActivateTaskbar(this.tid);};
		}

		BX.adjust(r.insertCell(-1), {style: {width: "9px"}}).appendChild(BX.create("DIV", {props: {className: 'tabs_common bx_btn_tabs_d0'}}));
		BX.adjust(r.insertCell(-1), {props: {className: "bxedtaskbaricontable", unselectable: "on"}});
	},

	ActivateTaskbar: function(id, bSave)
	{
		if (this.bShowing && this.bFirstDisplay)
			this.Show();

		BX.cleanNode(this.pDataColumn);
		BX.cleanNode(this.pTitleColumn);
		var j, i, l = this.arTaskbars.length, oActiveTaskbar;

		for(j = 0; j < l; j++)
		{
			this.arTaskbars[j].bActivated = false;
			if(this.arTaskbars[j].id == id)
			{
				this.pDataColumn.appendChild(this.arTaskbars[j].pWnd);
				this.pTitleColumn.appendChild(this.arTaskbars[j].pHeaderTable);

				this.arTaskbars[j].pWnd.style.display = "";
				this.sActiveTaskbar = id;

				oActiveTaskbar = this.arTaskbars[j];
				this.arTaskbars[j].bActivated = true;
				//this.Resize(); // ???
			}
			SETTINGS[this.pMainObj.name].arTaskbarSettings[this.arTaskbars[j].name].active = this.arTaskbars[j].bActivated;
		}

		if(this.pBottomColumn.childNodes[0])
		{
			var tsb_cells = this.pBottomColumn.childNodes[0].rows[0].cells;
			for(i = 0; i < tsb_cells.length - 1; i++)
			{
				if (i == 0)
				{
					if (tsb_cells[1].tid == id)
						tsb_cells[i].firstChild.className = 'tabs_common bx_btn_tabs_0a';
					else
						tsb_cells[i].firstChild.className = 'tabs_common bx_btn_tabs_0d';
					continue;
				}
				else if (i == tsb_cells.length - 2)
				{
					if (tsb_cells[tsb_cells.length-3].tid==id)
						tsb_cells[i].firstChild.className = 'tabs_common bx_btn_tabs_a0';
					else
						tsb_cells[i].firstChild.className = 'tabs_common bx_btn_tabs_d0';
				}
				else if((i+1)%2==0)
				{
					//TaskbarTasb cells
					if (tsb_cells[i].tid==id)
					{
						tsb_cells[i].className = 'bxedtaskbaricontableact';
						tsb_cells[i].style.backgroundImage = 'url(' + image_path + '/taskbar_tabs/a-bg.gif)';
					}
					else
					{
						tsb_cells[i].className = 'bxedtaskbaricontable';
						tsb_cells[i].style.backgroundImage = 'url(' + image_path + '/taskbar_tabs/d-bg.gif)';
					}
				}
				else
				{
					//switching between tabs
					if (tsb_cells[i-1].tid==id)
						tsb_cells[i].firstChild.className = 'tabs_common bx_btn_tabs_ad';
					else if (tsb_cells[i+1].tid==id)
						tsb_cells[i].firstChild.className = 'tabs_common bx_btn_tabs_da';
					else
						tsb_cells[i].firstChild.className = 'tabs_common bx_btn_tabs_dd';
				}
			}
			tsb_cells = null;
		}

		if (this.pMainObj.oBXTaskTabs)
			this.pMainObj.oBXTaskTabs.Refresh();

		if (bSave !== false)
			this.SaveConfig();
	}
}


function BXTaskbar()
{
}

BXTaskbar.prototype = {
Create: function(name, pMainObj, title, dx, dy)
{
	this.name = name;
	ar_BXTaskbarS[this.name + "_" + pMainObj.name] = this;
	this.pMainObj = pMainObj;
	this.pref = this.pMainObj.name.toUpperCase()+'_BXTaskBar_';
	this.id = "tb_" + Math.round(Math.random() * 100000);
	this.bVertical = false;
	this.title = title;
	this.bDeleted = false;
	this.thirdlevel = false;
	var _this = this;
	this.fullyLoaded = true;
	this.bActivated = false;

	if (!SETTINGS[this.pMainObj.name].arTaskbarSettings[this.name])
		SETTINGS[this.pMainObj.name].arTaskbarSettings[this.name] = arTaskbarSettings_default[this.name];

	this.bActive = SETTINGS[this.pMainObj.name].arTaskbarSettings[this.name].active;

	this.pWnd = BX.create("DIV", {props: {className: "bxedtaskbar", unselectable: "on"}});
	this.rootElementsCont = BX.create("DIV", {props: {className: "bxedtaskbar-root"}});
},

OnCreate: function()
{
	// Create taskbar title
	var _this = this;
	var pHeaderTable = this.pTaskbarSet.pTitleColumn.appendChild(BX.create("TABLE", {props: {className: "bxedtaskbartitletext"}}));

	pHeaderTable.setAttribute("__bxtagname", "_taskbar_default");
	this.pHeaderTable = pHeaderTable;

	var r = pHeaderTable.insertRow(-1);

	this.iconDiv = BX.adjust(r.insertCell(-1), {props: {className: 'def'}, style: {width: "1%", paddingLeft: "2px"}}).appendChild(BX.create("DIV"));
	BX.adjust(r.insertCell(-1), {props: {className: "head_text", noWrap: true, unselectable: "on"}, text: this.title});
	var cmBut = BX.adjust(r.insertCell(-1), {props:{className: "head-button-menu", title: BX_MESS.Actions}}).appendChild(BX.create("DIV"));

	cmBut.onmouseover = function(e)
	{
		this.style.margin =  "0px";
		this.style.border =  "#4B4B6F 1px solid";
		this.style.backgroundColor = "#FFC678";
	};
	cmBut.onmouseout = function(e)
	{
		this.style.margin =  "1px";
		this.style.borderStyle = "none";;
		this.style.backgroundColor = "transparent";
	};
	cmBut.onclick = function(e)
	{
		var _bxtgn = pHeaderTable.getAttribute("__bxtagname");
		if (!_bxtgn)
			return;

		var pos = BX.pos(this);
		pos.left += 22;
		pos.top += 20;
		oBXContextMenu.Show(2500, 0, pos, false, {pTaskbar: _this, bxtagname: _bxtgn}, _this.pMainObj, true);
	};

	var hideBut = BX.adjust(r.insertCell(-1), {props:{className: "head-button-hide", title: BX_MESS.Hide}, style: {width: "20px"}}).appendChild(BX.create("DIV"));
	hideBut.onclick = function(e)
	{
		_this.pTaskbarSet.Hide();
		SETTINGS[_this.pMainObj.name].arTBSetsSettings[_this.pTaskbarSet.iNum].show = false;
		_this.pTaskbarSet.SaveConfig();
	};

	if(this.OnTaskbarCreate)
		this.OnTaskbarCreate();
},

SetActive: function ()
{
	if(this.pTaskbarSet)
		this.pTaskbarSet.ActivateTaskbar(this.id);
},

Close: function(bRedrawTabs, bSaveConfig)
{
	SETTINGS[this.pMainObj.name].arTaskbarSettings[this.name].show = false;
	SETTINGS[this.pMainObj.name].arTaskbarSettings[this.name].active = false;
	ar_BXTaskbarS[this.name + "_" + this.pMainObj.name].bDeleted = true;

	if(this.pTaskbarSet)
	{
		if (bSaveConfig !== false)
			this.pTaskbarSet.SaveConfig();
		this.pTaskbarSet.DelTaskbar(this, bRedrawTabs);
	}
},

SetContent: function (sContent)
{
	this.pWnd.innerHTML = sContent;
},

CreateScrollableArea: function (pParent)
{
	return pParent;
	return pParent.appendChild(BX.create("DIV", {props: {className: "bx-taskbar-scroll"}}));

	var res = this.pMainObj.pDocument.createElement("DIV");
	res.style.position = "relative";
	res.style.left = "0px";
	res.style.right = "0px";
	res.style.width = "100%";
	res.style.height = "100%";
	pParent = pParent.appendChild(res);
	res = null;

	res = this.pMainObj.pDocument.createElement("DIV");
	res.style.position = "absolute";
	res.style.left = "0px";
	res.style.right = "0px";
	res.style.width = "100%";
	res.style.height = "100%";

	if(!BX.browser.IsIE())
		res.style.overflow = "-moz-scrollbars-vertical";

	//res.style.overflowY = "scroll";
	res.style.overflowY = "auto";
	res.style.overflowX = "hidden";

	res.style.scrollbar3dLightColor = "#C0C0C0";
	res.style.scrollbarArrowColor = "#252525";
	res.style.scrollbarBaseColor = "#C0C0C0";
	res.style.scrollbarDarkShadowColor = "#252525";
	res.style.scrollbarFaceColor = "#D4D4D4";
	res.style.scrollbarHighlightColor = "#EFEFEF";
	res.style.scrollbarShadowColor = "#EFEFEF";
	res.style.scrollbarTrackColor = "#DFDFDF";


	pParent = pParent.appendChild(res);
	res = null;

	return pParent;
},

DisplayElementList: function (arElements, oCont)
{
	BX.cleanNode(oCont);
	var hi, hlen = arElements.length;
	for (hi = 0; hi < hlen; hi++)
		this.DisplayElement(arElements[hi], oCont);
},

DisplayElement: function (arElement, oCont, orderInd, sPath)
{
	if (orderInd == undefined)
		orderInd = -1;

	if (arElement['isGroup'])
		this.DisplayGroupElement(arElement, oCont, orderInd, sPath);
	else
	{
		if (arElement['thirdlevel'])
		{
			if(this.thirdlevel.name && this.thirdlevel.name != arElement['thirdlevel'])
				this.Display3rdLevelSep(oCont,this.thirdlevel.sPath);
			this.DisplaySingleElement(arElement,oCont,orderInd,sPath);
			this.thirdlevel = {
					name  : arElement['thirdlevel'],
					sPath : sPath
				};
		}
		else
		{
			if(this.thirdlevel.name)
			{
				this.Display3rdLevelSep(oCont,this.thirdlevel.sPath);
				this.thirdlevel = [];
			}
			this.DisplaySingleElement(arElement,oCont,orderInd,sPath);
		}
	}

	if (this.rootElementsCont.parentNode)
		this.rootElementsCont.parentNode.removeChild(this.rootElementsCont);
	oCont.appendChild(this.rootElementsCont);
},

DisplaySingleElement: function (oElement, oCont, orderInd, sPath)
{
	if (sPath==undefined)
		sPath='';

	var _oTable = BX.create('TABLE', {props: {className: 'bxgroupblock1', title: BX_MESS.InsertTitle}});
	_oTable.setAttribute('__bxgroup1', '__' + oElement.name);
	var rowTitle = _oTable.insertRow(-1); //Group header
	//Left cell - icon
	var c = BX.adjust(rowTitle.insertCell(-1), {props: {className: 'iconcell1', unselectable: "on"}});

	var _this = this;
	//*** ICON ***
	ic = this.pMainObj.CreateElement('IMG', {src: oElement.icon || (image_path + '/component.gif')});
	ic.onerror = function(){this.src = image_path + '/component.gif';};
	ic.ondragstart = function(){if(window.event) window.event.cancelBubble = true;};
	this.pMainObj.SetBxTag(ic, {tag: oElement.tagname, params: oElement.params});

	if (_this.OnElementClick)
		ic.onclick = function(e){_this.OnElementClick(this, oElement);};

	_oTable.ondblclick = function()
	{
		var ic = BX.findChild(this, {tagName: 'IMG'}, true);
		if (!ic || !ic.id)
			return;

		var draggedElId = ic.id;
		_this.pMainObj.insertHTML('<img src="' + ic.src + '" id="' + ic.id + '">');
		setTimeout(function()
		{
			_this.OnElementDragEnd(_this.pMainObj.pEditorDocument.getElementById(draggedElId));
		}, 20);
	};

	if(BX.browser.IsIE())
	{
		ic.onmousedown = function (e)
		{
			_this.pMainObj.nLastDragNDropElement = this.id;
		};

		ic.ondragend = function (e)
		{
			_this.pMainObj.nLastDragNDropElementFire = false;
			if (_this.OnElementDragEnd != undefined)
				_this.pMainObj.nLastDragNDropElementFire = _this.OnElementDragEnd;
			_this.pMainObj.OnDragDrop();
		};
	}
	else
	{
		ic.onmousedown = function (e)
		{
			_this.pMainObj.SetFocus();
			_this.pMainObj.nLastDragNDropElement = this.id;
			_this.pMainObj.nLastDragNDropElementFire = false;
			if (_this.OnElementDragEnd != undefined)
				_this.pMainObj.nLastDragNDropElementFire = _this.OnElementDragEnd;
		};

		ic.ondragend = function (e) // For Firefox 3.5 and later
		{
			_this.pMainObj.nLastDragNDropElementFire = false;
			if (_this.OnElementDragEnd != undefined)
				_this.pMainObj.nLastDragNDropElementFire = _this.OnElementDragEnd;
			_this.pMainObj.OnDragDrop();
		};
	}
	c.appendChild(ic);
	c.id = 'element_' + oElement.name;
	ic = null;

	//*** TITLE ***
	c = rowTitle.insertCell(-1);
	c.style.paddingLeft = '5px';
	c.className = 'titlecell1';
	c.appendChild(document.createTextNode(oElement.title || oElement.name));

	if (sPath == '')
	{
		this.rootElementsCont.appendChild(_oTable);
	}
	else
	{
		var oGroup = this.GetGroup(oCont, sPath);
		if (oGroup)
			oGroup.rows[1].cells[0].appendChild(_oTable);
	}
},

Display3rdLevelSep: function (oCont,sPath)
{
	var _oSeparator = document.createElement('TABLE');
	_oSeparator.style.width = BX.browser.IsIE() ? '80%' : '100%';
	_oSeparator.style.height = "1px";
	var _oSepTR = _oSeparator.insertRow(-1);
	var _oSepTD = _oSepTR.insertCell(-1);
	_oSepTD.style.backgroundImage = 'url(' + image_path + '/new_taskbars/point.gif)';

	if (sPath=='')
		oCont.appendChild(_oSeparator);
	else
	{
		var oGroup = this.GetGroup(oCont,sPath);
		var childCell = oGroup.rows[1].cells[0];

		childCell.appendChild(_oSeparator);
	}
	_oSepTD = null;
	_oSepTR = null;
	_oSeparator = null;
},

DisplayGroupElement: function (arElement, oCont, orderInd, sPath)
{
	// create group
	var _this = this;
	if (sPath == undefined)
		sPath = '';

	if (sPath=='')
	{
		//Hight level group
		var _oTable = document.createElement('TABLE');
		oCont.appendChild(_oTable);
		_oTable.cellPadding = 0;
		_oTable.cellSpacing = 0;
		_oTable.width = '100%';
		_oTable.className = 'bxgroupblock0';
		_oTable.setAttribute('__bxgroup0', '__'+arElement.name);

		var rowTitle = _oTable.insertRow(-1); //Group header
		c = rowTitle.insertCell(-1); // Plus/Minus cell
		c.className = 'pluscell0';
		c.unselectable = "on";
		c.style.width = '20px';
		c.style.backgroundImage = 'url(' + image_path + '/new_taskbars/part_l.gif)';
		c.appendChild(this.pMainObj.CreateElement("DIV", {className: 'tskbr_common bx_btn_tabs_plus_small', id: this.pref + 'Group_plus_'+arElement.name}));

		c = rowTitle.insertCell(-1); //Central cell - title
		c.className = 'titlecell0';
		c.style.width = '900px';
		c.unselectable = "on";
		c.innerHTML = BXReplaceSpaceByNbsp((arElement.title) ? arElement.title : arElement.name);
		c.style.backgroundImage = 'url(' + image_path + '/new_taskbars/part_l.gif)';

		var rowData = _oTable.insertRow(-1); // Cell with child elements
		rowData.id = this.pref + 'Group_' + arElement.name;
		rowData.style.display = GetDisplStr(0);
		c = rowData.insertCell(-1);
		c.className = 'datacell0';
		c.colSpan = "2";

		arElement.hidden = true;
		rowTitle._el = arElement;
		rowTitle.onclick = function()
		{
			if (_this.PreBuildList && !_this.fullyLoaded)
			{
				var __this = this;
				BX.showWait();
				setTimeout(function()
				{
					_this.PreBuildList();
					_this.HideGroup(__this._el, !__this._el.hidden, 0);
					BX.closeWait();
				}, 1);
			}
			else
				_this.HideGroup(this._el, !this._el.hidden, 0);
		};

		var len = arElement.childElements.length;
		if (len<=0)
			return;

		for (var i=0; i<len; i++)
			this.DisplayElement(arElement.childElements[i],oCont,-1,arElement.name);
	}
	else
	{
		//1st level subgroup
		if (sPath.indexOf(',')!=-1)
			return;

		try
		{
			var oGroup = this.GetGroup(oCont,sPath);
			var childCell = oGroup.rows[1].cells[0];

			var _oTable = document.createElement('TABLE');
			_oTable.cellPadding = 0;
			_oTable.cellSpacing = 0;
			_oTable.width = '100%';
			_oTable.className = 'bxgroupblock1';

			_oTable.setAttribute('__bxgroup1','__'+arElement.name);

			var rowTitle = _oTable.insertRow(-1); //group title
			var c = rowTitle.insertCell(-1); //plus
			c.unselectable = "on";
			c.style.width = '0%';
			c.className = 'pluscell1';
			c.appendChild(this.pMainObj.CreateElement("IMG", {src: one_gif_src, className: 'tskbr_common bx_btn_tabs_plus_big', id: this.pref + 'Plus_1_icon_'+arElement.name}));

			var c = rowTitle.insertCell(-1); //icon
			c.unselectable = "on";
			c.style.width = '0%';
			c.className = 'iconfoldercell1';

			c.appendChild(this.pMainObj.CreateElement("DIV", {className: 'tskbr_common bx_btn_tabs_folder_c', id: this.pref + 'Folder_1_icon_'+arElement.name}));

			c = rowTitle.insertCell(-1); // title
			c.unselectable = "on";
			c.className = 'titlecell1';
			c.innerHTML = (arElement.title) ? arElement.title : arElement.name;

			var rowData = _oTable.insertRow(-1); //Cell with child elements
			rowData.style.display = GetDisplStr(0);
			rowData.id = this.pref + 'Group_1_'+arElement.name;
			c = rowData.insertCell(-1);
			c.className = 'datacell1';
			c.colSpan = "3";

			rowTitle._el = arElement;
			rowTitle.onclick = function(){_this.HideGroup(this._el,!this._el.hidden,1)};

			childCell.appendChild(_oTable);

			arElement.hidden = true;

			var len = arElement.childElements.length;
			if (len<=0)
				return;
			for (var i=0;i<len;i++)
				this.DisplayElement(arElement.childElements[i],oCont,-1,arElement.name);
		}
		catch(e)
		{
			return false;
		}
	}
	rowTitle = null;
	rowData = null;
	rowBottom = null;
	c = null;
	r = null;
},

//sPath - path  in tree
AddElement: function(oElement, oCont, sPath, orderInd)
{
	if (orderInd==undefined)
		orderInd = -1;
	this.DisplayElement(oElement, oCont, orderInd, sPath || "");
},

RemoveElement: function(elName, oCont, sPath)
{
	if (sPath == "")
	{
		var child, __bxgroup;
		for (var i = 0; i < oCont.childNodes.length; i++)
		{
			child = oCont.childNodes[i];
			__bxgroup = child.getAttribute('__bxgroup');
			if (__bxgroup == '__' + elName)
				oCont.removeChild(child);
		}
	}
	else
	{
		var arPath = sPath.split(',');
		var _len = arPath.length;

		if (_len == 0 || _len > 1)
			return false;

		for (var iCh = 0;iCh<oCont.childNodes.length;iCh++)
		{
			try
			{
				var grName = oCont.childNodes[iCh].getAttribute('__bxgroup'), row;
				if(grName == '__'+arPath[0])
				{
					_oCont = BX(this.pref + 'Group_'+arPath[0]);
					for (var j=0;j<_oCont.rows.length;j++)
					{
						row = _oCont.rows[j];
						if (row.cells[0].id=='element_'+elName)
							row.parentNode.removeChild(row);
					}
					break;
				}
			}
			catch(e)
			{
				continue;
			}
		}
	}
	return true;
},

HideGroup: function (arElement, bHide, ilevel)
{
	if (ilevel==undefined)
		ilevel = 0;

	if (ilevel==0)
	{
		var im_plus = BX(this.pref + 'Group_plus_'+arElement.name);
		var elementsGroup = BX(this.pref + 'Group_'+arElement.name);
		if(!bHide)
		{
			arElement.hidden = false;
			elementsGroup.style.display = GetDisplStr(1);
			im_plus.className = 'tskbr_common bx_btn_tabs_minus_small';
		}
		else
		{
			arElement.hidden = true;
			elementsGroup.style.display = GetDisplStr(0);
			im_plus.className = 'tskbr_common bx_btn_tabs_plus_small';
		}
	}
	else if(ilevel==1)
	{
		var plusIcon = BX(this.pref + 'Plus_1_icon_'+arElement.name);
		var groupIcon = BX(this.pref + 'Folder_1_icon_'+arElement.name);
		var elementsGroup1 = BX(this.pref + 'Group_1_'+arElement.name);
		if(!bHide)
		{
			arElement.hidden = false;
			elementsGroup1.style.display = GetDisplStr(1);
			plusIcon.className = 'tskbr_common bx_btn_tabs_minus_big';
			groupIcon.className = "tskbr_common bx_btn_tabs_folder_o";
		}
		else
		{
			arElement.hidden = true;
			elementsGroup1.style.display = GetDisplStr(0);
			plusIcon.className = 'tskbr_common bx_btn_tabs_plus_big';
			groupIcon.className = "tskbr_common bx_btn_tabs_folder_c";
		}
	}
},

GetGroup: function(oCont, sPath)
{
	var arPath = sPath.split(',');
	var len = arPath.length, grName, grName2, newCont;
	if (len<=2)
	{
		for (var iCh = 0; iCh < oCont.childNodes.length; iCh++)
		{
			try
			{
				grName = oCont.childNodes[iCh].getAttribute('__bxgroup0');
				if(grName == '__'+arPath[0])
				{
					if (len==1)
						return oCont.childNodes[iCh];
					else
					{
						newCont = oCont.childNodes[iCh].rows[1].cells[0];
						for (var iCh2 = 0; iCh2<newCont.childNodes.length; iCh2++)
						{
							grName2 = newCont.childNodes[iCh2].getAttribute('__bxgroup1');
							if(grName2 == '__'+arPath[1])
								return newCont.childNodes[iCh2];
						}
					}

				}
			}
			catch(e)
			{
				continue;
			}
		}

	}
	return false;
},

insertHTML: function(_html){this.pMainObj.insertHTML(_html);}
}

//BXPropertiesTaskbar
function BXPropertiesTaskbar()
{
	ar_BXPropertiesTaskbarS.push(this);
	var obj = this;
	obj.bDefault = false;
	obj.emptyInnerHTML = "<br /><span style='padding-left: 15px;'>" + BX_MESS.SelectAnyElement + "</span>";

	BXPropertiesTaskbar.prototype.OnTaskbarCreate = function ()
	{
		this.pHeaderTable.setAttribute("__bxtagname", "_taskbar_properties");
		BX.addClass(obj.pWnd, "bx-props-taskbar")
		this.pMainObj.oPropertiesTaskbar = this;
		this.icon = 'properties';
		this.iconDiv.className = 'tb_icon bxed-taskbar-icon-' + this.icon;
		var table = this.pMainObj.pDocument.createElement("TABLE");
		table.style.width = "100%";
		this.pCellPath = table.insertRow(-1).insertCell(-1);
		this.pCellPath.className = "bxproptagspath";
		this.pCellProps = table.insertRow(-1).insertCell(-1);
		this.pCellProps.style.height = "100%";
		this.pCellProps.vAlign = "top";

		this.pWnd.appendChild(table);

		this.pCellPath.style.height = "0%";
		this.pCellProps.style.height = "100%";

		this.pCellProps = this.CreateScrollableArea(this.pCellProps);
		this.pCellProps.className = "bxtaskbarprops";
		this.pCellProps.innerHTML = obj.emptyInnerHTML;

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

		table = null;
	}

	BXPropertiesTaskbar.prototype.OnSelectionChange = function (sReloadControl, pElement)
	{
		try{ // In split mode in IE fast view mode changing occurs Permission denied ERROR
		if (!obj.bActivated || !obj.pTaskbarSet.bShowing)
			return;

		var oSelected, pElementTemp, strPath = '';
		if (pElement)
			oSelected = pElement;
		else
			pElement = oSelected = obj.pMainObj.GetSelectionObject();

		if (pElement && pElement.ownerDocument != obj.pMainObj.pEditorDocument)
		{
			try{
				var pBody = obj.pMainObj.pEditorDocument.body;
				pElement = pBody.lastChild || pBody.appendChild(obj.pMainObj.pEditorDocument.createElement('BR'));
				obj.pMainObj.SelectElement(pElement);
			}catch(e){}
		}

		if(sReloadControl == "always" || !obj.oOldSelected || !BXElementEqual(oSelected, obj.oOldSelected))
		{
			obj.oOldSelected = oSelected;
			BX.cleanNode(obj.pCellPath);

			var tPath = BX.create("TABLE");
			tPath.className = "bxproptagspathinl";
			tPath.cellSpacing = 0;
			tPath.cellPadding = 1;
			var
				bxTag,
				rPath = tPath.insertRow(-1),
				cPath, pBut, oRange,
				cActiveTag = null,
				fPropertyPanel = null,
				fPropertyPanelElement = null;

			if(obj.pMainObj.pEditorDocument.body.createTextRange)
				oRange = obj.pMainObj.pEditorDocument.body.createTextRange();

			while(pElement && (pElementTemp = pElement.parentNode) != null)
			{
				if(pElementTemp.nodeType !=1 || !pElement.tagName)
				{
					pElement = pElementTemp;
					continue;
				}

				strPath = pElement.tagName.toLowerCase();

				bxTag = obj.pMainObj.GetBxTag(pElement);

				if (bxTag.tag)
				{
					strPath = bxTag.tag;
					fPropertyPanel = false;
					tPath.deleteRow(rPath);
					rPath = tPath.insertRow(-1);
				}

				if(strPath == 'tbody')
				{
					pElement = pElementTemp;
					continue;
				}

				cPath = rPath.insertCell(0);
				if(!fPropertyPanel && pPropertybarHandlers[strPath])
				{
					fPropertyPanel = pPropertybarHandlers[strPath];
					fPropertyPanelElement = pElement;
					cActiveTag = cPath;
				}

				cPath.innerHTML = '&lt;' + strPath + '&gt;';
				cPath.pElement = pElement;
				cPath.oRange = oRange;
				cPath.pMainObj = obj.pMainObj;
				cPath.onclick = function ()
				{
					if(this.oRange && this.oRange.moveToElementText)
					{
						this.oRange.moveToElementText(this.pElement);
						this.oRange.select();
					}
					else
					{
						this.pMainObj.pEditorWindow.getSelection().selectAllChildren(this.pElement);
					}
					this.pMainObj.OnEvent("OnSelectionChange");
				};

				pElement = pElementTemp;
			}

			// temp hack...
			var cPathLast = rPath.insertCell(-1);
			cPathLast.style.width = '100%';
			cPathLast.innerHTML = "&nbsp;";

			var bDefault = false;
			obj.pCellPath.appendChild(tPath);
			if(!fPropertyPanel)
			{
				fPropertyPanel = pPropertybarHandlers['default'];
				fPropertyPanelElement = oSelected;
				bDefault = true;
			}

			if(cActiveTag)
				cActiveTag.className = 'bxactive-tag';

			if(fPropertyPanelElement && fPropertyPanelElement.tagName && (!(obj.oOldPropertyPanelElement && BXElementEqual(fPropertyPanelElement, obj.oOldPropertyPanelElement)) || sReloadControl == "always"))
			{
				var sRealTag = fPropertyPanelElement.tagName.toLowerCase();
				bxTag = obj.pMainObj.GetBxTag(fPropertyPanelElement);

				if (bxTag.tag)
					sRealTag = bxTag.tag;
				obj.oOldPropertyPanelElement = fPropertyPanelElement;

				var bNew = false;
				if((sReloadControl == "always") || (bDefault && obj.bDefault != bDefault) || (!bDefault && (!obj.sOldTag || obj.sOldTag != sRealTag)))
				{
					obj.pMainObj.OnChange("OnPropertyChange", "");
					bNew = true;
					BX.cleanNode(obj.pCellProps);
				}

				obj.sOldTag = sRealTag;

				if(fPropertyPanel)
					fPropertyPanel(bNew, obj, fPropertyPanelElement);

				var w = (parseInt(obj.pTaskbarSet.pDataColumn.parentNode.offsetWidth) - 2);
				obj.pTaskbarSet.pDataColumn.style.width = (w > 0 ? w : 0) + 'px';
				obj.pMainObj.OnEvent("OnPropertybarChanged");
				ar_PROP_ELEMENTS.push(obj);
				obj.bDefault = bDefault;
			}
			tPath = rPath = cPath = pBut = null;
		}
		pElement = null;
		oSelected = null;

		}catch(e){}
		return true;
	}
}
oBXEditorUtils.addTaskBar('BXPropertiesTaskbar', 3 , BX_MESS.CompTBProp, [], 5);

function BXCreateTaskbars(pMainObj)
{
	var _sort = function(arr)
	{
		var l = arr.length, tmp, flag = false, i = 0;
		while (i < l - 1)
		{
			if (arr[i].sort - arr[i + 1].sort > 0)
			{
				tmp = arr[i + 1];
				arr[i + 1] = arr[i];
				arr[i] = tmp;
				i--;
			}
			i++;
		}
	}
	_sort(arBXTaskbars);

	if (!SETTINGS[pMainObj.name].arTaskbarSettings)
		SETTINGS[pMainObj.name].arTaskbarSettings = arTaskbarSettings_default;

	var _old_visualEffects = pMainObj.visualEffects;
	pMainObj.visualEffects = false;
	var i, aroTBSet, l = arBXTaskbars.length, oTB, tbkey, pTaskbar;

	for(i = 0; i < l; i++)
	{
		oTB = arBXTaskbars[i];
		tbkey = oTB.name + "_" + pMainObj.name;

		if (ar_BXTaskbarS[tbkey] && (ar_BXTaskbarS[tbkey].pMainObj.name == pMainObj.name) && !ar_BXTaskbarS[tbkey].bDeleted)
			continue;

		aroTBSet = SETTINGS[pMainObj.name].arTaskbarSettings[oTB.name];
		if (!aroTBSet || !pMainObj.allowedTaskbars[oTB.name])
			continue;

		if (!aroTBSet.show && oTB.name != "BXPropertiesTaskbar")
			continue;

		if (oTB.pos !== 2) // Right or bottom
			oTB.pos = 3;

		if ((oTB.arParams['bWithoutPHP'] === false && !pMainObj.arConfig["bWithoutPHP"]) ||
		oTB.arParams['bWithoutPHP'] !== false)
		{
			BX.extend(window[oTB.name], window.BXTaskbar);
			pTaskbar = new window[oTB.name]();

			pTaskbar.Create(oTB.name, pMainObj, oTB.title);
			pMainObj.arTaskbarSet[oTB.pos].AddTaskbar(pTaskbar, true);
		}
	}

	var tbs, l, i, j, bActivate;
	for(i in pMainObj.arTaskbarSet)
	{
		tbs = pMainObj.arTaskbarSet[i];
		if (!tbs || typeof tbs !== 'object' || !tbs.arTaskbars || !tbs.arTaskbars[0])
			continue;

		l = tbs.arTaskbars.length;

		if (l == 1 && !tbs.bShowing)
		{
			tbs.sActiveTaskbar = tbs.arTaskbars[0].id;
		}
		else
		{
			bActivate = false;
			for (j = 0; j < l; j++)
			{
				if (SETTINGS[pMainObj.name].arTaskbarSettings[tbs.arTaskbars[j].name].active)
				{
					tbs.ActivateTaskbar(tbs.arTaskbars[j].id, false);
					bActivate = true;
					break; // Activate and exit if we find active taskbar
				}
			}

			// If no active taskbars find - activate first
			if (!bActivate)
				tbs.ActivateTaskbar(tbs.arTaskbars[0].id, false);
		}
	}

	if (!pMainObj.oBXTaskTabs)
		pMainObj.oBXTaskTabs = new BXTaskTabs(pMainObj);

	// Refresh Taskbars
	var arTskbrSet = SETTINGS[pMainObj.name].arTaskbarSettings;
	var tId, tTitle, BXTaskbar;
	for (var k in ar_BXTaskbarS)
	{
		BXTaskbar = ar_BXTaskbarS[k];
		if(!pMainObj.CheckTaskbar(BXTaskbar))
			continue;

		tId = BXTaskbar.name;
		if (BXTaskbar.pMainObj.name != pMainObj.name || !arTskbrSet || !arTskbrSet[tId])
			continue;

		if (arTskbrSet[tId].show && !BXTaskbar.pTaskbarSet)
			pMainObj.arTaskbarSet[arTskbrSet[tId].position[0]].AddTaskbar(BXTaskbar, true);
		else if (!arTskbrSet[tId].show && BXTaskbar.pTaskbarSet)
			BXTaskbar.Close(false);
	}

	pMainObj.oBXTaskTabs.Draw();
	pMainObj.oBXTaskTabs.Refresh();

	setTimeout(function(){pMainObj.visualEffects = _old_visualEffects; pMainObj.oBXTaskTabs.Refresh();}, 500);
}

function BXTaskTabs(pMainObj)
{
	this.pMainObj = pMainObj;
	this.bRendered = false;
};

BXTaskTabs.prototype = {
	Draw: function()
	{
		var tbs, i, j, l, k, tb, pTab, _this = this, id;
		this.arTabs = [];
		this.arTabIndex = {};
		BX.cleanNode(this.pTabsCont);

		for(i in this.pMainObj.arTaskbarSet)
		{
			tbs = this.pMainObj.arTaskbarSet[i];
			if (!tbs || typeof tbs !== 'object' || !tbs.arTaskbars || !tbs.arTaskbars.length)
				continue;

			for(j = 0, k = tbs.arTaskbars.length; j < k; j++)
			{
				if (!this.bRendered)
				{
					this.pTabsCont = this.pMainObj.pTaskTabs.appendChild(BX.create("DIV", {props: {className: 'bxed-tasktab-cnt', unselectable : "on"}}));
					this.bRendered = true;
				}

				tb = tbs.arTaskbars[j];
				id = "tab_" + tb.id;

				pTab = BX.create("SPAN", {
					props: {
						id: id,
						className: "bxed-tasktab",
						title: tb.title,
						unselectable: "on"
					},
					events: {
						click: function(){_this.OnClick(this)},
						mouseover:  function(){_this.OnMouseOver(this)},
						mouseout:  function(){_this.OnMouseOut(this)}
					},
					html: '<i class="tasktab-left"></i><span class="tasktab-center"><span class="tasktab-icon bxed-taskbar-icon-' + tb.icon + '" unselectable="on"></span><span class="tasktab-text" unselectable="on">' + tb.title + '</span></span><i class="tasktab-right"></i>'
				});

				this.arTabs.push({
					id: id,
					cont: pTab,
					tb: tb,
					tbs: tbs,
					bPushed: tbs.sActiveTaskbar == tb.id
				});
				this.arTabIndex[id] = this.arTabs.length - 1;

				if (tbs.sActiveTaskbar == tb.id && tbs.bShowing)
					BX.addClass(pTab, "bxed-tasktab-pushed");

				this.pTabsCont.appendChild(pTab);
			}
		}
	},

	Refresh: function()
	{
		var i, l = this.arTabs.length, tab, bAct;
		for(i = 0; i < l; i++)
		{
			tab = this.arTabs[i];
			bAct = (tab.tbs.bShowing && tab.tb.id == tab.tbs.sActiveTaskbar);

			if (tab.bPushed == bAct)
				continue;

			tab.bPushed = bAct;
			if (bAct)
				BX.addClass(tab.cont, "bxed-tasktab-pushed");
			else
				BX.removeClass(tab.cont, "bxed-tasktab-pushed");
		}
	},

	OnClick: function(pObj)
	{
		var oTab = this.arTabs[this.arTabIndex[pObj.id]];
		if (oTab.bPushed)
		{
			oTab.bPushed = false;
			BX.removeClass(pObj, "bxed-tasktab-pushed");
			oTab.tbs.Hide();
		}
		else
		{
			oTab.bPushed = true;
			BX.addClass(pObj, "bxed-tasktab-pushed");
			if (!oTab.tbs.bShowing)
				oTab.tbs.Show();
			oTab.tbs.ActivateTaskbar(oTab.tb.id);
		}

		SETTINGS[oTab.tbs.pMainObj.name].arTBSetsSettings[oTab.tbs.iNum].show = oTab.bPushed;
	},

	OnMouseOver: function(pObj)
	{
		BX.addClass(pObj, "bxed-tasktab-over");
	},

	OnMouseOut: function(pObj)
	{
		BX.removeClass(pObj, "bxed-tasktab-over");
	},

	GetVPos: function()
	{
		var edPos = BX.pos(this.pMainObj.pWnd);
		return {
			t: parseInt(edPos.bottom) - 25,
			l: parseInt(edPos.left) + 50,
			w: 300,
			h: 25
		};
	}
}

function BXVisualMinimize(par)
{
	this.oDiv = document.body.appendChild(BX.create('DIV', {props: {className: 'visual_minimize'}, style: {display: 'none'}}));
}

BXVisualMinimize.prototype.Show = function(par)
{
	par.num = BX.browser.IsIE() ? 4 : 8;
	par.time = BX.browser.IsIE() ? 1 : 5;
	this.oDiv.style.display = 'block';

	var
		_this = this,
		i = 0,
		dt = Math.round((par.ePos.t - par.sPos.t) / par.num),
		dl = Math.round((par.ePos.l - par.sPos.l) / par.num),
		dw = Math.round((par.ePos.w - par.sPos.w) / par.num),
		dh = Math.round((par.ePos.h - par.sPos.h) / par.num),
		show = function()
		{
			i++;
			if (i > par.num - 1)
			{
				clearInterval(intId);
				_this.oDiv.style.display = 'none';
				if (par.callback)
					par.callback();
				return;
			}

			_this.oDiv.style.top = (par.sPos.t + dt * i) + 'px';
			_this.oDiv.style.left = (par.sPos.l + dl * i) + 'px';
			_this.oDiv.style.width = Math.abs(par.sPos.w + dw * i) + 'px';
			_this.oDiv.style.height = Math.abs(par.sPos.h + dh * i) + 'px';
		},
		intId = setInterval(show, par.time);
};

function showTranspToggle(arParams)
{
	if (!arParams) return;
	var pMainObj = arParams.pMainObj;
	var e = arParams.e;

	// For main document
	var TranspToggleMove = function(e)
	{
		e = getRealMousePos(e, pMainObj);
		if (arParams.bVertical)
			TranspToggle.style.top = adjustValue(arParams.pos.top, dY + e.realY);
		else
			TranspToggle.style.left = adjustValue(arParams.pos.left, dX + e.realX);
	};

	// For editor document
	var TranspToggleMoveF = function(e)
	{
		e = getRealMousePos(e, pMainObj, true);
		if (arParams.bVertical)
			TranspToggle.style.top = adjustValue(arParams.pos.top, dY + e.realY);
		else
			TranspToggle.style.left = adjustValue(arParams.pos.left, dX + e.realX);
	};

	var adjustValue = function(value, new_value)
	{
		var _cursor = cursor;

		if ((new_value < value) && (value - new_value > maxDiff))
		{
			new_value = value - maxDiff;
			_cursor = "not-allowed";
		}
		else if((new_value > value) && (new_value - value > minDiff))
		{
			new_value = value + minDiff;
			_cursor = "not-allowed";
		}

		if (curCursor != _cursor)
		{
			curCursor = _cursor;
			pBXEventDispatcher.SetCursor(curCursor);
		}

		return new_value + 'px';
	};

	// MouseUp handler
	var TranspToggleMouseUp = function()
	{
		pMainObj.arTaskbarSet[2]._SetTmpClass(true);

		// Clean event handlers
		removeAdvEvent(document, "mousemove", TranspToggleMove, true);
		removeAdvEvent(document, "mouseup", TranspToggleMouseUp, true);
		removeAdvEvent(pMainObj.pEditorDocument, "mousemove", TranspToggleMoveF, true);
		removeAdvEvent(pMainObj.pEditorDocument, "mouseup", TranspToggleMouseUp, true);

		if (BX.browser.IsIE())
		{
			removeAdvEvent(pMainObj.pEditorDocument, "selectstart", preventselect, true);
			removeAdvEvent(document, "selectstart", preventselect, true);
		}

		// Remove toggle
		TranspToggle.style.display = 'none';
		pBXEventDispatcher.SetCursor("default");

		var value = arParams.value - (arParams.bVertical ? (parseInt(TranspToggle.style.top) - arParams.pos.top) : (parseInt(TranspToggle.style.left) - arParams.pos.left));

		if (arParams.callbackObj)
			arParams.callbackFunc.apply(arParams.callbackObj, [value]);
		else
			arParams.callbackFunc(value);
	};

	var
		w, h, dY, dX, cursor, className, top, left,
		maxDiff = arParams.maxValue - arParams.value,
		minDiff = arParams.value - arParams.minValue;
	e = getRealMousePos(e, pMainObj);

	if (arParams.bVertical)
	{
		w = parseInt(arParams.width) + "px",
		h = parseInt(arParams.height ? arParams.height : 6)  + "px";
		dY = e.realY - parseInt(arParams.pos.top) - 6;
		top = (arParams.pos.top + 10) + "px";
		left = arParams.pos.left + "px";
		cursor = "row-resize";
		className = "transp_tog_h";
	}
	else
	{
		h = parseInt(arParams.height) + "px";
		w = parseInt((arParams.width) ? arParams.width : 6) + "px";
		dX = e.realX - parseInt(arParams.pos.left) - 6;
		top = arParams.pos.top + "px";
		left = (arParams.pos.left  + 10) + "px";
		cursor = "col-resize";
		className = "transp_tog_v";
	}
	var curCursor = cursor;
	pBXEventDispatcher.SetCursor(cursor);

	// Create toggle
	var TranspToggle = CACHE_DISPATCHER['TranspToggle'];
	BX.adjust(TranspToggle, {props: {className: className}, style: {display: 'block', width: w, height: h, top: top, left: left}});

	addAdvEvent(document, "mousemove", TranspToggleMove, true);
	addAdvEvent(document, "mouseup", TranspToggleMouseUp, true);
	addAdvEvent(pMainObj.pEditorDocument, "mousemove", TranspToggleMoveF, true);
	addAdvEvent(pMainObj.pEditorDocument, "mouseup", TranspToggleMouseUp, true);

	if (BX.browser.IsIE())
	{
		addAdvEvent(pMainObj.pEditorDocument, "selectstart", preventselect, true);
		addAdvEvent(document, "selectstart", preventselect, true);
	}

	return BX.PreventDefault(e);
}

// # # # # # # # # # # # # # # # #    ONE BIG TOOLBAR # # # # # # # # # # # # # # # #
// For lightMode == true
function BXGlobalToolbar(pMainObj)
{
	this.pMainObj = pMainObj;
	this.oCont = this.pMainObj.pTopToolbarset;
	this.oCont.style.display = this.oCont.parentNode.style.display = "";
	this.oCont.className = "bxedtoolbarset";
	this.oCont.unselectable = "on";
	this.oCont.appendChild(BX.create("DIV", {style: {width: '100%'}}));
}

BXGlobalToolbar.prototype = {
	AddButton: function(pButton)
	{
		this.oCont.firstChild.appendChild(BX.create("DIV", {props: {className: "bx-g-tlbr-but"}})).appendChild(pButton.pWnd);
	},

	LineBegin: function(bFirst)
	{
		// Hack for IE 7
		if (!bFirst && BX.browser.IsIE())
			this.oCont.firstChild.appendChild(BX.create("IMG", {props: {src: one_gif_src, className: "bx-g-tlbr-line-ie"}}));
		this.oCont.firstChild.appendChild(BX.create("DIV", {props: {className: "bx-g-tlbr-line-begin"}}));
	},

	LineEnd: function()
	{
		this.oCont.firstChild.appendChild(BX.create("DIV", {props: {className: "bx-g-tlbr-line-end"}}));
	}
}