

// AjaxRequest Class
//   :: Purpose: provides a simple way to handle an Ajax request. Updates AjaxData to add error handling through the Modal Box
//   :: Date: 
//   :: Required Files:
//         js.frameworks.prototype.*
//         js.application.controls.Browser
//         js.application.controls.Modal

var AjaxRequest = Class.create({
	
	// this.url
	
	initialize: function(url,callback,postHash){
		
		if(postHash){
			this.callPostAjax(url,callback,postHash);
		}else{
			this.setPoststring(url);
			this.callGetAjax(callback);
		}
		
	},
	
	callGetAjax: function(callback) {
		
		var errorHandler = this.showError.bind(this);
		
		new Ajax.Request(this.url,{
				method:'get',
				onSuccess:function(transport){
					
					try {
						
						var jsonObj = transport.responseText.evalJSON();
						
						if (jsonObj.ERROR) {
							
							errorHandler(jsonObj);
							
						} else {
							if(callback)callback(jsonObj);
						}
					 
					} catch(err) { 
						
						errorHandler(err);
					}
					
				},
				onFailure:function(transport){ 
					errorHandler(transport);
				}
			});
		
	},
	
	callPostAjax: function(url,callback,postHash) {
		
		var errorHandler = this.showError.bind(this);
		
		new Ajax.Request(url,{
				method:'post',
				parameters:postHash,
				onSuccess:function(transport){
					
					try{
						var jsonObj = transport.responseText.evalJSON();
						
						if (jsonObj.ERROR) {
							
							errorHandler(jsonObj);
							
						} else {
							if(callback)callback(jsonObj);
						}
						 
					} catch(err) { 
						errorHandler(err);
					};
		
				},
				onFailure:function(transport){ 
					errorHandler(transport);
				}
			});
		
	},
	
	showError: function(err) {
		
		if(err.DEBUG && err.DEBUG == true){
			
			var errDisplay = new Element('div');
			errDisplay.insert(err.MESSAGE);
			errDisplay.insert(new Element('br'));
			errDisplay.insert(err.CLASS);
			errDisplay.insert(new Element('br'));
			errDisplay.insert(err.LINE);
			
			new Modal.Alert(errDisplay).openBox();
			
		} else {
			
			if(err.MESSAGE){
			
				new Modal.Alert(err.MESSAGE).openBox();
			
			} else if(err.message){
				
				new Modal.Alert(err.message).openBox();
			
			} else if(err.status){
			
				new Modal.Alert(err.status).openBox();
				
			} else {
				
				new Modal.Alert('Unknown Error').openBox();
				
			}
			
		}
		
		
		
	},
	
	setPoststring: function(url) {
			
		this.url = url+'&requestId='+this.getRandom();
		
	},
		
	getRandom: function() {
			
		return Math.floor(Math.random()*1000000);
		
	}

});

// AjaxData Class
//   :: Purpose: provides a simple way to handle an Ajax request
//   :: Date: 
//   :: Required Files:
//         js.frameworks.prototype.*

function AjaxData() {
	
	this.url;
	
	AjaxData.prototype.init = function(url,callback,postHash) {
		
		// Constructor Function
		
		if(postHash){
			this.callPostAjax(url,callback,postHash);
		}else{
			this.setPoststring(url);
			this.callGetAjax(callback);
		}
		
	}
	
	AjaxData.prototype.callGetAjax = function(callback) {
		
		new Ajax.Request(this.url,{
				method:'get',
				onSuccess:function(transport){
					try{
						 var jsonObj = transport.responseText.evalJSON();
					} catch(err) { alert(err.message) /*window.location.reload()*/ };
					if(callback) {
						try{
							if(callback)callback(jsonObj);
						} catch(err) { alert(err.message) };
					}
		
				},
				onFailure:function(transport){ 
					alert('error! '+transport.status);
				}
			});
		
	}
	
	AjaxData.prototype.callPostAjax = function(url,callback,postHash) {
		
		new Ajax.Request(url,{
				method:'post',
				parameters:postHash,
				onSuccess:function(transport){
					try{
						 var jsonObj = transport.responseText.evalJSON();
					} catch(err) { alert(err.message) /*window.location.reload()*/ };
					if(callback) {
						try{
							if(callback)callback(jsonObj);
						} catch(err) { alert(err.message) };
					}
		
				},
				onFailure:function(transport){ 
					alert('error! '+transport.status);
				}
			});
		
	}
	
	AjaxData.prototype.setPoststring = function(url) {
			
		this.url = url+'&requestId='+this.getRandom();
		
	}
		
	AjaxData.prototype.getRandom = function() {
			
		return Math.floor(Math.random()*1000000);
		
	}

}

