// JavaScript Document
function mh(obj){
	var ob=document.getElementById(obj);
	ob.className="active";
}
function mh1(obj){
	var ob=document.getElementById(obj);
	ob.className="a";
}

function show_bdiv(){
var	minus;
if(navigator.appName=='Microsoft Internet Explorer'){
	minus=300;
}else if(navigator.appName=='Opera'){
	minus=320;
}else if(navigator.appName=='Netscape'){
	minus=44;
}

var to=document.getElementById("wrapper").clientHeight-minus;
adv='<div id="bottom-shadow" style="top:'+to+'px;">&nbsp;</div>';
return adv;
}

function resize(){
	if(navigator.appName!='Netscape'){
		var div=show_bdiv();document.write(div);
	}else{
		document.getElementById("content").style.marginTop='-12px';
	}				  
}

document.write("<script src='/js/prototype.js'></script>");

function selectAll(){
	var el=document.listOffice;
	var reverse = false;
	if (el.print_all.checked == true) reverse = true;
	else reverse = false;
	for (i=0; i < el.length; i++) 
	if (el.elements[i].type=='checkbox'){
			el.elements[i].checked = reverse;
	}
	//alert(el.length);
}

function checkEmail(form_name,em_fld){
	if(em_fld=="") em_fld="email";
	
	var email=eval('document.'+form_name+'.'+em_fld);
	var reg = new RegExp("[0-9a-z_]+@[0-9a-z_^.]+\\.[a-z]", 'i');
	if (!reg.test(email.value)) {alert('Email неверен!'); email.focus(); return false;}
	else return true;
}

function checkNumber(obj){
	valid="1234567890- ()";
	tmp="";
	for(i=0;(i<obj.value.length);i++)  {
		if (valid.indexOf(obj.value.charAt(i))!=-1)  {
			tmp=tmp+obj.value.charAt(i);};
		};  
	obj.value=tmp;	  
}

// Example:

// writeCookie("myCookie", "my name", 24);

// Stores the string "my name" in the cookie "myCookie" which expires after 24 hours.

function writeCookie(name, value, hours){
  var expire = "";
  if(hours != null){
    expire = new Date((new Date()).getTime() + hours * 3600000);
    expire = "; expires=" + expire.toGMTString();
  }
  document.cookie = name + "=" + value + expire;
}

// Example:

// alert( readCookie("myCookie") );

function readCookie(name){
  var cookieValue = "";
  var search = name + "=";
  if(document.cookie.length > 0){ 
    offset = document.cookie.indexOf(search);
    if (offset != -1){ 
      offset += search.length;
      end = document.cookie.indexOf(";", offset);
      if (end == -1) end = document.cookie.length;
      cookieValue = document.cookie.substring(offset, end)
    }
  }
  return cookieValue;
}

function sendMail(){
	if($F('semail')!=''){
		$('sendOfferTop').innerHTML='<img src="/images/window_loading.gif" align=absmiddle title="Идет отправка письма"> <small>Идет отправка письма...</small>';
		var url = "/js/sendoffer.php";
		var pars="email=" + $F('semail') + "&name="+ $F('sename') + "&id=" + $F('sid');
		var myAjax = new Ajax.Updater(
					{success: "sendOffer"}, 
					url, 
				{method: 'get', parameters: pars, onFailure: reportError, requestHeaders:['Content-Type', 'charset=windows-1251']});
		$('sendOfferTop').innerHTML='';
	}else{
		alert('Укажите номер телефона для связи!');
	}
}


function getCity(obj, type){
	$('dsf1').innerHTML='<strong>Метро: </strong><img src="/images/window_loading.gif" align=absmiddle title="Готовится список городов"> <small>Готовится список...</small>';
	a["city[]"].disabled=false;
	a.city_s.disabled=false;
	var okrug=obj.options[obj.selectedIndex].value;
	document.sForm.sf19[0].checked=false;
	document.sForm.sf19[1].checked=false;
	var url = "/js/city.php?t="+type;
	var pars="o="+okrug;
	var myAjax = new Ajax.Updater(
				{success: "dsf1"}, 
				url, 
				{method: 'get', parameters: pars, onFailure: reportError, requestHeaders:['Content-Type', 'charset=windows-1251']});
}

function reportError(request){
	alert('Ошибка соединения с сервером!\nПроверьте соединение с интернетом или обновите страницу.');
}








