
/*** default.js - 21.0 kb ***/
// JScript File

// APPLICATION FUNCTIONS
function out(s,t){var p;if(p=$('out')) p.innerHTML=(t?s:$('out').innerHTML+s);}
function findPosX(obj){var curleft=0;if(obj.offsetParent){while(obj.offsetParent){curleft+=obj.offsetLeft;obj=obj.offsetParent;}}else if(obj.x){curleft+=obj.x;}return curleft;}
function findPosY(obj){var curtop=0;if(obj.offsetParent){while(obj.offsetParent){curtop+=obj.offsetTop;obj=obj.offsetParent;}}else if(obj.y){curtop += obj.y;}return curtop;}

function hideAuthorTools(){var divs = document.getElementsByTagName("div");for(i=0;i<divs.length;i++){var div = divs[i];if (div.lang == "aa"){div.style.display = div.style.display == 'none' ? 'block' : 'none';}}}
function qs(n){n = n.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]");var s = "[\\?&]"+n+"=([^&#]*)";var r = new RegExp( s );var t = r.exec( window.location.href );if( t == null )return "";else return t[1];}

Ajax.Responders.register({
    onCreate: function(obj) {
    },
    onLoading: function(obj){
        Global.Cursor.Show();
    },
    onComplete: function(obj){
        switch(obj.transport.status){
            case 500:
            case 404:
                console.log(obj.transport.responseText);
                break;                
        }
        Global.Cursor.Hide();
    },
    onRequestStart: function(obj){
        obj.options.parameters = Object.extend(obj.options.parameters, {userstatus: _STATUS} || null);
    }
});

var Util = {
    outerHTML: function(element){
        var p = Builder.node('div', [element.cloneNode(true)]);
        var ret = p.innerHTML;
        p = null;
        return ret;
    }
}

Element.addMethods(Util);


// getPageScroll()
function getPageScroll(){var yScroll;if (self.pageYOffset) {yScroll = self.pageYOffset;} else if (document.documentElement && document.documentElement.scrollTop){yScroll = document.documentElement.scrollTop;} else if (document.body) {yScroll = document.body.scrollTop;}arrayPageScroll = new Array('',yScroll);return arrayPageScroll;}

// getPageSize()
function getPageSize(){var xScroll, yScroll;if (window.innerHeight && window.scrollMaxY) {xScroll = document.body.scrollWidth;yScroll = window.innerHeight + window.scrollMaxY;} else if (document.body.scrollHeight > document.body.offsetHeight){xScroll = document.body.scrollWidth;yScroll = document.body.scrollHeight;} else {xScroll = document.body.offsetWidth;yScroll = document.body.offsetHeight;}var windowWidth, windowHeight;if (self.innerHeight) {windowWidth = self.innerWidth;windowHeight = self.innerHeight;} else if (document.documentElement && document.documentElement.clientHeight) {windowWidth = document.documentElement.clientWidth;windowHeight = document.documentElement.clientHeight;} else if (document.body) {windowWidth = document.body.clientWidth;windowHeight = document.body.clientHeight;}if(yScroll < windowHeight){pageHeight = windowHeight;} else {pageHeight = yScroll;}if(xScroll < windowWidth){pageWidth = windowWidth;} else {pageWidth = xScroll;}arrayPageSize = new Array(pageWidth,pageHeight,windowWidth,windowHeight); return arrayPageSize;}

// RETURNS XML OBJECT
function getXml(str){var doc;if (window.ActiveXObject){doc = new ActiveXObject("Microsoft.XMLDOM");doc.async = "false";doc.loadXML(str);} else {var parser = new DOMParser();doc = parser.parseFromString(str, "text/xml");}return doc;}

// CURRENCY FUNCTION
function currency(num) {num = num.toString().replace(/\$|\,/g,'');if(isNaN(num)) num = "0"; sign = (num == (num = Math.abs(num)));num = Math.floor(num*100+0.50000000001);cents = num%100;num = Math.floor(num/100).toString();if(cents<10) cents = "0" + cents;for (var i = 0; i < Math.floor((num.length-(1+i))/3); i++) num = num.substring(0,num.length-(4*i+3))+','+ num.substring(num.length-(4*i+3)); return (((sign)?'':'-') + '$' + num + '.' + cents);}

Object.extend(String.prototype, {
    rep: function(object, pattern) {
        return new Template(this, pattern).evaluate(object);
    }  
});


var ddOpen = false;
var thisBox = null;
function barSearch(options, valId){
    var tb = $(valId);
    var page = '/s/?s=';

    if (tb.value == '' || tb.value.toLowerCase().indexOf('search') == 0){
        alert('You must enter a value to search.');
        return;
    }
    var newWindow = false;
    if (options) {
        var op = $(options);
        if (op.value != null){
            switch(op.value){
                case 'sbrforum':
                    page = 'http://forum.sbrforum.com/search.php?do=process&query=';
                    newWindow = true;
                break;            
                case 'sbr':
                    page = 'http://www.sportsbookreview.com/sr.aspx?s=';  
                    newWindow = true;          
                break;
                default:
                    page = 'http://www.' + _DOMAIN + '/s/?s=';
                break;
            }
        }
    } else {
        page = 'http://www.' + _DOMAIN + '/s/?s=';
    }
    var q = tb.value.replace(/([^\d\w\s]+|\s(a|an|and|are|as|at|be|by|for|from|in|is|it|of|on|or|that|the|this|to|was|which|with)\s)/g, ' ');
    q = q.replace(/\s+/g, '+');
    q = q.indexOf('+') == q.length-1 ? q.substr(0, q.length-1) : q;
    if (newWindow){
        window.open(page + q);
        return false;
    } else
        window.location.href = page + q;
    return false;
}

 function getSettings(obj) {
    var m = obj;
    var vars = {};
    m.select('input:not([type="checkbox"])').each(function(i){
        if (i.name || i.id){
            if (i.getAttribute('type') == 'radio' && i.checked)
                vars[i.id ? i.id : i.name] = i.value;
            else if (i.getAttribute('type') != 'radio')
                vars[i.name ? i.name : i.id] = escape(i.value);
        }
    });
    m.select('select').each(function(s){
        if (s.name || s.id){
            vars[s.name ? s.name : s.id] = escape(s.options[s.selectedIndex].value);
        }
    });
    m.select('textarea').each(function(t){
        if (t.name || t.id){
            vars[t.name ? t.name : t.id] = escape(t.value);
        }
    });
    m.select('input[type="checkbox"]').each(function(c){
        if (c.name || c.id){
            vars[c.name ? c.name : c.id] = c.checked;
        }
    });
    var s = "";
    for(k in vars){
        s += k + '=' + vars[k] + "&";
    }
    var ret = {};
    ret['vars'] = s;
    return ret;
}

function calcTime(offset) {

    // create Date object for current location
    d = new Date();
   
    // convert to msec
    // add local time zone offset
    // get UTC time in msec
    utc = d.getTime() + (d.getTimezoneOffset() * 60000);
   
    // create new Date object for different city
    // using supplied offset
    nd = new Date(utc + (3600000*offset));
   
    // return time as a string
    return nd;

}

/** 
* Tab Engine By SBR
**/
document.observe("dom:loaded", function() {
  // initially hide all containers for tab content
  var navTabs = [];
  $$('.tabs a').each(function(tab){
    navTabs.push(tab.readAttribute('tab'));
    $(tab).observe('click', function(){
    if($(tab.readAttribute('tab'))){
    $$('.tabs a.selected').each(function(e){
            e.removeClassName('selected');
        });
        $$('.tabbox .page').invoke('hide');
        
        $(tab.readAttribute('tab')).show();
        tab.addClassName('selected');
    }    
    });
    
  });
  
  //Check to see if the option in url is present
  if(document.URL.indexOf('#',0) >0){
    var id = document.URL.split('#').last();
    if(navTabs.indexOf(id) >=0){
      //tab exists
      $$('.tabs a.selected').each(function(e){
            e.removeClassName('selected');
        });
      $$('.tabbox .page').invoke('hide');
      $(id).show();
      $$('.tabs a').each(function(tab){
        if(tab.readAttribute('tab') == id){
        tab.addClassName('selected');
        }
      });   
    }
  }
});

/**
 * Ajax upload
 * Project page - http://valums.com/ajax-upload/
 * Copyright (c) 2008 Andris Valums, http://valums.com
 * Licensed under the MIT license (http://valums.com/mit-license/)
 * Version 3.1 (24.04.2009)
 */

/**
 * Changes from the previous version:
 * 1. Fixed Safari 4 (Mac) upload problem
 * Special thanks to Lauren Russell, Mike, Steffen for finding what caused this bug
 * 2. Improved compatability with jquery ui.
 * Thanks to Vladimir Shushkov
 * 3. Fixed problems with Opera, but you can't use false as a response now.
 * 
 * For the full changelog please visit: 
 * http://valums.com/ajax-upload-changelog/
 */

(function(){
	
var d = document, w = window;

/**
 * Get element by id
 */	
function get(element){
	if (typeof element == "string")
		element = d.getElementById(element);
	return element;
}

/**
 * Attaches event to a dom element
 */
function addEvent(el, type, fn){
	if (w.addEventListener){
		el.addEventListener(type, fn, false);
	} else if (w.attachEvent){
		var f = function(){
		  fn.call(el, w.event);
		};			
		el.attachEvent('on' + type, f)
	}
}


/**
 * Creates and returns element from html chunk
 */
var toElement = function(){
	var div = d.createElement('div');
	return function(html){
		div.innerHTML = html;
		var el = div.childNodes[0];
		div.removeChild(el);
		return el;
	}
}();

function hasClass(ele,cls){
	return ele.className.match(new RegExp('(\\s|^)'+cls+'(\\s|$)'));
}
function addClass(ele,cls) {
	if (!hasClass(ele,cls)) ele.className += " "+cls;
}
function removeClass(ele,cls) {
	var reg = new RegExp('(\\s|^)'+cls+'(\\s|$)');
	ele.className=ele.className.replace(reg,' ');
}

// getOffset function copied from jQuery lib (http://jquery.com/)
if (document.documentElement["getBoundingClientRect"]){
	// Get Offset using getBoundingClientRect
	// http://ejohn.org/blog/getboundingclientrect-is-awesome/
	var getOffset = function(el){
		var box = el.getBoundingClientRect(),
		doc = el.ownerDocument,
		body = doc.body,
		docElem = doc.documentElement,
		
		// for ie 
		clientTop = docElem.clientTop || body.clientTop || 0,
		clientLeft = docElem.clientLeft || body.clientLeft || 0,
		
		// In Internet Explorer 7 getBoundingClientRect property is treated as physical,
		// while others are logical. Make all logical, like in IE8.
		
		
		zoom = 1;
		if (body.getBoundingClientRect) {
			var bound = body.getBoundingClientRect();
			zoom = (bound.right - bound.left)/body.clientWidth;
		}
		if (zoom > 1){
			clientTop = 0;
			clientLeft = 0;
		}
		var top = box.top/zoom + (window.pageYOffset || docElem && docElem.scrollTop/zoom || body.scrollTop/zoom) - clientTop,
		left = box.left/zoom + (window.pageXOffset|| docElem && docElem.scrollLeft/zoom || body.scrollLeft/zoom) - clientLeft;
				
		return {
			top: top,
			left: left
		};
	}
	
} else {
	// Get offset adding all offsets 
	var getOffset = function(el){
		if (w.jQuery){
			return jQuery(el).offset();
		}		
			
		var top = 0, left = 0;
		do {
			top += el.offsetTop || 0;
			left += el.offsetLeft || 0;
		}
		while (el = el.offsetParent);
		
		return {
			left: left,
			top: top
		};
	}
}

function getBox(el){
	var left, right, top, bottom;	
	var offset = getOffset(el);
	left = offset.left;
	top = offset.top;
						
	right = left + el.offsetWidth;
	bottom = top + el.offsetHeight;		
		
	return {
		left: left,
		right: right,
		top: top,
		bottom: bottom
	};
}

/**
 * Crossbrowser mouse coordinates
 */
function getMouseCoords(e){		
	// pageX/Y is not supported in IE
	// http://www.quirksmode.org/dom/w3c_cssom.html			
	if (!e.pageX && e.clientX){
		// In Internet Explorer 7 some properties (mouse coordinates) are treated as physical,
		// while others are logical (offset).
		var zoom = 1;	
		var body = document.body;
		
		if (body.getBoundingClientRect) {
			var bound = body.getBoundingClientRect();
			zoom = (bound.right - bound.left)/body.clientWidth;
		}

		return {
			x: e.clientX / zoom + d.body.scrollLeft + d.documentElement.scrollLeft,
			y: e.clientY / zoom + d.body.scrollTop + d.documentElement.scrollTop
		};
	}
	
	return {
		x: e.pageX,
		y: e.pageY
	};		

}
/**
 * Function generates unique id
 */		
var getUID = function(){
	var id = 0;
	return function(){
		return 'ValumsAjaxUpload' + id++;
	}
}();

function fileFromPath(file){
	return file.replace(/.*(\/|\\)/, "");			
}

function getExt(file){
	return (/[.]/.exec(file)) ? /[^.]+$/.exec(file.toLowerCase()) : '';
}			

// Please use AjaxUpload , Ajax_upload will be removed in the next version
Ajax_upload = AjaxUpload = function(button, options){
	if (button.jquery){
		// jquery object was passed
		button = button[0];
	} else if (typeof button == "string" && /^#.*/.test(button)){					
		button = button.slice(1);				
	}
	button = get(button);	
	
	this._input = null;
	this._button = button;
	this._disabled = false;
	this._submitting = false;
	// Variable changes to true if the button was clicked
	// 3 seconds ago (requred to fix Safari on Mac error)
	this._justClicked = false;
	this._parentDialog = d.body;
			
	if (window.jQuery && jQuery.ui && jQuery.ui.dialog){
		var parentDialog = jQuery(self._button).parents('.ui-dialog-content');
		if (parentDialog.length){
			this._parentDialog = parentDialog[0];
		}
	}
					
	this._settings = {
		// Location of the server-side upload script
		action: 'upload.php',			
		// File upload name
		name: 'userfile',
		// Additional data to send
		data: {},
		// Submit file as soon as it's selected
		autoSubmit: true,
		// The type of data that you're expecting back from the server.
		// Html and xml are detected automatically.
		// Only useful when you are using json data as a response.
		// Set to "json" in that case. 
		responseType: false,
		// When user selects a file, useful with autoSubmit disabled			
		onChange: function(file, extension){},					
		// Callback to fire before file is uploaded
		// You can return false to cancel upload
		onSubmit: function(file, extension){},
		// Fired when file upload is completed
		onComplete: function(file, response) {}
	};

	// Merge the users options with our defaults
	for (var i in options) {
		this._settings[i] = options[i];
	}
	
	this._createInput();
	this._rerouteClicks();
}
			
// assigning methods to our class
AjaxUpload.prototype = {
	setData : function(data){
		this._settings.data = data;
	},
	disable : function(){
		this._disabled = true;
	},
	enable : function(){
		this._disabled = false;
	},
	// removes ajaxupload
	destroy : function(){
		if(this._input){
			if(this._input.parentNode){
				this._input.parentNode.removeChild(this._input);
			}
			this._input = null;
		}
	},				
	/**
	 * Creates invisible file input above the button 
	 */
	_createInput : function(){
		var self = this;
		var input = d.createElement("input");
		input.setAttribute('type', 'file');
		input.setAttribute('name', this._settings.name);
		var styles = {
			'position' : 'absolute'
			,'margin': '-5px 0 0 -175px'
			,'padding': 0
			,'width': '220px'
			,'height': '30px'								
			,'opacity': 0
			,'cursor': 'pointer'
			,'display' : 'none'
			,'zIndex' :  2147483583 //Max zIndex supported by Opera 9.0-9.2x 
			// Strange, I expected 2147483647					
		};
		for (var i in styles){
			input.style[i] = styles[i];
		}
		
		// Make sure that element opacity exists
		// (IE uses filter instead)
		if ( ! (input.style.opacity === "0")){
			input.style.filter = "alpha(opacity=0)";
		}
							
		this._parentDialog.appendChild(input);

		addEvent(input, 'change', function(){
			// get filename from input
			var file = fileFromPath(this.value);	
			if(self._settings.onChange.call(self, file, getExt(file)) == false ){
				return;				
			}														
			// Submit form when value is changed
			if (self._settings.autoSubmit){
				self.submit();						
			}						
		});
		
		// Fixing problem with Safari
		// The problem is that if you leave input before the file select dialog opens
		// it does not upload the file.
		// As dialog opens slowly (it is a sheet dialog which takes some time to open)
		// there is some time while you can leave the button.
		// So we should not change display to none immediately
		addEvent(input, 'click', function(){
			self.justClicked = true;
			setTimeout(function(){
				// we will wait 3 seconds for dialog to open
				self.justClicked = false;
			}, 3000);			
		});		
		
		this._input = input;
	},
	_rerouteClicks : function (){
		var self = this;
	
		// IE displays 'access denied' error when using this method
		// other browsers just ignore click()
		// addEvent(this._button, 'click', function(e){
		//   self._input.click();
		// });
				
		var box, dialogOffset = {top:0, left:0}, over = false;							
		addEvent(self._button, 'mouseover', function(e){
			if (!self._input || over) return;
			over = true;
			box = getBox(self._button);
					
			if (self._parentDialog != d.body){
				dialogOffset = getOffset(self._parentDialog);
			}	
		});
		
	
		// we can't use mouseout on the button,
		// because invisible input is over it
		addEvent(document, 'mousemove', function(e){
			var input = self._input;			
			if (!input || !over) return;
			
			if (self._disabled){
				removeClass(self._button, 'hover');
				input.style.display = 'none';
				return;
			}	
										
			var c = getMouseCoords(e);

			if ((c.x >= box.left) && (c.x <= box.right) && 
			(c.y >= box.top) && (c.y <= box.bottom)){			
				input.style.top = c.y - dialogOffset.top + 'px';
				input.style.left = c.x - dialogOffset.left + 'px';
				input.style.display = 'block';
				addClass(self._button, 'hover');				
			} else {		
				// mouse left the button
				over = false;
				if (!self.justClicked){
					input.style.display = 'none';
				}
				removeClass(self._button, 'hover');
			}			
		});			
			
	},
	/**
	 * Creates iframe with unique name
	 */
	_createIframe : function(){
		// unique name
		// We cannot use getTime, because it sometimes return
		// same value in safari :(
		var id = getUID();
		
		// Remove ie6 "This page contains both secure and nonsecure items" prompt 
		// http://tinyurl.com/77w9wh
		var iframe = toElement('<iframe src="javascript:false;" name="' + id + '" />');
		iframe.id = id;
		iframe.style.display = 'none';
		d.body.appendChild(iframe);			
		return iframe;						
	},
	/**
	 * Upload file without refreshing the page
	 */
	submit : function(){
		var self = this, settings = this._settings;	
					
		if (this._input.value === ''){
			// there is no file
			return;
		}
										
		// get filename from input
		var file = fileFromPath(this._input.value);			

		// execute user event
		if (! (settings.onSubmit.call(this, file, getExt(file)) == false)) {
			// Create new iframe for this submission
			var iframe = this._createIframe();
			
			// Do not submit if user function returns false										
			var form = this._createForm(iframe);
			form.appendChild(this._input);
			
			form.submit();
			
			d.body.removeChild(form);				
			form = null;
			this._input = null;
			
			// create new input
			this._createInput();
			
			var toDeleteFlag = false;
			
			addEvent(iframe, 'load', function(e){
				if (iframe.src == "about:blank"){						
					// First time around, do not delete.
					if( toDeleteFlag ){
						// Fix busy state in FF3
						setTimeout( function() {
							d.body.removeChild(iframe);
						}, 0);
					}
					return;
				}				
				
				var doc = iframe.contentDocument ? iframe.contentDocument : frames[iframe.id].document;

				// fixing Opera 9.26
				if (doc.readyState && doc.readyState != 'complete'){
					// Opera fires load event multiple times
					// Even when the DOM is not ready yet
					// this fix should not affect other browsers
					return;
				}
				
				// fixing Opera 9.64
				if (doc.body && doc.body.innerHTML == "false"){
					// In Opera 9.64 event was fired second time
					// when body.innerHTML changed from false 
					// to server response approx. after 1 sec
					return;				
				}
				
				var response;
									
				if (doc.XMLDocument){
					// response is a xml document IE property
					response = doc.XMLDocument;
				} else if (doc.body){
					// response is html document or plain text
					response = doc.body.innerHTML;
					if (settings.responseType == 'json'){
						response = window["eval"]("(" + response + ")");
					}
				} else {
					// response is a xml document
					var response = doc;
				}
																			
				settings.onComplete.call(self, file, response);
						
				// Reload blank page, so that reloading main page
				// does not re-submit the post. Also, remember to
				// delete the frame
				toDeleteFlag = true;				
				iframe.src = "about:blank"; //load event fired				 								
			});
	
		} else {
			// clear input to allow user to select same file
			this._input.value = '';						
		}
	},		
	/**
	 * Creates form, that will be submitted to iframe
	 */
	_createForm : function(iframe){
		var settings = this._settings;
		
		// method, enctype must be specified here
		// because changing this attr on the fly is not allowed in IE 6/7		
		var form = toElement('<form method="post" enctype="multipart/form-data"></form>');
		form.style.display = 'none';
		form.action = settings.action;
		form.target = iframe.name;
		d.body.appendChild(form);
		
		// Create hidden input element for each data key
		for (var prop in settings.data){
			var el = d.createElement("input");
			el.type = 'hidden';
			el.name = prop;
			el.value = settings.data[prop];
			form.appendChild(el);
		}			
		return form;
	}	
};
})();

/*** CustomControls.js - 7.0 kb ***/
// JScript File
// CONSOLE PROTECTION
if(typeof(console) == 'undefined')
    console = {log: function(obj){}};


// DATE.FORMAT.JS
var dateFormat = function () {
	var	token        = /d{1,4}|m{1,4}|yy(?:yy)?|([HhMsTt])\1?|[LloZ]|"[^"]*"|'[^']*'/g,
		timezone     = /\b(?:[PMCEA][SDP]T|(?:Pacific|Mountain|Central|Eastern|Atlantic) (?:Standard|Daylight|Prevailing) Time|(?:GMT|UTC)(?:[-+]\d{4})?)\b/g,
		timezoneClip = /[^-+\dA-Z]/g,
		pad = function (value, length) {
			value = String(value);
			length = parseInt(length) || 2;
			while (value.length < length)
				value = "0" + value;
			return value;
		};

	// Regexes and supporting functions are cached through closure
	return function (date, mask) {
		// Treat the first argument as a mask if it doesn't contain any numbers
		if (
			arguments.length == 1 &&
			(typeof date == "string" || date instanceof String) &&
			!/\d/.test(date)
		) {
			mask = date;
			date = undefined;
		}

		date = date ? new Date(date) : new Date();
		if (isNaN(date))
			throw "invalid date";

		var dF = dateFormat;
		mask   = String(dF.masks[mask] || mask || dF.masks["default"]);

		var	d = date.getDate(),
			D = date.getDay(),
			m = date.getMonth(),
			y = date.getFullYear(),
			H = date.getHours(),
			M = date.getMinutes(),
			s = date.getSeconds(),
			L = date.getMilliseconds(),
			o = date.getTimezoneOffset(),
			flags = {
				d:    d,
				dd:   pad(d),
				ddd:  dF.i18n.dayNames[D],
				dddd: dF.i18n.dayNames[D + 7],
				m:    m + 1,
				mm:   pad(m + 1),
				mmm:  dF.i18n.monthNames[m],
				mmmm: dF.i18n.monthNames[m + 12],
				yy:   String(y).slice(2),
				yyyy: y,
				h:    H % 12 || 12,
				hh:   pad(H % 12 || 12),
				H:    H,
				HH:   pad(H),
				M:    M,
				MM:   pad(M),
				s:    s,
				ss:   pad(s),
				l:    pad(L, 3),
				L:    pad(L > 99 ? Math.round(L / 10) : L),
				t:    H < 12 ? "a"  : "p",
				tt:   H < 12 ? "am" : "pm",
				T:    H < 12 ? "A"  : "P",
				TT:   H < 12 ? "AM" : "PM",
				Z:    (String(date).match(timezone) || [""]).pop().replace(timezoneClip, ""),
				o:    (o > 0 ? "-" : "+") + pad(Math.floor(Math.abs(o) / 60) * 100 + Math.abs(o) % 60, 4)
			};

		return mask.replace(token, function ($0) {
			return ($0 in flags) ? flags[$0] : $0.slice(1, $0.length - 1);
		});
	};
}();

// Some common format strings
dateFormat.masks = {
	"default":       "ddd mmm d yyyy HH:MM:ss",
	shortDate:       "m/d/yy",
	mediumDate:      "mmm d, yyyy",
	longDate:        "mmmm d, yyyy",
	fullDate:        "dddd, mmmm d, yyyy",
	shortTime:       "h:MM TT",
	mediumTime:      "h:MM:ss TT",
	longTime:        "h:MM:ss TT Z",
	isoDate:         "yyyy-mm-dd",
	isoTime:         "HH:MM:ss",
	isoDateTime:     "yyyy-mm-dd'T'HH:MM:ss",
	isoFullDateTime: "yyyy-mm-dd'T'HH:MM:ss.lo"
};

// Internationalization strings
dateFormat.i18n = {
	dayNames: [
		"Sun", "Mon", "Tue", "Wed", "Thr", "Fri", "Sat",
		"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"
	],
	monthNames: [
		"Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec",
		"January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"
	]
};

// For convenience...
Date.prototype.format = function (mask) {
	return dateFormat(this, mask);
}

// String Builder
var StringBuilder = Class.create({
    initialize:     function() { this.array = new Array(); },
    Append:         function(str) { this.array.push(str); },
    AppendStrings:  function(arr) { this.array.push(arr.join("")); },
    AppendFormat:   function(str, obj) { this.array.push(str.interpolate(obj)); },
    AppendLine:     function() { this.array.push("\n"); },
    Length:         function() { return this.array.join("").length; },
    ToString:       function(j) { return this.array.join(j == null ? "" : j); }
});


var SSMath = function() {
    var usa = function() {
        this.UPrice = function(risk, towin) {
            return (towin >= risk) ? (towin/risk) * 100 : (risk/towin) * -100;
        }
        this.URisk = function(price, towin) {
            return (price > 0) ? (towin/price) * 100 : (-price * towin) / 100;
        }
        this.UToWin = function(price, risk) {
            return (price > 0) ? (price * risk) / 100 : (risk/-price) * 100;
        }
    }
    this.USAOdds = new usa();

    var dec = function() {
        this.UPrice = function(risk, towin) {
            return (towin/risk) + 1;
        }
        this.URisk = function(price, towin) {
            return towin / (price - 1);
        }
        this.UToWin = function(price, risk) {
            return (price * risk) - risk;
        }
    }
    this.Decimal = new dec();
    this.ToCurrency = function(num) {num = num.toString().replace(/\$|\,/g,'');if(isNaN(num)) num = "0"; sign = (num == (num = Math.abs(num)));num = Math.floor(num*100+0.50000000001);cents = num%100;num = Math.floor(num/100).toString();if(cents<10) cents = "0" + cents;for (var i = 0; i < Math.floor((num.length-(1+i))/3); i++) num = num.substring(0,num.length-(4*i+3))+','+ num.substring(num.length-(4*i+3)); return (((sign)?'':'-') + num + '.' + cents);}
}

var ModuleBox = {
    Toggle: function(obj, id){
        var content = $(id);
        new Effect.toggle(content, 'blind', {duration:.3, afterFinish: function(){
            var visible = content.getStyle('display').toLowerCase() == 'block';
            obj.className = visible ? "moduleBox_arrowDown" : "moduleBox_arrowRight";
        }});
    }
}

var Forms = {
    CreateEnterActions: function(){
        Event.observe(window, 'load', function(){
            $(document.body).select('input[type="text"]','input[type="password"]').each(function(textbox){
                if (textbox.getAttribute('buttonRel') != null){
                    var buttonId = textbox.getAttribute('buttonRel');
                    Event.observe(textbox, 'keydown', function(event){
                        if(event.which || event.keyCode){
			                if ((event.which == 13) || (event.keyCode == 13)) {
			                    $(buttonId).click();
			                    return false;
			                }
			             } else
			                return true;
                    }.bind(this));                    
                }
            });
        });
    },
    CreateAjaxEnterActions: function() {
        $(document.body).select('input[type="text"]','input[type="password"]').each(function(textbox){
            if (textbox.getAttribute('ajaxButtonRel') != null){var buttonId = textbox.getAttribute('buttonRel');
                $addHandler(textbox, 'keydown', Forms.HandleEnterKey);
            }
        });
    },
    HandleEnterKey: function(evt){
        if (evt.keyCode == Sys.UI.Key.enter){ 
            evt.preventDefault();
            var textbox = $(this);
            if (textbox.getAttribute('ajaxButtonRel') != null){
                var button = $(textbox.getAttribute('ajaxButtonRel'));
                __doPostBack(button.name, '');                              
                setTimeout(function(){$(textbox.id).focus();}, 500);
                evt.returnValue = false;
                return false;
            }
        }        
    }
}

Forms.CreateEnterActions();
Event.observe(window, 'load', Forms.CreateAjaxEnterActions);


/*** date-en.js - 25.0 kb ***/
/**
 * Version: 1.0 Alpha-1 
 * Build Date: 13-Nov-2007
 * Copyright (c) 2006-2007, Coolite Inc. (http://www.coolite.com/). All rights reserved.
 * License: Licensed under The MIT License. See license.txt and http://www.datejs.com/license/. 
 * Website: http://www.datejs.com/ or http://www.coolite.com/datejs/
 */
Date.CultureInfo={name:"en-US",englishName:"English (United States)",nativeName:"English (United States)",dayNames:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],abbreviatedDayNames:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],shortestDayNames:["Su","Mo","Tu","We","Th","Fr","Sa"],firstLetterDayNames:["S","M","T","W","T","F","S"],monthNames:["January","February","March","April","May","June","July","August","September","October","November","December"],abbreviatedMonthNames:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],amDesignator:"AM",pmDesignator:"PM",firstDayOfWeek:0,twoDigitYearMax:2029,dateElementOrder:"mdy",formatPatterns:{shortDate:"M/d/yyyy",longDate:"dddd, MMMM dd, yyyy",shortTime:"h:mm tt",longTime:"h:mm:ss tt",fullDateTime:"dddd, MMMM dd, yyyy h:mm:ss tt",sortableDateTime:"yyyy-MM-ddTHH:mm:ss",universalSortableDateTime:"yyyy-MM-dd HH:mm:ssZ",rfc1123:"ddd, dd MMM yyyy HH:mm:ss GMT",monthDay:"MMMM dd",yearMonth:"MMMM, yyyy"},regexPatterns:{jan:/^jan(uary)?/i,feb:/^feb(ruary)?/i,mar:/^mar(ch)?/i,apr:/^apr(il)?/i,may:/^may/i,jun:/^jun(e)?/i,jul:/^jul(y)?/i,aug:/^aug(ust)?/i,sep:/^sep(t(ember)?)?/i,oct:/^oct(ober)?/i,nov:/^nov(ember)?/i,dec:/^dec(ember)?/i,sun:/^su(n(day)?)?/i,mon:/^mo(n(day)?)?/i,tue:/^tu(e(s(day)?)?)?/i,wed:/^we(d(nesday)?)?/i,thu:/^th(u(r(s(day)?)?)?)?/i,fri:/^fr(i(day)?)?/i,sat:/^sa(t(urday)?)?/i,future:/^next/i,past:/^last|past|prev(ious)?/i,add:/^(\+|after|from)/i,subtract:/^(\-|before|ago)/i,yesterday:/^yesterday/i,today:/^t(oday)?/i,tomorrow:/^tomorrow/i,now:/^n(ow)?/i,millisecond:/^ms|milli(second)?s?/i,second:/^sec(ond)?s?/i,minute:/^min(ute)?s?/i,hour:/^h(ou)?rs?/i,week:/^w(ee)?k/i,month:/^m(o(nth)?s?)?/i,day:/^d(ays?)?/i,year:/^y((ea)?rs?)?/i,shortMeridian:/^(a|p)/i,longMeridian:/^(a\.?m?\.?|p\.?m?\.?)/i,timezone:/^((e(s|d)t|c(s|d)t|m(s|d)t|p(s|d)t)|((gmt)?\s*(\+|\-)\s*\d\d\d\d?)|gmt)/i,ordinalSuffix:/^\s*(st|nd|rd|th)/i,timeContext:/^\s*(\:|a|p)/i},abbreviatedTimeZoneStandard:{GMT:"-000",EST:"-0400",CST:"-0500",MST:"-0600",PST:"-0700"},abbreviatedTimeZoneDST:{GMT:"-000",EDT:"-0500",CDT:"-0600",MDT:"-0700",PDT:"-0800"}};
Date.getMonthNumberFromName=function(name){var n=Date.CultureInfo.monthNames,m=Date.CultureInfo.abbreviatedMonthNames,s=name.toLowerCase();for(var i=0;i<n.length;i++){if(n[i].toLowerCase()==s||m[i].toLowerCase()==s){return i;}}
return-1;};Date.getDayNumberFromName=function(name){var n=Date.CultureInfo.dayNames,m=Date.CultureInfo.abbreviatedDayNames,o=Date.CultureInfo.shortestDayNames,s=name.toLowerCase();for(var i=0;i<n.length;i++){if(n[i].toLowerCase()==s||m[i].toLowerCase()==s){return i;}}
return-1;};Date.isLeapYear=function(year){return(((year%4===0)&&(year%100!==0))||(year%400===0));};Date.getDaysInMonth=function(year,month){return[31,(Date.isLeapYear(year)?29:28),31,30,31,30,31,31,30,31,30,31][month];};Date.getTimezoneOffset=function(s,dst){return(dst||false)?Date.CultureInfo.abbreviatedTimeZoneDST[s.toUpperCase()]:Date.CultureInfo.abbreviatedTimeZoneStandard[s.toUpperCase()];};Date.getTimezoneAbbreviation=function(offset,dst){var n=(dst||false)?Date.CultureInfo.abbreviatedTimeZoneDST:Date.CultureInfo.abbreviatedTimeZoneStandard,p;for(p in n){if(n[p]===offset){return p;}}
return null;};Date.prototype.clone=function(){return new Date(this.getTime());};Date.prototype.compareTo=function(date){if(isNaN(this)){throw new Error(this);}
if(date instanceof Date&&!isNaN(date)){return(this>date)?1:(this<date)?-1:0;}else{throw new TypeError(date);}};Date.prototype.equals=function(date){return(this.compareTo(date)===0);};Date.prototype.between=function(start,end){var t=this.getTime();return t>=start.getTime()&&t<=end.getTime();};Date.prototype.addMilliseconds=function(value){this.setMilliseconds(this.getMilliseconds()+value);return this;};Date.prototype.addSeconds=function(value){return this.addMilliseconds(value*1000);};Date.prototype.addMinutes=function(value){return this.addMilliseconds(value*60000);};Date.prototype.addHours=function(value){return this.addMilliseconds(value*3600000);};Date.prototype.addDays=function(value){return this.addMilliseconds(value*86400000);};Date.prototype.addWeeks=function(value){return this.addMilliseconds(value*604800000);};Date.prototype.addMonths=function(value){var n=this.getDate();this.setDate(1);this.setMonth(this.getMonth()+value);this.setDate(Math.min(n,this.getDaysInMonth()));return this;};Date.prototype.addYears=function(value){return this.addMonths(value*12);};Date.prototype.add=function(config){if(typeof config=="number"){this._orient=config;return this;}
var x=config;if(x.millisecond||x.milliseconds){this.addMilliseconds(x.millisecond||x.milliseconds);}
if(x.second||x.seconds){this.addSeconds(x.second||x.seconds);}
if(x.minute||x.minutes){this.addMinutes(x.minute||x.minutes);}
if(x.hour||x.hours){this.addHours(x.hour||x.hours);}
if(x.month||x.months){this.addMonths(x.month||x.months);}
if(x.year||x.years){this.addYears(x.year||x.years);}
if(x.day||x.days){this.addDays(x.day||x.days);}
return this;};Date._validate=function(value,min,max,name){if(typeof value!="number"){throw new TypeError(value+" is not a Number.");}else if(value<min||value>max){throw new RangeError(value+" is not a valid value for "+name+".");}
return true;};Date.validateMillisecond=function(n){return Date._validate(n,0,999,"milliseconds");};Date.validateSecond=function(n){return Date._validate(n,0,59,"seconds");};Date.validateMinute=function(n){return Date._validate(n,0,59,"minutes");};Date.validateHour=function(n){return Date._validate(n,0,23,"hours");};Date.validateDay=function(n,year,month){return Date._validate(n,1,Date.getDaysInMonth(year,month),"days");};Date.validateMonth=function(n){return Date._validate(n,0,11,"months");};Date.validateYear=function(n){return Date._validate(n,1,9999,"seconds");};Date.prototype.set=function(config){var x=config;if(!x.millisecond&&x.millisecond!==0){x.millisecond=-1;}
if(!x.second&&x.second!==0){x.second=-1;}
if(!x.minute&&x.minute!==0){x.minute=-1;}
if(!x.hour&&x.hour!==0){x.hour=-1;}
if(!x.day&&x.day!==0){x.day=-1;}
if(!x.month&&x.month!==0){x.month=-1;}
if(!x.year&&x.year!==0){x.year=-1;}
if(x.millisecond!=-1&&Date.validateMillisecond(x.millisecond)){this.addMilliseconds(x.millisecond-this.getMilliseconds());}
if(x.second!=-1&&Date.validateSecond(x.second)){this.addSeconds(x.second-this.getSeconds());}
if(x.minute!=-1&&Date.validateMinute(x.minute)){this.addMinutes(x.minute-this.getMinutes());}
if(x.hour!=-1&&Date.validateHour(x.hour)){this.addHours(x.hour-this.getHours());}
if(x.month!==-1&&Date.validateMonth(x.month)){this.addMonths(x.month-this.getMonth());}
if(x.year!=-1&&Date.validateYear(x.year)){this.addYears(x.year-this.getFullYear());}
if(x.day!=-1&&Date.validateDay(x.day,this.getFullYear(),this.getMonth())){this.addDays(x.day-this.getDate());}
if(x.timezone){this.setTimezone(x.timezone);}
if(x.timezoneOffset){this.setTimezoneOffset(x.timezoneOffset);}
return this;};Date.prototype.clearTime=function(){this.setHours(0);this.setMinutes(0);this.setSeconds(0);this.setMilliseconds(0);return this;};Date.prototype.isLeapYear=function(){var y=this.getFullYear();return(((y%4===0)&&(y%100!==0))||(y%400===0));};Date.prototype.isWeekday=function(){return!(this.is().sat()||this.is().sun());};Date.prototype.getDaysInMonth=function(){return Date.getDaysInMonth(this.getFullYear(),this.getMonth());};Date.prototype.moveToFirstDayOfMonth=function(){return this.set({day:1});};Date.prototype.moveToLastDayOfMonth=function(){return this.set({day:this.getDaysInMonth()});};Date.prototype.moveToDayOfWeek=function(day,orient){var diff=(day-this.getDay()+7*(orient||+1))%7;return this.addDays((diff===0)?diff+=7*(orient||+1):diff);};Date.prototype.moveToMonth=function(month,orient){var diff=(month-this.getMonth()+12*(orient||+1))%12;return this.addMonths((diff===0)?diff+=12*(orient||+1):diff);};Date.prototype.getDayOfYear=function(){return Math.floor((this-new Date(this.getFullYear(),0,1))/86400000);};Date.prototype.getWeekOfYear=function(firstDayOfWeek){var y=this.getFullYear(),m=this.getMonth(),d=this.getDate();var dow=firstDayOfWeek||Date.CultureInfo.firstDayOfWeek;var offset=7+1-new Date(y,0,1).getDay();if(offset==8){offset=1;}
var daynum=((Date.UTC(y,m,d,0,0,0)-Date.UTC(y,0,1,0,0,0))/86400000)+1;var w=Math.floor((daynum-offset+7)/7);if(w===dow){y--;var prevOffset=7+1-new Date(y,0,1).getDay();if(prevOffset==2||prevOffset==8){w=53;}else{w=52;}}
return w;};Date.prototype.isDST=function(){console.log('isDST');return this.toString().match(/(E|C|M|P)(S|D)T/)[2]=="D";};Date.prototype.getTimezone=function(){return Date.getTimezoneAbbreviation(this.getUTCOffset,this.isDST());};Date.prototype.setTimezoneOffset=function(s){var here=this.getTimezoneOffset(),there=Number(s)*-6/10;this.addMinutes(there-here);return this;};Date.prototype.setTimezone=function(s){return this.setTimezoneOffset(Date.getTimezoneOffset(s));};Date.prototype.getUTCOffset=function(){var n=this.getTimezoneOffset()*-10/6,r;if(n<0){r=(n-10000).toString();return r[0]+r.substr(2);}else{r=(n+10000).toString();return"+"+r.substr(1);}};Date.prototype.getDayName=function(abbrev){return abbrev?Date.CultureInfo.abbreviatedDayNames[this.getDay()]:Date.CultureInfo.dayNames[this.getDay()];};Date.prototype.getMonthName=function(abbrev){return abbrev?Date.CultureInfo.abbreviatedMonthNames[this.getMonth()]:Date.CultureInfo.monthNames[this.getMonth()];};Date.prototype._toString=Date.prototype.toString;Date.prototype.toString=function(format){var self=this;var p=function p(s){return(s.toString().length==1)?"0"+s:s;};return format?format.replace(/dd?d?d?|MM?M?M?|yy?y?y?|hh?|HH?|mm?|ss?|tt?|zz?z?/g,function(format){switch(format){case"hh":return p(self.getHours()<13?self.getHours():(self.getHours()-12));case"h":return self.getHours()<13?self.getHours():(self.getHours()-12);case"HH":return p(self.getHours());case"H":return self.getHours();case"mm":return p(self.getMinutes());case"m":return self.getMinutes();case"ss":return p(self.getSeconds());case"s":return self.getSeconds();case"yyyy":return self.getFullYear();case"yy":return self.getFullYear().toString().substring(2,4);case"dddd":return self.getDayName();case"ddd":return self.getDayName(true);case"dd":return p(self.getDate());case"d":return self.getDate().toString();case"MMMM":return self.getMonthName();case"MMM":return self.getMonthName(true);case"MM":return p((self.getMonth()+1));case"M":return self.getMonth()+1;case"t":return self.getHours()<12?Date.CultureInfo.amDesignator.substring(0,1):Date.CultureInfo.pmDesignator.substring(0,1);case"tt":return self.getHours()<12?Date.CultureInfo.amDesignator:Date.CultureInfo.pmDesignator;case"zzz":case"zz":case"z":return"";}}):this._toString();};
Date.now=function(){return new Date();};Date.today=function(){return Date.now().clearTime();};Date.prototype._orient=+1;Date.prototype.next=function(){this._orient=+1;return this;};Date.prototype.last=Date.prototype.prev=Date.prototype.previous=function(){this._orient=-1;return this;};Date.prototype._is=false;Date.prototype.is=function(){this._is=true;return this;};Number.prototype._dateElement="day";Number.prototype.fromNow=function(){var c={};c[this._dateElement]=this;return Date.now().add(c);};Number.prototype.ago=function(){var c={};c[this._dateElement]=this*-1;return Date.now().add(c);};(function(){var $D=Date.prototype,$N=Number.prototype;var dx=("sunday monday tuesday wednesday thursday friday saturday").split(/\s/),mx=("january february march april may june july august september october november december").split(/\s/),px=("Millisecond Second Minute Hour Day Week Month Year").split(/\s/),de;var df=function(n){return function(){if(this._is){this._is=false;return this.getDay()==n;}
return this.moveToDayOfWeek(n,this._orient);};};for(var i=0;i<dx.length;i++){$D[dx[i]]=$D[dx[i].substring(0,3)]=df(i);}
var mf=function(n){return function(){if(this._is){this._is=false;return this.getMonth()===n;}
return this.moveToMonth(n,this._orient);};};for(var j=0;j<mx.length;j++){$D[mx[j]]=$D[mx[j].substring(0,3)]=mf(j);}
var ef=function(j){return function(){if(j.substring(j.length-1)!="s"){j+="s";}
return this["add"+j](this._orient);};};var nf=function(n){return function(){this._dateElement=n;return this;};};for(var k=0;k<px.length;k++){de=px[k].toLowerCase();$D[de]=$D[de+"s"]=ef(px[k]);$N[de]=$N[de+"s"]=nf(de);}}());Date.prototype.toJSONString=function(){return this.toString("yyyy-MM-ddThh:mm:ssZ");};Date.prototype.toShortDateString=function(){return this.toString(Date.CultureInfo.formatPatterns.shortDatePattern);};Date.prototype.toLongDateString=function(){return this.toString(Date.CultureInfo.formatPatterns.longDatePattern);};Date.prototype.toShortTimeString=function(){return this.toString(Date.CultureInfo.formatPatterns.shortTimePattern);};Date.prototype.toLongTimeString=function(){return this.toString(Date.CultureInfo.formatPatterns.longTimePattern);};Date.prototype.getOrdinal=function(){switch(this.getDate()){case 1:case 21:case 31:return"st";case 2:case 22:return"nd";case 3:case 23:return"rd";default:return"th";}};
(function(){Date.Parsing={Exception:function(s){this.message="Parse error at '"+s.substring(0,10)+" ...'";}};var $P=Date.Parsing;var _=$P.Operators={rtoken:function(r){return function(s){var mx=s.match(r);if(mx){return([mx[0],s.substring(mx[0].length)]);}else{throw new $P.Exception(s);}};},token:function(s){return function(s){return _.rtoken(new RegExp("^\s*"+s+"\s*"))(s);};},stoken:function(s){return _.rtoken(new RegExp("^"+s));},until:function(p){return function(s){var qx=[],rx=null;while(s.length){try{rx=p.call(this,s);}catch(e){qx.push(rx[0]);s=rx[1];continue;}
break;}
return[qx,s];};},many:function(p){return function(s){var rx=[],r=null;while(s.length){try{r=p.call(this,s);}catch(e){return[rx,s];}
rx.push(r[0]);s=r[1];}
return[rx,s];};},optional:function(p){return function(s){var r=null;try{r=p.call(this,s);}catch(e){return[null,s];}
return[r[0],r[1]];};},not:function(p){return function(s){try{p.call(this,s);}catch(e){return[null,s];}
throw new $P.Exception(s);};},ignore:function(p){return p?function(s){var r=null;r=p.call(this,s);return[null,r[1]];}:null;},product:function(){var px=arguments[0],qx=Array.prototype.slice.call(arguments,1),rx=[];for(var i=0;i<px.length;i++){rx.push(_.each(px[i],qx));}
return rx;},cache:function(rule){var cache={},r=null;return function(s){try{r=cache[s]=(cache[s]||rule.call(this,s));}catch(e){r=cache[s]=e;}
if(r instanceof $P.Exception){throw r;}else{return r;}};},any:function(){var px=arguments;return function(s){var r=null;for(var i=0;i<px.length;i++){if(px[i]==null){continue;}
try{r=(px[i].call(this,s));}catch(e){r=null;}
if(r){return r;}}
throw new $P.Exception(s);};},each:function(){var px=arguments;return function(s){var rx=[],r=null;for(var i=0;i<px.length;i++){if(px[i]==null){continue;}
try{r=(px[i].call(this,s));}catch(e){throw new $P.Exception(s);}
rx.push(r[0]);s=r[1];}
return[rx,s];};},all:function(){var px=arguments,_=_;return _.each(_.optional(px));},sequence:function(px,d,c){d=d||_.rtoken(/^\s*/);c=c||null;if(px.length==1){return px[0];}
return function(s){var r=null,q=null;var rx=[];for(var i=0;i<px.length;i++){try{r=px[i].call(this,s);}catch(e){break;}
rx.push(r[0]);try{q=d.call(this,r[1]);}catch(ex){q=null;break;}
s=q[1];}
if(!r){throw new $P.Exception(s);}
if(q){throw new $P.Exception(q[1]);}
if(c){try{r=c.call(this,r[1]);}catch(ey){throw new $P.Exception(r[1]);}}
return[rx,(r?r[1]:s)];};},between:function(d1,p,d2){d2=d2||d1;var _fn=_.each(_.ignore(d1),p,_.ignore(d2));return function(s){var rx=_fn.call(this,s);return[[rx[0][0],r[0][2]],rx[1]];};},list:function(p,d,c){d=d||_.rtoken(/^\s*/);c=c||null;return(p instanceof Array?_.each(_.product(p.slice(0,-1),_.ignore(d)),p.slice(-1),_.ignore(c)):_.each(_.many(_.each(p,_.ignore(d))),px,_.ignore(c)));},set:function(px,d,c){d=d||_.rtoken(/^\s*/);c=c||null;return function(s){var r=null,p=null,q=null,rx=null,best=[[],s],last=false;for(var i=0;i<px.length;i++){q=null;p=null;r=null;last=(px.length==1);try{r=px[i].call(this,s);}catch(e){continue;}
rx=[[r[0]],r[1]];if(r[1].length>0&&!last){try{q=d.call(this,r[1]);}catch(ex){last=true;}}else{last=true;}
if(!last&&q[1].length===0){last=true;}
if(!last){var qx=[];for(var j=0;j<px.length;j++){if(i!=j){qx.push(px[j]);}}
p=_.set(qx,d).call(this,q[1]);if(p[0].length>0){rx[0]=rx[0].concat(p[0]);rx[1]=p[1];}}
if(rx[1].length<best[1].length){best=rx;}
if(best[1].length===0){break;}}
if(best[0].length===0){return best;}
if(c){try{q=c.call(this,best[1]);}catch(ey){throw new $P.Exception(best[1]);}
best[1]=q[1];}
return best;};},forward:function(gr,fname){return function(s){return gr[fname].call(this,s);};},replace:function(rule,repl){return function(s){var r=rule.call(this,s);return[repl,r[1]];};},process:function(rule,fn){return function(s){var r=rule.call(this,s);return[fn.call(this,r[0]),r[1]];};},min:function(min,rule){return function(s){var rx=rule.call(this,s);if(rx[0].length<min){throw new $P.Exception(s);}
return rx;};}};var _generator=function(op){return function(){var args=null,rx=[];if(arguments.length>1){args=Array.prototype.slice.call(arguments);}else if(arguments[0]instanceof Array){args=arguments[0];}
if(args){for(var i=0,px=args.shift();i<px.length;i++){args.unshift(px[i]);rx.push(op.apply(null,args));args.shift();return rx;}}else{return op.apply(null,arguments);}};};var gx="optional not ignore cache".split(/\s/);for(var i=0;i<gx.length;i++){_[gx[i]]=_generator(_[gx[i]]);}
var _vector=function(op){return function(){if(arguments[0]instanceof Array){return op.apply(null,arguments[0]);}else{return op.apply(null,arguments);}};};var vx="each any all".split(/\s/);for(var j=0;j<vx.length;j++){_[vx[j]]=_vector(_[vx[j]]);}}());(function(){var flattenAndCompact=function(ax){var rx=[];for(var i=0;i<ax.length;i++){if(ax[i]instanceof Array){rx=rx.concat(flattenAndCompact(ax[i]));}else{if(ax[i]){rx.push(ax[i]);}}}
return rx;};Date.Grammar={};Date.Translator={hour:function(s){return function(){this.hour=Number(s);};},minute:function(s){return function(){this.minute=Number(s);};},second:function(s){return function(){this.second=Number(s);};},meridian:function(s){return function(){this.meridian=s.slice(0,1).toLowerCase();};},timezone:function(s){return function(){var n=s.replace(/[^\d\+\-]/g,"");if(n.length){this.timezoneOffset=Number(n);}else{this.timezone=s.toLowerCase();}};},day:function(x){var s=x[0];return function(){this.day=Number(s.match(/\d+/)[0]);};},month:function(s){return function(){this.month=((s.length==3)?Date.getMonthNumberFromName(s):(Number(s)-1));};},year:function(s){return function(){var n=Number(s);this.year=((s.length>2)?n:(n+(((n+2000)<Date.CultureInfo.twoDigitYearMax)?2000:1900)));};},rday:function(s){return function(){switch(s){case"yesterday":this.days=-1;break;case"tomorrow":this.days=1;break;case"today":this.days=0;break;case"now":this.days=0;this.now=true;break;}};},finishExact:function(x){x=(x instanceof Array)?x:[x];var now=new Date();this.year=now.getFullYear();this.month=now.getMonth();this.day=1;this.hour=0;this.minute=0;this.second=0;for(var i=0;i<x.length;i++){if(x[i]){x[i].call(this);}}
this.hour=(this.meridian=="p"&&this.hour<13)?this.hour+12:this.hour;if(this.day>Date.getDaysInMonth(this.year,this.month)){throw new RangeError(this.day+" is not a valid value for days.");}
var r=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second);if(this.timezone){r.set({timezone:this.timezone});}else if(this.timezoneOffset){r.set({timezoneOffset:this.timezoneOffset});}
return r;},finish:function(x){x=(x instanceof Array)?flattenAndCompact(x):[x];if(x.length===0){return null;}
for(var i=0;i<x.length;i++){if(typeof x[i]=="function"){x[i].call(this);}}
if(this.now){return new Date();}
var today=Date.today();var method=null;var expression=!!(this.days!=null||this.orient||this.operator);if(expression){var gap,mod,orient;orient=((this.orient=="past"||this.operator=="subtract")?-1:1);if(this.weekday){this.unit="day";gap=(Date.getDayNumberFromName(this.weekday)-today.getDay());mod=7;this.days=gap?((gap+(orient*mod))%mod):(orient*mod);}
if(this.month){this.unit="month";gap=(this.month-today.getMonth());mod=12;this.months=gap?((gap+(orient*mod))%mod):(orient*mod);this.month=null;}
if(!this.unit){this.unit="day";}
if(this[this.unit+"s"]==null||this.operator!=null){if(!this.value){this.value=1;}
if(this.unit=="week"){this.unit="day";this.value=this.value*7;}
this[this.unit+"s"]=this.value*orient;}
return today.add(this);}else{if(this.meridian&&this.hour){this.hour=(this.hour<13&&this.meridian=="p")?this.hour+12:this.hour;}
if(this.weekday&&!this.day){this.day=(today.addDays((Date.getDayNumberFromName(this.weekday)-today.getDay()))).getDate();}
if(this.month&&!this.day){this.day=1;}
return today.set(this);}}};var _=Date.Parsing.Operators,g=Date.Grammar,t=Date.Translator,_fn;g.datePartDelimiter=_.rtoken(/^([\s\-\.\,\/\x27]+)/);g.timePartDelimiter=_.stoken(":");g.whiteSpace=_.rtoken(/^\s*/);g.generalDelimiter=_.rtoken(/^(([\s\,]|at|on)+)/);var _C={};g.ctoken=function(keys){var fn=_C[keys];if(!fn){var c=Date.CultureInfo.regexPatterns;var kx=keys.split(/\s+/),px=[];for(var i=0;i<kx.length;i++){px.push(_.replace(_.rtoken(c[kx[i]]),kx[i]));}
fn=_C[keys]=_.any.apply(null,px);}
return fn;};g.ctoken2=function(key){return _.rtoken(Date.CultureInfo.regexPatterns[key]);};g.h=_.cache(_.process(_.rtoken(/^(0[0-9]|1[0-2]|[1-9])/),t.hour));g.hh=_.cache(_.process(_.rtoken(/^(0[0-9]|1[0-2])/),t.hour));g.H=_.cache(_.process(_.rtoken(/^([0-1][0-9]|2[0-3]|[0-9])/),t.hour));g.HH=_.cache(_.process(_.rtoken(/^([0-1][0-9]|2[0-3])/),t.hour));g.m=_.cache(_.process(_.rtoken(/^([0-5][0-9]|[0-9])/),t.minute));g.mm=_.cache(_.process(_.rtoken(/^[0-5][0-9]/),t.minute));g.s=_.cache(_.process(_.rtoken(/^([0-5][0-9]|[0-9])/),t.second));g.ss=_.cache(_.process(_.rtoken(/^[0-5][0-9]/),t.second));g.hms=_.cache(_.sequence([g.H,g.mm,g.ss],g.timePartDelimiter));g.t=_.cache(_.process(g.ctoken2("shortMeridian"),t.meridian));g.tt=_.cache(_.process(g.ctoken2("longMeridian"),t.meridian));g.z=_.cache(_.process(_.rtoken(/^(\+|\-)?\s*\d\d\d\d?/),t.timezone));g.zz=_.cache(_.process(_.rtoken(/^(\+|\-)\s*\d\d\d\d/),t.timezone));g.zzz=_.cache(_.process(g.ctoken2("timezone"),t.timezone));g.timeSuffix=_.each(_.ignore(g.whiteSpace),_.set([g.tt,g.zzz]));g.time=_.each(_.optional(_.ignore(_.stoken("T"))),g.hms,g.timeSuffix);g.d=_.cache(_.process(_.each(_.rtoken(/^([0-2]\d|3[0-1]|\d)/),_.optional(g.ctoken2("ordinalSuffix"))),t.day));g.dd=_.cache(_.process(_.each(_.rtoken(/^([0-2]\d|3[0-1])/),_.optional(g.ctoken2("ordinalSuffix"))),t.day));g.ddd=g.dddd=_.cache(_.process(g.ctoken("sun mon tue wed thu fri sat"),function(s){return function(){this.weekday=s;};}));g.M=_.cache(_.process(_.rtoken(/^(1[0-2]|0\d|\d)/),t.month));g.MM=_.cache(_.process(_.rtoken(/^(1[0-2]|0\d)/),t.month));g.MMM=g.MMMM=_.cache(_.process(g.ctoken("jan feb mar apr may jun jul aug sep oct nov dec"),t.month));g.y=_.cache(_.process(_.rtoken(/^(\d\d?)/),t.year));g.yy=_.cache(_.process(_.rtoken(/^(\d\d)/),t.year));g.yyy=_.cache(_.process(_.rtoken(/^(\d\d?\d?\d?)/),t.year));g.yyyy=_.cache(_.process(_.rtoken(/^(\d\d\d\d)/),t.year));_fn=function(){return _.each(_.any.apply(null,arguments),_.not(g.ctoken2("timeContext")));};g.day=_fn(g.d,g.dd);g.month=_fn(g.M,g.MMM);g.year=_fn(g.yyyy,g.yy);g.orientation=_.process(g.ctoken("past future"),function(s){return function(){this.orient=s;};});g.operator=_.process(g.ctoken("add subtract"),function(s){return function(){this.operator=s;};});g.rday=_.process(g.ctoken("yesterday tomorrow today now"),t.rday);g.unit=_.process(g.ctoken("minute hour day week month year"),function(s){return function(){this.unit=s;};});g.value=_.process(_.rtoken(/^\d\d?(st|nd|rd|th)?/),function(s){return function(){this.value=s.replace(/\D/g,"");};});g.expression=_.set([g.rday,g.operator,g.value,g.unit,g.orientation,g.ddd,g.MMM]);_fn=function(){return _.set(arguments,g.datePartDelimiter);};g.mdy=_fn(g.ddd,g.month,g.day,g.year);g.ymd=_fn(g.ddd,g.year,g.month,g.day);g.dmy=_fn(g.ddd,g.day,g.month,g.year);g.date=function(s){return((g[Date.CultureInfo.dateElementOrder]||g.mdy).call(this,s));};g.format=_.process(_.many(_.any(_.process(_.rtoken(/^(dd?d?d?|MM?M?M?|yy?y?y?|hh?|HH?|mm?|ss?|tt?|zz?z?)/),function(fmt){if(g[fmt]){return g[fmt];}else{throw Date.Parsing.Exception(fmt);}}),_.process(_.rtoken(/^[^dMyhHmstz]+/),function(s){return _.ignore(_.stoken(s));}))),function(rules){return _.process(_.each.apply(null,rules),t.finishExact);});var _F={};var _get=function(f){return _F[f]=(_F[f]||g.format(f)[0]);};g.formats=function(fx){if(fx instanceof Array){var rx=[];for(var i=0;i<fx.length;i++){rx.push(_get(fx[i]));}
return _.any.apply(null,rx);}else{return _get(fx);}};g._formats=g.formats(["yyyy-MM-ddTHH:mm:ss","ddd, MMM dd, yyyy H:mm:ss tt","ddd MMM d yyyy HH:mm:ss zzz","d"]);g._start=_.process(_.set([g.date,g.time,g.expression],g.generalDelimiter,g.whiteSpace),t.finish);g.start=function(s){try{var r=g._formats.call({},s);if(r[1].length===0){return r;}}catch(e){}
return g._start.call({},s);};}());Date._parse=Date.parse;Date.parse=function(s){var r=null;if(!s){return null;}
try{r=Date.Grammar.start.call({},s);}catch(e){return null;}
return((r[1].length===0)?r[0]:null);};Date.getParseFunction=function(fx){var fn=Date.Grammar.formats(fx);return function(s){var r=null;try{r=fn.call({},s);}catch(e){return null;}
return((r[1].length===0)?r[0]:null);};};Date.parseExact=function(s,fx){return Date.getParseFunction(fx)(s);};