var Loader = Class.create({
	
	// Constructor
	initialize: function(parent){
		
		this.parent = $(parent);
		
		this.setElement();
		
	},

//** Public Methods **//
	open: function(){
		
		try{
			
			this.setDimensions();
			
			this.setOffset();
			
			this.parent.appendChild(this.element);
			
		}catch(err){ alert(err.toString()); }
		
	},
	
	close: function(){
		
		try{
			this.element.remove();
		}catch(err){ /* Nothing to remove */ }
		
	},
	
	reset: function(){
		
		this.close();
		
		this.open();
		
	},
	
//** Private Methods **//
	setDimensions: function(){
		
		this.dimensions = this.parent.getDimensions();
		
		this.element.setStyle({
							  'height': this.dimensions.height + 'px',
							  'width':this.dimensions.width + 'px'
							  });
		
	},

	setElement: function(){
		
		this.element = new Element('div',{'class':'box_loader'});
		
		this.element.appendChild(this.loaderImage = new Element('div',{'class':'box_loader_image_wrapper'}));
		
		this.loaderImage.appendChild(new Element('div',{'class':'box_loader_image'}).update('Loading. Please Wait...'));
	
	},
	
	setOffset: function(){
		
		this.offset = this.parent.positionedOffset();
		
		this.element.setStyle({
							  'top':this.offset.top + 'px',
							  'left':this.offset.left + 'px'
							  });
		
		var offsetTop = ((this.dimensions.height*.3) > 75)?50:this.dimensions.height*.3;
		
		this.loaderImage.setStyle({
								  'top':offsetTop + 'px',
								  'left':((this.dimensions.width/2)-120) + 'px'
								  });
		
	}

});

/*var Loader = Class.create({					  
	initialize: function(parentId){
		
		var parentEl = $(parentId);
		var parentSize = parentEl.getDimensions();
		parentEl._originalHeight = parentSize.height+'px';
		parentEl._originalWidth = parentSize.width+'px';
		parentEl.relativize();
		this.element = this.createLoader(parentSize);
		parentEl.insert({top:this.element});
		
	},
	// Public Methods
	showIt: function(){
		
		this.element.style.display = 'block';
		
	},
	hideIt: function(){
		
		this.element.style.display = 'none';
		
	},
	// Private Methods
	createLoader: function(size){
		
		var frag = new Element('div',{'class':'box-loader','style':'position:absolute;top:0;left:0;display:none;'});
		var loaderBoxFrag = new Element('div',{'class':'box-loader-image','style':'height:'+size.height+'px;width:'+size.width+'px'});
		frag.appendChild(loaderBoxFrag);
		return frag;
		
	}
});*/

// HoverBox Class
//   :: Purpose: provides a hover box that displays pre-formatted data
//   :: Date: 
//   :: Required Files:
//         js.frameworks.prototype.*