var tooltip = {

	/* НАЧАЛО НАСТРОЕК */
	options: {
		attr_name: "tooltip", // наименование создаваемого tooltip'ого атрибута
		blank_text: "(откроется в новом окне)", // текст для ссылок с target="_blank"
		newline_entity: "  ", // укажите пустую строку (""), если не хотите использовать в tooltip'ах многострочность; ежели хотите, то укажите тот символ или символы, которые будут заменяться на перевод строки
		max_width: 0, // максимальная ширина tooltip'а в пикселах; обнулите это значение, если ширина должна быть нелимитирована
		delay: 100, // задержка при показе tooltip'а в миллисекундах
		skip_tags: ["link", "style"] // теги, у которых не обрабатываем атрибуты alt и title
	},
	/* КОНЕЦ НАСТРОЕК */

	t: document.createElement("DIV"),
	c: null,
	g: false,
	canvas: null,

	m: function(e){
		if (tooltip.g){
			var x = window.event ? event.clientX + (tooltip.canvas.scrollLeft || document.body.scrollLeft) : e.pageX;
			var y = window.event ? event.clientY + (tooltip.canvas.scrollTop || document.body.scrollTop) : e.pageY;
			tooltip.a(x, y);
		}
	},

	d: function(){
		tooltip.canvas = document.getElementsByTagName(document.compatMode && document.compatMode == "CSS1Compat" ? "HTML" : "BODY")[0];
		tooltip.t.setAttribute("id", "tooltip");
		document.body.appendChild(tooltip.t);
		if (tooltip.options.max_width) tooltip.t.style.maxWidth = tooltip.options.max_width + "px"; // all but ie
		var a = document.all && !window.opera ? document.all : document.getElementsByTagName("*"); // in opera 9 document.all produces type mismatch error
		var l = a.length;
		for (var i = 0; i < l; i++){

			if (!a[i] || tooltip.options.skip_tags.in_array(a[i].tagName.toLowerCase())) continue;

			var tooltip_title = a[i].getAttribute("title"); // returns form object if IE & name="title"; then IE crashes; so...
			if (tooltip_title && typeof tooltip_title != "string") tooltip_title = "";

			var tooltip_alt = a[i].getAttribute("alt");
			var tooltip_blank = a[i].getAttribute("target") && a[i].getAttribute("target") == "_blank" && tooltip.options.blank_text;
			if (tooltip_title || tooltip_blank){
				a[i].setAttribute(tooltip.options.attr_name, tooltip_blank ? (tooltip_title ? tooltip_title + " " + tooltip.options.blank_text : tooltip.options.blank_text) : tooltip_title);
				if (a[i].getAttribute(tooltip.options.attr_name)){
					a[i].removeAttribute("title");
					if (tooltip_alt && a[i].complete) a[i].removeAttribute("alt");
					tooltip.l(a[i], "mouseover", tooltip.s);
					tooltip.l(a[i], "mouseout", tooltip.h);
				}
			}else if (tooltip_alt && a[i].complete){
				a[i].setAttribute(tooltip.options.attr_name, tooltip_alt);
				if (a[i].getAttribute(tooltip.options.attr_name)){
					a[i].removeAttribute("alt");
					tooltip.l(a[i], "mouseover", tooltip.s);
					tooltip.l(a[i], "mouseout", tooltip.h);
				}
			}
			if (!a[i].getAttribute(tooltip.options.attr_name) && tooltip_blank){
				//
			}
		}
		document.onmousemove = tooltip.m;
		window.onscroll = tooltip.h;
		tooltip.a(-99, -99);
	},
	
	_: function(s){
		s = s.replace(/\&/g,"&amp;");
		s = s.replace(/\</g,"&lt;");
		s = s.replace(/\>/g,"&gt;");
		return s;
	},

	s: function(e){
		if (typeof tooltip == "undefined") return;
		var d = window.event ? window.event.srcElement : e.target;
		if (!d.getAttribute(tooltip.options.attr_name)) return;
		var s = d.getAttribute(tooltip.options.attr_name);
		if (tooltip.options.newline_entity){
			var s = tooltip._(s);
			s = s.replace(eval("/" + tooltip._(tooltip.options.newline_entity) + "/g"), "<br />");
			tooltip.t.innerHTML = s;
		}else{
			if (tooltip.t.firstChild) tooltip.t.removeChild(tooltip.t.firstChild);
			tooltip.t.appendChild(document.createTextNode(s));
		}
		tooltip.c = setTimeout(function(){
			tooltip.t.style.visibility = 'visible';
		}, tooltip.options.delay);
		tooltip.g = true;
	},

	h: function(e){
		if (typeof tooltip == "undefined") return;
		tooltip.t.style.visibility = "hidden";
		if (!tooltip.options.newline_entity && tooltip.t.firstChild) tooltip.t.removeChild(tooltip.t.firstChild);
		clearTimeout(tooltip.c);
		tooltip.g = false;
		tooltip.a(-99, -99);
	},

	l: function(o, e, a){
		if (o.addEventListener) o.addEventListener(e, a, false); // was true--Opera 7b workaround!
		else if (o.attachEvent) o.attachEvent("on" + e, a);
			else return null;
	},

	a: function(x, y){
		var w_width = tooltip.canvas.clientWidth ? tooltip.canvas.clientWidth + (tooltip.canvas.scrollLeft || document.body.scrollLeft) : window.innerWidth + window.pageXOffset;
		var w_height = window.innerHeight ? window.innerHeight + window.pageYOffset : tooltip.canvas.clientHeight + (tooltip.canvas.scrollTop || document.body.scrollTop); // should be vice verca since Opera 7 is crazy!

		if (document.all && document.all.item && !window.opera) tooltip.t.style.width = tooltip.options.max_width && tooltip.t.offsetWidth > tooltip.options.max_width ? tooltip.options.max_width + "px" : "auto";
		
		var t_width = tooltip.t.offsetWidth;
		var t_height = tooltip.t.offsetHeight;

		tooltip.t.style.left = x + 8 + "px";
		tooltip.t.style.top = y + 8 + "px";
		
		if (x + t_width > w_width) tooltip.t.style.left = w_width - t_width + "px";
		if (y + t_height > w_height) tooltip.t.style.top = w_height - t_height + "px";
	}
}