/*** AjaxPager.js - 1.0 kb ***/
var AjaxPager =  function(vars) {
    var g = this;
    g.boxId = vars.boxId;
    g.className = vars.className;
    g.repeaterId = vars.repeaterId;
    g.page = vars.page;
    g.pageSize = vars.pageSize;
    g.locked = false;
    g.onComplete = vars.onComplete;
    g.paramKey = AjaxPagerParams.key;
    g.cache = {};
    
    if (window.PagersCache == null)
        window.PagersCache = {};
    
    if (!window.PagersCache[vars.repeaterId]){
        window.PagersCache[vars.repeaterId] = {}
    }

    this.ChangePage = function(newPage) {
        if (window.PagersCache[vars.repeaterId]['Page' + newPage + AjaxPagerParams.key()] != null){
            $(g.repeaterId).update(window.PagersCache[vars.repeaterId]['Page' + newPage + AjaxPagerParams.key()]);
            return;
        }
        if(!g.locked) {
            g.locked = true;
            var params = {
                    'page': newPage,
                    'pageSize':g.pageSize,
                    'boxId': g.boxId,
                    'className':g.className,
                    'repeaterId':g.repeaterId
                };
            Object.extend(params, window.AjaxPagerParams || {});
            new Ajax.Request('/ajax/?a=Pager_NewPage',{
                method: 'post',
                parameters: params, 
                onSuccess: function(t) {
                    window.PagersCache[vars.repeaterId]['Page' + newPage + AjaxPagerParams.key()] = t.responseText;
                    g.page++;
                    $(g.repeaterId).update(t.responseText);
                }, onComplete: function(t) {
                    g.locked = false;
                    if (g.onComplete)
                        g.onComplete(g);
                }
            });
        }
    }
};