function HoverBox() {
	
	this.boxId;
	this.landingDiv;
	this.boxdata;
	this.top;
	this.left;
	
	HoverBox.prototype.init = function(event,id,data) {
			
		this.boxId = id;
		this.boxdata = data;
		this.setLandingDiv(event);
		this.positionBox(event);
		this.addToDom(this.createBoxHtml());
		this.createDraggable();
		
	}
	
	HoverBox.prototype.createDraggable = function() {
		
		new Draggable(
			this.boxId,
				{ 	handle:'hd',
					constraint:'',
					snap: false,
					revert: false,
					ghosting: false,
					mode:'absolute'
				}
			);

	}
	
	HoverBox.prototype.setLandingDiv = function(event) {
		
		this.landingDiv = event.element().up('.geo_data').id;
		
	}
	
	HoverBox.prototype.getParent = function() {
		
		return '.popup';
		
	}
	
	HoverBox.prototype.positionBox = function(event) {
		
		var parentElement = event.findElement(this.getParent());
		
		var boxSize = parentElement.getDimensions();
		var viewportPosition = parentElement.viewportOffset();
		
		var parentXMid = viewportPosition.left + boxSize.width/2;
		var parentYMid = viewportPosition.top + boxSize.height/2;
		
		if(event.pointerX() < parentXMid) {
			// mouse is to the left of the box midpoint
			this.left = boxSize.width-250;
		} else {
			// mouse is to the right of the box midpoint
			this.left = 20;
		}
		
		this.top = 100;
		
		/*
		if(event.pointerY() < parentYMid) {
			// mouse is above the box midpoint
			this.top = boxSize.height-200;
		} else {
			// mouse is below the box midpoint
			this.top = 50;
		}*/
		
		
	}
	
	HoverBox.prototype.addToDom = function(box) {
		
		box.style.top = this.top+'px';
		box.style.left = this.left+'px';
		
		$(this.landingDiv).appendChild(box);
		
		
	}
	
	HoverBox.prototype.createBoxHtml = function() {
		
		/*
		<div class="hoverbox">
			<div class="hoverbox-wrapper">
				<div class="tr">&nbsp;</div>
				<div class="tl">&nbsp;</div>
				<div class="hd">
					Title
				</div>
				<div class="ml">
					<div class="mr">
						Content
						<div class="bl">&nbsp;</div>
						<div class="br">&nbsp;</div>
					</div>
				</div>
			</div>
		</div>
		*/
		
		var box = new Element('div',{'class':'hoverbox','id':this.boxId});
		var boxWrapper = new Element('div',{'class':'hoverbox-wrapper'});
		
		// corners
		var tr = new Element('div',{'class':'tr'}).update('\u00a0\u00a0\u00a0\u00a0\u00a0');
		var tl = new Element('div',{'class':'tl'}).update('\u00a0\u00a0\u00a0\u00a0\u00a0');
		var br = new Element('div',{'class':'br'}).update('\u00a0\u00a0\u00a0\u00a0\u00a0');
		var bl = new Element('div',{'class':'bl'}).update('\u00a0\u00a0\u00a0\u00a0\u00a0');
		
		// header
		var hd = new Element('div',{'class':'hd'}).update(this.getBoxTitle());
		hd.style.cursor = 'move';
		
		// body
		var ml = new Element('div',{'class':'ml'});
		var mr = new Element('div',{'class':'mr'});
		var content = new Element('div',{'class':'hoverbox-content'});
		
		content.appendChild(this.getBoxContent());
		mr.appendChild(content);
		mr.appendChild(bl);
		mr.appendChild(br);
		ml.appendChild(mr);
		
		boxWrapper.appendChild(tr);
		boxWrapper.appendChild(tl);
		boxWrapper.appendChild(hd);
		boxWrapper.appendChild(ml);
		
		box.appendChild(boxWrapper);
		
		return box;
	}
	
	HoverBox.prototype.getBoxTitle = function() {
		
		return 'Box Title';
		
	}
	
	HoverBox.prototype.getBoxContent = function() {
		
		return 'Box Content';
		
	}
	
}

// DataTable Class
//   :: Purpose: a table that displays pre-formatted data in a scrollable format
//   :: Date: 
//   :: Required Files:
//         js.frameworks.prototype.*