Array.prototype.in_array = function(value){
	var l = this.length;
	for (var i = 0; i < l; i++)
		if (this[i] === value) return true;
	return false;
};

var root = window.addEventListener || window.attachEvent ? window : document.addEventListener ? document : null;
if (root){
	if (root.addEventListener) root.addEventListener("load", tooltip.d, false);
	else if (root.attachEvent) root.attachEvent("onload", tooltip.d);
}


/**
 * iBox 2.2 (Build 1612)
 * For more info & download: http://www.ibegin.com/labs/ibox/
 * Created as a part of the iBegin Labs Project - http://www.ibegin.com/labs/
 * For licensing please see readme.html (MIT Open Source License)
*/
var iBox = function() {
	var _pub = {
		// label for the close link
		close_label: 'Закрыть',

		// show iframed content in the parent window
		// this *does not* work with #containers
		inherit_frames: false,

		// how fast to fade in the overlay/ibox (this is each step in ms)
		fade_in_speed: 10,
		fade_out_speed: 100,

		// our attribute identifier for our iBox elements
		attribute_name: 'rel',
		
		// tags to hide when we show our box
		tags_to_hide: ['select', 'embed', 'object'],

		// default width of the box (when displaying html only)
		// height is calculated automatically
		default_width: 600,

		// public version number
		version_number: '2.2',
		// internal build number
		build_number: '1612',

		// browser checks		
		is_opera: navigator.userAgent.indexOf('Opera/9') != -1,
		is_ie: navigator.userAgent.indexOf("MSIE ") != -1,
		is_ie6: false /*@cc_on || @_jscript_version < 5.7 @*/,
		is_firefox: navigator.appName == "Netscape" && navigator.userAgent.indexOf("Gecko") != -1 && navigator.userAgent.indexOf("Netscape") == -1,
		is_mac: navigator.userAgent.indexOf('Macintosh') != -1,

		// url for including images/external files
		base_url: '',
		
		/**
		 * Updates the base_url variable.
		 * @param {String} path Relative or absolute path to this file.
		 */
		setPath: function(path) {
			_pub.base_url = path;
		},
		
		/**
		 * Checks a container for specified tags containing rel="ibox"
		 * @param {Object} container
		 * @param {String} tag_name
		 */
		checkTags: function(container, tag_name) {
			if (!container) var container = document.body;
			if (!tag_name) var tag_name = 'a';
			var els = container.getElementsByTagName(tag_name);
			for (var i=0; i<els.length; i++) {
				if (els[i].getAttribute(_pub.attribute_name)) {
					var t = els[i].getAttribute(_pub.attribute_name);
					if ((t.indexOf("ibox") != -1) || t.toLowerCase() == "ibox") { // check if this element is an iBox element
						els[i].onclick = _pub.handleTag;
					}
				}
			}
		},
		
		/**
		 * Binds arguments to a callback function
		 */
		bind: function(fn) {
				var args = [];
				for (var n=1; n<arguments.length; n++) args.push(arguments[n]);
				return function(e) { return fn.apply(this, [e].concat(args)); };
		},

		/**
		 * Sets the content of the ibox
		 * @param {String} content HTML content
		 * @param {Object} params
		 */
		html: function(content, params) {
			if (content === undefined) return els.content;
			if (params === undefined) var params = {};
			if (!active.is_loaded) return;
			_pub.clear();

			_pub.updateObject(els.wrapper.style, {display: 'block', visibility: 'hidden', left: 0, top: 0, height: '', width: ''});
			
			if (typeof(content) == 'string') els.content.innerHTML = content;
			else els.content.appendChild(content);

			var pagesize = _pub.getPageSize();

			if (params.can_resize === undefined) params.can_resize = true;
			if (params.fade_in === undefined) params.use_fade = true;

			if (params.fullscreen) {
				params.width = '100%';
				params.height = '100%';
			}
			
			// reset offsets
			offset.container = [els.wrapper.offsetLeft*2, els.wrapper.offsetTop*2];
			offset.wrapper = [els.wrapper.offsetWidth-els.content.offsetWidth, els.wrapper.offsetHeight-els.content.offsetHeight];

			// TODO: remove the +4 when issue is solved with calculations
			offset.wrapper[1] += 4;

			if (params.width) var width = params.width;
			else var width = _pub.default_width;

			if (params.height) var height = params.height;
			else {
				els.content.style.height = '100%';
				var height = els.content.offsetHeight + 12;
				els.content.style.height = '';
			}
			active.dimensions = [width, height];
			active.params = params;
			_pub.reposition();

			// XXX: Fix for inline containers which had elements that were hidden
			for (var i=0; i<_pub.tags_to_hide.length; i++) {
				showTags(_pub.tags_to_hide[i], els.content);
			}

			els.wrapper.style.visibility = 'visible';
		},
		
		/**
		 * Empties the content of the iBox (also hides the loading indicator)
		 */
		clear: function() {
			els.loading.style.display = "none";
			while (els.content.firstChild) els.content.removeChild(els.content.firstChild);
		},
		
		/**
		 * Loads text into the ibox
		 * @param {String} text
		 * @param {String} title
		 * @param {Object} params
		 */
		show: function(text, title, params) {
			showInit(title, params, function() {
				_pub.html(text, active.params);
			});
		},
		/**
		 * Loads a url into the ibox
		 * @param {String} url
		 * @param {String} title
		 * @param {Object} params
		 */
		showURL: function(url, title, params) {
			showInit(title, params, function() {
				for (var i=0; i<_pub.plugins.list.length; i++) {
					var plugin = _pub.plugins.list[i];
					if (plugin.match(url)) {
						active.plugin = plugin;
						plugin.render(url, active.params);
						break;
					}
				}
			});
		},

		/**
		 * Hides the iBox
		 */
		hide: function() {
			if (active.plugin) {
				// call the plugins unload method
				if (active.plugin.unload) active.plugin.unload();
			}
			active = {}
			_pub.clear();
			// restore elements that were hidden
			for (var i=0; i<_pub.tags_to_hide.length; i++) showTags(_pub.tags_to_hide[i]);

			els.loading.style.display = 'none';
			els.wrapper.style.display = 'none';
			_pub.fade(els.overlay, _pub.getOpacity(null, els.overlay), 0, _pub.fade_out_speed, function() { els.overlay.style.display = 'none';});
			_pub.fireEvent('hide');
		},

		/**
		 * Repositions the iBox wrapper based on the params set originally.
		 */
		reposition: function() {
			if (!active.is_loaded) return;

			// center loading box
			if (els.loading.style.display != 'none') _pub.center(els.loading);
			
			// update ibox width/height/position
			if (active.dimensions) {
				var pagesize = _pub.getPageSize();

				var width = active.dimensions[0];
				var height = active.dimensions[1];
				
				if (height.toString().indexOf('%') != -1) {
					els.wrapper.style.height = (Math.max(document.documentElement.clientHeight, document.body.clientHeight, pagesize.height) - offset.container[0])*(parseInt(height)/100) + 'px';
				}
				else if (height) {
					els.content.style.height = height + 'px';
					// TODO: if we dont set wrapper height, it doesnt restrict the height and the box is fine
					// so offset.wrapper[1] must not be correct
					els.wrapper.style.height = els.content.offsetHeight + offset.wrapper[1] + 'px';
				}
				else {
					els.wrapper.style.height = els.content.offsetHeight + offset.wrapper[1] + 'px';
				}
				var container_offset = (els.content.offsetHeight - els.content.firstChild.offsetHeight);
				if (width.toString().indexOf('%') != -1) {
					els.wrapper.style.width = (Math.max(document.documentElement.clientWidth, document.body.clientWidth, pagesize.width) - offset.container[1])*(parseInt(width)/100) + 'px';
					var container_offset = 0;
				}
				else {
					els.content.style.width = width + 'px';
					els.wrapper.style.width = els.content.offsetWidth + offset.wrapper[0] + 'px';
				}

				_pub.updateObject(els.content.style, {width: '', height: ''});

				var width = parseInt(els.wrapper.style.width);
				var height = parseInt(els.wrapper.style.height);

				// if we can resize this, make sure it fits in our page bounds
				if (active.params.can_resize) {
					var x = pagesize.width;
					var y = pagesize.height;
					
					x -= offset.container[0];
					y -= offset.container[1];
					if (width > x) {
						if (active.params.constrain) height = height * (x/width);
						width = x;
					}
					if (height > y) {
						if (active.params.constrain) width = width * (y/height);
						height = y;
					}
					_pub.updateObject(els.wrapper.style, {width: width + 'px', height: height + 'px'});
				}

				//els.content.style.width = width - offset.wrapper[0] + 'px';
				// TODO: this isn't adjusting to the right height for containers that are smaller than the page height
				// resize the wrappers height based on the content boxes height
				// this needs to be height - ibox_content[margin+padding+border]
				els.content.style.height = height - offset.wrapper[1] + 'px';
				if (active.dimensions != ['100%', '100%']) _pub.center(els.wrapper);
			}
			
			// fix overlay width/height (cant use css fixed on ie6 or fx or any
			// browser really due to issues)
			els.overlay.style.height = Math.max(document.body.clientHeight, document.documentElement.clientHeight) + 'px';
		},

		updateObject: function(obj, params) {
			for (var i in params) obj[i] = params[i];
		},

		/**
		 * Centers an object
		 * @param {Object} obj
		 */
		center: function(obj) {
			var pageSize = _pub.getPageSize();
			var scrollPos = _pub.getScrollPos();
			var emSize = _pub.getElementSize(obj);
			var x = Math.round((pageSize.width - emSize.width) / 2 + scrollPos.scrollX);
			var y = Math.round((pageSize.height - emSize.height) / 2 + scrollPos.scrollY);
			if (obj.offsetLeft) x -= obj.offsetLeft;
			if (obj.offsetTop) y -= obj.offsetTop;
			if (obj.style.left) x += parseInt(obj.style.left);
			if (obj.style.top) y += parseInt(obj.style.top);
			// this nearly centers it due to scrollbars
			x -= 10;
			_pub.updateObject(obj.style, {top: y + 'px', left: x + 'px'});
		},
		
		getStyle: function(obj, styleProp) {
			if (obj.currentStyle)
				return obj.currentStyle[styleProp];
			else if (window.getComputedStyle)
				return document.defaultView.getComputedStyle(obj,null).getPropertyValue(styleProp);
		},

		/**
		 * Gets the scroll positions
		 */
		getScrollPos: function() {
			var docElem = document.documentElement;
			return {
				scrollX: document.body.scrollLeft || window.pageXOffset || (docElem && docElem.scrollLeft),
				scrollY: document.body.scrollTop || window.pageYOffset || (docElem && docElem.scrollTop)
			};
		},

		/**
		 * Gets the page constraints
		 */
		getPageSize: function() {
			return {
				width: window.innerWidth || (document.documentElement && document.documentElement.clientWidth) || document.body.clientWidth,
				height: window.innerHeight || (document.documentElement && document.documentElement.clientHeight) || document.body.clientHeight
			};
		},

		/**
		 * Gets an objects offsets
		 * @param {Object} obj
		 */
		getElementSize: function(obj) {
			return {
				width: obj.offsetWidth || obj.style.pixelWidth,
				height: obj.offsetHeight || obj.style.pixelHeight
			};
		},
		
		fade: function(obj, start, end, speed, callback) {
			if (start === undefined || !(start >= 0) || !(start <= 100)) var start = 0;
			if (end === undefined || !(end >= 0) || !(end <= 100)) var end = 100;
			if (speed === undefined) var speed = 0;

			if (obj.fader) clearInterval(obj.fader);

			if (!speed) {
				_pub.setOpacity(null, obj, end);
				if (callback) callback();
			}
			
			var opacity_difference = end - start; 
			var time_total = speed; // time is speed (jQuery compat)
			var step_size = 25; // step size in ms
			var steps = time_total / step_size; // total number of steps
			var increment = Math.ceil(opacity_difference / steps); // how much to incr per step
			
			obj.fader = setInterval(_pub.bind(function(e, obj, increment, end, callback) {
				var opacity = _pub.getOpacity(e, obj) + increment;
				_pub.setOpacity(e, obj, opacity);
				if ((increment < 0 && opacity <= end) || (increment > 0 && opacity >= end)) {
					_pub.setOpacity(e, obj, end);
					clearInterval(obj.fader);
					if (callback) callback();
				}
			}, obj, increment, end, callback), step_size);
		},

		/**
		 * Sets the opacity of an element
		 * @param {Object} obj
		 * @param {Integer} value
		 */
		setOpacity: function(e, obj, value) {
			value = Math.round(value);
			obj.style.opacity = value/100;
			obj.style.filter = 'alpha(opacity=' + value + ')';
		},
		
		/**
		 * Gets the opacity of an element
		 * @param {Object} obj
		 * @return {Integer} value
		 */
		getOpacity: function(e, obj) {
			return _pub.getStyle(obj, 'opacity')*100;
		},
		
		/**
		 * Creates a new XMLHttpRequest object based on browser
		 */
		createXMLHttpRequest: function() {
			var http;
			if (window.XMLHttpRequest) { // Mozilla, Safari,...
				http = new XMLHttpRequest();
				if (http.overrideMimeType) {
					// set type accordingly to anticipated content type
					http.overrideMimeType('text/html');
				}
			}
			else if (window.ActiveXObject) { // IE
				try {
					http = new ActiveXObject("Msxml2.XMLHTTP");
				} catch (e) {
					try {
						http = new ActiveXObject("Microsoft.XMLHTTP");
					} catch (e) {}
				}
			}
			if (!http) {
				alert('Cannot create XMLHTTP instance');
				return false;
			}
			return http;
		},
		
		addEvent: function(obj, evType, fn) {
			if (obj.addEventListener) {
				obj.addEventListener(evType, fn, false);
				return true;
			}
			else if (obj.attachEvent) {
				var r = obj.attachEvent("on"+evType, fn);
				return r;
			}
			else {
				return false;
			}
		},
		
		addEventListener: function(name, callback) {
			if (!events[name]) events[name] = new Array();
			events[name].push(callback);
		},
		
		/**
		 * Causes all event listeners attached to `name` event to
		 * execute.
		 * @param {String} name Event name
		 */
		fireEvent: function(name) {
				if (events[name] && events[name].length) {
					for (var i=0; i<events[name].length; i++) {
						var args = [];
						for (var n=1; n<arguments.length; n++) args.push(arguments[n]);
						// Events returning false stop propagation
						if (events[name][i](args) === false) break;
					}
				}
		},
		
		/**
		 * Parses the arguments in the rel attribute
		 * @param {String} query
		 */
		parseQuery: function(query) {
			 var params = new Object();
			 if (!query) return params; 
			 var pairs = query.split(/[;&]/);
			 var end_token;
			 for (var i=0; i<pairs.length; i++) {
					var keyval = pairs[i].split('=');
					if (!keyval || keyval.length != 2) continue;
					var key = unescape(keyval[0]);
					var val = unescape(keyval[1]);
					val = val.replace(/\+/g, ' ');
					if (val[0] == '"') var token = '"';
					else if (val[0] == "'") var token = "'";
					else var token = null;
					if (token) {
						if (val[val.length-1] != token) {
							do {
								i += 1;
								val += '&'+pairs[i];
							}
							while ((end_token = pairs[i][pairs[i].length-1]) != token)
						}
						val = val.substr(1, val.length-2);
					}
					if (val == 'true') val = true;
					else if (val == 'false') val = false;
					else if (val == 'null') val = null;
					params[key] = val;
			 }
			 return params;
		},
		/**
		 * Handles the onclick event for iBox anchors.
		 * @param {Event} e
		 */
		handleTag: function(e) {
			var t = this.getAttribute('rel');
			var params = _pub.parseQuery(t.substr(5,999));
			if (params.target) var url = params.target;
			else if (this.target && !params.ignore_target) var url = this.target;
			else var url = this.href;
			var title = this.title;
			if (_pub.inherit_frames && window.parent) window.parent.iBox.showURL(url, title, params);
			else _pub.showURL(url, title, params);
			return false;
		},
		
		plugins: {
			list: new Array(),
			register: function(func, last) {
				if (last === undefined) var last = false;
				if (!last) {
					_pub.plugins.list = [func].concat(_pub.plugins.list);
				}
				else {
					_pub.plugins.list.push(func);
				}
			}
		}
	};
	
	// private methods and variables
	var active = {};
	
	// events
	var events = {};

	// some containers
	// we store these in memory instead of finding them each time
	var els = {};
	
	var offset = {};
	
	/**
	 * Creates the iBox container and appends it to an element
	 * @param {HTMLObject} elem Container to attach to
	 * @return {HTMLObject} iBox element
	 */
	var create = function(elem) {
		pagesize = _pub.getPageSize();
		
		// TODO: why isnt this using DOM tools
		// a trick on just creating an ibox wrapper then doing an innerHTML on our root ibox element
		els.container = document.createElement('div');
		els.container.id = 'ibox';

		els.overlay = document.createElement('div');
		els.overlay.style.display = 'none';
		_pub.setOpacity(null, els.overlay, 0);
		// firefox mac has issues with opacity and flash
		if (!_pub.is_firefox) els.overlay.style.background = '';
		else els.overlay.style.backgroundImage = "url('" + _pub.base_url + "images/bg.png')";
		els.overlay.id = 'ibox_overlay';
		params = {position: 'absolute', top: 0, left: 0, width: '100%'};
		_pub.updateObject(els.overlay.style, params);
		els.overlay.onclick = _pub.hide;
		els.container.appendChild(els.overlay);

		els.loading = document.createElement('div');
		els.loading.id = 'ibox_loading';
		els.loading.innerHTML = 'Loading...';
		els.loading.style.display = 'none';
		els.loading.onclick = _pub.hide
		els.container.appendChild(els.loading);

		els.wrapper = document.createElement('div')
		els.wrapper.id = 'ibox_wrapper';
		_pub.updateObject(els.wrapper.style, {position: 'absolute', top: 0, left: 0, display: 'none'});

		els.content = document.createElement('div');
		els.content.id = 'ibox_content';
		_pub.updateObject(els.content.style, {overflow: 'auto'})
		els.wrapper.appendChild(els.content);
	
		var child = document.createElement('div');
		child.id = 'ibox_footer_wrapper';
	
		var child2 = document.createElement('a');
		child2.innerHTML = _pub.close_label;
		child2.href = 'javascript:void(0)';
		child2.onclick = _pub.hide;
		child.appendChild(child2);
	
		els.footer = document.createElement('div');
		els.footer.id = 'ibox_footer';
		els.footer.innerHTML = '&nbsp;';
		child.appendChild(els.footer);
		els.wrapper.appendChild(child);

		els.container.appendChild(els.wrapper);

		elem.appendChild(els.container);
				
		_pub.updateObject(els.wrapper.style, {right: '', bottom: ''});
		
		return els.container;
	};
	
	/**
	 * Hides tags within the container
	 * @param {String} tag The name of the tag (e.g. 'a')
	 * @param {HTMLObject} container The container to restore tags within (defaults to document)
	 */
	var hideTags = function(tag, container) {
		if (container === undefined) var container = document.body;
		var list = container.getElementsByTagName(tag);
		for (var i=0; i<list.length; i++) {
			if (_pub.getStyle(list[i], 'visibility') != 'hidden' && list[i].style.display != 'none') {
				list[i].style.visibility = 'hidden';
				list[i].wasHidden = true;
			}
		}
	};
	
	/**
	 * Shows all previously hidden tags in a container.
	 * @param {String} tag The name of the tag (e.g. 'a')
	 * @param {HTMLObject} container The container to restore tags within (defaults to document)
	 */
	var showTags = function(tag, container) {
		if (container === undefined) var container = document.body;
		var list = container.getElementsByTagName(tag);
		for (var i=0; i<list.length; i++) {
			if (list[i].wasHidden) {
				list[i].style.visibility = 'visible';
				list[i].wasHidden = null;
			}
		}
	};
	
	var showInit = function(title, params, callback) {
		if (!_initialized) initialize();
		if (params === undefined) var params = {};
		if (active.plugin) _pub.hide();

		active.is_loaded = true;
		active.params = params;
		
		els.loading.style.display = "block";
		
		_pub.center(els.loading);
		_pub.reposition();

		// hide tags
		for (var i=0; i<_pub.tags_to_hide.length; i++) {
			hideTags(_pub.tags_to_hide[i]);
		}

		// set title here
		els.footer.innerHTML = title || "&nbsp;";

		// setup background
		els.overlay.style.display = "block";
		
		if (!_pub.is_firefox) var amount = 70;
		else var amount = 100;
		_pub.fade(els.overlay, _pub.getOpacity(null, els.overlay), amount, _pub.fade_in_speed, callback);
		
		_pub.fireEvent('show');
	};
	
	var drawCSS = function() {
		// Core CSS (positioning/etc)

		var core_styles = "#ibox {z-index:1000000;text-align:left;} #ibox_overlay {z-index:1000000;} #ibox_loading {position:absolute;z-index:1000001;} #ibox_wrapper {margin:30px;position:absolute;top:0;left:0;z-index:1000001;} #ibox_content {z-index:1000002;margin:27px 5px 5px 5px;padding:2px;} #ibox_content object {display:block;} #ibox_content .ibox_image {width:100%;height:100%;margin:0;padding:0;border:0;display:block;} #ibox_footer_wrapper a {float:right;display:block;outline:0;margin:0;padding:0;} #ibox_footer_wrapper {text-align:left;position:absolute;top:5px;right:5px;left:5px;white-space:nowrap;overflow:hidden;}";
		
		// Default style/theme/skin/whatever
		var default_skin = "#ibox_footer_wrapper {font-weight:bold;height:20px;line-height:20px;} #ibox_footer_wrapper a {text-decoration:none;background:#888;border:1px solid #666;line-height:16px;padding:0 5px;color:#333;font-weight:bold;font-family:Verdana, Arial, Helvetica, sans-serif;font-size:10px;} #ibox_footer_wrapper a:hover {background-color:#fff;color:#111;} #ibox_footer_wrapper {font-size:12px;font-family:Verdana, Arial, Helvetica, sans-serif;color:#111;} #ibox_wrapper {border:1px solid #ccc;} #ibox_wrapper {background-color:#fff;}#ibox_content {background-color:#fff;border:1px solid #666;} #ibox_loading {padding:50px; background:#fff;color:#fff;font-size:16px;font-weight:bold;}";

		var head = document.getElementsByTagName("head")[0];

		// tricky hack for IE
		// because IE doesn't like when you insert stuff the proper way
		// and we cant use relative paths to include this as an external
		// stylesheet
		var htmDiv = document.createElement('div');

		htmDiv.innerHTML = '<p>x</p><style type="text/css">'+default_skin+'</style>';
		head.insertBefore(htmDiv.childNodes[1], head.firstChild);

		htmDiv.innerHTML = '<p>x</p><style type="text/css">'+core_styles+'</style>';
		head.insertBefore(htmDiv.childNodes[1], head.firstChild);
	};

	var _initialized = false;
	var initialize = function() {
		// make sure we haven't already done this
		if (_initialized) return;
		_initialized = true;
		// elements here start the look up from the start non <a> tags
		drawCSS();
		var els = document.getElementsByTagName('script');
		var src;
		for (var i=0, el=null; (el = els[i]); i++) {
			if (!(src = el.getAttribute('src'))) continue;
			src = src.split('?')[0];
			if (src.substr(src.length-8) == '/ibox.js') {
				_pub.setPath(src.substr(0, src.length-7));
				break;
			}
		}
		create(document.body);
		_pub.checkTags(document.body, 'a');
		_pub.http = _pub.createXMLHttpRequest();
		_pub.fireEvent('load');
	};
	
	_pub.addEvent(window, 'keypress', function(e){ if (e.keyCode == (window.event ? 27 : e.DOM_VK_ESCAPE)) { iBox.hide(); }});
	_pub.addEvent(window, 'resize', _pub.reposition);
	_pub.addEvent(window, 'load', initialize);
	_pub.addEvent(window, 'scroll', _pub.reposition);

	// DEFAULT PLUGINS

	/**
	 * Handles embedded containers in the page based on url of #container.
	 * This _ONLY_ works with hidden containers.
	 */
	var iBoxPlugin_Container = function() {
		var was_error = false;
		var original_wrapper = null;
		return {
			/**
			 * Matches the url and returns true if it fits this plugin.
			 */
			match: function(url) {
				return url.indexOf('#') != -1;
			},
			/**
			 * Called when this plugin is unloaded.
			 */
			unload: function() {
				if (was_error) return;
				var elemSrc = _pub.html().firstChild;
				if (elemSrc) {
					elemSrc.style.display = 'none';
					original_wrapper.appendChild(elemSrc);
				}
			},
			/**
			 * Handles the output
			 * @param {iBox} ibox
			 * @param {String} url
			 * @return {iBoxContent} an instance or subclass of iBoxContent
			 */
			render: function(url, params) {
				was_error = false;
				var elemSrcId = url.substr(url.indexOf("#") + 1);
				var elemSrc = document.getElementById(elemSrcId);
				// If the element doesnt exist, break the switch
				if (!elemSrc) {
					was_error = true;
					_pub.html(document.createTextNode('There was an error loading the document.'), params);
				}
				else {
					original_wrapper = elemSrc.parentNode;
					elemSrc.style.display = 'block';
					_pub.html(elemSrc, params);
				}
			}
		}
	}();
	_pub.plugins.register(iBoxPlugin_Container, true);

	/**
	 * Handles images
	 */
	var iBoxPlugin_Image = function() {
		// Image types (for auto detection of image display)
		var image_types = /\.jpg|\.jpeg|\.png|\.gif/gi;

		return {
			match: function(url) {
				return url.match(image_types);
			},

			render: function(url, params) {	
				var img = document.createElement('img');
				img.onclick = _pub.hide;
				img.className = 'ibox_image'
				img.style.cursor = 'pointer';
				img.onload = function() {
					_pub.html(img, {width: this.width, height: this.height, constrain: true})
				}
				img.onerror = function() {
					_pub.html(document.createTextNode('There was an error loading the document.'), params);
				}
				img.src = url;
			}
		}
	}();
	_pub.plugins.register(iBoxPlugin_Image);

	var iBoxPlugin_YouTube = function() {
		var youtube_url = /(?:http:\/\/)?(?:www\d*\.)?(youtube\.(?:[a-z]+))\/(?:v\/|(?:watch(?:\.php)?)?\?(?:.+&)?v=)([^&]+).*/;
		return {
			match: function(url) {
				return url.match(youtube_url);
			},

			render: function(url, params) {
				var _match = url.match(youtube_url);
				var domain = _match[1];
				var id = _match[2];
				params.width = 425;
				params.height = 355;
				params.constrain = true;
				var html = '<span><object width="100%" height="100%" style="overflow: hidden; display: block;"><param name="movie" value="http://www.' + domain + '/v/' + id + '"/><param name="wmode" value="transparent"/><embed src="http://www.' + domain + '/v/' + id + '" type="application/x-shockwave-flash" wmode="transparent" width="100%" height="100%"></embed></object></span>';
				_pub.html(html, params);
			}
		}
	}();
	_pub.plugins.register(iBoxPlugin_YouTube);

	var iBoxPlugin_Document = function() {
		return {
			match: function(url) {
				return true;
			},

			render: function(url, params) {
				_pub.http.open('get', url, true);

				_pub.http.onreadystatechange = function() {
					if (_pub.http.readyState == 4) {
						// XXX: why does status return 0?
						if (_pub.http.status == 200 || _pub.http.status == 0) {
							_pub.html(_pub.http.responseText, params);
						}
						else {
							_pub.html(document.createTextNode('There was an error loading the document.'), params);
						}
					}
				}
				_pub.http.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
				try {
					_pub.http.send(null);
				}
				catch (ex) {
					_pub.html(document.createTextNode('There was an error loading the document.'), params);
				}
			}
		};
	}();
	_pub.plugins.register(iBoxPlugin_Document, true);

	return _pub;
}();