/*** Calendar.js - 12.0 kb ***/
// CALENDAR.JS
// JavaScript Document
var Calendar = function(vars){
	var g = this;	
	this.vars = vars;
	this.holder = null;
	this.startDate = g.vars.startDate ? g.vars.startDate : new Date();
	this.calendarClass = g.vars.calendarClass ? g.vars.calendarClass : '';
	this.currentDate = g.startDate;
	this.cells = Array();
	this.onNext = g.vars.onNext ? g.vars.onNext : null;
	this.onPrevious = g.vars.onPrevious ? g.vars.onPrevious : null;
	this.monthHeader = null;
	this.month = null;
	
	this.init = function(){
		g.holder = $(g.vars.holderId);
		g.makeCalendar(g.holder, g.startDate);
		if (g.vars.onInit)
		    g.vars.onInit(g);
	}
	
	this.reInit = function() {
	    g.holder = $(g.vars.holderId);
	    g.makeCalendar(g.holder, g.currentDate);
	}
	
	this.clear = function(){
		g.holder.update('');
		g.cells = null;
		g.cells = new Array();
	}
	
	this.Next = function(d1){
		g.clear();
		var thisDate = new Date();
		thisDate.setFullYear(g.currentDate.getFullYear(), g.currentDate.getMonth() + 1, 1);
		g.currentDate = thisDate;
		g.makeCalendar(g.holder, thisDate);
		if(g.onNext)
			g.onNext(g.cells, new g.Month(g.currentDate.getMonth(), g.currentDate.getFullYear()));
	}
	
	this.Previous = function(){
		g.clear();
		var thisDate = new Date();
		thisDate.setFullYear(g.currentDate.getFullYear(),g.currentDate.getMonth() - 1, 1);
		g.currentDate = thisDate;
		g.makeCalendar(g.holder, thisDate);
		if (g.onPrevious)
			g.onPrevious(g.cells, new g.Month(g.currentDate.getMonth(), g.currentDate.getFullYear()));
	}
	this.Create = function(){	  
	    g.holder.innerHTML = '';
	    g.makeCalendar(g.holder, g.currentDate);
	}
	this.makeCalendar = function(obj, d){
		var c = this;
		this.d = d;
		this.obj = obj;
		c.month = new g.Month(d.getMonth(), d.getFullYear());
		g.month = c.month;
		var table = Builder.node('table', {cellspacing:0,cellpadding:0,'class':g.calendarClass});
		table.className = g.calendarClass;
		if(Prototype.Browser.IE)
			var tbody = Builder.node('tbody');
		var tr = Builder.node('tr');
		tr.className = g.calendarClass + "_header";
		
		var td = Builder.node('td');
		if (g.vars.showPrevious){
			td.innerHTML = (g.vars.nextText ? g.vars.prevText : '&lt;&lt;');
			td.className = g.calendarClass+'_prev';
			Event.observe(td, "click", function(){g.Previous(d);});
		} else {
			td.innerHTML = '&nbsp;';
		}
		tr.appendChild(td);
		var td1 = Builder.node('td', {colSpan:5,'class':g.calendarClass+'_month'});
		td1.className = g.calendarClass + '_month';
		td1.innerHTML = c.month.Name + "&nbsp;" + c.month.year;
		if (g.vars.onClickMonth){
			Event.observe(td1, "click", function(){
				g.vars.onClickMonth(td1, c.month);									 
			});
		}
		g.monthHeader = td1;
		tr.appendChild(td1);
		
		td = Builder.node('td');
		if (g.vars.showNext){
			Event.observe(td, "click", function(){g.Next(d);});
			td.innerHTML = (g.vars.nextText ? g.vars.nextText : '&gt;&gt;');
			td.className = g.calendarClass+'_next';
		} else 
			td.innerHTML = '&nbsp;';
		tr.appendChild(td);
		if(Prototype.Browser.IE)
			tbody.appendChild(tr);
		else
			table.appendChild(tr);
		
		tr = Builder.node('tr');
		for(i=0;i<g.WeekDays.length;i++){
			td = Builder.node('td', {'class':g.calendarClass + '_days'});	
			td.className = g.calendarClass + '_days';		
			td.innerHTML = g.WeekDays[i];
			tr.appendChild(td);
		}
		if(Prototype.Browser.IE)
			tbody.appendChild(tr);
		else
			table.appendChild(tr);
		var weeks = c.month.Weeks();
		for(i=0;i<weeks.length;i++){
			tr = Builder.node('tr');
			for(k=0;k<weeks[i].length;k++){
				g.cells.push(weeks[i][k]);
				tr.appendChild(weeks[i][k]);
			}
			if(Prototype.Browser.IE)
				tbody.appendChild(tr);
			else
				table.appendChild(tr);
		}
		if(Prototype.Browser.IE)
			table.appendChild(tbody);
		
		obj.appendChild(table);
		if (g.vars.onCreate)
		    g.vars.onCreate(g);
		table = null;tr = null;td = null;	
	}
	
	this.Month = function(id, year){
		var m = this;
		this.id = id;
		this.year = year;
		this.Days = id != 1 ? g.MonthDays[m.id] : m.year % 4 == 0 ? g.MonthDays[m.id] + 1 : g.MonthDays[m.id];
		
		this.date = new Date();
		this.date.setFullYear(m.year, m.id, 1);
		this.lastDate = new Date();
		this.lastDate.setFullYear(m.year, m.id, m.Days);
		this.Name = g.MonthNames[m.id];
		this.ShortName = g.MonthNames[m.id].substr(0, 3);
		this.StartDay = m.date.getDay();
		this.firstFullWeek = m.StartDay == 0;
		this.lastFullWeek = (m.StartDay + m.Days) % 7 - 1 == -1;
		this.WeekCount = Math.ceil((m.Days + m.StartDay) / 7);
		this.firstCell = null, this.lastCell = null;
		
		this.Weeks = function(){
			var weeks = Array();
			if (m.firstFullWeek){
				weeks.push(m.Previous().LastWeek('last'));
				weeks.push(m.FirstWeek('this'));
			} else
				weeks.push(m.Previous().LastWeek('last').concat(m.FirstWeek('this')));
			
			for(j=1;j<m.WeekCount-1;j++)			
				weeks.push(m.GetWeek(j));				
			
			if (m.lastFullWeek){
				weeks.push(m.LastWeek('this'));
				weeks.push(m.Next().FirstWeek('next'));
			} else
				weeks.push(m.LastWeek('this').concat(m.Next().FirstWeek('next')));
			
			var cnt = m.WeekCount + (m.lastFullWeek ? 1 : 0) + (m.firstFullWeek ? 1 : 0)			
			if (g.vars.onDateSelect){
				for(j=0;j<cnt;j++){
					for(k=0;k<weeks[j].length;k++){
						Event.observe(weeks[j][k], "click", function(){
							var ret = {
								id:this.id,
								date:new Date(this.getAttribute("value")),
								cell:this,
								otherMonth:(this.className.indexOf('last') >= 0 || this.className.indexOf('next') >= 0)
							};
							if (g.vars.onDateSelect)
							    g.vars.onDateSelect(ret); 
						});
					}
				}
			}
			return weeks;
		}
		
		this.GetWeek = function(_int){
			var gw = this;
			var days = Array();
			gw.dated = m.id+1 + '/{0}/' + m.year;
			if (_int == 0) return m.FirstWeek('this');
			if (_int == m.WeekCount) return m.LastWeek('this');
			var start = 7 - m.StartDay + 1;
			var s = ""
			for(i=0;i<7;i++){
				var val = (7 * (_int - 1) + start + i)
				var fd = dateFormat(new Date(gw.dated.replace('{0}',val)), "mm/dd/yyyy");
				var d = Builder.node('td', {id:"cal_"+fd.replace(/\//g,""),'class':g.calendarClass + '_thisMonth',value:fd,month:'this'});
				d.appendChild(new Element('span').update(val));
				days.push(d);
			}
			return days;
		}
		
		this.LastWeek = function(c){
			var lw = this;
			var days = Array();
			lw.dated = m.id+1 + '/{0}/' + m.year;
			var day = (m.StartDay + m.Days) % 7 - 1;
			day = day == -1 ? 6 : day;
			var s = "";
			for (i=m.Days-day;i<=m.Days;i++){
				var fd = dateFormat(new Date(lw.dated.replace('{0}',i)), "mm/dd/yyyy");
				var d = Builder.node('td', {id:"cal_"+fd.replace(/\//g,""),'class':g.calendarClass + '_' + c + 'Month',value:fd,month:c});
				d.className = g.calendarClass + '_' + c + 'Month';
				d.appendChild(new Element('span').update(i));
				days.push(d);
				if(i==m.Days)
					m.lastCell = d;				
			}
			return days;
		}			
		
		this.FirstWeek = function(c){
			var fw = this;
			var days = Array();
			fw.dated = m.id+1 + '/{0}/' + m.year;
			var day = 7 - m.StartDay;
			var s = "";
			for (i=1;i<=day;i++){
				var fd = dateFormat(new Date(fw.dated.replace('{0}',i)), "mm/dd/yyyy");
				var d = Builder.node('td', {id:"cal_"+fd.replace(/\//g,""),'class':g.calendarClass + '_' + c + 'Month',value:fd,month:c});
				d.className = g.calendarClass + '_' + c + 'Month';
				d.appendChild(new Element('span').update(i));
				days.push(d);
				if(i==1)
					m.firstCell = d;
			}
			return days;
		}
		
		this.Previous = function(){
			var pid = m.id - 1 < 0 ? 11 : m.id - 1;
			var pyear = pid == 11 ? m.year - 1 : m.year;
			return new g.Month(pid, pyear);
		}
		
		this.Next = function(){
			var pid = m.id + 1 > 11 ? 0 : m.id + 1;
			var pyear = pid == 0 ? m.year + 1 : m.year;
			return new g.Month(pid, pyear);
		}
	}
	
	this.WeekDays = g.vars.WeekDays ? g.vars.WeekDays : new Array('S','M','T','W','T','F','S');
	this.MonthDays = new Array(31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31);
	this.MonthNames = new Array('January','February','March','April','May','June','July','August','September','October','November','December');
	
	if (g.vars.autostart || g.vars.autostart == null)
	    g.init();
}

// POPUP CALENDER CLASS
var PopupCalendar = function(vars){
    var g = this;
    this.vars = vars;
    this.textBox = $(g.vars.textId);
    this.trigger = $(g.vars.triggerId);
    this.holder = $(g.vars.holderId);
    this.onSelect = vars.onSelect;
    this.disablePrevious = g.vars.disablePrevious ? true : g.vars.disablePrevious;
    this.calendar = null;
    this.to = 0;
    this.DisableDate = new Date().setDate(new Date().getDate() - 1);
    
    this.Show = function(){
        var pos = g.textBox.cumulativeOffset();
        g.holder.setStyle({
            position: 'absolute',
            left:pos.left + 'px',
            top: pos.top + g.textBox.getHeight() + 'px'
        });
        clearTimeout(g.to);
        if (!g.holder.visible())
            if (Prototype.Browser.IE)
                g.holder.setStyle({display:'block'});
            else
                new Effect.toggle(g.holder, 'blind', {duration:.3});
    }
    this.Hide = function(){
        g.to = setTimeout(function(){
            if (g.holder.visible())
                new Effect.toggle(g.holder, 'blind', {duration:.2});
        }, 200);
    }
    this.init = function(){
        Event.observe(g.textBox, "focus", function(){ g.Show();});
        Event.observe(g.textBox, "blur", function(){g.Hide();}); 
        Event.observe(g.holder, "mouseover", function(){ clearTimeout(g.to); });
        Event.observe(g.holder, "click", function(){ clearTimeout(g.to);  });
        Event.observe(g.trigger, "click", function(){ if (g.holder.visible()) g.Hide(); else g.textBox.focus(); });         
        Event.observe(window, "load", function(){ document.body.appendChild(g.holder); });
        
        g.CreateCalendar();
        g.PaintCalendar();
    }
    this.CreateCalendar = function(){
        g.calendar = null;
        g.holder.update(''); 
        g.calendar = new Calendar({
            holderId: g.holder.id,
            startDate: new Date(g.vars.startDate),
            calendarClass: 'popup_calendar',
            showPrevious: true,
            showNext: true,
            nextText: '►',
            prevText: '◄',
            onDateSelect:function(date){
                g.updateText(date);
                g.holder.setStyle({display:'none'}); //g.textBox.focus();
                if (g.onSelect != null && g.onSelect)
                    g.onSelect(date);
            },
            onCreate:function(){
                if (g.calendar)
                    g.PaintCalendar();
                var button = new Element('span', {'class': 'popup_today'}).update('Today');
                button.className = 'popup_today';
                Event.observe(button, "click", function(){
                    g.textBox.setValue(dateFormat(new Date(), "mm/dd/yyyy"));
                });
                var todayHolder = new Element('div', {'class': 'popup_todayHolder'})
                todayHolder.className = 'popup_todayHolder';
                todayHolder.appendChild(button);
                
                button = new Element('span', {'class': 'popup_today', style:'padding:2px 17px 2px 18px;margin-left:1px;'}).update('Close');
                button.className = 'popup_today';
                Event.observe(button, 'click', function(){
                    g.textBox.blur();
                    g.Hide();
                });
                todayHolder.appendChild(button);
                g.holder.appendChild(todayHolder);
            },
            onNext:function(){ g.textBox.focus(); },
            onPrev:function(){ g.textBox.focus(); }            
        });
    }
    this.PaintCalendar = function(){
        if (g.DisableDate == null) return;
        $(g.calendar.cells).each(function(cell){
            var d = new Date(cell.getAttribute('value'));
            if (d <= g.DisableDate && g.disablePrevious)
                cell.addClassName('popup_cellDisabled');
            else
                cell.removeClassName('popup_cellDisabled');
        });
    }
    this.updateText = function(date){
        if (g.DisableDate && g.disablePrevious)
            if (date.date <= g.DisableDate) return;
         
        g.textBox.setValue(dateFormat(date.date, "mm/dd/yyyy"));
        if (g.vars.endDateId != ''){
            eval('#{0}.DisableDate = new Date(#{1});#{0}.PaintCalendar();'.interpolate({0:g.vars.endDateId, 1:date.date.getTime()}));
        }
    }
    this.init();
}


/*** Chart.js - 5.0 kb ***/
var ChartClass = Class.create({
    initialize:function(options){
        this.originalOptions = {
            showLabels:true,
            width:685,
            height:200,
            cht:'lxy',
            invalidNumberReplacement:-1,
            chartDataTag:'chd=e:__,',
            chartColor:'224499',
            usePercentMethod:false,
            title:'',
            useNegative:false,
            yRange:false,
            LabelModulusSkip:1
        }
        this.options = {}
       Object.extend(this.options, this.originalOptions);
       Object.extend(this.options, options || {});
  
    },
    
    /**
    * Expects an array of rows with unique html elements in those rows to contain the key and value respectively
    * i.e. <div class='row'><span class='label'>Tuesday</span><span class='value'>100</span></div>
    * You would pass in $$('.row'), '.label', '.value'
    **/
    DrawChart:function(containerId, tableRows, keyInRow, valueInRow, options){
      Object.extend(this.options, options || {});
        //Create the days Array
        var Data = new Array();
        
        //Go through the rows and make label => total pairs
        tableRows.each(function(e){
           if(isNaN(parseInt($(e).down(valueInRow).innerHTML)))
               return;
                
                if(Data.find(function(d){return d[0] == $(e).down(keyInRow).innerHTML}) != undefined){
                    day = Data.find(function(d){return d[0] == $(e).down(keyInRow).innerHTML});
                    day[1] = parseInt($(e).down(valueInRow).innerHTML.sub(',','')) + parseInt(day[1]);
                }else{
                 Data.push(new Array($(e).down(keyInRow).innerHTML, parseInt($(e).down(valueInRow).innerHTML.sub(',',''))));
                }
        });
        var Total = 0;
        var MaxX = 0;
        var MinY = 0;
        var ChartUrl = "http://chart.apis.google.com/chart?";
        if(this.options.title != '')
            ChartUrl = ChartUrl + "chtt="+this.options.title;
        ChartUrl = ChartUrl+"&cht="+this.options.cht+"&chco="+this.options.chartColor+"&chm=B,76A4FB,0,0,0&chs="+this.options.width+"x"+this.options.height+"&"+this.options.chartDataTag;
         
         
        Data.each(function(row){
            if(row[1] > MaxX)
                MaxX = row[1];
            if(row[1] < MinY)
                MinY = row[1];
            Total = Total+row[1];
        }); 
        console.log(MinY);
        if(this.options.useNegative && MinY >= 0){
            this.options.useNegative = false;
            //Don't use negative because there isn't any negative
            console.log('turning off negative, there is not any negative numbers in datarange');
       }
        
        if(this.options.useNegative){
            for(i = 0;i<Data.length;i++){
                Data[i][1] = Data[i][1] + Math.abs(MinY);
            }
            
        }
       
          if(this.options.usePercentMethod){
          console.log(Total+ " - Max:"+MaxX);
           ratio = 4095 / MaxX;
           Data.each(function(row){
                row[1] = row[1] * ratio;
                 //row[1] = row[1] / MaxX;
                //row[1] = (row[1] / MaxX)*100;
                //row[1] = row[1] / (100/4095);
            });
         }
         
          Data.each(function(day){
           ChartUrl = ChartUrl+Chart.encodeNumber(Math.abs(day[1]));
          });
          
          if(this.options.showLabels){
              ChartUrl = ChartUrl+"&chxt=x";
              if(this.options.useNegative)
                ChartUrl +=",y";
                
                
              ChartUrl += "&chxl=0:|";
              
                
              for(i = 0;i<Data.length;i++){
              
                if(i % this.options.LabelModulusSkip == 0)
                ChartUrl = ChartUrl+Data[i][0].sub(',','%2c')+"|";
                else
                    ChartUrl += " |";
              }
              Data.each(function(day){
               
              });
              
              if(this.options.useNegative){
                ChartUrl += "|1:"+"|"+MinY+"|0|"+MaxX;
                ChartUrl += "&chg=0,50,1,0";
                }
             }
         console.log(ChartUrl);
         
         var img = new Image();
         img.src = ChartUrl;
         img.onload = function(){
         $(containerId).update(img);
         }
        Object.extend(this.options, this.originalOptions);
        return ChartUrl;
        
    },
    encodeNumber:function(number){
        var EXTENDED_MAP= 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-.';
     
        var numericVal = new Number(number);
        if(isNaN(numericVal)) {
        console.log('Value not permitted:'+number);
          return "-1";
        } else if (numericVal < 0 || numericVal > EXTENDED_MAP.length *
            EXTENDED_MAP.length - 1) {
          return "-1";
        }
     
        var quotient = Math.floor(numericVal / EXTENDED_MAP.length);
        var remainder = numericVal - EXTENDED_MAP.length * quotient
        return EXTENDED_MAP.charAt(quotient) + EXTENDED_MAP.charAt(remainder);
    }



});

var Chart = new ChartClass();
 
  
 

/*** Dropdown.js - 10.0 kb ***/
var DropDown = Class.create({ 
    initialize: function(options) {
        // Variables
        this.Options = options;
        this.showing = false;
        this.Timeout = 0;
        
        // Display Options
        this.Effect = options.effects;
        this.AlignLeft = options.align == null || options.align == 'left' ? true : false;
        this.Padding = options.padding || {top: 0, left:0, right:0};
        this.Shadow = null || options.shadow;
        this.MaxHeight = options.max || 300;
        
        // Close Options
        this.CloseOnClick = options.closeOnClick != null && options.closeOnClick;
        this.CloseOnMouseout = options.closeOnMouseout != null && options.closeOnMouseout;
        this.ShowOnMouseover = options.showOnMouseover != null && options.showOnMouseover;
        
        // Get Elements
        this.Trigger = $(options.trigger);
        this.BaseElement = options.baseElement == 'parent' ? this.Trigger.parentNode :         
            options.baseElement == 'self' ? this.Trigger : $(options.baseElement);        
        this.DisplayElement = $(options.displayElement);
        
        // Event Listeners
        this.hideListener = this.Hide.bindAsEventListener(this);
        this.showFinishListener = this.ShowFinish.bindAsEventListener(this);
        this.hideFinishListener = this.HideFinish.bindAsEventListener(this);
        
        this.HideDropDown = function(){ 
            clearTimeout(this.Timeout);
            this.DisplayElement.setStyle({display:'none'}); 
            if (this.Shadow && this.Shadow.obj){
                this.Shadow.obj.setStyle({display:'none'});
            }
        }.bind(this);
        
        // Go
        this.MakeTrigger();
    }, 
    // Creates trigger function and assigns Events
    MakeTrigger: function(){
        // Return if there's no trigger to make
        if (this.Trigger == null) 
            return;
        
        Event.observe(this.Trigger, 'click', this.TriggerClick.bind(this));
        if (this.ShowOnMouseover){        
            Event.observe(this.Trigger, 'mouseover', this.Show.bind(this));
            this.CloseOnMouseout = true;
        }
        var g = this;
        
        // If close on mouse out option is selected, assign events
        if (this.CloseOnMouseout){
            Event.observe(this.DisplayElement, 'mouseout', function(){g.Timeout = setTimeout(g.Hide.bind(g), 300);});
            Event.observe(this.BaseElement, 'mouseout', function(){g.Timeout = setTimeout(g.Hide.bind(g), 300);});
            Event.observe(this.DisplayElement, 'mouseover', function(){clearTimeout(g.Timeout);});
            Event.observe(this.BaseElement, 'mouseover', function(){clearTimeout(g.Timeout);});
            
            if (this.ShowOnMouseover){
                Event.observe(this.Trigger, 'mouseout', function(){g.Timeout = setTimeout(g.Hide.bind(g), 300);});
                Event.observe(this.Trigger, 'mouseover', function(){clearTimeout(g.Timeout);});
            }
        }
        
        // If close on click is selected, assign events
        if (!this.CloseOnClick)
            Event.observe(this.DisplayElement, 'click', this.Show.bind(this));
        
        // Assign Default Events
        Event.observe(this.BaseElement, 'click', function(){this.showing = true;});
        Event.observe(window, 'load', this.MoveDisplayElement.bind(this));
    },
    // Handles Clicking the Trigger element
    TriggerClick: function(){
        if (this.DisplayElement.getStyle('display') == 'block')
            this.Hide();
        else
            this.Show();    
    },
    // Moves display element to the body tag so positioning is correct
    MoveDisplayElement: function(){
        $(document.body).appendChild(this.DisplayElement); 
        if (this.Shadow != null){        
            var shadow = new Element('div').update('&nbsp;');
            shadow.setStyle({
                position: 'absolute',                
                opacity: this.Shadow.opacity,
                background: '#000000',
                display: 'none'
            });
            this.Shadow.obj = shadow;
            $(document.body).appendChild(shadow);
        }            
    },
    // Shows display element
    Show: function(){
        // Assign hide for clicking on the window
        Event.observe(document.body, 'click', this.hideListener);
        
        // Run Functions
        this.ShowBegin();
        
        // Get Baseelement postition
        var pos = this.BaseElement.cumulativeOffset();
        
        // Get Effects
        var hasEffect = this.Effect != null && this.Effect.show != 'none' && this.Effect.show != null && this.DisplayElement.getStyle('display') == 'none';
        
        // Find if we need to align the popup box to the right of the base element
        var anchorRight = pos.left + this.DisplayElement.getWidth() > document.viewport.getWidth() || !this.AlignLeft;
        
        if (this.DisplayElement.getHeight() > this.MaxHeight)
            this.DisplayElement.setStyle({ height: this.MaxHeight + 'px', overflow: 'auto'});               
        // Assign Styles
        this.DisplayElement.setStyle({
            position: 'absolute',
            top: pos.top + this.BaseElement.getHeight() + this.Padding.top + 'px',
            display: 'none',
            zIndex: 1000
        });
        
        // Assign correct left/right values
        if (this.AlignLeft) {
            this.DisplayElement.setStyle({
                left: anchorRight ? pos.left + this.BaseElement.getWidth() - this.DisplayElement.getWidth() + this.Padding.left + 'px' : pos.left + this.Padding.left + 'px'
            });
        } else {
            this.DisplayElement.setStyle({
                right: anchorRight ? 
                    document.viewport.getWidth() - (pos.left + this.BaseElement.getWidth()) + this.Padding.right + 'px' : 
                    document.viewport.getWidth() - (pos.left + this.DisplayElement.getWidth()) + this.Padding.right + 'px'
            });
        }
        this.showing = true;
        if (hasEffect)
            Effect.toggle(this.DisplayElement, this.Effect.show, {duration: this.Effect.duration, afterFinish: this.showFinishListener});
        else {
            this.DisplayElement.setStyle({display: 'block'});
            this.ShowFinish();
       }
    },
    ResizeShadow: function(){
        this.ShowShadow();
    },
    // Displays Shadow
    ShowShadow: function(){
        var pos = this.DisplayElement.cumulativeOffset();
        if (pos.top == 0 && pos.left == 0) return;        
        this.Shadow.obj.setStyle({
            top: pos.top + this.Shadow.offset + 'px',
            left: pos.left + this.Shadow.offset + 'px',
            width: this.DisplayElement.getWidth() + 'px',
            height: this.DisplayElement.getHeight() + 'px',            
            display: 'block'
        });
    },
    // Fires before show starts
    ShowBegin: function(){
        if(this.Options.onShowBegin)
            this.Options.onShowBegin(this);
    },
    // Fires after show is complete
    ShowFinish: function(){
        //this.showing = false;
        
        if (this.Shadow != null)
            this.ShowShadow();
            
        if(this.Options.onShowFinish)
            this.Options.onShowFinish(this);
    },
    // Hides display element
    Close: function(){ this.Hide(); },
    Hide: function(){    
        // If showing do nothing
        if (this.showing) {this.showing = false; return;}
        
        if(this.Shadow != null && this.Shadow.obj != null)
            this.Shadow.obj.setStyle({display:'none'});
        
        // Find effect
        var hasEffect = this.Effect != null && this.Effect.hide != 'none' && this.Effect.hide != null && this.DisplayElement.getStyle('display') == 'block';
        if (hasEffect)
            Effect.toggle(this.DisplayElement, this.Effect.hide, {duration:this.Effect.duration, afterFinish: this.hideFinishListener});
        else {
            this.DisplayElement.setStyle({ display: !hasEffect ? 'none' : 'block' });
            this.HideFinish();
        }
            
        // Clear window click event
        Event.stopObserving(document.body, 'click', this.hideListener);
    },
    HideFinish: function(){
        if(this.Options.onHideFinish)
            this.Options.onHideFinish(this);
    }
});

var UserDropDown = Class.create(DropDown, {
    initialize: function($super, userId){
        $super({
            trigger: 'userDropDown_Trigger_' + userId,
            baseElement: 'parent',
            displayElement: 'userDropDown_' + userId,
            closeOnClick: false,
            align: 'right',
            padding: {top: 1, left: 0, right: 0},
            shadow: {opacity: .2, offset: 2},
            effects: {
                show: 'blind',
                hide: 'none',
                duration: .2
            },
            onShowBegin: function(t){
                t.Trigger.addClassName('userDropDown_Over');
            },        
            onShowFinish: function(t){          
            },
            onHideFinish: function(t){
                t.Trigger.removeClassName('userDropDown_Over');
            }        
        });
    }
});

var PickDeleter = Class.create(DropDown, {
    initialize: function($super, pickId){
        $super({
            trigger: 'pick_games_deletePick' + pickId,
            baseElement: 'parent',
            displayElement: 'pick_games_deletePick' + pickId + '_dd',
            closeOnClick: false,
            align: 'right',
            padding: { top: 1, left: 0, right: 0 },
            shadow: { opacity: .2, offset: .2 },
            effects: {
                show: 'blind',
                hide: 'none',
                duration: .2
            },
            onShowBegin: function(t){
                $(t.Trigger).addClassName('deleteOn');
            }, 
            onShowFinish: function(t){
                $(this.displayElement).select('input.reasonBox')[0].focus();
            },
            onHideFinish: function(t){
                $(t.Trigger).removeClassName('deleteOn');
            } 
        });
    }
});

/*** DynamicTextBox.js - 2.0 kb ***/
var DynamicBox = Class.create({
    initialize: function(obj){
    
        this.div = obj;
        this.HTML = this.div.innerHTML;
        this.Showing = false;
        
        // Event Listeners
        this.hideListener = this.Hide.bindAsEventListener(this);
        this.showFinishListener = this.ShowFinish.bindAsEventListener(this);
        this.hideFinishListener = this.HideFinish.bindAsEventListener(this);
        
        this.MakeTrigger();
    },
    MakeTrigger: function(){
        Event.observe(this.div, 'click', this.Show.bind(this));            
    },
    Show: function(){
        if (this.Showing) return;
        this.Showing = true;
        var height = this.div.getHeight();
        this.div.update('');
        this.div.addClassName('adminClassEditing');
        this.div.update('<textarea class="dynamicBoxTextArea" style="width:#{1}px;height:#{2}px;">#{0}</textarea>'.interpolate({
            0:this.HTML,
            1:this.div.getWidth() - 27,
            2:height
        }));
        console.log(this.div.getHeight());
        var textarea = this.div.select('textarea')[0];
        textarea.focus();
        var holder = new Element('div', {'class': 'alignCenter'});
        this.div.appendChild(holder);
        var submitButton = new Element('input', {type: 'button', value: 'Save'});
        Event.observe(submitButton, 'click', function(){
            this.HTML = textarea.value;
            new Ajax.Request('/ajax/?a=DynamicTextBox_EditBox', {
                method: 'post',
                parameters: {boxid: this.div.getAttribute('key'), value: this.HTML },
                onComplete: function(t){
                },
                onSuccess: function(t){
                    this.Hide();
                }
            });
            this.Hide();
        }.bind(this));
        var cancelButton = new Element('input', {type: 'button', value: 'Cancel'});
        Event.observe(cancelButton, 'click', function(){
            this.Hide();
        }.bind(this));
        holder.appendChild(submitButton);
        holder.appendChild(cancelButton);
    },
    Hide: function(){
        setTimeout(function(){this.Showing = false;}.bind(this), 100);
        this.div.update(this.HTML);
        this.div.removeClassName('adminClassEditing');
    },
    HideFinish: function(){},
    ShowFinish: function(){}
})
DynamicBox.LoadDynamicBoxes = function(){
    Event.observe(window, 'load', function(){
        $(document.body).select('div[rel="dynamic"]').each(function(div){
            div.addClassName('adminClass');
            var db = new DynamicBox(div);
        });
    });
}

/*** Global.js - 10.0 kb ***/
var Global = {

    Initialize : function(){
        //Initiating the search boxes
        Global.Search.initiate($$('input.search_query').first());
         Global.Cursor.C = $('loadCursor');
        document.body.appendChild(Global.Cursor.C);            
       
    },
    InitializeAfterLoad : function(){
        Global.TextboxPretext();
        Global.Errors.Box = $('errorHolder').select('div')[0];
        Global.Cursor.Follow();        
        Global.Cursor.Hide();
    },
    Cursor: {
        Follow: function() {
            this.FX = this.MoveIt.bindAsEventListener(this);
            Event.observe(window.document,'mousemove', this.FX);
            if(Global.Cursor.C) Global.Cursor.C.show();
        },
        Stop: function() {
            Event.stopObserving(window.document, 'mousemove', this.FX);
            setTimeout(function() { if(Global.Cursor.C) Global.Cursor.C.hide(); }, 10000);
        },
        MoveIt: function(e) {
            var tempX = Event.pointerX(e) + 10;
            var tempY = Event.pointerY(e) + 10;
            if(Global.Cursor.C) Global.Cursor.C.setStyle({top: tempY + 'px', left: tempX + 'px'});
        },
        Show: function(){ if(Global.Cursor.C) Global.Cursor.C.show(); },
        Hide: function() { setTimeout(function() { if(Global.Cursor.C) Global.Cursor.C.hide(); }, 100); },
        FX: null,
        C: null
    },
    TextboxPretext: function(){
        $(document.body).select('input[type="text"]','textarea').each(function(textbox){
            if(textbox.getAttribute('preText') != null){                    
                var preText = textbox.getAttribute('preText');
                textbox.preTextValue = preText;
                if (preText == '___DONE___')
                    return;                     
                textbox.setAttribute('preText', '___DONE___');
                var color = textbox.getStyle('color');   
                if (textbox.value == '' || textbox.value == preText){
                    textbox.value = preText;
                    textbox.setStyle({color: '#999999'});  
                }                               
                Event.observe(textbox, 'focus', function(event){
                    if(textbox.value == preText){
                        textbox.value = '';
                        textbox.setStyle({color: color});
                    }
                });
                Event.observe(textbox, 'blur', function(event){
                    if(textbox.value == ''){
                        textbox.value = preText;  
                        textbox.setStyle({color: '#999999'});                          
                    }
                });
            }
        });
    },
    VerifyNumeric: function(obj, event, errorHolderId){
        var code;
        if (!event) var event = window.event;
        if (event.keyCode) code = event.keyCode;
        else if (event.which) code = event.which;
        var character = String.fromCharCode(code);
        if (character.blank()) return true; 
        
        if (!character.match(/^\d+$/) == null){
            Event.stop(event);
            return false;
        }
        var e = $(errorHolderId);
        
        if ($F(obj).match(/^\d+$/) == null){
            e.update('Must be numeric');
            e.show();
        } else {
            e.update('');
            e.hide();
        }
    },
    Errors: {
        Items: new Array(),
        Box: null, // Gets set with Global.Initalize()
        Add: function(message) {
            Global.Errors.Items.push(message);
        },
        Show: function() {
            // Clear the message box
            Global.Errors.Box.update('');
            
            // Create the list of errors
            var ul = new Element('ul');
            ul.addClassName('errorList');
            ul.update('<h3>The following errors occurred</h3>');
            
            // Add a new bullet for each message
            $(Global.Errors.Items).each(function(message) {
                var item = new Element('li');
                item.update(message);
                ul.appendChild(item);
            });
            
            // Clear the list of items
            Global.Errors.Items = new Array();
            
            // Add the list to the error box
            Message.Alert(ul.innerHTML);
        },
        Hide: function() {
            Global.Errors.Box.hide();
        }
    },
    FixPageForm: function(force){
        Event.observe(window, 'load', function(){
            if ($('aspnetForm'))
                $('aspnetForm').action = window.location;
        });
        if (force === true)
            if ($('aspnetForm'))
                $('aspnetForm').action = window.location;
    },
    CountCharsDown: function(e,obj,max) {
        if (!e) var e = window.event;
        code = e.keyCode ? e.keyCode : e.charCode;
           
        var length = obj.value.length;
        switch(code) {
            case 8:  // backspace
            case 46: // delete
            case 27: // escape
            case 13: // enter
            case 37: // left
            case 38: // up
            case 39: // right
            case 40: // down
            case 9:  // tab
                return true;
            default:
                if(length >= max) return false;
                break;
        }
    },
    CountCharsUp: function(e, obj, max) {
        var length = max - obj.value.length;
        $(obj.id + '_counter').update("(#{length} characters left)".interpolate({length: length}));
    },
    FormValues: function(obj) {
        var vars = {};
        obj.select('input:not([type="checkbox"])').each(function(i){
            if (i.name || i.id){
                if (i.getAttribute('type') == 'radio' && i.checked)
                    vars[i.name ? i.name : i.id] = i.value;
                else if (i.getAttribute('type') != 'radio')
                    vars[i.name ? i.name : i.id] = escape(i.value);
            }
        });
        obj.select('select').each(function(s){
            if (s.name || s.id){
                vars[s.name ? s.name : s.id] = escape(s.options[s.selectedIndex].value);
            }
        });
        obj.select('textarea').each(function(t){
            if (t.name || t.id){
                vars[t.name ? t.name : t.id] = escape(t.value);
            }
        });
        obj.select('input[type="checkbox"]').each(function(c){
            if (c.name || c.id){
                vars[c.name ? c.name : c.id] = c.checked;
            }
        });
        var s = "";
        for(k in vars){
            s += k.replace(/.+\$.+\$/,'') + '=' + vars[k] + "&";
        }
        return { vars: vars, serialize: s };
    },
    ShowTooltip: function(text,obj,cssClass) {
        obj = $(obj);
        var pos = obj.positionedOffset();
        
        var div;
        if($('toolbox') == null) {
            div = new Element('div', {id: 'toolbox'});
            obj.ancestors()[0].insertBefore(div,obj);   
        }
        else 
            div = $('toolbox');

        div.classNames().each(function(i) {
            div.removeClassName(i);
        });
        div.addClassName(cssClass);
        div.update(text);
        
        var width = pos.left + obj.getWidth() + 2;
        if(width + div.getWidth() > window.innerWidth)
            width = pos.left - div.getWidth() - 2;
            
        div.setStyle({top: pos.top +'px', left: width + 'px'});
        $(div).show({duration: 800 });
        
        Event.observe(obj, 'mouseout', function(e) { Global.HideTooltip(div); });
    },
    HideTooltip: function(obj) {
        $(obj).hide({duration: 800 });
    },
    Initalize: function() {
        alert('deprecated');
    },
    Resize: function(current, max){
        var ret = {width: 0, height: 0};
        
        var ratio = parseFloat(current.width)/parseFloat(current.height);
        var horizontal = current.width >= current.height;
        
        if (horizontal)
            ret = current.width > max ? {width: max, height: parseInt(max * ratio)} : {width: current.width, height: current.height };
        else
            ret = current.height > max ? {width: parseInt(max * ratio), height: max } : {width: current.width, height: current.height };
        
        return ret;        
    },
    
    /** This cures the bug in .NET which ignores groupnames in radio buttons when radio buttons are in a repeater.
    You must set the radiobutton's onclick to call this function (in the ItemDatabound) **/
    SetUniqueRadioButton : function(nameregex, current)
    {
    
       re = new RegExp(nameregex);
       for(i = 0; i < document.forms[0].elements.length; i++)
       {
          elm = document.forms[0].elements[i]
          if (elm.type == 'radio')
          {
             if (re.test(elm.name))
             {
                elm.checked = false;
            }
          }
       }
       current.checked = true;
    },
    
    Search : {
        _initiated :false,
        _defaultWords:'search',
        initiate : function(obj){
            if(this._initiated || !obj)
                return;
            this._defaultWords = obj.value;
            Event.observe(obj, 'click', function(){
                if(obj.value == Global.Search._defaultWords)
                obj.value = '';
            });
            Event.observe(obj, 'keydown', Global.Search.TrapReturn);
            _initiated = true;
        },
        Query :function(q){
            //check to see if looking into product descriptions
            searchString = "/search/";
            searchString += escape(q);  
            if($$('.searchProductDescription:checked ').length > 0)
                searchString += "/?description=1";
            
            
            window.location = searchString;
        },
        TrapReturn:function(evt,obj){
            
            var charCode = (evt.which) ? evt.which : event.keyCode;
            if(charCode == 13){
               Global.Search.Query(this.value);
               return false;
               }
        }
    
    }
}
//DOM
document.observe("dom:loaded", Global.Initialize);
Event.observe(window, 'load', Global.InitializeAfterLoad);


/*** Lightbox.js - 6.0 kb ***/
var Lightbox = {
	lightboxType : null,
	lightboxCurrentContentID : null,
	isOn:false,
	showBoxString : function(content, boxWidth, boxHeight){
	
		this.setLightboxDimensions(boxWidth, boxHeight);
		this.lightboxType = 'string';
		var contents = $('boxContents');
		contents.innerHTML = content;
		this.showBox();
	
		return false;
	},


	showBoxImage : function(href) {
	
		this.lightboxType = 'image';
		var contents = $('boxContents');
		var objImage = document.createElement("img");
		$(objImage).identify();
		contents.update('');
		contents.appendChild(objImage);
		imgPreload = new Image();
		imgPreload.src = href;
		$(imgPreload).identify();
		
		//This is because if a user is trying to show the same lightbox, 
		//The image is already cached and onload never gets called
		
		if(imgPreload.complete)
		    {
		        
		        Lightbox.center('box');
		        objImage.onload = function(){
		            Lightbox.center('box');
		            Lightbox.showBox();
		            }
		        objImage.src = href;
		        
		}
		else{
		        objImage.onload = function(){
			            Lightbox.center('box');
			            Lightbox.showBox();
			        }
		        objImage.src = href;   
		}
	
		return true;
	},

	showBoxByID : function(id, boxWidth, boxHeight) {
		this.lightboxType = 'id';
		this.lightboxCurrentContentID = id;
		this.setLightboxDimensions(boxWidth, boxHeight);
		var element = $(id);
		var contents = $('boxContents');
		contents.appendChild(element);
		Element.show(id);
		this.showBox();
		return false;
	},

	showBoxByAJAX : function(href, boxWidth, boxHeight) {
		this.lightboxType = 'ajax';
		this.setLightboxDimensions(boxWidth, boxHeight);
		var contents = $('boxContents');
		var myAjax = new Ajax.Updater(contents, href, {method: 'get'});
		this.showBox();
		return false;
	},
	
	setLightboxDimensions : function(width, height) {
		var windowSize = this.getPageDimensions();
		if(width) {
			if(width < windowSize[0]) {
				$('box').style.width = width + 'px';
			} else {
				$('box').style.width = (windowSize[0] - 50) + 'px';
			}
		}
		if(height) {
			if(height < windowSize[1]) {
				$('box').style.height = height + 'px';
			} else {
				$('box').style.height = (windowSize[1] - 50) + 'px';
			}
		}
	},


	showBox : function() {
		Element.show('overlay');
		Element.show('box');
		
		this.isOn = true;
		this.center('box');
		Lightbox.recenterer = Event.observe(window, 'scroll',function(){
		    Lightbox.center('box');
		});
		
		return false;
	},
	
	
	hideBox : function(){
		var contents = $('boxContents');
		if(this.lightboxType == 'id') {
			var body = document.getElementsByTagName("body").item(0);
			Element.hide(this.lightboxCurrentContentID);
			body.appendChild($(this.lightboxCurrentContentID));
		}
		contents.innerHTML = '';
		//$('box').style.width = 0;
		//$('box').style.height = 0;
		Element.hide('box');
		Element.hide('overlay');
		this.isOn = false;
		return false;
	},
	
	// taken from lightbox js, modified argument return order
	getPageDimensions : function(){
		var xScroll, yScroll;
	
		if (window.innerHeight && window.scrollMaxY) {	
			xScroll = document.body.scrollWidth;
			yScroll = window.innerHeight + window.scrollMaxY;
		} else if (document.body.scrollHeight > document.body.offsetHeight){ // all but Explorer Mac
			xScroll = document.body.scrollWidth;
			yScroll = document.body.scrollHeight;
		} else { // Explorer Mac...would also work in Explorer 6 Strict, Mozilla and Safari
			xScroll = document.body.offsetWidth;
			yScroll = document.body.offsetHeight;
		}
		
		var windowWidth, windowHeight;
		if (self.innerHeight) {	// all except Explorer
			windowWidth = self.innerWidth;
			windowHeight = self.innerHeight;
		} else if (document.documentElement && document.documentElement.clientHeight) { // Explorer 6 Strict Mode
			windowWidth = document.documentElement.clientWidth;
			windowHeight = document.documentElement.clientHeight;
		} else if (document.body) { // other Explorers
			windowWidth = document.body.clientWidth;
			windowHeight = document.body.clientHeight;
		}	
		
		// for small pages with total height less then height of the viewport
		if(yScroll < windowHeight){
			pageHeight = windowHeight;
		} else { 
			pageHeight = yScroll;
		}
	
		// for small pages with total width less then width of the viewport
		if(xScroll < windowWidth){	
			pageWidth = windowWidth;
		} else {
			pageWidth = xScroll;
		}
		arrayPageSize = new Array(windowWidth,windowHeight,pageWidth,pageHeight) 
		return arrayPageSize;
	},
	
	center : function(element){
	    if(!this.isOn)
	       return;
		try{
			element = document.getElementById(element);
		}catch(e){
			return;
		}
		
		var windowSize = this.getPageDimensions();
		var window_width  = windowSize[0];
		var window_height = windowSize[1];
		
		$('overlay').style.height = windowSize[3] + 'px';
		
		element.style.position = 'absolute';
		element.style.zIndex   = 99;
	
		var scrollY = 0;
	    
		if ( document.documentElement && document.documentElement.scrollTop ){
			scrollY = document.documentElement.scrollTop;
		}else if ( document.body && document.body.scrollTop ){
			scrollY = document.body.scrollTop;
		}else if ( window.pageYOffset ){
			scrollY = window.pageYOffset;
		}else if ( window.scrollY ){
			scrollY = window.scrollY;
		}
	    
		var elementDimensions = Element.getDimensions(element);
		
		var setX = ( window_width  - elementDimensions.width  ) / 2;
		var setY = ( window_height - elementDimensions.height ) / 2 + scrollY;
	
		setX = ( setX < 0 ) ? 0 : setX;
		setY = ( setY < 0 ) ? 0 : setY;
	
		element.style.left = setX + "px";
		element.style.top  = setY + "px";
		
		Element.show(element);
	},
	
	init : function() {				  
		var lightboxtext = '<div id="overlay" onclick="Lightbox.hideBox()" style="display:none"></div>';
		lightboxtext += '<div id="box" style="display:none">';
		lightboxtext += '<img id="close" src="/store/images/icons/close.gif" onClick="Lightbox.hideBox()" alt="Close" title="Close this window" />';
		lightboxtext += '<div id="boxContents"></div>';
		lightboxtext += '</div>';
		var body = document.getElementsByTagName("body").item(0);
		new Insertion.Bottom(body, lightboxtext);
	}
}


document.observe("dom:loaded", function() {
Lightbox.init();
    $$('img.lightBox').each(function(e){
        e.observe('click',function(){
            Lightbox.showBoxImage(e.src);
        });
    });
});






/*** Menu.js - 2.0 kb ***/
var Menu = Class.create({ 
    initialize: function(options){
        this.Options = options;
        this.Holder = $(options.holder);
        this.DropDowns = new Array();
        this.Options.tag = this.Options.tag == null ? "a" : this.Options.tag;
        this.Options.align = this.Options.align == null ? "right" : this.Options.align;
        this.BindLinks(this);
    },
    ShowItem: function(index){
        var dd = this.DropDowns.find(function(p){
            return p.Id == 'dd_' + index;
        });        
		
        dd.Show();
    },
    BindLinks: function(g){
        var i = 0;
        this.Holder.select('ul')[0].select(g.Options.tag).each(function(a){
            if (a.select('span').length == 0)
                return;
            var sb = new StringBuilder();
            sb.Append('menu_');
            sb.Append(a.getAttribute('rel'));
            var dd = new DropDown({
                trigger: a.select('span')[0],
                baseElement: 'parent',
                displayElement: sb.ToString(),
                closeOnClick: false,
                align: g.Options.align,
                shadow: {opacity: .2, offset: 4},
                effects: g.Options.effects,
                closeOnMouseout: true,
                padding: g.Options.padding,
                showOnMouseover: g.Options.showOnMouseover,
                onShowBegin: function(){
                    $(this.DropDowns).each(function(d){
                        if (dd.Id != d.Id) {
                            d.HideDropDown();
                            d.BaseElement.removeClassName('menuBarSelected');
                        }
                    });
                    dd.BaseElement.addClassName('menuBarSelected');
                }.bind(this),
                onHideFinish: function(){
                    dd.BaseElement.removeClassName('menuBarSelected');
                }
            });
            dd.Id = 'dd_' + i;
            i++;
            this.DropDowns.push(dd);
        }.bind(this));
    }
});

/*** Message.js - 7.0 kb ***/
var Message = Class.create({
    initialize: function(options){
        this.options = {
            OverlayColor: '#000000',
            OverlayOpacity: .5,
            OverlayHideOnClick: false, 
            Draggable: false,
            InnerHTML: '&nbsp;',
            InnerDom: null,
            IsMessage: true,
            onButtonInit: null,
            Width:'100%'
        };
        this.ClickedMessage = false;
        this.MainButton = null;
        this.Buttons = new Array();
        Object.extend(this.options, options || {});
        
        this.MakeElements();            
    },
    MakeElements: function(){
        if (this.Holder == null)
            this.Holder = this.MakeHolder();
        if (this.Overlay == null)
            this.Overlay = this.MakeOverlay();
        if (this.MessageHolder == null)
            this.MessageHolder = this.MakeMessageHolder();   
        if (this.MessageElement == null)
            this.MessageElement = this.MakeMessageElement();
            
        if (this.options.Draggable)
            new Draggable(this.MessageElement, {handle: 'message_messageTitle'});
    },
    MakeHolder: function(){
        var holder = new Element('div', {'class': 'message_holder'});
        var height = $(document.body).getHeight() > document.viewport.getHeight() ? $(document.body).getHeight() : document.viewport.getHeight();
        holder.setStyle({
            width: '100%',
            height: height + 'px',
            position: 'absolute',
            top: '0px',
            left: '0px',
            zIndex: '50',
            display: 'none'
        });
        $(document.body).appendChild(holder);
        return holder;
    },
    MakeOverlay: function(){
        var overlay = new Element('div', {'class': 'message_overlay'});
        var height = $(document.body).getHeight() > document.viewport.getHeight() ? $(document.body).getHeight() : document.viewport.getHeight();
        overlay.setStyle({
            background: this.options.OverlayColor,
            width: '100%',
            height: height + 'px',
            position: 'absolute',
            top: '0px',
            left: '0px',
            zIndex: '51',
            display: 'block',
            opacity: this.options.OverlayOpacity
        });
        if (this.options.OverlayHideOnClick){
            Event.observe(overlay, 'click', function(){
                this.Hide();                    
            }.bind(this));
        }
        this.Holder.appendChild(overlay);
        return overlay;
    },
    MakeMessageHolder: function(){
        var message = new Element('div', {'class': 'message_messageHolder'});
        message.setStyle({
            marginTop: '100px',
            width: this.options.Width,
            position: 'fixed',
            zIndex: '52'
        });
        if((""+this.options.Width+"").endsWith("px")){
            var leftMargin = (document.viewport.getWidth()-parseInt(this.options.Width))/2;
            leftMargin += "px";
            message.setStyle({marginLeft:leftMargin});
        }
       
        if (this.options.OverlayHideOnClick){
            Event.observe(message, 'click', function(){
                this.Hide();                    
            }.bind(this));
        }
        this.Holder.appendChild(message);
        return message;        
    },
    MakeMessageElement: function(){
        var holder = new Element('div', {'class': 'message_messageElement'});
        if (this.options.IsMessage){
            holder.setStyle({
                margin: '0px auto',
                fontSize: '14px',
                fontWeight: 'bold',
                width: '300px',
                background: '#FFFFFF',
                border: '2px solid #D0D0D0'
            });
        } else {
            if (this.options.InnerDom.Css)
                holder.setStyle(this.options.InnerDom.Css)
        }
        
        
        Event.observe(holder, 'click', function(){
            this.ClickedMessage = true;   
        }.bind(this));
        
        var title = new Element('div', {'class': 'message_messageTitle', rel: 'title'}).setStyle({            
            padding: '5px',
            background: 'url(#{0}/images/map03.png) 0px 0px repeat-x'.interpolate({0:_HERE}),
            fontSize: '15px',
            fontWeight: 'bold',
            color: '#FFFFFF'
        }).update('Message Box');
        
        holder.appendChild(title);
        
        var body = new Element('div', {'class': 'message_messageBody', rel: 'body'}).setStyle({            
            padding: '5px',
            background: '#FFFFFF',
            fontSize: '12px'            
        }).update('Message');
        
        holder.appendChild(body);
        
        var buttons = new Element('div', {'class': 'message_messageButtons', rel: 'buttons'}).setStyle({            
            padding: '5px',
            background: '#FFFFFF',
            fontSize: '12px',
            textAlign: 'center'            
        });
                
        var button1 = new Element('a', {'class': 'blueButton', rel: 'ok_button', href: 'javascript:void(0);'}).setStyle({
            fontWeight: 'bold',
            cursor: 'pointer',
            margin: '0px auto',
            display: 'inline-block'
        }).update('Ok');
        
        Event.observe(button1, 'click', function(){            
            this.ClickedMessage = false;   
            this.Hide();
        }.bind(this));
        
        this.Buttons.push(button1);
        if(this.options.onButtonInit)
            this.options.onButtonInit(this.Buttons);
            
        this.MainButton = button1;        
        
        if (this.options.InnerDom && this.options.InnerDom.Buttons){
            this.options.InnerDom.Buttons.each(function(button){
                this.Buttons.push(button);
            }.bind(this));
        }       
        this.Buttons.each(function(button, i){
            button.addClassName('blueButton');
            buttons.appendChild(button);            
        }.bind(this));
        
        holder.appendChild(buttons);
        
        this.MessageHolder.appendChild(holder);
        return holder;        
    },
    UpdateTitle: function(str){
        this.MessageElement.select('div[rel="title"]')[0].update(str);
    },
    UpdateMessage: function(obj){        
        var _b = this.MessageElement.select('div[rel="body"]')[0];        
        if (typeof(obj) == 'string')
            _b.update(obj);
        else {
            _b.update('');
            _b.appendChild(obj);
        }
    },
    Show: function(){
        this.Holder.show();
        if(this.MainButton)
            this.MainButton.focus();
    },
    Hide: function(){
        if(this.ClickedMessage){
            this.ClickedMessage = false;
            return;
        }
        new Effect.Fade(this.Holder, {duration: .3});
    }
});
Message.LightBox = function(elements,options){   
    var messageOptions = {
        IsMessage: false,
        Draggable: true,
        InnerDom: elements,
        OverlayHideOnClick: true,
        onButtonInit: elements.onButtonInit
    } 
    Object.extend(messageOptions, options || {});
    var message = new Message(messageOptions);
    message.UpdateTitle(elements.Title == null ? 'Box' : elements.Title);
    message.UpdateMessage(elements.Body);
    message.Show();
    return message;
}
Message.Alert = function(str, title){
    var message = new Message({
        InnerHTML: str,
        Draggable: true,
        OverlayHideOnClick: true
    });    
    message.UpdateTitle(title == null ? 'Alert' : title);
    message.UpdateMessage(str);
    message.Show();
}

/*** Product.js - 2.0 kb ***/
var ProductClass = Class.create({
    initialize: function (options) {
        this.Options = options;
        this.Adding = false;
    },
    AddToCart: function (productId, quantity, optionsQueryString, requiredUserInput) {
        if (this.Adding)
            return;
        this.Adding = true;
        if (quantity < 1) {
            alert('Please enter a quantity');
            Product.Adding = false;
            return;

        }
        q = Object.toQueryString({
            id: productId,
            quantity: quantity
        });
        q2 = "";

        requiredOk = true;
        requiredUserInput.each(function (b) {
            if (b.value == "") {
                new Effect.Shake(b);
                $(b).focus();
                requiredOk = false;
            }
            q2 += "&" + b.name + "=" + b.value;

        });
        if (!requiredOk) {
            alert("Please complete all required fields");
            Product.Adding = false;
            return false;
        }
        new Ajax.Request('/ajax/?a=Product_AddToCart', {
            method: 'post',
            dataType: 'json',
            postBody: optionsQueryString + '&' + q + q2,
            onComplete: function () { Product.Adding = false; },
            onFailure: function (e) {

                if (e.status == 502)
                    alert(e.responseText);
                else if (e.status == 500)
                    alert("Please login to add this item to your cart");

            }
        });

    },

    UpdateSettings: function (object, id) {
        settings = Settings.GetSettings($('configureSettings'));
        $(object).update('<span>Saving...</span>');
        new Ajax.Request('/ajax/?a=Product_Update', {
            method: 'post',
            parameters: {
                id: id,
                settings: settings["vars"]
            },
            onSuccess: function (e) {
                if (e.responseJSON.status == 'success') {
                    $(object).update('<span>Success</span>');
                    history.back();
                }
            },
            onFailure: function () {
                $(object).update('<span>Try Again</span>');
                alert('Sorry, an error occurred.');
            }

        });

    }
});
var Product = new ProductClass();


/*** Settings.js - 6.0 kb ***/
var Settings = { 
    Buttons: { Prev: null, Next: null },
    CurrentPage: 1,
    MaxPage: 6,
    ShowButtons: true,
    BuildPreview: true,
    EditView: false,
    ChangePage: function(id) {
        if(id > 0 && id <= this.MaxPage) {
            if(this.ShowButtons) {
                // Show both buttons incase one was hidden
                // on the last page
                this.Buttons.Prev.show();
                this.Buttons.Next.show();
                this.Buttons.Submit.hide();
                
                // Hide the previous or next button if
                // we're on the first page or the last page
                if(id == 1)
                    this.Buttons.Prev.hide();
                if(id == this.MaxPage) {
                    this.Buttons.Submit.show();
                    this.Buttons.Next.hide();
                }
            }
            
            // Hide the current page
            //Element.clonePosition('page'+this.CurrentPage, 'page'+id);
            //new Effect.Fade('page'+this.CurrentPage,{limit:1,duration:0.5});
            $('page'+this.CurrentPage).hide();
            
            $('tab'+this.CurrentPage).removeClassName('tabSelected');
            
            // Show the new page
            $('page'+id).show();
            //new Effect.Appear('page'+id,{queue:'end', duration:.5, limit:1});
            $('tab'+id).addClassName('tabSelected');
            
            // Update the current page
            this.CurrentPage = id;     
            
            if(this.BuildPreview)
                this.BuildPreview();
            
            // Every time we change page hide all the open items
            if(this.EditView)
                $(this.Items).each(function(i) { Settings.ShowDisplay(i); });
                
           // new Effect.ScrollTo('createHolder');
            
//            if (window.location.href.indexOf("#top") < 0)
//                new Effect.ScrollTo('top');//window.location = window.location.href + "#top";
//            else
//                window.location = window.location.href;                
        }
    },
    ChangePageByName: function(page_name){
    var selected_tab = 1;
                switch(page_name.toLowerCase()){
                        case 'general':
                            valid = true;
                            selected_tab = 1;
                            break;
                        case 'settings':
                            selected_tab = 2;
                            break;
                        case 'sports':
                            selected_tab = 3;
                            break;
                        case 'sportsbooks':
                            selected_tab = 4;
                            break;
                        default:
                            selected_tab = 1;
                            break;
                    }

                    Settings.ChangePage(selected_tab);
    
    },
    ShowEdit: function(id) {
        var edit = $$('#'+id+' .right .editBox')[0];
        var display = $$('#'+id+' .right .displayBox')[0];
        
        display.hide();
        edit.show();
    },
    ShowDisplay: function(id) {
        var edit = $$('#'+id+' .right .editBox')[0];
        var display = $$('#'+id+' .right .displayBox')[0];
        
        display.select('span')[0].innerHTML = this.ItemData[id].GetHtml();
        display.show();
        edit.hide();
    },
    BuildPreview: function() {
        var page = $('page5');
        page.update('');
        page.appendChild(Builder.node('h2',{},"Preview Contest Settings"));
        
        var outer = new Element('div');        
        outer.addClassName('settingsBody');
        
        $(this.Items).each(function(item) {
            var main = new Element('div');
            main.addClassName('previewContainer');
            
            var header = new Element('div');
            header.addClassName('previewHeader');
            header.update($$('#'+item+' .left h4')[0].innerHTML);
            
            var desc = new Element('div');
            desc.addClassName('previewDescription');
            desc.update($$('#'+item+' .left span')[0].innerHTML);
            
            var data = new Element('div');
            data.addClassName('previewData');

            if (Settings.ItemData[item]){
                var str = Settings.ItemData[item].GetHtml();
            }
            //alert('---|' + Settings.ItemData[item].Empty + '|---');
            str = str == '' ? '<span style="color: red">#{0}</span>'.interpolate({0: Settings.ItemData[item].Empty.innerHTML}) : str; 
            data.update(str);
            
            main.appendChild(header);
            main.appendChild(desc);
            main.appendChild(data);
            outer.appendChild(main);             
        });
        
        page.appendChild(outer);
    },
    PrintValue: function(data) {
        return $(data.obj).value;
    },
    PrintRadio: function(data) {
        for(var i = 0; i < data.obj.length; i++) {
            if(data.obj[i].checked) {
                return data.obj[i].value;
                break;
            }
        }
        return '';
    },
    PrintCombo: function(data) {
        return data.obj.options[data.obj.selectedIndex].innerHTML;
    },
    AddSetting: function(name, f, data) {
        this.Items.push(name);
        this.ItemData[name] = {
            Data: data,
            GetHtml: function() { return f(data); },
            Empty: new Element('span',{style: 'color: red'}).update(data.empty)
        };
    },
    
    GetSettings:function(obj){
    var m = obj;
    var vars = {};
    m.select('input:not([type="checkbox"])').each(function(i){
        if (i.name || i.id){
            if (i.getAttribute('type') == 'radio' && i.checked)
                vars[i.id ? i.id : i.name] = i.value;
            else if (i.getAttribute('type') != 'radio')
                vars[i.name ? i.name : i.id] = escape(i.value);
        }
    });
    m.select('select').each(function(s){
        if (s.name || s.id){
            vars[s.name ? s.name : s.id] = escape(s.options[s.selectedIndex].value);
        }
    });
    m.select('textarea').each(function(t){
        if (t.name || t.id){
            vars[t.name ? t.name : t.id] = escape(t.value);
        }
    });
    m.select('input[type="checkbox"]').each(function(c){
        if (c.name || c.id){
            vars[c.name ? c.name : c.id] = c.checked;
        }
    });
    var s = "";
    for(k in vars){
        s += k + '=' + vars[k] + "&";
    }
    var ret = {};
    ret['vars'] = s;
    return ret;
    },
    Items: new Array(),
    ItemData: { }
}




/*** Tooltip.js - 1.0 kb ***/
var Tooltip = Class.create({
    initialize: function(options){
        this.options = {
            only: 'tooltip',
            attribute: 'title',
            tooltipId: 'tooltipPopup'
        }
        this.Tips = new Array();
        this.Holder = $(this.options.tooltipId);
        Object.extend(this.options, options || {});
    }
});
Tooltip.prototype.BuildTooltipBox = function(){
    this.Holder = new Element('div', {id: this.options.tooltipId})
    this.Holder.setStyle({
        position: 'absolute',
        top: '0px',
        left: '0px',
        background: '#FFFFCC',
        border: '1px solid #FFCC00',
        padding: '5px',
        display: 'none',
        maxWidth: '200px',
        zIndex: 100
    });
    document.body.appendChild(this.Holder);
}
Tooltip.prototype.Load = function(){    
    if (this.Holder == null)
        this.BuildTooltipBox();
    $(document.body).select('.#{0}'.interpolate({0: this.options.only})).each(function(obj, idx){
        var text = obj.getAttribute(this.options.attribute);        
        if (text.blank()) return;
        
        obj[this.options.attribute] = '';
        
        Event.observe(obj, 'mouseover', function(){
            pos = obj.cumulativeOffset();
            this.Holder.setStyle({
                top: (pos.top + obj.getHeight()) + 'px',
                left: pos.left + 'px'
            });
            this.Holder.update(text);
            this.Holder.show();
        }.bind(this));
        Event.observe(obj, 'mouseout', function(){
            this.Holder.hide();
        }.bind(this));
        this.Tips.push({
            obj: obj,
            index: idx
        });
    }.bind(this));
}

Event.observe(window, 'load', function(){
    var t = new Tooltip();
    t.Load();
});

/*** Transaction.js - 9.0 kb ***/

window.AjaxPagerParams = {
    sort: 1,
    filter: '',
    cacheKey:1,
    key: function(){
        return '#{0}----#{1}----#{2}'.interpolate({0: this.sort, 1: this.filter, 2: this.cacheKey});
    }
};
var TransactionLog = Class.create({
    initialize: function(options){
        this.options = {
            location: window.location.pathname.endsWith('/') ? window.location.pathname : window.location.pathname + '/'
        };
        Object.extend(this.options, options || {});
        this.Filters = new Array();
        this.Filter = null;
        this.Points = this.GetPointValue();
        this.SendingAjax = false;
    },
    GetPointValue: function(){
        var b = $('balancebox');
        if (b == null) return 0;
        var points = parseInt(b.getAttribute('balance'));
        return points;
    },
    AddFilter: function(objId, allowMultiple, type, key, fn){
        var filter = {
            obj: $(objId),
            allowMultiple: allowMultiple,
            type: type,
            key: key,
            value: null,
            valueFunction:fn == undefined ? false : fn
        };    
        
        filter.value = this._getFilterValue(filter);
        this.Filters.push(filter);
    },
    _getFilterValue: function(filter){
        var ret = null;
        if(filter.valueFunction)
            ret = eval(filter.valueFunction);
        else
            ret = filter.obj.value.blank() ? null : filter.obj.value;
        
        // Ranges Values
        if (filter.type  == 2)
            ret = filter.obj.value.match(/^0?%%0?$/) ? null : filter.obj.value;
        if (ret != null)
            ret = ret.replace(/,{2,}/, ',').replace(/(^,+|,$)/, '');
        return ret;
    },
    UpdateValues: function(){
        this.Filters.each(function(f){
            f.value = this._getFilterValue(f);
        }.bind(this));
    },
    BuildFilter: function(){
        var ret = new StringBuilder();
        this.Filters.each(function(filter){
      
         if (filter.value == null || filter.value == 'Search keyword') return;
            ret.AppendFormat('#{0}:#{1}', {0: filter.key,
             1: filter.value});
        });
        
        return ret.ToString('|');
    },
    ProcessData: function(filter, data){
        window.location.href = '#{0}#/filter/#{1}'.interpolate({0: this.options.location, 1: filter});
    },
    DoSort: function(obj){
        AjaxPagerParams['sort'] = $(obj).value;
        this.Search(null);
    },
    Search: function(obj){
        this.UpdateValues();
        this.Filter = this.BuildFilter();
        AjaxPagerParams['filter'] = this.Filter;
		
        var params = {};
        for(k in AjaxPagerParams) {
            if (typeof(AjaxPagerParams[k]) == 'function') continue;
            params[k] = AjaxPagerParams[k];
        }
        
        if (this.AjaxPager != null)
            this.AjaxPager.ChangePage(1);
    },
    DisplayGroupedRow:function(div, link){
       
        
         if(link.hasClassName('open')){
            link.removeClassName('open');
            new Effect.toggle(div, 'Slide', {duration:0.3});
        }else{
            link.addClassName('open');
            new Effect.toggle(div, 'Slide', {duration:0.3});
        }
        return;
        
        
        $(link).up('td').select('a').each(function(l){l.removeClassName('open');});
        if(div.visible()){
        
            if(div.hasClassName(cssClass)){
                new Effect.SlideUp(div, {duration:0.3});
                link.removeClassName('open');
                
                div.removeClassName(cssClass);
                return;
                }
                else{
                    new Effect.toggle(div, 'Slide', {
                        duration:0.3,
                        limit:1,
                        afterFinish:function(){
                            div.update(data);
                            new Effect.SlideDown(div,  {duration:0.3,queue:'end'});
                            link.addClassName('open');
                            }});
                 }
            }
        else{
            div.update(data);
             new Effect.toggle(div, 'Slide', {duration:0.3,queue:'end'});
              link.addClassName('open');
            }
          
       $w(div.className).each(function(e){
          div.removeClassName(e);
       });
               
       div.addClassName(cssClass);
    }
});
TransactionLog.prototype.HasPoints = function(){
    return true;
    this.Points = this.GetPointValue();
    return this.Points > 0;
}
TransactionLog.prototype.ShowTransferBox = function(obj, boxId){
    if (!this.HasPoints()){
        Message.Alert('You do not have enough points.', 'Alert');
        return;
    }
    obj = $(obj);
    if ($('tooltipPopup'))
        $('tooltipPopup').hide();
    if ($(boxId).visible())
        return;
    var pos = obj.cumulativeOffset();
    var p = $(boxId);
    
    p.setStyle({
        top: (pos.top + obj.getHeight()) + 'px',
        left: (pos.left - ( p.getWidth() - obj.getWidth()) + 10) + 'px'
    });
    new Effect.Appear(boxId, {duration: .2, afterFinish: function(){
        p.down('div').down('div').down('div').down('input').focus();
    }});
}
TransactionLog.prototype.VerifyAmount = function(obj, errorHolderId){
    var input = parseInt($F(obj));
    if (this.Points < input){
        $(obj).value = 0;
        Message.Alert('You do not have enough points.', 'Alert');
        return false;
    }
}
TransactionLog.prototype.DoTransfer = function(obj){
    obj = $(obj);
    // Sanity Checks
    if (obj.hasClassName('grayButton')) return;
        
    if ($F(this.TransferUserSearch.options.textbox).blank()) {
        Message.Alert('You must specify a user account.');
        return;
    }    
    
    var params = {  }
    var holder = obj.up('table');
    
    holder.select('input','textarea').each(function(d){
        
            params[d.id] = $F(d);             
    });
    
    params['transferUser'] = this.TransferUserSearch.options.textbox.value.split(';').first().strip();
     
    
    if (parseInt(params['transferAmount']) == 0){
        Message.Alert('You must specify an amount.');
        return;
    }
        
    obj.addClassName('grayButton');
    if (this.SendingAjax) return;
    this.SendingAjax = true;
    new Ajax.Request('/ajax/?a=User_Transfer', {
        method: 'post',
        parameters: params,
        onSuccess: function(t){
            this.ProcessTransfer(t.responseText.evalJSON(false), obj);            
        }.bind(this),
        onComplete: function(t){
            this.SendingAjax = false;  
        }.bind(this),
        onFailure: function(t){
            Message.Alert(t.responseText, 'Alert');
            obj.removeClassName('grayButton');
        }.bind(this)
    });
}
TransactionLog.prototype.ProcessTransfer = function(t, obj){
    var message = '';
    var closebox = false;
    switch(t.status){
        case 1:
            message = 'Transfer is complete.';
            closebox = true;
            break;
        case 3:
            message = 'You have insufficient funds to make this transfer.';
            break;
        case 4:
            message = 'Invalid Deposit Account';
            break;
        case 5:
            message = 'Invalid Withdrawl Account';
            break;
        default:
            break;
    }
    Message.Alert(message, t.status == 1 ? 'Complete' : 'Alert')
    if (closebox){                    
        new Effect.toggle('transferConsoleHolder', 'appear', {duration:.1, afterFinish: function(){
            obj.removeClassName('grayButton');
            window.location.reload();
        }});          
    } else {
        obj.removeClassName('grayButton');
    }
}
TransactionLog.prototype.Toggle = function(obj){
    obj = $(obj);
    new Effect.toggle($(obj.parentNode.parentNode).down('div.pointsFilterContent'), 'blind', {
        duration: .2,
        afterFinish: function(){
            if (obj.hasClassName('pointsFilterTogglerMin'))
                obj.removeClassName('pointsFilterTogglerMin');
            else
                obj.addClassName('pointsFilterTogglerMin');
        }
    });
}
TransactionLog.prototype.GetFilterRange = function(obj){
    var inputs = $(obj.parentNode).select('input[type="text"]');
    var field = $(obj.parentNode.parentNode).select('input[type="hidden"]')[0];
    field.value = inputs.collect(function(i){ return i.value; }).join("%%");
}
TransactionLog.prototype.UpdateCheckboxList = function(obj, f){
    var h = $(f);
    var holder = $(obj.parentNode.parentNode);
    h.value = holder.select('input[type="checkbox"]').collect(function(i){
        if (i.checked)
            return i.value;
    }).join(',');
    h.value = h.value.endsWith(',') ? h.value.substring(0, h.value.length - 1) : h.value;   
}
TransactionLog.prototype.ListenToTR = function(){
    $$('tr.transactionListEntry').each(function(e){
        $(e).observe('click', function(){
            //window.location = '/points/transaction/'+$(e).down('td').down('a').innerHTML;
        });
    });
}
var tlog = new TransactionLog();

/*** UserSearch.js - 12.0 kb ***/
var UserSearch = Class.create({
    initialize: function(options){
        this.options = {
            textbox: $(options.textboxId),
            optionsHolder: $(options.holderId),
            optionsStatus: $(options.holderId).select('div.us_holder_status')[0],
            holder: $(options.holderId).select('div.us_options')[0],
            sending: false, 
            lastSearch: '',
            currentSearch: '',
            currentSelection: -1,
            options: new Array(),
            maxResults:5,
            maxSelections:1,
            typeTo: 0,
            to: 0,
            onSelect: null,
            preText : $(options.textboxId).getAttribute('preText'),
            mode: options.mode == null ? UserSearch.MODE.SINGLE : options.mode
        };
        this.SelectedUser = null;
        this.users = {};
        this.InitEvents();
    },
    InitEvents: function(){
        Event.observe(window, 'load', function(){
            document.body.appendChild(this.options.optionsHolder);
        }.bind(this));
        //observing keyups & keydowns
        Event.observe(this.options.textbox, 'keyup', this.GetKeyUp.bind(this));
        Event.observe(this.options.textbox,'keydown', this.GetKeyDown.bind(this));
        
        //we must do this instead of on blur because of event collision
        Event.observe(document, 'click', this.Hide.bind(this));
        
        //This corrects IE's stupid rendering bugs (If we did this by css).
        //Element.absolutize(this.options.optionsHolder.up());
		Element.clonePosition(this.options.optionsHolder, this.options.textbox, {setHeight:false,offsetTop:23});
		
		//This tries to get users every 1/3 second. (If the last search was the same, it won't make an ajax call)
		//This is because if a person types in the username very fast. I.e. "Whitey", and the ajax call gets called on the "t", but is not 
		//finished by the time the letters "ey" were inputted, the latest search results would have been for "WHit"
		setInterval(function(){
            if(this.Value() != this.options.preText)
            this.GetUsers(this.Value().strip());	
            
            
            	       
        }.bind(this),300);
	},
    Value: function(){
        var vals = $F(this.options.textbox).split(';');
        return vals.length == 0 ? $F(this.options.textbox) : vals[vals.length-1];
    },
    Clear: function(){
        this.options.textbox.value = '';          
    },
    GetKeyDown: function(e){
        var toReturn = true;
        var code = e.keyCode ? e.keyCode : e.charCode;
        switch(code){
            case 9: //tab  
                if(this.options.options.length > 1){
                    e.shiftKey ? this.SelectPrev() : this.SelectNext();
                    toReturn = false;
                    Event.stop(e);
                 }else
                    this.Hide();
                break;
            case 8: //backspace
                this.options.lastSearch = '';
                this.SelectedUser = null;
                break;
            case 13: //enter
                if (this.options.currentSelection >= 0) {
                    this.Select();
                    Event.stop(e);
                    return false;
                }
                Event.stop(e);
                break; 
            case 37: //left arrow
            case 39: //right arrow
            case 46: //delte 
                break;
            default:
                if (this.options.mode == UserSearch.MODE.SINGLE && $F(this.options.textbox).indexOf(';') > 1) {
                    Event.stop(e);
                    return false;
                }
                break;
        }
        
        return true;
    },
    GetKeyUp: function(e){
        var code = e.keyCode ? e.keyCode : e.charCode;
        switch(code){
       
            case 40: //down arrow
                Event.stop(e);
                if (this.options.options.length > 0 && this.options.currentSelection <= this.options.options.length)
                    this.SelectNext();
                return false;
            case 38: //up arrow
                Event.stop(e);
                if (this.options.options.length > 0 && this.options.currentSelection > 0)
                    this.SelectPrev();
                return false;
            case 27: //escape
            case 13: //enter
                if (this.options.currentSelection >= 0) {
                    this.Select();
                    Event.stop(e);
                    return false;
                }
                Event.stop(e);
                break;
            case 44: //comma
            case 32: //space
                break;
            case 59: //semicolon
                this.Hide();
                return true;
                break;                
            case 37: //left arrow
            case 39: //right arrow
            case 33: //page up  
            case 34: //page down  
            case 36: //home  
            case 35: //end    
            case 9:  //tab  
                //this.Hide();
                break;
            case 16: //shift  
            case 17: //ctrl  
            case 18: //alt  
            case 20: //caps lock
            case 46: //delete
            default:
                break;
		}
		var s = this.Value().strip();
		
		this.options.currentSearch = s;
        
        /*********************************
            BRIAN EDIT BUG FIX 361
        if(s.length > 2 && s.indexOf("@") < 0)
            this.GetUsers(s);
		else
		    this.Hide();
		**********************************/
		// Test for email.
		this.GetUsers(s);
		this.options.lastSearch = s;
		return true;
    },
    
    HideStatus:function(){
        this.options.optionsStatus.hide();
    },
    UpdateStatus: function(message) {
    this.options.optionsStatus.show();
        if (!message && message > 0){
            this.options.optionsStatus.update('<img src="' + _HERE + '/images/spacer.gif" width="1" height="22" /> #{0} User#{1}'.interpolate({
                0:this.options.options.length == 0 ? 'No' : this.options.options.length,
                1:this.options.options.length == 1 ? '' : 's'
                })
            );
        } else 
            this.options.optionsStatus.update(message);
            
    },
    UpdateHeight: function(count){
        var height = (count >= 8 ? 8 * 30 : count * 30) + 'px';
        this.options.holder.setStyle({'height':height});
        //new Effect.Morph(this.options.holder, {style: 'height:' + height, duration: .3});
    },
    SelectPrev: function(){
        this.options.currentSelection--;
        if (this.options.currentSelection < 0)
            this.options.currentSelection = 0;
        var divs = this.options.holder.select('div.us_option');
        this.RemoveSelection();
        
        divs[this.options.currentSelection].addClassName('us_option_selected');
        this.options.textbox.focus();
    },
    SelectNext: function(){
        this.options.currentSelection++;
        if (this.options.currentSelection > this.options.options.length -1)
            this.options.currentSelection = this.options.options.length - 1;
        var divs = this.options.holder.select('div.us_option');
        this.RemoveSelection();
        
        if (divs.length > 0)
            divs[this.options.currentSelection].addClassName('us_option_selected');
        this.options.textbox.focus();
    },
    Select: function(vars){
        if (this.options.onSelect)
            this.options.onSelect(this.options.currentSelection);
        this.options.options[this.options.currentSelection].onClick();
        //this.Hide();
    },
    Hide: function(){
    
    if (this.options.optionsHolder.visible())
        new Effect.Fade(this.options.optionsHolder, { 
        duration:0.2, 
        queue: 
            { 
            position: 'end',
            scope: 'autocomplete',
            limit: 1 
            } 
        }); 
       
        this.options.currentSelection = -1;
//        this.options.to = setTimeout(function(){        
//            if (this.options.optionsHolder.visible())
//                    this.options.optionsHolder.hide();
//                //new Effect.toggle(this.options.optionsHolder, 'blind', {duration: .3});
//            }.bind(this), 500);
    },
    Show: function(){
        var pos = this.options.textbox.cumulativeOffset();
        
        this.options.optionsHolder.setStyle({
            top: (pos.top + this.options.textbox.getHeight()) + 'px',
            left: pos.left + 'px',
            width: this.options.textbox.getWidth() - 2 + 'px',
            display: 'block',
            position: 'absolute',
            zIndex: '1000'
        });
    },
    MakeOption: function(u){
        var div = new Element('div', {'class':'us_option'});
        div.className = 'us_option';
        div.update(u.username);
        return div;
    },
    BindData: function(s){
	
        this.options.holder.update('');
        this.options.options = new Array();
        this.options.currentSelection = -1;
        tmp_counter = 0;
        $(this.users).each(function(u){
		    if(tmp_counter > this.options.maxResults)
		        return;
            var div = this.MakeOption(u);
           
            var option = {
                obj: div,
                value: u.username,
                userInfo: u,
                onClick: function(){
                this.options.textbox.value = "#{0}; #{1} ; ".interpolate({
                        0:this.options.textbox.value.substring(0, this.options.textbox.value.lastIndexOf(';')),
                        1:option.userInfo.username
                    }).replace(new RegExp('^(; |\n)', 'i'), '');
                    this.options.textbox.focus();
                    this.options.currentSelection = -1;
                    this.options.options = new Array();
                   this.SelectedUser = option.userInfo;
                   this.Hide();
                }.bind(this)
               
            }
            
            this.options.options.push(option);
            Event.observe(div, 'click', option.onClick.bind(this));
            Event.observe(div, 'mouseout', function(){
                this.RemoveSelection();
                this.options.currentSelection = -1;
            }.bind(this));
            $(this.options.holder).appendChild(div);
                
            tmp_counter++;
        }.bind(this));
            if(this.options.options.length > 0){
                this.options.currentSelection = -1;
                this.SelectNext(); 
                this.Show();
            }else{
                //Using this instead of Hide() because it looks crisper
                this.options.optionsHolder.hide();
            }
    },
    RemoveSelection: function(){
        this.options.holder.select('div.us_option_selected').each(function(div){
            div.removeClassName('us_option_selected');
        }.bind(this));
    },
    GetUsers: function(string){
        if (this.options.sending || string.length < 3 || this.options.lastSearch == string) return;
        
        if(/^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}$/.test(string))
        {
            this.Hide();
            return;
        }
        
        this.options.sending = true;
        this.users = null;
        this.options.lastSearch = string;
        
        new Ajax.Request('/ajax/?a=User_SearchUsers', {
            method: 'post',
            parameters: {key: string},
            requestHeaders: {Accept: 'application/json'},
            onSuccess: function(t){
                try{
                    this.users = t.responseText.evalJSON(false).root;
                    var _users = this.users;
                    if(this.users != null)
                        this.BindData(string);
                }catch(err){
                    this.Hide();
                }				
            }.bind(this),
            onComplete: function(t){
                this.options.sending = false;
				this.HideStatus();
            }.bind(this)
        });
    }
});
UserSearch.MODE = {
    SINGLE: 0,
    MULTI: 1
}