function DataTable() {

	this.width;
	this.height = 400;
	this.tableWidth;
	this.columnData;
	/* this.columnData is an Array of objects with attributes:
		name
		header
		width
		align  */
	
	DataTable.prototype.init = function(data,columnData,parent,width) {
		try{
			this.setWidth(width);
			this.columnData = columnData;
			
			$(parent).appendChild(this.formatData(data));
		} catch(err) {
			alert('DataTable: '+err.message);
		}
		
	}
	
	DataTable.prototype.setWidth = function(width) {
		
		var tempwidth = new Number(width);
		
		if(tempwidth == 'NaN'){
			throw 'width is not a number';
		} else {
			this.width = tempwidth.valueOf();
			this.tableWidth = this.width-15;
		}
	}
	
	DataTable.prototype.formatData = function(r) {
		
		var returnFrag = document.createDocumentFragment();
		
		if (r.recordcount == 0) {
			
			var noData = new Element('p').update('No data available.');
			
			returnFrag.appendChild(noData);
			
		} else {
			
			returnFrag.appendChild(this.formatHeader());
			
			returnFrag.appendChild(this.formatBody(r));
			
		}
		
		return returnFrag;
		
	}

	DataTable.prototype.formatHeader = function() {

		var table = new Element('table',{'width':'auto','cellpadding':'0','cellspacing':'0','border':'0'});
		table.style.padding = '0px 15px 0px 0px';
		var tbody = new Element('tbody');
		
		var headerRow = new Element('tr');
		
		for(var i=0;i<this.columnData.length;i++){
			
			if(i == this.columnData.length-1) {
				// last column
				//var tdWidth = new Number(this.columnData[i].width).valueOf() + 20;
				var thEl = new Element('th',{'width':this.columnData[i].width,'align':this.columnData[i].align}).update(this.columnData[i].header);
				thEl.style.padding = '0px 20px 0px 0px';
			} else {
			
				var thEl = new Element('th',{'width':this.columnData[i].width,'align':this.columnData[i].align}).update(this.columnData[i].header);
			}
			
			headerRow.appendChild(thEl);
			
			
		}
		tbody.appendChild(headerRow);
		table.appendChild(tbody);
		
		return table;
		
	}
	
	DataTable.prototype.formatBody = function(r) {
		
		if(r.recordcount > 10){
		
			var bodyHolder = new Element('div',{'style':'overflow:auto;overflow-x:hidden'});
			bodyHolder.style.height = this.height+'px';
			bodyHolder.style.width = this.width+'px';
			
			bodyHolder.appendChild(this.formatRows(r));
			
			return bodyHolder;
			
		} else {
			
			return this.formatRows(r);
			
		}
	}
	
	DataTable.prototype.formatRows = function(r) {
		/*		
		The last cell in each row needs padding-right = 20px and width = width + 20px (to compensate the padding).
		Also, the container div needs overflow-x: hidden (hides horizontal scroll)
		*/
		var table = new Element('table',{'width':this.tableWidth,'cellpadding':'0','cellspacing':'0','border':'0'});
		var tbody = new Element('tbody');			
		var i;
		
		for(i=0;i<r.recordcount;i++){
			
			var dataRow = new Element('tr',{'class':this.getRowClass(i+1)});
			var t;
			var z = this.columnData.length;
			for(t=0;t<z;t++){
				
				var colName = this.columnData[t].name;
				var colValue = eval('r.data.'+colName+'[i]');
				var colType;
				if(!this.columnData[t].type) { colType = 'num' } else { colType = this.columnData[t].type };
				
				if(t == z-1) {
					// last column
					var tdWidth = new Number(this.columnData[t].width).valueOf() + 20;
					var tdEl = new Element('td',{'width':tdWidth,'align':this.columnData[t].align});
					tdEl.style.padding = '0px 20px 0px 0px';
				} else {
				
					var tdEl = new Element('td',{'width':this.columnData[t].width,'align':this.columnData[t].align});
					
				}
				
				if(this.columnData[t].secondary) { 
					
					var colSecond = this.columnData[t].secondary;
					var secValue = eval('r.data.'+colSecond+'[i]');
					var valueOutput = this.formatColumn(colValue,colType,secValue);
					
				} else {
					
					var valueOutput = this.formatColumn(colValue,colType);
					
				}
				
				dataRow.appendChild(tdEl.update(valueOutput));
				
			}
			
			tbody.appendChild(dataRow);
		}
		
		table.appendChild(tbody);
		
		return table;
	}
	
	DataTable.prototype.formatColumn = function(value,type,secondary){
		
		if(type == 'num') {
		
			return this.formatNum(value);
			
		} else if(type == 'date') {
			
			return this.formatDate(value);
			
		} else if(type == 'percent') {
			
			return this.formatPercent(value);
		
		} else if(type == 'weight') {
			
			return this.formatWeight(value);
			
		} else if(type == 'decimal') {
			
			return this.formatDecimal(value);
			
		} else {
			
			return value;
			
		}
		
	}
	
	DataTable.prototype.formatNum = function(value){
		
		var tempnum = new Number(value);
		
		if(tempnum == 'NaN'){
			return value;
		} else {
			return addCommas(value);
		}
		
	}
	
	DataTable.prototype.formatDecimal = function(value,digits){
		
		if(!digits){ digits = 1 };
		
		var tempnum = new Number(value);
		
		if(tempnum == 'NaN'){
			return value;
		} else {
			tempnum.toFixed(digits);
		}
		
		tempstr = new String(tempnum);
		
		x = tempstr.split('.');
		
		if(!x[1]){ x[1] = '' };
		
		if(x[1].length != digits){ 
			var loopLen = digits - x[1].length;
			var q;
			for(q=0;q<loopLen;q++){
				
				x[1] = x[1]+'0';
				
			}
			
		};
		
		return addCommas(x[0]+'.'+x[1]);
		
	}
	
	DataTable.prototype.formatPercent = function(value){
		
		return addCommas(value)+' %';
		
	}
	
	DataTable.prototype.formatWeight = function(value){
		
		return addCommas(value)+' lbs.';
		
	}
	
	DataTable.prototype.formatDate = function(value){
		
		var dateString;
		
		if(value.search('00:00:00') != -1){
			dateString = convertJsonDate(value).format('m/d/yyyy');
		} else {
			dateString = convertJsonDate(value).format('m/d/yyyy')+' '+convertJsonDate(value).format('shortTime');
		};
		
		return dateString;
		
	}
	
	DataTable.prototype.getRowClass = function(rowNum){
		
		if(rowNum % 2 == 1){ return '' } else { return 'alt'};
		
	}
	
}



/*
	Date Format 1.1
	(c) 2007 Steven Levithan <stevenlevithan.com>
	MIT license
	With code by Scott Trenda (Z and o flags, and enhanced brevity)
*/

/*** dateFormat
	Accepts a date, a mask, or a date and a mask.
	Returns a formatted version of the given date.
	The date defaults to the current date/time.
	The mask defaults ``"ddd mmm d yyyy HH:MM:ss"``.
*/
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);
}


function convertJsonDate(str) {
	
	// input format: 2008-09-17 00:00:00.0
	var finalDate = new Date();
	var dateString = str.substr(0,10);
	var timeString = str.substr(11,8);
	
	dateString = dateString.split('-');
	timeString = timeString.split(':');
	
	if(dateString.length != 3 && timeString.length != 3) { throw 'Not a JSON formatted date' };
	
	finalDate.setYear(dateString[0]);
	finalDate.setMonth(dateString[1]-1);
	finalDate.setDate(dateString[2]);
	
	finalDate.setHours(timeString[0]);
	finalDate.setMinutes(timeString[1]);
	finalDate.setSeconds(timeString[2]);
	
	//alert('date: '+finalDate);
	
	return finalDate;
}


function addCommas(nStr)
{
	nStr += '';
	x = nStr.split('.');
	x1 = x[0];
	x2 = x.length > 1 ? '.' + x[1] : '';
	var rgx = /(\d+)(\d{3})/;
	while (rgx.test(x1)) {
		x1 = x1.replace(rgx, '$1' + ',' + '$2');
	}
	return x1 + x2;
}

function expand(thisId) {
	var test;
	test = document.getElementById(thisId).style;
	
	if (test.display == "none"){
		test.display = "block";
	}	
	else
	{
		test.display = "none";	
	}
	
	return;
}

function checkUncheckAll(theElement) {
	var theForm = theElement.form, z = 0;
	
	for(z=0; z<theForm.length;z++){
		if(theForm[z].type == 'checkbox' && theForm[z].name != 'checkall'){
			theForm[z].checked = theElement.checked;
		}
	}
}

function getViewportDimensions() {
    var intH = 0, intW = 0;
    
    if(self.innerHeight) {
       intH = window.innerHeight;
       intW = window.innerWidth;
    } 
    else {
        if(document.documentElement && document.documentElement.clientHeight) {
            intH = document.documentElement.clientHeight;
            intW = document.documentElement.clientWidth;
        }
        else {
            if(document.body) {
                intH = document.body.clientHeight;
                intW = document.body.clientWidth;
            }
        }
    }

    return {
        height: parseInt(intH, 10),
        width: parseInt(intW, 10)
    };
}

function rand( min, max ) {
    var argc = arguments.length;
    if (argc == 0) {
        min = 0;
        max = 2147483647;
    } else if (argc == 1) {
        throw new Error('Warning: rand() expects exactly 2 parameters, 1 given');
    }
    return Math.floor(Math.random() * (max - min + 1)) + min;
}

function getCheckedValue(radioObj) {

	var radioLength = radioObj.length;
	var radioValue;
	
	for(var i = 0; i < radioLength; i++) {
		if(radioObj[i].checked == true) {
			radioValue = radioObj[i].value;
		}
	}
	
	return radioValue;

}