_ayt_vldtr = function ()
{
	_ayt_vldtr.OnLoad();
}

_ayt_vldtr.getElementsByAttr = function(attr, frm, tag)
{

	var all = document.getElementById(frm).getElementsByTagName(tag);
	var elements = [];
	
	for(var i = 0; i < all.length; i++)
	{
		if(all[i].getAttribute(attr))elements.push(all[i]);
	}
	
	return elements;
}

_ayt_vldtr.getFormsByAttr = function(attr)
{

	var all = document.getElementsByTagName('form');
	var elements = [];
	
	for(var i = 0; i < all.length; i++)
	{
		if(all[i].getAttribute(attr))elements.push(all[i]);
	}
	
	return elements;
}

_ayt_vldtr.init = function ()
{	
	var elem = _ayt_vldtr.getFormsByAttr('id');
	
	var tag_elem = new Array('input', 'select', 'textarea');
	
	var item_elem_arr = new Array();
	
	for(var x = 0; x < elem.length; x++)
	{
		//Extraemos Cada Formulario
		for (c = 0; c < tag_elem.length; c++)
		{
			item_elem = _ayt_vldtr.getElementsByAttr('id', elem[x].id , tag_elem[c]);
			
			_ayt_vldtr.AddOnSubmit(elem[x].id);

			for(y = 0; y < item_elem.length; y++)
			{						
				if(item_elem[y].className)
				{
					var classItem = item_elem[y].className;
	
					if(classItem.match(/\[(.*?)\]/g))
					{
						var matches = classItem.match(/(.*?)\[/g);				
						
						for (n=0; n<matches.length; n++)
						{
							_ayt_vldtr_form_fnc = matches[0].substring(0, matches[0].length-1);
						}
					}
					
					if(classItem.match(/\[(.*?)\]/g))
					{
						var matches = classItem.match(/\[(.*?)\]/g);
						
						for (n=0; n < matches.length; n++)
						{
							_ayt_vldtr_form_msg = matches[0].substring(2, matches[0].length-2);
						}
					}
					
					if ( (typeof _ayt_vldtr_form_fnc != "undefined") && (typeof _ayt_vldtr_form_msg != "undefined") )
					{
						_ayt_vldtr.AddHandlers(item_elem[y].id, _ayt_vldtr_form_fnc, _ayt_vldtr_form_msg, 0);
						
						delete _ayt_vldtr_form_fnc; 
						delete _ayt_vldtr_form_msg; 	
					}
				}
			}			
			
			delete item_elem; 
		}
	}
	
	delete elem; 
}

_ayt_vldtr.onSubmit = function (frm)
{	
	var tag_elem = new Array('input', 'select', 'textarea');
	
	var item_elem_arr = new Array();
	
	//Extraemos Cada Formulario
	for (c = 0; c < tag_elem.length; c++)
	{
		item_elem = _ayt_vldtr.getElementsByAttr('id', frm , tag_elem[c]);
			
		_ayt_vldtr.AddOnSubmit(frm);

		for(y = 0; y < item_elem.length; y++)
		{						
			if(item_elem[y].className)
			{
				var classItem = item_elem[y].className;
	
				if(classItem.match(/\[(.*?)\]/g))
				{
					var matches = classItem.match(/(.*?)\[/g);				
				
					for (n=0; n<matches.length; n++)
					{
						_ayt_vldtr_form_fnc = matches[0].substring(0, matches[0].length-1);
					}
				}
				
				if(classItem.match(/\[(.*?)\]/g))
				{
					var matches = classItem.match(/\[(.*?)\]/g);
						
					for (n=0; n < matches.length; n++)
					{
						_ayt_vldtr_form_msg = matches[0].substring(2, matches[0].length-2);
					}
				}
				
				if ( (typeof _ayt_vldtr_form_fnc != "undefined") && (typeof _ayt_vldtr_form_msg != "undefined") )
				{
					switch (_ayt_vldtr_form_fnc)
					{
						case "emptyCheck":
							
							state = _ayt_vldtr.emptyCheck(item_elem[y].id, _ayt_vldtr_form_msg, 1);
						
							if (state == false)
							{
								return state;
							}
							
						break;
					}
						
					delete _ayt_vldtr_form_fnc; 
					delete _ayt_vldtr_form_msg; 	
				}
			}
		}			
			
		delete item_elem; 
	}
	
	return state;
}

_ayt_vldtr.AddHandlers  = function (id, fnc, msg, mode)
{
	document.getElementById(id).onchange = function ()
	{
		_ayt_vldtr.emptyCheck(id, msg, mode);
	}
}

_ayt_vldtr.OnLoad  = function ()
{
	window.onload = function ()
	{
		_ayt_vldtr.init();
	}
}

_ayt_vldtr.AddOnSubmit = function (id)
{
	document.getElementById(id).onsubmit = function ()
	{
		return _ayt_vldtr.onSubmit(id);
	}
}


_ayt_vldtr.emptyCheck = function (id, msg, mode)
{
	if ((document.getElementById(id).value == "") || (document.getElementById(id).value==null))
	{
		if(mode==1)
		{
			alert(msg);
			document.getElementById(id).focus();
			document.getElementById(id).style.background  = "#fcdbde";
			return false;
		}
				
		document.getElementById(id).focus();
		document.getElementById(id).style.background  = "#fcdbde";
		return false;
	}
	else
	{
		var expanded = document.getElementById(id).style.background = "#FFFFFF";
		if(mode==1)
		{
		}
		else
		{
			return false;
		}
	}
}


_ayt_vldtr.emailCheck = function (id, msg, mode)
{
	if ((document.getElementById(id).value == "") || (document.getElementById(id).value==null))
	{
		if(mode==1)
		{
			alert(msg);
			document.getElementById(id).focus();
			document.getElementById(id).style.background  = "#fcdbde";
			return false;
		}
				
		document.getElementById(id).focus();
		document.getElementById(id).style.background  = "#fcdbde";
		return false;
	}
	else
	{
		var expanded = document.getElementById(id).style.background = "#FFFFFF";
		if(mode==1)
		{
		}
		else
		{
			return false;
		}
	}
}





_ayt_vldtr();// ===================================================================
// GLOBAL STUFF - Init global data class
// ===================================================================
function ayt_grid_global_data ()
{
	this.grid_arr = new Array ();
	this.sort_field = 0;
	this.sort_inverted = 0;
}

// ===================================================================
// PUBLIC FUNCTIONS
// ===================================================================
function aytgrid_get_grid ( id ) 
{
	return _ayt_grid_global_data.grid_arr [ id ];
}

function aytgrid_set_cell_value ( full_id, val )
{
	var v = full_id.split ( ":" );
        var g = aytgrid_get_grid ( v [ 0 ] );
	if ( ! g ) return 0
        var r = g.get_row ( v [ 2 ] );

        r [ v [ 1 ] ] = val;

	return g
}

var _ayt_grid_global_data = new ayt_grid_global_data ();
var _aytg_resize_cell;
var _aytg_resize_start_x = -1;

// Flag T/F to know if the current browser is the almighty bugged Internet Exploder.
var _aytg_is_ie = ( document.all != null );

// ===================================================================
// Grid Resize Functions
// ===================================================================
function grid_resize_cell_down ( id )
{
	_aytg_resize_cell = document.getElementById ( id );

	document.onmousemove = grid_resize_callback;
	if ( ! _aytg_is_ie ) 
	{
		document.captureEvents(Event.MOUSEMOVE);
	} else {
		while ( ! _aytg_resize_cell )
		{
			_aytg_resize_cell = document.getElementById ( id );
			if ( confirm ( "The buggy Internet Explorer cannot get the ID: " + id + ". Try again?\nBTW: You should really consider to switch to Mozilla Firefox (www.getfirefox.com)" ) == false ) break;
		}
	}
}

function grid_resize_cell_up ()
{
	if ( ! _aytg_resize_cell ) return;

	document.onmousemove = null;

	// later
	if ( ! _aytg_is_ie )
	{
		document.releaseEvents(Event.MOUSEMOVE);
	}

	if ( _aytg_resize_cell.old_className ) _aytg_resize_cell.className = _aytg_resize_cell.old_className;
	_aytg_resize_start_x = -1;

	// Save the new column width inside _column_width array;
	var res = _aytg_resize_cell.id.split ( "_th" );
	var name = res [ 0 ];
	var num  = res [ 1 ];

	var grid = _ayt_grid_global_data.grid_arr [ name ];
	var attrs = grid.get_col_attrs ( num );

	attrs [ "ayt_width" ] = _aytg_resize_cell.width;

	_aytg_resize_cell = null;
}

function grid_resize_callback ( e )
{
	var cur_x, cur_y;

	if ( ( ! _aytg_is_ie ) && ( e.pageX ) )
		cur_x = e.pageX;
	else 
		cur_x = event.x;

	if ( _aytg_resize_start_x == -1 ) 
	{
		_aytg_resize_start_x = 1;
		_aytg_resize_start_x = cur_x - _aytg_resize_cell.offsetWidth;
	}

	if ( cur_x <= _aytg_resize_start_x ) cur_x = _aytg_resize_start_x +1;

	_aytg_resize_cell.width = ( cur_x - _aytg_resize_start_x );
}

// ===================================================================
// FUNCIONES AYTGrid Cálculos
// ===================================================================
function _aytg_calc_fac_total(sumBI, sumIMP, dataBind, typeBind)
{
	sum = 0;			
	sum = parseFloat(sumBI) + parseFloat(sumIMP);
						
	switch (typeBind)
	{
		case 'innerHTML':
			document.getElementById(dataBind).innerHTML = sum;
		break;

		case 'value':
			document.getElementById(dataBind).value = sum;
		break;	
				
		case 'return':
			return sum;
		break;				
	}
}


function _aytg_calc_fac_sub_total(aytg_id, colSum, colCant, colST, renderFC)
{
	result = 0;
	colSumValue = 0;
	colCantValue = 0;

	for (i=0;i<aytg_id.rows.length;i++)
	{
		if(document.getElementById("rDG"+aytg_id.id+":"+colSum+":"+i)==false)
		{
			colSumValue  = document.getElementById(aytg_id.id+":"+colSum+":"+i).innerHTML;
			colCantValue = document.getElementById(aytg_id.id+":"+colCant+":"+i).innerHTML;
					
			result =  (parseFloat(colSumValue) * parseFloat(colCantValue));
					
			colSumValue = 0;
			colCantValue = 0;
			
			document.getElementById(aytg_id.id+":"+colST+":"+i).innerHTML = renderFC(result, aytg_id.id+':'+colST+':'+i);
		}
		else
		{
			colSumValue  = document.getElementById("rDG:"+aytg_id.id+":"+colSum+":"+i).innerHTML;
			colCantValue = document.getElementById(aytg_id.id+":"+colCant+":"+i).innerHTML;
					
			result =  (parseFloat(colSumValue) * parseFloat(colCantValue));
					
			colSumValue = 0;
			colCantValue = 0;
					
			document.getElementById(aytg_id.id+":"+colST+":"+i).innerHTML = renderFC(result, aytg_id.id+':'+colST+':'+i);
		}
	}			
}

function _aytg_calc_fac_imp(aytg_id, colSum, colCant, colIMP, dataBind, typeBind)
{
	sum = 0;
	colSumValue = 0;
	colCantValue = 0;
	colIMPValue = 0;

	for (i=0;i<aytg_id.rows.length;i++)
	{
		if(document.getElementById("rDG"+aytg_id.id+":"+colSum+":"+i)==false)
		{
			colSumValue  = document.getElementById(aytg_id.id+":"+colSum+":"+i).innerHTML;
			colCantValue = document.getElementById(aytg_id.id+":"+colCant+":"+i).innerHTML;
			colIMPValue = document.getElementById(aytg_id.id+":"+colIMP+":"+i).innerHTML;
					
			sum = sum+ ((parseFloat(colIMPValue)/100)*(parseFloat(colSumValue) * parseFloat(colCantValue)));
					
			colSumValue = 0;
			colCantValue = 0;
			colIMPValue = 0;
		}
		else
		{
			colSumValue  = document.getElementById("rDG:"+aytg_id.id+":"+colSum+":"+i).innerHTML;
			colCantValue = document.getElementById(aytg_id.id+":"+colCant+":"+i).innerHTML;
			colIMPValue  = document.getElementById("rDG:"+aytg_id.id+":"+colIMP+":"+i).innerHTML;
			sum = sum+ ((parseFloat(colIMPValue)/100)*(parseFloat(colSumValue) * parseFloat(colCantValue)));
					
			colSumValue = 0;
			colCantValue = 0;
			colIMPValue = 0;
		}
	}
			
	switch (typeBind)
	{
		case 'innerHTML':
			document.getElementById(dataBind).innerHTML = sum;
		break;

		case 'value':
			document.getElementById(dataBind).value = sum;
		break;	
				
		case 'return':
			return sum;
		break;				
	}		
}

function _aytg_calc_fac_tax_base(aytg_id, colSum, colCant, dataBind, typeBind)
{
	sum = 0;
	colSumValue = 0;
	colCantValue = 0;
	
	for (i=0;i<aytg_id.rows.length;i++)
	{
		if(document.getElementById("rDG"+aytg_id.id+":"+colSum+":"+i)==false)
		{
			colSumValue  = document.getElementById(aytg_id.id+":"+colSum+":"+i).innerHTML;
			colCantValue = document.getElementById(aytg_id.id+":"+colCant+":"+i).innerHTML;
					
			sum = sum+ (parseFloat(colSumValue) * parseFloat(colCantValue));
					
			colSumValue = 0;
			colCantValue = 0;
		}
		else
		{
			colSumValue  = document.getElementById("rDG:"+aytg_id.id+":"+colSum+":"+i).innerHTML;
			colCantValue = document.getElementById(aytg_id.id+":"+colCant+":"+i).innerHTML;
					
			sum = sum+ (parseFloat(colSumValue) * parseFloat(colCantValue));
					
			colSumValue = 0;
			colCantValue = 0;
		}
	}
			
	switch (typeBind)
	{
		case 'innerHTML':
			document.getElementById(dataBind).innerHTML = sum;
		break;

		case 'value':
			document.getElementById(dataBind).value = sum;
		break;	
				
		case 'return':
			return sum;
		break;				
	}
}


// ===================================================================
// FUNCIONES AYTGrid Render
// ===================================================================
function _aytg_col_render ( txt, x , rndr_str ) 
{
	rndr_str = rndr_str.replace(/%3%/gi, x);
	rndr_str = rndr_str.replace(/%4%/gi, 'rDG:' + x +'');
	rndr_str = rndr_str.replace(/%1%/gi, '<span id="rDG:' + x +'">' + txt + '</span>');
	rndr_str = rndr_str.replace(/%2%/gi, txt);


	str_return = rndr_str; 
	return str_return; 
}

function _aytg_grid_value (aytg_id)
{
	num_cols = aytg_id.headers.length;
	num_rows = aytg_id.rows.length;

	aytg_v = '<aytg>';			
	aytg_v += '\n';			

	for (i=0;i<num_rows;i++)
	{
		aytg_v += '     ';			
		aytg_v += '<row>';			
		aytg_v += '\n';
					
		for (ir=0;ir<num_cols;ir++)
		{
			aytg_v += '        ';			
			aytg_v += '<col>';			
						
			if(!document.getElementById("rDG:"+aytg_id.id+":"+ir+":"+i))
			{
				cell_value = document.getElementById(aytg_id.id+":"+ir+":"+i).innerHTML;
				aytg_v += cell_value;			
			}
			else
			{
				cell_value = document.getElementById("rDG:"+aytg_id.id+":"+ir+":"+i).innerHTML;
				aytg_v += cell_value;	
			}
			
			aytg_v += '</col>';			
			aytg_v += '\n';	
			cell_value = '';
		}
					
		aytg_v += '     ';			
		aytg_v += '</row>';			
		aytg_v += '\n';			
	}
	aytg_v += '</aytg>';	

		document.getElementById(aytg_id.frm).value = aytg_v;
	
}

// ===================================================================
// Grid Edit Functions
// ===================================================================
function grid_edit_abort_or_blur ( input, cell_id, evt )
{
        evt = (evt) ? evt : event;

	var ccode = ( evt.charCode ) ? evt.charCode : ( ( evt.which ) ? evt.which : evt.keyCode );
        var ch = String.fromCharCode ( ccode );

	// User confirmed input by pressing "enter key"
	if ( ccode == 13 ) return input.blur ();

	// User aborted input
	if ( ccode == 27 )
	{
		var v = cell_id.split ( ":" );
		var grid = _ayt_grid_global_data.grid_arr [ v [ 0 ] ];
		input.value = grid.rows [ v [ 2 ] ] [ "data" ] [ v [ 1 ] ];
		input.blur ();
	}

	return true;
}

function grid_edit_end ( input, cell_id )
{
	var v = cell_id.split ( ":" );
	var grid = _ayt_grid_global_data.grid_arr [ v [ 0 ] ];
	var oldv = grid.rows [ v [ 2 ] ] [ "data" ] [ v [ 1 ] ];
	var attrs = grid.get_col_attrs ( v [ 1 ] );

	if ( oldv != input.value )
	{
		if ( attrs [ "ayt_validator" ] )
			if ( attrs [ "ayt_validator" ] ( input.value ) == false )
			{
				alert ( attrs [ "ayt_validator_alert" ].replace(/%1%/gi, input.value));
				return input.focus ();
			}

		grid.rows [ v [ 2 ] ] [ "data" ] [ v [ 1 ] ] = input.value;
		if ( grid.onchange ) grid.onchange ( grid, v [ 1 ], v [ 2 ], input.value );
		if ( grid.sort_on_edit ) grid.sort ();
	}

	return grid.render ();
}

function grid_cell_txt_edit ( cell )
{
	var v = cell.id.split ( ":" );
	var grid = _ayt_grid_global_data.grid_arr [ v [ 0 ] ];
	var val;
	var s, el, size;
	var attrs = grid.get_col_attrs ( v [ 2 ] );
	var type = attrs [ "ayt_type" ];

	if ( ! type ) type = 'str';

	val = String ( grid.rows [ v [ 2 ] ] [ "data" ] [ v [ 1 ] ] );

	s  = '<input type="text" id="grid_edit_cell" value="' + val + '" ';
	s += ' onblur="grid_edit_end ( this, \'' + cell.id + '\' )" ';
	s += ' onfocus="this.select()" ';


	if ( attrs [ "ayt_chars" ] )
		s += 'onkeypress="return grid_edit_filter_chars ( event, \'' + attrs [ "ayt_chars" ] + '\' )" ';

	s += ' onkeydown="grid_edit_abort_or_blur(this, \'' + cell.id + '\', event)" ';
	s += ' size="'+ val.length + '" ';
	s += ' class="g_edit_box" ';
	if ( type == 'int' ) s += ' style="text-align: right;" ';
	s += '/>';

	cell.innerHTML = s;

	el = document.getElementById ( "grid_edit_cell" );
	el.focus ();
}

function grid_edit_filter_chars ( evt, valids ) {
        evt = (evt) ? evt : event;

        if ( evt.charCode < 32 ) return true;
                                                                                                                                                   
        var ccode = ( evt.charcode ) ? evt.charcode : ( ( evt.which ) ? evt.which : evt.keycode );
        var ch = String.fromCharCode ( ccode ).toLowerCase ();

	valids = valids.toLowerCase ();

        if ( valids.indexOf ( ch ) == -1 ) return false;

        return true;
}


function grid_header_mdown ( header )
{
	if ( header.className == 'g_header_down' ) return;

	header.old_className = header.className;
	header.className = 'g_header_down';
	
}

function grid_header_mup ( header )
{
	if ( header.old_className ) header.className = header.old_className;
}

function grid_header_click ( header )
{
	var name, num, res, grid;
	
	res = header.id.split ( "_gh" );
	name = res [ 0 ];
	num  = res [ 1 ];

	grid = _ayt_grid_global_data.grid_arr [ name ];

	grid.set_sort_field ( num );

	grid.sort ()
}

function grid_row_over ( row )
{
	var old_col = row.style.backgroundColor;
	var hover_col = _ayt_grid_global_data.grid_arr [ row.firstChild.id.split ( ":" ) [ 0 ] ].cols [ "hover" ];

	if ( _aytg_resize_cell ) grid_resize_cell_up ();

	if ( ( row.selected ) || ( old_col == hover_col ) ) return;

	row.old_color = old_col;
	row.style.backgroundColor = hover_col;
}

function grid_row_out ( row )
{
	if ( ! row.selected ) row.style.backgroundColor = row.old_color;
}

function grid_cell_click ( cell )
{
	var v = cell.id.split ( ":" );
	var grid = _ayt_grid_global_data.grid_arr [ v [ 0 ] ];
	var val;

	val = grid.rows [ v [ 2 ] ] [ "data" ] [ v [ 1 ] ];

	sel = grid._cell_click ( grid, cell, v [ 2 ], v [ 1 ], val );
	
	if ( sel )
	{
		cell.old_border = cell.style.borderColor;
		cell.style.borderColor = grid.cols [ "rowsel" + ( v [ 2 ] % 2 ) ];
	} else
		cell.style.borderColor = cell.old_border;

	cell.selected = sel;
}

// ===================================================================
// Row selection function
// ===================================================================
function grid_row_click ( cell, grid_id, row_num )
{
	var grid = _ayt_grid_global_data.grid_arr [ grid_id ];
	var row = cell.parentNode;

	if ( row.selected )
	{
		row.selected = false;
		grid_row_out ( row );
	} else {
		row.selected = true;
		row.style.backgroundColor = grid.cols [ "rowsel" + ( row_num % 2 ) ];
	}

	grid.rows_selected [ row_num ] = row.selected;

	if ( grid.onrowselect ) grid.onrowselect ( grid, row_num, row.selected );
}

// ===================================================================
// Internal Functions
// ===================================================================
function ayt_grid_int_sort ( a, b )
{
	var res = 0;
	var v1, v2;

	v1 = parseInt ( a [ "data" ][ _ayt_grid_global_data.sort_field ] );
	v2 = parseInt ( b [ "data" ][ _ayt_grid_global_data.sort_field ] );

	if  ( v1 < v2 ) res = -1;
	else if ( v1 > v2 ) res = 1;

	if ( _ayt_grid_global_data.sort_inverted ) res *= -1;

	return res;
}

function ayt_grid_str_sort ( a, b )
{
	var res = 0;
	var v1, v2;

	v1 = a [ "data" ][ _ayt_grid_global_data.sort_field ];
	v2 = b [ "data" ][ _ayt_grid_global_data.sort_field ];

	if ( v1 < v2 ) res = -1;
	else if ( v1 > v2 ) res = 1;

	if ( _ayt_grid_global_data.sort_inverted ) res *= -1;

	return res;
}

function _aytg_set_headers ()
{
	this.headers = arguments;
}

function _aytg_set_sort_field ( num )
{
	if ( num == this.sort_field ) 
		this.sort_inverted = ! this.sort_inverted;
	else
	{
		this.sort_field = num;
		this.sort_inverted = false;
	}
}

function _aytg_set_cell_click ( fname )
{
	this._cell_click = fname;

	if ( this.id && this.autorender ) this.render ();
}

function _aytg_set_size ( w, h )
{
	this._width = w;
	this._height = h;
	if ( this.id && this.autorender ) this.render ();
}

function _aytg_set_scrollbars ( sbars )
{
	this._scrollbars = sbars;
	if ( this.id && this.autorender ) this.render ();
}

function _aytg_set_border ( bsize, style, color )
{
	this._border = bsize;
	if ( style ) this._border_style = style;
	if ( color ) this._border_color = color;

	if ( this.id && this.autorender ) this.render ();
}

function _aytg_set_sortable ( sortable )
{
	this._sortable = sortable ;

	if ( this.id && this.autorender ) this.render ();
}

function _aytg_set_highlight ( hl )
{
	this._row_hl = hl ;

	if ( this.id && this.autorender ) this.render ();
}

function _aytg_sort ()
{
	if ( this.sort_field == -1 ) return;

	var attrs = this.get_col_attrs ( this.sort_field );
	var ctype = attrs [ "ayt_type" ];
	var sfunc;

	if ( ! ctype ) ctype = "str";
	sfunc = { "str" : ayt_grid_str_sort,
	  	  "int" : ayt_grid_int_sort,
	  	  "date": ayt_grid_str_sort } [ ctype ];

	_ayt_grid_global_data.sort_field = this.sort_field;
	_ayt_grid_global_data.sort_inverted = this.sort_inverted;
	this.rows.sort ( sfunc );
	this.render ( this.id );
}

function _aytg_add_row ()
{
	var arr;

	arr = { "data" : arguments, "style" : this.current_style };

	this.rows.push ( arr );
}


function _aytg_del_row (row)
{
	this.rows.splice(row,1);
}

function _aytg_del_rows_select()
{
	if(this.rows.length == this.rows_selected.length)
	{
	
		if(this.rows_selected.length >0)
		{
			ir = 0;
			for (i=0;i<=this.rows_selected.length;i++)
			{
				if(this.rows_selected[i]==true)
				{
					this.rows.splice(i-ir,1);
					ir++;
				}
			}
		}

		this.add_default_row(this.default_row);
		this.render( this.id );
		
	}
	else
	{
		if(this.rows_selected.length >0)
		{
			ir = 0;
			for (i=0;i<=this.rows_selected.length;i++)
			{
				if(this.rows_selected[i]==true)
				{
					this.rows.splice(i-ir,1);
					ir++;
				}
			}
		}	
	}
}

function _aytg_del_lastrow ()
{
	this.rows.splice(this.rows.length-1,1);
}

function _aytg_change_style(cual, op)
{
	var actual = cual.className;
	var newclass = actual;
	if( actual != '_aytg_press' ) 
	{
		switch(op) 
		{
			case 'over':
				newclass = 'g_button_hover';
			break;
			case 'out':
				newclass = 'g_button';
			break;
			case 'down':
				newclass = 'g_button_down';
			break;
			case 'up':
				newclass = 'g_button_hover';
			break;
			case 'press':
				newclass = 'g_button_down';
			break;
		}
	} else if(op=='press') 
	{
		newclass = 'g_button_down';
		
	} else if(op=='unpress') 
	{
		newclass = 'g_button';
	}
	if( newclass!=actual ) 
	{
		cual.className = newclass;
	}
}

function _aytg_delrow (id)
{
    var g = aytgrid_get_grid ( id );		
	
	if(g.rows.length > 1)
	{
		g.del_lastrow();
		g.render( g.id );
	}
	else
	{
		g.del_lastrow();
		g.add_default_row(g.default_row);
		g.render( g.id );
	}
}

function _aytg_addrow (id)
{
    var g = aytgrid_get_grid ( id );	
	g.add_default_row(g.default_row);
	g.render( g.id );
}

function _aytg_add_default_row (data)
{
	var arr;
	data = data.replace(/"/gi, '');
	data = data.split("<%--%>");
	arr = { "data" : data, "style" : this.current_style };
	this.rows.push ( arr );
}

function _aytg_delselectedrows (id)
{
    var g = aytgrid_get_grid ( id );	
	
	g.del_rows_select();
	g.render( g.id );
}

function _aytg_get_str ()
{
	var t, len;
	var s = '';
	var id, td_id;
	var attrs;
	
	len = this.headers.length;
	if(this.width==0)
	{
		_aytg_width = '';
		_aytg_col_num_width = '';
	}
	else
	{
		_aytg_width = 'width="'+ this.width +'"';
		_aytg_col_num_width = 'width="35"';
	}
	
	s += '<table class="g_table" '+ _aytg_width +' cellspacing="0" cellpadding="0">';

	if(this.toolbar == true)
	{
		s += '<tr><td colspan="'+len*2+'">';
		s += '<div class="g_toolbar">';
		s += '<div class="g_toolbar_button0">';
		s += '<img class="g_button" onMouseOver="_aytg_change_style(this, \'over\');"  onmouseout="_aytg_change_style(this, \'out\');" onMouseDown="_aytg_change_style(this, \'down\');" onMouseUp="_aytg_change_style(this, \'up\');" onclick="_aytg_delrow(\''+this.id +'\');" src="http://www.ayalnet.com/intl/themes/corporate/img.php?fdr=screen&sfdr=plugins/aytgrid&fyle=up" width="21" height="9" />';
		s += '<br />';
		s += '<img class="g_button" onMouseOver="_aytg_change_style(this, \'over\');"  onmouseout="_aytg_change_style(this, \'out\');" onMouseDown="_aytg_change_style(this, \'down\');" onMouseUp="_aytg_change_style(this, \'up\');" onclick="_aytg_addrow(\''+this.id +'\');" src="http://www.ayalnet.com/intl/themes/corporate/img.php?fdr=screen&sfdr=plugins/aytgrid&fyle=down" width="21" height="9" />';
		s += '</div>';
		s += '<div class="g_toolbar_button1">';
		s += '<img class="g_button" onMouseOver="_aytg_change_style(this, \'over\');"  onmouseout="_aytg_change_style(this, \'out\');" onMouseDown="_aytg_change_style(this, \'down\');" onMouseUp="_aytg_change_style(this, \'up\');" onclick="_aytg_delselectedrows(\''+this.id +'\');" src="http://www.ayalnet.com/intl/themes/corporate/img.php?fdr=screen&sfdr=plugins/aytgrid&fyle=delete" width="18" height="18" />';
		s += '</div>';
		s += '<div class="g_toolbar_clear">&nbsp;</div>';
		s += '</div>';
		s += '</td></tr>';
	}
	
	// Row selections are discarted on rendering
	this.rows_selected = new Array ();

	if ( this.headers )
	{
		

		s += '<tr>';
		if ( this._show_row_num ) s+= '<td '+_aytg_col_num_width+'><div class="g_header">&nbsp</div></td>';

		len = this.headers.length;

		for ( t = 0; t < len; t ++ )
		{
			attrs = this.get_col_attrs ( t );
		
			td_id = this.id + "_th" + t;
			id = this.id + "_gh" + t;

			s += '<td id="' + td_id + '" ';
			if ( attrs [ "ayt_width" ] ) s += 'style="width: ' + attrs [ "ayt_width" ] + 'px;" ';
			s +='><div id="' + id + '" class="g_header"';
			if ( this._click_cb [ t ] )
			{
				if ( this._click_cb [ t ] != -1 ) 
				{
					s += ' onclick="' + this._click_cb [ t ] +  '"';
					s += ' onmousedown="grid_header_mdown(this)"';
					s += ' onmouseup="grid_header_mup(this)"';
					// s += ' onmouseout="grid_header_mup(this)" ';
				}
			} else if ( this._sortable ) {
					s += ' onclick="grid_header_click(this)"';
					s += ' onmousedown="grid_header_mdown(this)"';
					s += ' onmouseup="grid_header_mup(this)"';
					//s += ' onmouseout="grid_header_mup(this)" ';
			}

			s += '>'+ this.headers [ t ] + "</div></td>"; 

			if ( this.resize_cols )
				s += '<td class="g_resize" onmousedown="grid_resize_cell_down(\'' + td_id + '\')" onmouseup="grid_resize_cell_up()"></td>';
		}
		s += '</tr>';
	}

	var r, i, rlen, bgc, align, hl, style, rowcol, fullrow, v;

	len = this.rows.length;
	rlen = this.rows[0]['data'].length;	// All rows must be equal size
	for ( t = 0; t < len; t ++ )
	{
		fullrow = this.rows [ t ];
		r 	= fullrow [ 'data' ];
		style	= fullrow [ 'style' ];
		rowcol  = fullrow [ 'color' ];

		if ( rowcol )
			bgc = ' bgcolor="' + rowcol + '"';
		else 
			bgc = ' bgcolor="' + this.cols [ style + ( t % 2 ) ] + '"';

		if ( this._row_hl )
			hl = ' onmouseover="grid_row_over(this)" onmouseout="grid_row_out(this)" ';
		else
			hl = '';
		
		if ( this.resize_cols ) s +='<tr><td class="g_resize_row_tr" colspan="'+ rlen +'"></td></tr>';
		s += '<tr ' + hl + bgc + '>';
		if ( this._show_row_num ) 
		{
			s+= '<td class="g_header"';
			if ( this._row_sel )
			{
				s += ' onmousedown="grid_header_mdown(this)"';
				s += ' onmouseup="grid_header_mup(this)"';
				s += ' onclick="grid_row_click(this,\'' + this.id + '\',' + t + ')"';
			}

			s += ' id="' + this.id + ':' + t + '"';

			s+= '>' + ( this.start_counter + t ) + '</td>';
		}

		for ( i = 0; i < rlen; i ++ )
		{
			attrs = this.get_col_attrs ( i );

			var ca = attrs [ "ayt_align" ];
			var ctype = attrs [ "ayt_type" ];
			var cell_id = this.id + ":" + i + ":" + t;

			if ( ca )
				align = 'align="' + ca + '"';
			else if ( ctype && ( ctype != 'str' ) )
				align = 'align="right"';
			else
				align = "";
			
			s += '<td class="g_cell" valign="top" ' + align;
			
			if ( attrs [ "ayt_edit" ] ) s += ' ondblclick="grid_cell_' + attrs [ "ayt_edit" ] + '_edit(this)" ';
			if ( this._cell_click ) s += ' onclick="grid_cell_click(this)" ';
			s += ' id="' + cell_id + '"';
			s += '>'; 
			if ( attrs [ "ayt_render" ] )
				v = attrs [ "ayt_render" ] ( r [ i ], cell_id , attrs [ "ayt_render_str" ]);
			else
				v = r [ i ];
			s += v;
			s += '</td>';
			if ( this.resize_cols ) s += '<td class="g_resize_row"></td>';

		}
		s += '</tr>';
	}

	s += "</table>";
	
	return s;
}

function _aytg_render ( objId )
{
	if ( objId == undefined ) objId = this.id;

	this.id = objId;
	var obj = document.getElementById ( objId );

	obj.innerHTML = this.get_str ();

	if ( this._scrollbars )
		obj.style.overflow = "auto";
	else
		obj.style.overflow = "visible";	// was "none"


	if ( this._width )  obj.style.width = this._width;
	if ( this._height ) obj.style.height = this._height;
	if ( this._border ) 
	{
		if ( this._border_style ) obj.style.border = this._border_style;
		if ( this._border_color ) obj.style.borderColor = this._border_color;
		obj.style.borderWidth = this._border + "px";
	}
	
	// Bind element to the ayt_grid_array
	_ayt_grid_global_data.grid_arr [ objId ] = this;

	if ( this.onrender ) this.onrender ( this );
}

function _aytg_set_row_attr ( row_num, name, val )
{
	if ( ( row_num == undefined ) || ( row_num == -1 )  ) row_num = this.rows.length -1;

	var attrs = this.get_row_attrs ( row_num );

	attrs [ name ] = val;
}

function _aytg_set_row_color ( col, row_num )
{
	if ( ( row_num == undefined ) || ( row_num == -1 )  ) row_num = this.rows.length -1;

	this.rows [ row_num ] [ 'color' ] = col;
}

function _aytg_set_row_style ( style, row_num )
{
	if ( ( row_num == undefined ) || ( row_num == -1 )  ) row_num = this.rows.length -1;
	
	this.rows [ row_num ] [ 'style' ] = style;
}

function _aytg_set_col_align ( col, align )
{
	var attrs = this.get_col_attrs ( col );
	attrs [ "ayt_align" ] = align;
}

function _aytg_set_col_editable ( col, edit )
{
	var attrs = this.get_col_attrs ( col );
	attrs [ "ayt_edit" ] = edit;
}


function _aytg_get_value ( x, y )
{
	return this.rows [ y ] [ x ];
}

function _aytg_set_col_valid_chars ( col, chars )
{
	var attrs = this.get_col_attrs ( col );
	attrs [ "ayt_chars" ] = chars;
}

function _aytg_set_col_validation ( col, func, msg_alert )
{
	var attrs = this.get_col_attrs ( col );
	attrs [ "ayt_validator" ] = func;
	attrs [ "ayt_validator_alert" ] = msg_alert;
}

function _aytg_set_row_select ( rsel )
{
	this._row_sel = rsel;
	if ( this._row_sel ) this._show_row_num = true;

	if ( this.id && this.autorender ) this.render ();
}

function _aytg_show_row_num ( show )
{
	this._show_row_num = true;
	if ( this.id && this.autorender ) this.render ();
}

function _aytg_set_col_type ( col, type )
{
	var attrs = this.get_col_attrs ( col );
	attrs [ "ayt_type" ] = type;
}

function _aytg_set_col_render ( col, render, render_str )
{
	var attrs = this.get_col_attrs ( col );
	attrs [ "ayt_render" ] = render;
	attrs [ "ayt_render_str" ] = render_str;
}


function _aytg_get_row ( row )
{
	return this.rows [ row ] [ "data" ];
}

function _aytg_set_click_cb ( col, callback )
{
	this._click_cb [ col ] = callback;

	if ( this.id && this.autorender ) this.render ();
}

function _aytg_set_style ( style )
{
	this.current_style = style;

	if ( this.id && this.autorender ) this.render ();
}

function _aytg_get_col_attrs ( col )
{
	var attrs = this._column_attrs [ col ];
	if ( attrs ) return ( attrs );

	return this._column_attrs [ col ] = new Array ();
}

function _aytg_get_row_attrs ( row_num )
{
	if ( ( row_num == undefined ) || ( row_num == -1 )  ) row_num = this.rows.length -1;

	var attrs = this.rows [ row_num ] [ 'ayt_attrs' ];

	if ( attrs ) return attrs;

	return this.rows [ row_num ] [ 'ayt_attrs' ] = new Array ();
}

function _aytg_length ()
{
	return ( this.rows.length );
}


function AYTGrid ( auto_render )
{
	// ===========================================
	// Public attribs
	// ===========================================

	this.id = 0;
	
	this.toolbar = false;
		
	this.frm = 0;
	
	this.start_counter = 0;
	
	this.default_row = '';

	this.width = 0;
	
	// ===========================================
	// PUBLIC FLAGS
	// ===========================================

	// Flag T/F. If True, any modification (done with set_* funcs) will immediately renderd on grid
	this.autorender = auto_render;	

	// Flag T/F. If True, grid will be re-sorted on value changes
	this.sort_on_edit = false;

	// ===========================================
	// PUBLIC CALLBACKS
	// ===========================================
	// Function to be called when data in grid changes
	this.onchange = false;

	// Function to be called after the grid redraws
	this.onrender = false;
	
	this.name = '';

	// Callback to be called when the user selects / deselects a row
	this.onrowselect = false;

	// Flag T/F. If True, user can resize column at runtime
	this.resize_cols = false;
	
	// ===========================================
	// PUBLIC ATTRIBUTES
	// ===========================================

	// Array rows_selected
	this.rows_selected = false;	// This array keeps track of selected rows

	// Colors
	this.cols = { "hover" 	: "#deecfd",
		     "rowsel0"	: "#c9d7eb",
		     "rowsel1"	: "#b2c5df",
		     "normal0"	: "#ffffff",
		     "normal1"	: "#dee6f0",
		     "error0"	: "#ff0033",
		     "error1"	: "#cc0033",
		     "warn0"	: "#ffff99",
		     "warn1"	: "#ffff66",
		     "note0"	: "#9aff9a",
		     "note1"	: "#4eee94"
		    };

	// Default style
	this.current_style = "normal";


	// =============================================================================================
	// Private Stuff - Do not directly modify these values!
	// =============================================================================================
	this.headers = 0;
	this.rows = new Array ();
	this.sort_field = -1;
	this.sort_inverted = false;
		
	this._row_style = new Array ();

	this._column_attrs = new Array ();

	// This array stores the custom click callbacks
	this._click_cb = new Array ();
	
	// Flag T/F. If True, the grid is sortable (by clicking on the headers)
	this._sortable = false;

	// Flag T/F. If True, scrollbars are used.
	this._scrollbars = false;

	// Force grid container width
	this._width = this.width;

	// Force grid container height
	this._height = 0;

	// Grid container border size (in pixels)
	this._border = 0;

	// Grid container border style (solid, dashed, dotted...)
	this._border_style = 0;

	// Grid container block color
	this._border_color = 0;

	// Function callback for every cell click
	this._cell_click = 0;

	// Function callback for every row click
	this._row_click = 0;

	// Flag T/F. If True rows will be highlighted when the mouse scrolls over them.
	this._row_hl = false;

	// Flag T/F. If True rows number are shown and rows are selectable by clicking on them.
	this._show_row_num = false;

	// Flag T/F. If True rows number are shown and rows are selectable by clicking on them.
	this._row_sel = false;

	// Public methods
	this.add_row 		 = _aytg_add_row;
	this.add_default_row = _aytg_add_default_row;
	this.del_row 		 = _aytg_del_row;
	this.del_lastrow 	 = _aytg_del_lastrow;
	this.del_rows_select = _aytg_del_rows_select;
	
	this.facTL           = _aytg_calc_fac_total;
    this.facST			 = _aytg_calc_fac_sub_total;
    this.facIMP			 = _aytg_calc_fac_imp;
	this.facBI		     = _aytg_calc_fac_tax_base;
	
	this.col_render      = _aytg_col_render;
	this.set_grid_value  = _aytg_grid_value;
	this.get_col_attrs	 = _aytg_get_col_attrs;		
	this.get_row 		 = _aytg_get_row;
	this.get_row_attrs	 = _aytg_get_row_attrs;	
	this.get_str 		 = _aytg_get_str;
	this.getv		     = _aytg_get_value;
	this.length		     = _aytg_length;			
	this.render 		 = _aytg_render;
	this.set_border 	 = _aytg_set_border;
	this.set_cell_click  = _aytg_set_cell_click;
	this.set_click_cb	 = _aytg_set_click_cb;
	this.set_col_align	 = _aytg_set_col_align;
	this.set_col_editable	= _aytg_set_col_editable;
	this.set_col_render	 = _aytg_set_col_render;
	this.set_col_type	 = _aytg_set_col_type;
	this.set_col_valid_chars = _aytg_set_col_valid_chars;
	this.set_col_validation = _aytg_set_col_validation;
	this.set_headers    	= _aytg_set_headers;
	this.set_highlight	 = _aytg_set_highlight;
	this.set_row_attr	 = _aytg_set_row_attr;	
	this.set_row_color	 = _aytg_set_row_color;
	this.set_row_select  = _aytg_set_row_select;
	this.set_row_style	 = _aytg_set_row_style;
	this.set_scrollbars  = _aytg_set_scrollbars;
	this.set_size 		 = _aytg_set_size;
	this.set_sort_field  = _aytg_set_sort_field;
	this.set_sortable	 = _aytg_set_sortable;
	this.set_style		 = _aytg_set_style;
	this.show_row_num	 = _aytg_show_row_num;
	this.sort 		     = _aytg_sort;
}
function check_integer ( n ) { return RegExp ( "^[-+]?[0-9]+$" ).test( n ); }
function check_string ( s ) { return RegExp ( "^[a-zA-Z]+$" ).test( s ); }
function check_alfanum_string ( s ) { return RegExp ( "^[a-zA-Z0-9]+$" ).test( s ); } 
function check_date ( s ) { return RegExp ( "^[0-9]{4,4}.[0-9]{2,2}.[0-9]{2,2}$" ).test( s ); }
function check_time ( s ) { return RegExp ( "^[012][0-9]:[0-5][0-9]$" ).test( s ); }
function check_email ( s ) { return RegExp ( "^[a-zA-Z0-9-_.]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}$" ).test( s ); }
function check_float ( n )
{
	if (n.length == 0) return false;

	var first_char = n.charAt(0);
	if (first_char != '-' && first_char != '.' &&
	    (first_char < '0' || first_char > '9')) return false;

	var dot = false;
	var digit_expected = false;
	if (first_char == '.') {
		dot = true;
		digit_expected = true;
	} else if (first_char == '-')
		digit_expected = true;

	if (digit_expected && n.length < 2) return false;

	for (var count = 1; count < n.length; count++) {
		var c = n.charAt(count);
		if (c == '.') {
			if (dot) return false;
			dot = true;
		} else if (c < '0' || c > '9')
			return false;
	}

	return true;
}(function(){var l=this,g,y=l.jQuery,p=l.$,o=l.jQuery=l.$=function(E,F){return new o.fn.init(E,F)},D=/^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/,f=/^.[^:#\[\.,]*$/;o.fn=o.prototype={init:function(E,H){E=E||document;if(E.nodeType){this[0]=E;this.length=1;this.context=E;return this}if(typeof E==="string"){var G=D.exec(E);if(G&&(G[1]||!H)){if(G[1]){E=o.clean([G[1]],H)}else{var I=document.getElementById(G[3]);if(I&&I.id!=G[3]){return o().find(E)}var F=o(I||[]);F.context=document;F.selector=E;return F}}else{return o(H).find(E)}}else{if(o.isFunction(E)){return o(document).ready(E)}}if(E.selector&&E.context){this.selector=E.selector;this.context=E.context}return this.setArray(o.makeArray(E))},selector:"",jquery:"1.3.1",size:function(){return this.length},get:function(E){return E===g?o.makeArray(this):this[E]},pushStack:function(F,H,E){var G=o(F);G.prevObject=this;G.context=this.context;if(H==="find"){G.selector=this.selector+(this.selector?" ":"")+E}else{if(H){G.selector=this.selector+"."+H+"("+E+")"}}return G},setArray:function(E){this.length=0;Array.prototype.push.apply(this,E);return this},each:function(F,E){return o.each(this,F,E)},index:function(E){return o.inArray(E&&E.jquery?E[0]:E,this)},attr:function(F,H,G){var E=F;if(typeof F==="string"){if(H===g){return this[0]&&o[G||"attr"](this[0],F)}else{E={};E[F]=H}}return this.each(function(I){for(F in E){o.attr(G?this.style:this,F,o.prop(this,E[F],G,I,F))}})},css:function(E,F){if((E=="width"||E=="height")&&parseFloat(F)<0){F=g}return this.attr(E,F,"curCSS")},text:function(F){if(typeof F!=="object"&&F!=null){return this.empty().append((this[0]&&this[0].ownerDocument||document).createTextNode(F))}var E="";o.each(F||this,function(){o.each(this.childNodes,function(){if(this.nodeType!=8){E+=this.nodeType!=1?this.nodeValue:o.fn.text([this])}})});return E},wrapAll:function(E){if(this[0]){var F=o(E,this[0].ownerDocument).clone();if(this[0].parentNode){F.insertBefore(this[0])}F.map(function(){var G=this;while(G.firstChild){G=G.firstChild}return G}).append(this)}return this},wrapInner:function(E){return this.each(function(){o(this).contents().wrapAll(E)})},wrap:function(E){return this.each(function(){o(this).wrapAll(E)})},append:function(){return this.domManip(arguments,true,function(E){if(this.nodeType==1){this.appendChild(E)}})},prepend:function(){return this.domManip(arguments,true,function(E){if(this.nodeType==1){this.insertBefore(E,this.firstChild)}})},before:function(){return this.domManip(arguments,false,function(E){this.parentNode.insertBefore(E,this)})},after:function(){return this.domManip(arguments,false,function(E){this.parentNode.insertBefore(E,this.nextSibling)})},end:function(){return this.prevObject||o([])},push:[].push,find:function(E){if(this.length===1&&!/,/.test(E)){var G=this.pushStack([],"find",E);G.length=0;o.find(E,this[0],G);return G}else{var F=o.map(this,function(H){return o.find(E,H)});return this.pushStack(/[^+>] [^+>]/.test(E)?o.unique(F):F,"find",E)}},clone:function(F){var E=this.map(function(){if(!o.support.noCloneEvent&&!o.isXMLDoc(this)){var I=this.cloneNode(true),H=document.createElement("div");H.appendChild(I);return o.clean([H.innerHTML])[0]}else{return this.cloneNode(true)}});var G=E.find("*").andSelf().each(function(){if(this[h]!==g){this[h]=null}});if(F===true){this.find("*").andSelf().each(function(I){if(this.nodeType==3){return}var H=o.data(this,"events");for(var K in H){for(var J in H[K]){o.event.add(G[I],K,H[K][J],H[K][J].data)}}})}return E},filter:function(E){return this.pushStack(o.isFunction(E)&&o.grep(this,function(G,F){return E.call(G,F)})||o.multiFilter(E,o.grep(this,function(F){return F.nodeType===1})),"filter",E)},closest:function(E){var F=o.expr.match.POS.test(E)?o(E):null;return this.map(function(){var G=this;while(G&&G.ownerDocument){if(F?F.index(G)>-1:o(G).is(E)){return G}G=G.parentNode}})},not:function(E){if(typeof E==="string"){if(f.test(E)){return this.pushStack(o.multiFilter(E,this,true),"not",E)}else{E=o.multiFilter(E,this)}}var F=E.length&&E[E.length-1]!==g&&!E.nodeType;return this.filter(function(){return F?o.inArray(this,E)<0:this!=E})},add:function(E){return this.pushStack(o.unique(o.merge(this.get(),typeof E==="string"?o(E):o.makeArray(E))))},is:function(E){return !!E&&o.multiFilter(E,this).length>0},hasClass:function(E){return !!E&&this.is("."+E)},val:function(K){if(K===g){var E=this[0];if(E){if(o.nodeName(E,"option")){return(E.attributes.value||{}).specified?E.value:E.text}if(o.nodeName(E,"select")){var I=E.selectedIndex,L=[],M=E.options,H=E.type=="select-one";if(I<0){return null}for(var F=H?I:0,J=H?I+1:M.length;F<J;F++){var G=M[F];if(G.selected){K=o(G).val();if(H){return K}L.push(K)}}return L}return(E.value||"").replace(/\r/g,"")}return g}if(typeof K==="number"){K+=""}return this.each(function(){if(this.nodeType!=1){return}if(o.isArray(K)&&/radio|checkbox/.test(this.type)){this.checked=(o.inArray(this.value,K)>=0||o.inArray(this.name,K)>=0)}else{if(o.nodeName(this,"select")){var N=o.makeArray(K);o("option",this).each(function(){this.selected=(o.inArray(this.value,N)>=0||o.inArray(this.text,N)>=0)});if(!N.length){this.selectedIndex=-1}}else{this.value=K}}})},html:function(E){return E===g?(this[0]?this[0].innerHTML:null):this.empty().append(E)},replaceWith:function(E){return this.after(E).remove()},eq:function(E){return this.slice(E,+E+1)},slice:function(){return this.pushStack(Array.prototype.slice.apply(this,arguments),"slice",Array.prototype.slice.call(arguments).join(","))},map:function(E){return this.pushStack(o.map(this,function(G,F){return E.call(G,F,G)}))},andSelf:function(){return this.add(this.prevObject)},domManip:function(K,N,M){if(this[0]){var J=(this[0].ownerDocument||this[0]).createDocumentFragment(),G=o.clean(K,(this[0].ownerDocument||this[0]),J),I=J.firstChild,E=this.length>1?J.cloneNode(true):J;if(I){for(var H=0,F=this.length;H<F;H++){M.call(L(this[H],I),H>0?E.cloneNode(true):J)}}if(G){o.each(G,z)}}return this;function L(O,P){return N&&o.nodeName(O,"table")&&o.nodeName(P,"tr")?(O.getElementsByTagName("tbody")[0]||O.appendChild(O.ownerDocument.createElement("tbody"))):O}}};o.fn.init.prototype=o.fn;function z(E,F){if(F.src){o.ajax({url:F.src,async:false,dataType:"script"})}else{o.globalEval(F.text||F.textContent||F.innerHTML||"")}if(F.parentNode){F.parentNode.removeChild(F)}}function e(){return +new Date}o.extend=o.fn.extend=function(){var J=arguments[0]||{},H=1,I=arguments.length,E=false,G;if(typeof J==="boolean"){E=J;J=arguments[1]||{};H=2}if(typeof J!=="object"&&!o.isFunction(J)){J={}}if(I==H){J=this;--H}for(;H<I;H++){if((G=arguments[H])!=null){for(var F in G){var K=J[F],L=G[F];if(J===L){continue}if(E&&L&&typeof L==="object"&&!L.nodeType){J[F]=o.extend(E,K||(L.length!=null?[]:{}),L)}else{if(L!==g){J[F]=L}}}}}return J};var b=/z-?index|font-?weight|opacity|zoom|line-?height/i,q=document.defaultView||{},s=Object.prototype.toString;o.extend({noConflict:function(E){l.$=p;if(E){l.jQuery=y}return o},isFunction:function(E){return s.call(E)==="[object Function]"},isArray:function(E){return s.call(E)==="[object Array]"},isXMLDoc:function(E){return E.nodeType===9&&E.documentElement.nodeName!=="HTML"||!!E.ownerDocument&&o.isXMLDoc(E.ownerDocument)},globalEval:function(G){G=o.trim(G);if(G){var F=document.getElementsByTagName("head")[0]||document.documentElement,E=document.createElement("script");E.type="text/javascript";if(o.support.scriptEval){E.appendChild(document.createTextNode(G))}else{E.text=G}F.insertBefore(E,F.firstChild);F.removeChild(E)}},nodeName:function(F,E){return F.nodeName&&F.nodeName.toUpperCase()==E.toUpperCase()},each:function(G,K,F){var E,H=0,I=G.length;if(F){if(I===g){for(E in G){if(K.apply(G[E],F)===false){break}}}else{for(;H<I;){if(K.apply(G[H++],F)===false){break}}}}else{if(I===g){for(E in G){if(K.call(G[E],E,G[E])===false){break}}}else{for(var J=G[0];H<I&&K.call(J,H,J)!==false;J=G[++H]){}}}return G},prop:function(H,I,G,F,E){if(o.isFunction(I)){I=I.call(H,F)}return typeof I==="number"&&G=="curCSS"&&!b.test(E)?I+"px":I},className:{add:function(E,F){o.each((F||"").split(/\s+/),function(G,H){if(E.nodeType==1&&!o.className.has(E.className,H)){E.className+=(E.className?" ":"")+H}})},remove:function(E,F){if(E.nodeType==1){E.className=F!==g?o.grep(E.className.split(/\s+/),function(G){return !o.className.has(F,G)}).join(" "):""}},has:function(F,E){return F&&o.inArray(E,(F.className||F).toString().split(/\s+/))>-1}},swap:function(H,G,I){var E={};for(var F in G){E[F]=H.style[F];H.style[F]=G[F]}I.call(H);for(var F in G){H.style[F]=E[F]}},css:function(G,E,I){if(E=="width"||E=="height"){var K,F={position:"absolute",visibility:"hidden",display:"block"},J=E=="width"?["Left","Right"]:["Top","Bottom"];function H(){K=E=="width"?G.offsetWidth:G.offsetHeight;var M=0,L=0;o.each(J,function(){M+=parseFloat(o.curCSS(G,"padding"+this,true))||0;L+=parseFloat(o.curCSS(G,"border"+this+"Width",true))||0});K-=Math.round(M+L)}if(o(G).is(":visible")){H()}else{o.swap(G,F,H)}return Math.max(0,K)}return o.curCSS(G,E,I)},curCSS:function(I,F,G){var L,E=I.style;if(F=="opacity"&&!o.support.opacity){L=o.attr(E,"opacity");return L==""?"1":L}if(F.match(/float/i)){F=w}if(!G&&E&&E[F]){L=E[F]}else{if(q.getComputedStyle){if(F.match(/float/i)){F="float"}F=F.replace(/([A-Z])/g,"-$1").toLowerCase();var M=q.getComputedStyle(I,null);if(M){L=M.getPropertyValue(F)}if(F=="opacity"&&L==""){L="1"}}else{if(I.currentStyle){var J=F.replace(/\-(\w)/g,function(N,O){return O.toUpperCase()});L=I.currentStyle[F]||I.currentStyle[J];if(!/^\d+(px)?$/i.test(L)&&/^\d/.test(L)){var H=E.left,K=I.runtimeStyle.left;I.runtimeStyle.left=I.currentStyle.left;E.left=L||0;L=E.pixelLeft+"px";E.left=H;I.runtimeStyle.left=K}}}}return L},clean:function(F,K,I){K=K||document;if(typeof K.createElement==="undefined"){K=K.ownerDocument||K[0]&&K[0].ownerDocument||document}if(!I&&F.length===1&&typeof F[0]==="string"){var H=/^<(\w+)\s*\/?>$/.exec(F[0]);if(H){return[K.createElement(H[1])]}}var G=[],E=[],L=K.createElement("div");o.each(F,function(P,R){if(typeof R==="number"){R+=""}if(!R){return}if(typeof R==="string"){R=R.replace(/(<(\w+)[^>]*?)\/>/g,function(T,U,S){return S.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i)?T:U+"></"+S+">"});var O=o.trim(R).toLowerCase();var Q=!O.indexOf("<opt")&&[1,"<select multiple='multiple'>","</select>"]||!O.indexOf("<leg")&&[1,"<fieldset>","</fieldset>"]||O.match(/^<(thead|tbody|tfoot|colg|cap)/)&&[1,"<table>","</table>"]||!O.indexOf("<tr")&&[2,"<table><tbody>","</tbody></table>"]||(!O.indexOf("<td")||!O.indexOf("<th"))&&[3,"<table><tbody><tr>","</tr></tbody></table>"]||!O.indexOf("<col")&&[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"]||!o.support.htmlSerialize&&[1,"div<div>","</div>"]||[0,"",""];L.innerHTML=Q[1]+R+Q[2];while(Q[0]--){L=L.lastChild}if(!o.support.tbody){var N=!O.indexOf("<table")&&O.indexOf("<tbody")<0?L.firstChild&&L.firstChild.childNodes:Q[1]=="<table>"&&O.indexOf("<tbody")<0?L.childNodes:[];for(var M=N.length-1;M>=0;--M){if(o.nodeName(N[M],"tbody")&&!N[M].childNodes.length){N[M].parentNode.removeChild(N[M])}}}if(!o.support.leadingWhitespace&&/^\s/.test(R)){L.insertBefore(K.createTextNode(R.match(/^\s*/)[0]),L.firstChild)}R=o.makeArray(L.childNodes)}if(R.nodeType){G.push(R)}else{G=o.merge(G,R)}});if(I){for(var J=0;G[J];J++){if(o.nodeName(G[J],"script")&&(!G[J].type||G[J].type.toLowerCase()==="text/javascript")){E.push(G[J].parentNode?G[J].parentNode.removeChild(G[J]):G[J])}else{if(G[J].nodeType===1){G.splice.apply(G,[J+1,0].concat(o.makeArray(G[J].getElementsByTagName("script"))))}I.appendChild(G[J])}}return E}return G},attr:function(J,G,K){if(!J||J.nodeType==3||J.nodeType==8){return g}var H=!o.isXMLDoc(J),L=K!==g;G=H&&o.props[G]||G;if(J.tagName){var F=/href|src|style/.test(G);if(G=="selected"&&J.parentNode){J.parentNode.selectedIndex}if(G in J&&H&&!F){if(L){if(G=="type"&&o.nodeName(J,"input")&&J.parentNode){throw"type property can't be changed"}J[G]=K}if(o.nodeName(J,"form")&&J.getAttributeNode(G)){return J.getAttributeNode(G).nodeValue}if(G=="tabIndex"){var I=J.getAttributeNode("tabIndex");return I&&I.specified?I.value:J.nodeName.match(/(button|input|object|select|textarea)/i)?0:J.nodeName.match(/^(a|area)$/i)&&J.href?0:g}return J[G]}if(!o.support.style&&H&&G=="style"){return o.attr(J.style,"cssText",K)}if(L){J.setAttribute(G,""+K)}var E=!o.support.hrefNormalized&&H&&F?J.getAttribute(G,2):J.getAttribute(G);return E===null?g:E}if(!o.support.opacity&&G=="opacity"){if(L){J.zoom=1;J.filter=(J.filter||"").replace(/alpha\([^)]*\)/,"")+(parseInt(K)+""=="NaN"?"":"alpha(opacity="+K*100+")")}return J.filter&&J.filter.indexOf("opacity=")>=0?(parseFloat(J.filter.match(/opacity=([^)]*)/)[1])/100)+"":""}G=G.replace(/-([a-z])/ig,function(M,N){return N.toUpperCase()});if(L){J[G]=K}return J[G]},trim:function(E){return(E||"").replace(/^\s+|\s+$/g,"")},makeArray:function(G){var E=[];if(G!=null){var F=G.length;if(F==null||typeof G==="string"||o.isFunction(G)||G.setInterval){E[0]=G}else{while(F){E[--F]=G[F]}}}return E},inArray:function(G,H){for(var E=0,F=H.length;E<F;E++){if(H[E]===G){return E}}return -1},merge:function(H,E){var F=0,G,I=H.length;if(!o.support.getAll){while((G=E[F++])!=null){if(G.nodeType!=8){H[I++]=G}}}else{while((G=E[F++])!=null){H[I++]=G}}return H},unique:function(K){var F=[],E={};try{for(var G=0,H=K.length;G<H;G++){var J=o.data(K[G]);if(!E[J]){E[J]=true;F.push(K[G])}}}catch(I){F=K}return F},grep:function(F,J,E){var G=[];for(var H=0,I=F.length;H<I;H++){if(!E!=!J(F[H],H)){G.push(F[H])}}return G},map:function(E,J){var F=[];for(var G=0,H=E.length;G<H;G++){var I=J(E[G],G);if(I!=null){F[F.length]=I}}return F.concat.apply([],F)}});var C=navigator.userAgent.toLowerCase();o.browser={version:(C.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/)||[0,"0"])[1],safari:/webkit/.test(C),opera:/opera/.test(C),msie:/msie/.test(C)&&!/opera/.test(C),mozilla:/mozilla/.test(C)&&!/(compatible|webkit)/.test(C)};o.each({parent:function(E){return E.parentNode},parents:function(E){return o.dir(E,"parentNode")},next:function(E){return o.nth(E,2,"nextSibling")},prev:function(E){return o.nth(E,2,"previousSibling")},nextAll:function(E){return o.dir(E,"nextSibling")},prevAll:function(E){return o.dir(E,"previousSibling")},siblings:function(E){return o.sibling(E.parentNode.firstChild,E)},children:function(E){return o.sibling(E.firstChild)},contents:function(E){return o.nodeName(E,"iframe")?E.contentDocument||E.contentWindow.document:o.makeArray(E.childNodes)}},function(E,F){o.fn[E]=function(G){var H=o.map(this,F);if(G&&typeof G=="string"){H=o.multiFilter(G,H)}return this.pushStack(o.unique(H),E,G)}});o.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(E,F){o.fn[E]=function(){var G=arguments;return this.each(function(){for(var H=0,I=G.length;H<I;H++){o(G[H])[F](this)}})}});o.each({removeAttr:function(E){o.attr(this,E,"");if(this.nodeType==1){this.removeAttribute(E)}},addClass:function(E){o.className.add(this,E)},removeClass:function(E){o.className.remove(this,E)},toggleClass:function(F,E){if(typeof E!=="boolean"){E=!o.className.has(this,F)}o.className[E?"add":"remove"](this,F)},remove:function(E){if(!E||o.filter(E,[this]).length){o("*",this).add([this]).each(function(){o.event.remove(this);o.removeData(this)});if(this.parentNode){this.parentNode.removeChild(this)}}},empty:function(){o(">*",this).remove();while(this.firstChild){this.removeChild(this.firstChild)}}},function(E,F){o.fn[E]=function(){return this.each(F,arguments)}});function j(E,F){return E[0]&&parseInt(o.curCSS(E[0],F,true),10)||0}var h="jQuery"+e(),v=0,A={};o.extend({cache:{},data:function(F,E,G){F=F==l?A:F;var H=F[h];if(!H){H=F[h]=++v}if(E&&!o.cache[H]){o.cache[H]={}}if(G!==g){o.cache[H][E]=G}return E?o.cache[H][E]:H},removeData:function(F,E){F=F==l?A:F;var H=F[h];if(E){if(o.cache[H]){delete o.cache[H][E];E="";for(E in o.cache[H]){break}if(!E){o.removeData(F)}}}else{try{delete F[h]}catch(G){if(F.removeAttribute){F.removeAttribute(h)}}delete o.cache[H]}},queue:function(F,E,H){if(F){E=(E||"fx")+"queue";var G=o.data(F,E);if(!G||o.isArray(H)){G=o.data(F,E,o.makeArray(H))}else{if(H){G.push(H)}}}return G},dequeue:function(H,G){var E=o.queue(H,G),F=E.shift();if(!G||G==="fx"){F=E[0]}if(F!==g){F.call(H)}}});o.fn.extend({data:function(E,G){var H=E.split(".");H[1]=H[1]?"."+H[1]:"";if(G===g){var F=this.triggerHandler("getData"+H[1]+"!",[H[0]]);if(F===g&&this.length){F=o.data(this[0],E)}return F===g&&H[1]?this.data(H[0]):F}else{return this.trigger("setData"+H[1]+"!",[H[0],G]).each(function(){o.data(this,E,G)})}},removeData:function(E){return this.each(function(){o.removeData(this,E)})},queue:function(E,F){if(typeof E!=="string"){F=E;E="fx"}if(F===g){return o.queue(this[0],E)}return this.each(function(){var G=o.queue(this,E,F);if(E=="fx"&&G.length==1){G[0].call(this)}})},dequeue:function(E){return this.each(function(){o.dequeue(this,E)})}});
/*
 * Sizzle CSS Selector Engine - v0.9.3
 *  Copyright 2009, The Dojo Foundation
 *  Released under the MIT, BSD, and GPL Licenses.
 *  More information: http://sizzlejs.com/
 */
(function(){var Q=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]+['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[]+)+|[>+~])(\s*,\s*)?/g,K=0,G=Object.prototype.toString;var F=function(X,T,aa,ab){aa=aa||[];T=T||document;if(T.nodeType!==1&&T.nodeType!==9){return[]}if(!X||typeof X!=="string"){return aa}var Y=[],V,ae,ah,S,ac,U,W=true;Q.lastIndex=0;while((V=Q.exec(X))!==null){Y.push(V[1]);if(V[2]){U=RegExp.rightContext;break}}if(Y.length>1&&L.exec(X)){if(Y.length===2&&H.relative[Y[0]]){ae=I(Y[0]+Y[1],T)}else{ae=H.relative[Y[0]]?[T]:F(Y.shift(),T);while(Y.length){X=Y.shift();if(H.relative[X]){X+=Y.shift()}ae=I(X,ae)}}}else{var ad=ab?{expr:Y.pop(),set:E(ab)}:F.find(Y.pop(),Y.length===1&&T.parentNode?T.parentNode:T,P(T));ae=F.filter(ad.expr,ad.set);if(Y.length>0){ah=E(ae)}else{W=false}while(Y.length){var ag=Y.pop(),af=ag;if(!H.relative[ag]){ag=""}else{af=Y.pop()}if(af==null){af=T}H.relative[ag](ah,af,P(T))}}if(!ah){ah=ae}if(!ah){throw"Syntax error, unrecognized expression: "+(ag||X)}if(G.call(ah)==="[object Array]"){if(!W){aa.push.apply(aa,ah)}else{if(T.nodeType===1){for(var Z=0;ah[Z]!=null;Z++){if(ah[Z]&&(ah[Z]===true||ah[Z].nodeType===1&&J(T,ah[Z]))){aa.push(ae[Z])}}}else{for(var Z=0;ah[Z]!=null;Z++){if(ah[Z]&&ah[Z].nodeType===1){aa.push(ae[Z])}}}}}else{E(ah,aa)}if(U){F(U,T,aa,ab)}return aa};F.matches=function(S,T){return F(S,null,null,T)};F.find=function(Z,S,aa){var Y,W;if(!Z){return[]}for(var V=0,U=H.order.length;V<U;V++){var X=H.order[V],W;if((W=H.match[X].exec(Z))){var T=RegExp.leftContext;if(T.substr(T.length-1)!=="\\"){W[1]=(W[1]||"").replace(/\\/g,"");Y=H.find[X](W,S,aa);if(Y!=null){Z=Z.replace(H.match[X],"");break}}}}if(!Y){Y=S.getElementsByTagName("*")}return{set:Y,expr:Z}};F.filter=function(ab,aa,ae,V){var U=ab,ag=[],Y=aa,X,S;while(ab&&aa.length){for(var Z in H.filter){if((X=H.match[Z].exec(ab))!=null){var T=H.filter[Z],af,ad;S=false;if(Y==ag){ag=[]}if(H.preFilter[Z]){X=H.preFilter[Z](X,Y,ae,ag,V);if(!X){S=af=true}else{if(X===true){continue}}}if(X){for(var W=0;(ad=Y[W])!=null;W++){if(ad){af=T(ad,X,W,Y);var ac=V^!!af;if(ae&&af!=null){if(ac){S=true}else{Y[W]=false}}else{if(ac){ag.push(ad);S=true}}}}}if(af!==g){if(!ae){Y=ag}ab=ab.replace(H.match[Z],"");if(!S){return[]}break}}}ab=ab.replace(/\s*,\s*/,"");if(ab==U){if(S==null){throw"Syntax error, unrecognized expression: "+ab}else{break}}U=ab}return Y};var H=F.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF_-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF_-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*_-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF_-]|\\.)+)(?:\((['"]*)((?:\([^\)]+\)|[^\2\(\)]*)+)\2\))?/},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(S){return S.getAttribute("href")}},relative:{"+":function(W,T){for(var U=0,S=W.length;U<S;U++){var V=W[U];if(V){var X=V.previousSibling;while(X&&X.nodeType!==1){X=X.previousSibling}W[U]=typeof T==="string"?X||false:X===T}}if(typeof T==="string"){F.filter(T,W,true)}},">":function(X,T,Y){if(typeof T==="string"&&!/\W/.test(T)){T=Y?T:T.toUpperCase();for(var U=0,S=X.length;U<S;U++){var W=X[U];if(W){var V=W.parentNode;X[U]=V.nodeName===T?V:false}}}else{for(var U=0,S=X.length;U<S;U++){var W=X[U];if(W){X[U]=typeof T==="string"?W.parentNode:W.parentNode===T}}if(typeof T==="string"){F.filter(T,X,true)}}},"":function(V,T,X){var U="done"+(K++),S=R;if(!T.match(/\W/)){var W=T=X?T:T.toUpperCase();S=O}S("parentNode",T,U,V,W,X)},"~":function(V,T,X){var U="done"+(K++),S=R;if(typeof T==="string"&&!T.match(/\W/)){var W=T=X?T:T.toUpperCase();S=O}S("previousSibling",T,U,V,W,X)}},find:{ID:function(T,U,V){if(typeof U.getElementById!=="undefined"&&!V){var S=U.getElementById(T[1]);return S?[S]:[]}},NAME:function(S,T,U){if(typeof T.getElementsByName!=="undefined"&&!U){return T.getElementsByName(S[1])}},TAG:function(S,T){return T.getElementsByTagName(S[1])}},preFilter:{CLASS:function(V,T,U,S,Y){V=" "+V[1].replace(/\\/g,"")+" ";var X;for(var W=0;(X=T[W])!=null;W++){if(X){if(Y^(" "+X.className+" ").indexOf(V)>=0){if(!U){S.push(X)}}else{if(U){T[W]=false}}}}return false},ID:function(S){return S[1].replace(/\\/g,"")},TAG:function(T,S){for(var U=0;S[U]===false;U++){}return S[U]&&P(S[U])?T[1]:T[1].toUpperCase()},CHILD:function(S){if(S[1]=="nth"){var T=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(S[2]=="even"&&"2n"||S[2]=="odd"&&"2n+1"||!/\D/.test(S[2])&&"0n+"+S[2]||S[2]);S[2]=(T[1]+(T[2]||1))-0;S[3]=T[3]-0}S[0]="done"+(K++);return S},ATTR:function(T){var S=T[1].replace(/\\/g,"");if(H.attrMap[S]){T[1]=H.attrMap[S]}if(T[2]==="~="){T[4]=" "+T[4]+" "}return T},PSEUDO:function(W,T,U,S,X){if(W[1]==="not"){if(W[3].match(Q).length>1){W[3]=F(W[3],null,null,T)}else{var V=F.filter(W[3],T,U,true^X);if(!U){S.push.apply(S,V)}return false}}else{if(H.match.POS.test(W[0])){return true}}return W},POS:function(S){S.unshift(true);return S}},filters:{enabled:function(S){return S.disabled===false&&S.type!=="hidden"},disabled:function(S){return S.disabled===true},checked:function(S){return S.checked===true},selected:function(S){S.parentNode.selectedIndex;return S.selected===true},parent:function(S){return !!S.firstChild},empty:function(S){return !S.firstChild},has:function(U,T,S){return !!F(S[3],U).length},header:function(S){return/h\d/i.test(S.nodeName)},text:function(S){return"text"===S.type},radio:function(S){return"radio"===S.type},checkbox:function(S){return"checkbox"===S.type},file:function(S){return"file"===S.type},password:function(S){return"password"===S.type},submit:function(S){return"submit"===S.type},image:function(S){return"image"===S.type},reset:function(S){return"reset"===S.type},button:function(S){return"button"===S.type||S.nodeName.toUpperCase()==="BUTTON"},input:function(S){return/input|select|textarea|button/i.test(S.nodeName)}},setFilters:{first:function(T,S){return S===0},last:function(U,T,S,V){return T===V.length-1},even:function(T,S){return S%2===0},odd:function(T,S){return S%2===1},lt:function(U,T,S){return T<S[3]-0},gt:function(U,T,S){return T>S[3]-0},nth:function(U,T,S){return S[3]-0==T},eq:function(U,T,S){return S[3]-0==T}},filter:{CHILD:function(S,V){var Y=V[1],Z=S.parentNode;var X=V[0];if(Z&&(!Z[X]||!S.nodeIndex)){var W=1;for(var T=Z.firstChild;T;T=T.nextSibling){if(T.nodeType==1){T.nodeIndex=W++}}Z[X]=W-1}if(Y=="first"){return S.nodeIndex==1}else{if(Y=="last"){return S.nodeIndex==Z[X]}else{if(Y=="only"){return Z[X]==1}else{if(Y=="nth"){var ab=false,U=V[2],aa=V[3];if(U==1&&aa==0){return true}if(U==0){if(S.nodeIndex==aa){ab=true}}else{if((S.nodeIndex-aa)%U==0&&(S.nodeIndex-aa)/U>=0){ab=true}}return ab}}}}},PSEUDO:function(Y,U,V,Z){var T=U[1],W=H.filters[T];if(W){return W(Y,V,U,Z)}else{if(T==="contains"){return(Y.textContent||Y.innerText||"").indexOf(U[3])>=0}else{if(T==="not"){var X=U[3];for(var V=0,S=X.length;V<S;V++){if(X[V]===Y){return false}}return true}}}},ID:function(T,S){return T.nodeType===1&&T.getAttribute("id")===S},TAG:function(T,S){return(S==="*"&&T.nodeType===1)||T.nodeName===S},CLASS:function(T,S){return S.test(T.className)},ATTR:function(W,U){var S=H.attrHandle[U[1]]?H.attrHandle[U[1]](W):W[U[1]]||W.getAttribute(U[1]),X=S+"",V=U[2],T=U[4];return S==null?V==="!=":V==="="?X===T:V==="*="?X.indexOf(T)>=0:V==="~="?(" "+X+" ").indexOf(T)>=0:!U[4]?S:V==="!="?X!=T:V==="^="?X.indexOf(T)===0:V==="$="?X.substr(X.length-T.length)===T:V==="|="?X===T||X.substr(0,T.length+1)===T+"-":false},POS:function(W,T,U,X){var S=T[2],V=H.setFilters[S];if(V){return V(W,U,T,X)}}}};var L=H.match.POS;for(var N in H.match){H.match[N]=RegExp(H.match[N].source+/(?![^\[]*\])(?![^\(]*\))/.source)}var E=function(T,S){T=Array.prototype.slice.call(T);if(S){S.push.apply(S,T);return S}return T};try{Array.prototype.slice.call(document.documentElement.childNodes)}catch(M){E=function(W,V){var T=V||[];if(G.call(W)==="[object Array]"){Array.prototype.push.apply(T,W)}else{if(typeof W.length==="number"){for(var U=0,S=W.length;U<S;U++){T.push(W[U])}}else{for(var U=0;W[U];U++){T.push(W[U])}}}return T}}(function(){var T=document.createElement("form"),U="script"+(new Date).getTime();T.innerHTML="<input name='"+U+"'/>";var S=document.documentElement;S.insertBefore(T,S.firstChild);if(!!document.getElementById(U)){H.find.ID=function(W,X,Y){if(typeof X.getElementById!=="undefined"&&!Y){var V=X.getElementById(W[1]);return V?V.id===W[1]||typeof V.getAttributeNode!=="undefined"&&V.getAttributeNode("id").nodeValue===W[1]?[V]:g:[]}};H.filter.ID=function(X,V){var W=typeof X.getAttributeNode!=="undefined"&&X.getAttributeNode("id");return X.nodeType===1&&W&&W.nodeValue===V}}S.removeChild(T)})();(function(){var S=document.createElement("div");S.appendChild(document.createComment(""));if(S.getElementsByTagName("*").length>0){H.find.TAG=function(T,X){var W=X.getElementsByTagName(T[1]);if(T[1]==="*"){var V=[];for(var U=0;W[U];U++){if(W[U].nodeType===1){V.push(W[U])}}W=V}return W}}S.innerHTML="<a href='#'></a>";if(S.firstChild&&S.firstChild.getAttribute("href")!=="#"){H.attrHandle.href=function(T){return T.getAttribute("href",2)}}})();if(document.querySelectorAll){(function(){var S=F,T=document.createElement("div");T.innerHTML="<p class='TEST'></p>";if(T.querySelectorAll&&T.querySelectorAll(".TEST").length===0){return}F=function(X,W,U,V){W=W||document;if(!V&&W.nodeType===9&&!P(W)){try{return E(W.querySelectorAll(X),U)}catch(Y){}}return S(X,W,U,V)};F.find=S.find;F.filter=S.filter;F.selectors=S.selectors;F.matches=S.matches})()}if(document.getElementsByClassName&&document.documentElement.getElementsByClassName){H.order.splice(1,0,"CLASS");H.find.CLASS=function(S,T){return T.getElementsByClassName(S[1])}}function O(T,Z,Y,ac,aa,ab){for(var W=0,U=ac.length;W<U;W++){var S=ac[W];if(S){S=S[T];var X=false;while(S&&S.nodeType){var V=S[Y];if(V){X=ac[V];break}if(S.nodeType===1&&!ab){S[Y]=W}if(S.nodeName===Z){X=S;break}S=S[T]}ac[W]=X}}}function R(T,Y,X,ab,Z,aa){for(var V=0,U=ab.length;V<U;V++){var S=ab[V];if(S){S=S[T];var W=false;while(S&&S.nodeType){if(S[X]){W=ab[S[X]];break}if(S.nodeType===1){if(!aa){S[X]=V}if(typeof Y!=="string"){if(S===Y){W=true;break}}else{if(F.filter(Y,[S]).length>0){W=S;break}}}S=S[T]}ab[V]=W}}}var J=document.compareDocumentPosition?function(T,S){return T.compareDocumentPosition(S)&16}:function(T,S){return T!==S&&(T.contains?T.contains(S):true)};var P=function(S){return S.nodeType===9&&S.documentElement.nodeName!=="HTML"||!!S.ownerDocument&&P(S.ownerDocument)};var I=function(S,Z){var V=[],W="",X,U=Z.nodeType?[Z]:Z;while((X=H.match.PSEUDO.exec(S))){W+=X[0];S=S.replace(H.match.PSEUDO,"")}S=H.relative[S]?S+"*":S;for(var Y=0,T=U.length;Y<T;Y++){F(S,U[Y],V)}return F.filter(W,V)};o.find=F;o.filter=F.filter;o.expr=F.selectors;o.expr[":"]=o.expr.filters;F.selectors.filters.hidden=function(S){return"hidden"===S.type||o.css(S,"display")==="none"||o.css(S,"visibility")==="hidden"};F.selectors.filters.visible=function(S){return"hidden"!==S.type&&o.css(S,"display")!=="none"&&o.css(S,"visibility")!=="hidden"};F.selectors.filters.animated=function(S){return o.grep(o.timers,function(T){return S===T.elem}).length};o.multiFilter=function(U,S,T){if(T){U=":not("+U+")"}return F.matches(U,S)};o.dir=function(U,T){var S=[],V=U[T];while(V&&V!=document){if(V.nodeType==1){S.push(V)}V=V[T]}return S};o.nth=function(W,S,U,V){S=S||1;var T=0;for(;W;W=W[U]){if(W.nodeType==1&&++T==S){break}}return W};o.sibling=function(U,T){var S=[];for(;U;U=U.nextSibling){if(U.nodeType==1&&U!=T){S.push(U)}}return S};return;l.Sizzle=F})();o.event={add:function(I,F,H,K){if(I.nodeType==3||I.nodeType==8){return}if(I.setInterval&&I!=l){I=l}if(!H.guid){H.guid=this.guid++}if(K!==g){var G=H;H=this.proxy(G);H.data=K}var E=o.data(I,"events")||o.data(I,"events",{}),J=o.data(I,"handle")||o.data(I,"handle",function(){return typeof o!=="undefined"&&!o.event.triggered?o.event.handle.apply(arguments.callee.elem,arguments):g});J.elem=I;o.each(F.split(/\s+/),function(M,N){var O=N.split(".");N=O.shift();H.type=O.slice().sort().join(".");var L=E[N];if(o.event.specialAll[N]){o.event.specialAll[N].setup.call(I,K,O)}if(!L){L=E[N]={};if(!o.event.special[N]||o.event.special[N].setup.call(I,K,O)===false){if(I.addEventListener){I.addEventListener(N,J,false)}else{if(I.attachEvent){I.attachEvent("on"+N,J)}}}}L[H.guid]=H;o.event.global[N]=true});I=null},guid:1,global:{},remove:function(K,H,J){if(K.nodeType==3||K.nodeType==8){return}var G=o.data(K,"events"),F,E;if(G){if(H===g||(typeof H==="string"&&H.charAt(0)==".")){for(var I in G){this.remove(K,I+(H||""))}}else{if(H.type){J=H.handler;H=H.type}o.each(H.split(/\s+/),function(M,O){var Q=O.split(".");O=Q.shift();var N=RegExp("(^|\\.)"+Q.slice().sort().join(".*\\.")+"(\\.|$)");if(G[O]){if(J){delete G[O][J.guid]}else{for(var P in G[O]){if(N.test(G[O][P].type)){delete G[O][P]}}}if(o.event.specialAll[O]){o.event.specialAll[O].teardown.call(K,Q)}for(F in G[O]){break}if(!F){if(!o.event.special[O]||o.event.special[O].teardown.call(K,Q)===false){if(K.removeEventListener){K.removeEventListener(O,o.data(K,"handle"),false)}else{if(K.detachEvent){K.detachEvent("on"+O,o.data(K,"handle"))}}}F=null;delete G[O]}}})}for(F in G){break}if(!F){var L=o.data(K,"handle");if(L){L.elem=null}o.removeData(K,"events");o.removeData(K,"handle")}}},trigger:function(I,K,H,E){var G=I.type||I;if(!E){I=typeof I==="object"?I[h]?I:o.extend(o.Event(G),I):o.Event(G);if(G.indexOf("!")>=0){I.type=G=G.slice(0,-1);I.exclusive=true}if(!H){I.stopPropagation();if(this.global[G]){o.each(o.cache,function(){if(this.events&&this.events[G]){o.event.trigger(I,K,this.handle.elem)}})}}if(!H||H.nodeType==3||H.nodeType==8){return g}I.result=g;I.target=H;K=o.makeArray(K);K.unshift(I)}I.currentTarget=H;var J=o.data(H,"handle");if(J){J.apply(H,K)}if((!H[G]||(o.nodeName(H,"a")&&G=="click"))&&H["on"+G]&&H["on"+G].apply(H,K)===false){I.result=false}if(!E&&H[G]&&!I.isDefaultPrevented()&&!(o.nodeName(H,"a")&&G=="click")){this.triggered=true;try{H[G]()}catch(L){}}this.triggered=false;if(!I.isPropagationStopped()){var F=H.parentNode||H.ownerDocument;if(F){o.event.trigger(I,K,F,true)}}},handle:function(K){var J,E;K=arguments[0]=o.event.fix(K||l.event);var L=K.type.split(".");K.type=L.shift();J=!L.length&&!K.exclusive;var I=RegExp("(^|\\.)"+L.slice().sort().join(".*\\.")+"(\\.|$)");E=(o.data(this,"events")||{})[K.type];for(var G in E){var H=E[G];if(J||I.test(H.type)){K.handler=H;K.data=H.data;var F=H.apply(this,arguments);if(F!==g){K.result=F;if(F===false){K.preventDefault();K.stopPropagation()}}if(K.isImmediatePropagationStopped()){break}}}},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(H){if(H[h]){return H}var F=H;H=o.Event(F);for(var G=this.props.length,J;G;){J=this.props[--G];H[J]=F[J]}if(!H.target){H.target=H.srcElement||document}if(H.target.nodeType==3){H.target=H.target.parentNode}if(!H.relatedTarget&&H.fromElement){H.relatedTarget=H.fromElement==H.target?H.toElement:H.fromElement}if(H.pageX==null&&H.clientX!=null){var I=document.documentElement,E=document.body;H.pageX=H.clientX+(I&&I.scrollLeft||E&&E.scrollLeft||0)-(I.clientLeft||0);H.pageY=H.clientY+(I&&I.scrollTop||E&&E.scrollTop||0)-(I.clientTop||0)}if(!H.which&&((H.charCode||H.charCode===0)?H.charCode:H.keyCode)){H.which=H.charCode||H.keyCode}if(!H.metaKey&&H.ctrlKey){H.metaKey=H.ctrlKey}if(!H.which&&H.button){H.which=(H.button&1?1:(H.button&2?3:(H.button&4?2:0)))}return H},proxy:function(F,E){E=E||function(){return F.apply(this,arguments)};E.guid=F.guid=F.guid||E.guid||this.guid++;return E},special:{ready:{setup:B,teardown:function(){}}},specialAll:{live:{setup:function(E,F){o.event.add(this,F[0],c)},teardown:function(G){if(G.length){var E=0,F=RegExp("(^|\\.)"+G[0]+"(\\.|$)");o.each((o.data(this,"events").live||{}),function(){if(F.test(this.type)){E++}});if(E<1){o.event.remove(this,G[0],c)}}}}}};o.Event=function(E){if(!this.preventDefault){return new o.Event(E)}if(E&&E.type){this.originalEvent=E;this.type=E.type}else{this.type=E}this.timeStamp=e();this[h]=true};function k(){return false}function u(){return true}o.Event.prototype={preventDefault:function(){this.isDefaultPrevented=u;var E=this.originalEvent;if(!E){return}if(E.preventDefault){E.preventDefault()}E.returnValue=false},stopPropagation:function(){this.isPropagationStopped=u;var E=this.originalEvent;if(!E){return}if(E.stopPropagation){E.stopPropagation()}E.cancelBubble=true},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=u;this.stopPropagation()},isDefaultPrevented:k,isPropagationStopped:k,isImmediatePropagationStopped:k};var a=function(F){var E=F.relatedTarget;while(E&&E!=this){try{E=E.parentNode}catch(G){E=this}}if(E!=this){F.type=F.data;o.event.handle.apply(this,arguments)}};o.each({mouseover:"mouseenter",mouseout:"mouseleave"},function(F,E){o.event.special[E]={setup:function(){o.event.add(this,F,a,E)},teardown:function(){o.event.remove(this,F,a)}}});o.fn.extend({bind:function(F,G,E){return F=="unload"?this.one(F,G,E):this.each(function(){o.event.add(this,F,E||G,E&&G)})},one:function(G,H,F){var E=o.event.proxy(F||H,function(I){o(this).unbind(I,E);return(F||H).apply(this,arguments)});return this.each(function(){o.event.add(this,G,E,F&&H)})},unbind:function(F,E){return this.each(function(){o.event.remove(this,F,E)})},trigger:function(E,F){return this.each(function(){o.event.trigger(E,F,this)})},triggerHandler:function(E,G){if(this[0]){var F=o.Event(E);F.preventDefault();F.stopPropagation();o.event.trigger(F,G,this[0]);return F.result}},toggle:function(G){var E=arguments,F=1;while(F<E.length){o.event.proxy(G,E[F++])}return this.click(o.event.proxy(G,function(H){this.lastToggle=(this.lastToggle||0)%F;H.preventDefault();return E[this.lastToggle++].apply(this,arguments)||false}))},hover:function(E,F){return this.mouseenter(E).mouseleave(F)},ready:function(E){B();if(o.isReady){E.call(document,o)}else{o.readyList.push(E)}return this},live:function(G,F){var E=o.event.proxy(F);E.guid+=this.selector+G;o(document).bind(i(G,this.selector),this.selector,E);return this},die:function(F,E){o(document).unbind(i(F,this.selector),E?{guid:E.guid+this.selector+F}:null);return this}});function c(H){var E=RegExp("(^|\\.)"+H.type+"(\\.|$)"),G=true,F=[];o.each(o.data(this,"events").live||[],function(I,J){if(E.test(J.type)){var K=o(H.target).closest(J.data)[0];if(K){F.push({elem:K,fn:J})}}});o.each(F,function(){if(this.fn.call(this.elem,H,this.fn.data)===false){G=false}});return G}function i(F,E){return["live",F,E.replace(/\./g,"`").replace(/ /g,"|")].join(".")}o.extend({isReady:false,readyList:[],ready:function(){if(!o.isReady){o.isReady=true;if(o.readyList){o.each(o.readyList,function(){this.call(document,o)});o.readyList=null}o(document).triggerHandler("ready")}}});var x=false;function B(){if(x){return}x=true;if(document.addEventListener){document.addEventListener("DOMContentLoaded",function(){document.removeEventListener("DOMContentLoaded",arguments.callee,false);o.ready()},false)}else{if(document.attachEvent){document.attachEvent("onreadystatechange",function(){if(document.readyState==="complete"){document.detachEvent("onreadystatechange",arguments.callee);o.ready()}});if(document.documentElement.doScroll&&typeof l.frameElement==="undefined"){(function(){if(o.isReady){return}try{document.documentElement.doScroll("left")}catch(E){setTimeout(arguments.callee,0);return}o.ready()})()}}}o.event.add(l,"load",o.ready)}o.each(("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error").split(","),function(F,E){o.fn[E]=function(G){return G?this.bind(E,G):this.trigger(E)}});o(l).bind("unload",function(){for(var E in o.cache){if(E!=1&&o.cache[E].handle){o.event.remove(o.cache[E].handle.elem)}}});(function(){o.support={};var F=document.documentElement,G=document.createElement("script"),K=document.createElement("div"),J="script"+(new Date).getTime();K.style.display="none";K.innerHTML='   <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>';var H=K.getElementsByTagName("*"),E=K.getElementsByTagName("a")[0];if(!H||!H.length||!E){return}o.support={leadingWhitespace:K.firstChild.nodeType==3,tbody:!K.getElementsByTagName("tbody").length,objectAll:!!K.getElementsByTagName("object")[0].getElementsByTagName("*").length,htmlSerialize:!!K.getElementsByTagName("link").length,style:/red/.test(E.getAttribute("style")),hrefNormalized:E.getAttribute("href")==="/a",opacity:E.style.opacity==="0.5",cssFloat:!!E.style.cssFloat,scriptEval:false,noCloneEvent:true,boxModel:null};G.type="text/javascript";try{G.appendChild(document.createTextNode("window."+J+"=1;"))}catch(I){}F.insertBefore(G,F.firstChild);if(l[J]){o.support.scriptEval=true;delete l[J]}F.removeChild(G);if(K.attachEvent&&K.fireEvent){K.attachEvent("onclick",function(){o.support.noCloneEvent=false;K.detachEvent("onclick",arguments.callee)});K.cloneNode(true).fireEvent("onclick")}o(function(){var L=document.createElement("div");L.style.width="1px";L.style.paddingLeft="1px";document.body.appendChild(L);o.boxModel=o.support.boxModel=L.offsetWidth===2;document.body.removeChild(L)})})();var w=o.support.cssFloat?"cssFloat":"styleFloat";o.props={"for":"htmlFor","class":"className","float":w,cssFloat:w,styleFloat:w,readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",tabindex:"tabIndex"};o.fn.extend({_load:o.fn.load,load:function(G,J,K){if(typeof G!=="string"){return this._load(G)}var I=G.indexOf(" ");if(I>=0){var E=G.slice(I,G.length);G=G.slice(0,I)}var H="GET";if(J){if(o.isFunction(J)){K=J;J=null}else{if(typeof J==="object"){J=o.param(J);H="POST"}}}var F=this;o.ajax({url:G,type:H,dataType:"html",data:J,complete:function(M,L){if(L=="success"||L=="notmodified"){F.html(E?o("<div/>").append(M.responseText.replace(/<script(.|\s)*?\/script>/g,"")).find(E):M.responseText)}if(K){F.each(K,[M.responseText,L,M])}}});return this},serialize:function(){return o.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?o.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||/select|textarea/i.test(this.nodeName)||/text|hidden|password/i.test(this.type))}).map(function(E,F){var G=o(this).val();return G==null?null:o.isArray(G)?o.map(G,function(I,H){return{name:F.name,value:I}}):{name:F.name,value:G}}).get()}});o.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","),function(E,F){o.fn[F]=function(G){return this.bind(F,G)}});var r=e();o.extend({get:function(E,G,H,F){if(o.isFunction(G)){H=G;G=null}return o.ajax({type:"GET",url:E,data:G,success:H,dataType:F})},getScript:function(E,F){return o.get(E,null,F,"script")},getJSON:function(E,F,G){return o.get(E,F,G,"json")},post:function(E,G,H,F){if(o.isFunction(G)){H=G;G={}}return o.ajax({type:"POST",url:E,data:G,success:H,dataType:F})},ajaxSetup:function(E){o.extend(o.ajaxSettings,E)},ajaxSettings:{url:location.href,global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:function(){return l.ActiveXObject?new ActiveXObject("Microsoft.XMLHTTP"):new XMLHttpRequest()},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},ajax:function(M){M=o.extend(true,M,o.extend(true,{},o.ajaxSettings,M));var W,F=/=\?(&|$)/g,R,V,G=M.type.toUpperCase();if(M.data&&M.processData&&typeof M.data!=="string"){M.data=o.param(M.data)}if(M.dataType=="jsonp"){if(G=="GET"){if(!M.url.match(F)){M.url+=(M.url.match(/\?/)?"&":"?")+(M.jsonp||"callback")+"=?"}}else{if(!M.data||!M.data.match(F)){M.data=(M.data?M.data+"&":"")+(M.jsonp||"callback")+"=?"}}M.dataType="json"}if(M.dataType=="json"&&(M.data&&M.data.match(F)||M.url.match(F))){W="jsonp"+r++;if(M.data){M.data=(M.data+"").replace(F,"="+W+"$1")}M.url=M.url.replace(F,"="+W+"$1");M.dataType="script";l[W]=function(X){V=X;I();L();l[W]=g;try{delete l[W]}catch(Y){}if(H){H.removeChild(T)}}}if(M.dataType=="script"&&M.cache==null){M.cache=false}if(M.cache===false&&G=="GET"){var E=e();var U=M.url.replace(/(\?|&)_=.*?(&|$)/,"$1_="+E+"$2");M.url=U+((U==M.url)?(M.url.match(/\?/)?"&":"?")+"_="+E:"")}if(M.data&&G=="GET"){M.url+=(M.url.match(/\?/)?"&":"?")+M.data;M.data=null}if(M.global&&!o.active++){o.event.trigger("ajaxStart")}var Q=/^(\w+:)?\/\/([^\/?#]+)/.exec(M.url);if(M.dataType=="script"&&G=="GET"&&Q&&(Q[1]&&Q[1]!=location.protocol||Q[2]!=location.host)){var H=document.getElementsByTagName("head")[0];var T=document.createElement("script");T.src=M.url;if(M.scriptCharset){T.charset=M.scriptCharset}if(!W){var O=false;T.onload=T.onreadystatechange=function(){if(!O&&(!this.readyState||this.readyState=="loaded"||this.readyState=="complete")){O=true;I();L();H.removeChild(T)}}}H.appendChild(T);return g}var K=false;var J=M.xhr();if(M.username){J.open(G,M.url,M.async,M.username,M.password)}else{J.open(G,M.url,M.async)}try{if(M.data){J.setRequestHeader("Content-Type",M.contentType)}if(M.ifModified){J.setRequestHeader("If-Modified-Since",o.lastModified[M.url]||"Thu, 01 Jan 1970 00:00:00 GMT")}J.setRequestHeader("X-Requested-With","XMLHttpRequest");J.setRequestHeader("Accept",M.dataType&&M.accepts[M.dataType]?M.accepts[M.dataType]+", */*":M.accepts._default)}catch(S){}if(M.beforeSend&&M.beforeSend(J,M)===false){if(M.global&&!--o.active){o.event.trigger("ajaxStop")}J.abort();return false}if(M.global){o.event.trigger("ajaxSend",[J,M])}var N=function(X){if(J.readyState==0){if(P){clearInterval(P);P=null;if(M.global&&!--o.active){o.event.trigger("ajaxStop")}}}else{if(!K&&J&&(J.readyState==4||X=="timeout")){K=true;if(P){clearInterval(P);P=null}R=X=="timeout"?"timeout":!o.httpSuccess(J)?"error":M.ifModified&&o.httpNotModified(J,M.url)?"notmodified":"success";if(R=="success"){try{V=o.httpData(J,M.dataType,M)}catch(Z){R="parsererror"}}if(R=="success"){var Y;try{Y=J.getResponseHeader("Last-Modified")}catch(Z){}if(M.ifModified&&Y){o.lastModified[M.url]=Y}if(!W){I()}}else{o.handleError(M,J,R)}L();if(X){J.abort()}if(M.async){J=null}}}};if(M.async){var P=setInterval(N,13);if(M.timeout>0){setTimeout(function(){if(J&&!K){N("timeout")}},M.timeout)}}try{J.send(M.data)}catch(S){o.handleError(M,J,null,S)}if(!M.async){N()}function I(){if(M.success){M.success(V,R)}if(M.global){o.event.trigger("ajaxSuccess",[J,M])}}function L(){if(M.complete){M.complete(J,R)}if(M.global){o.event.trigger("ajaxComplete",[J,M])}if(M.global&&!--o.active){o.event.trigger("ajaxStop")}}return J},handleError:function(F,H,E,G){if(F.error){F.error(H,E,G)}if(F.global){o.event.trigger("ajaxError",[H,F,G])}},active:0,httpSuccess:function(F){try{return !F.status&&location.protocol=="file:"||(F.status>=200&&F.status<300)||F.status==304||F.status==1223}catch(E){}return false},httpNotModified:function(G,E){try{var H=G.getResponseHeader("Last-Modified");return G.status==304||H==o.lastModified[E]}catch(F){}return false},httpData:function(J,H,G){var F=J.getResponseHeader("content-type"),E=H=="xml"||!H&&F&&F.indexOf("xml")>=0,I=E?J.responseXML:J.responseText;if(E&&I.documentElement.tagName=="parsererror"){throw"parsererror"}if(G&&G.dataFilter){I=G.dataFilter(I,H)}if(typeof I==="string"){if(H=="script"){o.globalEval(I)}if(H=="json"){I=l["eval"]("("+I+")")}}return I},param:function(E){var G=[];function H(I,J){G[G.length]=encodeURIComponent(I)+"="+encodeURIComponent(J)}if(o.isArray(E)||E.jquery){o.each(E,function(){H(this.name,this.value)})}else{for(var F in E){if(o.isArray(E[F])){o.each(E[F],function(){H(F,this)})}else{H(F,o.isFunction(E[F])?E[F]():E[F])}}}return G.join("&").replace(/%20/g,"+")}});var m={},n,d=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];function t(F,E){var G={};o.each(d.concat.apply([],d.slice(0,E)),function(){G[this]=F});return G}o.fn.extend({show:function(J,L){if(J){return this.animate(t("show",3),J,L)}else{for(var H=0,F=this.length;H<F;H++){var E=o.data(this[H],"olddisplay");this[H].style.display=E||"";if(o.css(this[H],"display")==="none"){var G=this[H].tagName,K;if(m[G]){K=m[G]}else{var I=o("<"+G+" />").appendTo("body");K=I.css("display");if(K==="none"){K="block"}I.remove();m[G]=K}this[H].style.display=o.data(this[H],"olddisplay",K)}}return this}},hide:function(H,I){if(H){return this.animate(t("hide",3),H,I)}else{for(var G=0,F=this.length;G<F;G++){var E=o.data(this[G],"olddisplay");if(!E&&E!=="none"){o.data(this[G],"olddisplay",o.css(this[G],"display"))}this[G].style.display="none"}return this}},_toggle:o.fn.toggle,toggle:function(G,F){var E=typeof G==="boolean";return o.isFunction(G)&&o.isFunction(F)?this._toggle.apply(this,arguments):G==null||E?this.each(function(){var H=E?G:o(this).is(":hidden");o(this)[H?"show":"hide"]()}):this.animate(t("toggle",3),G,F)},fadeTo:function(E,G,F){return this.animate({opacity:G},E,F)},animate:function(I,F,H,G){var E=o.speed(F,H,G);return this[E.queue===false?"each":"queue"](function(){var K=o.extend({},E),M,L=this.nodeType==1&&o(this).is(":hidden"),J=this;for(M in I){if(I[M]=="hide"&&L||I[M]=="show"&&!L){return K.complete.call(this)}if((M=="height"||M=="width")&&this.style){K.display=o.css(this,"display");K.overflow=this.style.overflow}}if(K.overflow!=null){this.style.overflow="hidden"}K.curAnim=o.extend({},I);o.each(I,function(O,S){var R=new o.fx(J,K,O);if(/toggle|show|hide/.test(S)){R[S=="toggle"?L?"show":"hide":S](I)}else{var Q=S.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/),T=R.cur(true)||0;if(Q){var N=parseFloat(Q[2]),P=Q[3]||"px";if(P!="px"){J.style[O]=(N||1)+P;T=((N||1)/R.cur(true))*T;J.style[O]=T+P}if(Q[1]){N=((Q[1]=="-="?-1:1)*N)+T}R.custom(T,N,P)}else{R.custom(T,S,"")}}});return true})},stop:function(F,E){var G=o.timers;if(F){this.queue([])}this.each(function(){for(var H=G.length-1;H>=0;H--){if(G[H].elem==this){if(E){G[H](true)}G.splice(H,1)}}});if(!E){this.dequeue()}return this}});o.each({slideDown:t("show",1),slideUp:t("hide",1),slideToggle:t("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(E,F){o.fn[E]=function(G,H){return this.animate(F,G,H)}});o.extend({speed:function(G,H,F){var E=typeof G==="object"?G:{complete:F||!F&&H||o.isFunction(G)&&G,duration:G,easing:F&&H||H&&!o.isFunction(H)&&H};E.duration=o.fx.off?0:typeof E.duration==="number"?E.duration:o.fx.speeds[E.duration]||o.fx.speeds._default;E.old=E.complete;E.complete=function(){if(E.queue!==false){o(this).dequeue()}if(o.isFunction(E.old)){E.old.call(this)}};return E},easing:{linear:function(G,H,E,F){return E+F*G},swing:function(G,H,E,F){return((-Math.cos(G*Math.PI)/2)+0.5)*F+E}},timers:[],fx:function(F,E,G){this.options=E;this.elem=F;this.prop=G;if(!E.orig){E.orig={}}}});o.fx.prototype={update:function(){if(this.options.step){this.options.step.call(this.elem,this.now,this)}(o.fx.step[this.prop]||o.fx.step._default)(this);if((this.prop=="height"||this.prop=="width")&&this.elem.style){this.elem.style.display="block"}},cur:function(F){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null)){return this.elem[this.prop]}var E=parseFloat(o.css(this.elem,this.prop,F));return E&&E>-10000?E:parseFloat(o.curCSS(this.elem,this.prop))||0},custom:function(I,H,G){this.startTime=e();this.start=I;this.end=H;this.unit=G||this.unit||"px";this.now=this.start;this.pos=this.state=0;var E=this;function F(J){return E.step(J)}F.elem=this.elem;if(F()&&o.timers.push(F)==1){n=setInterval(function(){var K=o.timers;for(var J=0;J<K.length;J++){if(!K[J]()){K.splice(J--,1)}}if(!K.length){clearInterval(n)}},13)}},show:function(){this.options.orig[this.prop]=o.attr(this.elem.style,this.prop);this.options.show=true;this.custom(this.prop=="width"||this.prop=="height"?1:0,this.cur());o(this.elem).show()},hide:function(){this.options.orig[this.prop]=o.attr(this.elem.style,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(H){var G=e();if(H||G>=this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;var E=true;for(var F in this.options.curAnim){if(this.options.curAnim[F]!==true){E=false}}if(E){if(this.options.display!=null){this.elem.style.overflow=this.options.overflow;this.elem.style.display=this.options.display;if(o.css(this.elem,"display")=="none"){this.elem.style.display="block"}}if(this.options.hide){o(this.elem).hide()}if(this.options.hide||this.options.show){for(var I in this.options.curAnim){o.attr(this.elem.style,I,this.options.orig[I])}}this.options.complete.call(this.elem)}return false}else{var J=G-this.startTime;this.state=J/this.options.duration;this.pos=o.easing[this.options.easing||(o.easing.swing?"swing":"linear")](this.state,J,0,1,this.options.duration);this.now=this.start+((this.end-this.start)*this.pos);this.update()}return true}};o.extend(o.fx,{speeds:{slow:600,fast:200,_default:400},step:{opacity:function(E){o.attr(E.elem.style,"opacity",E.now)},_default:function(E){if(E.elem.style&&E.elem.style[E.prop]!=null){E.elem.style[E.prop]=E.now+E.unit}else{E.elem[E.prop]=E.now}}}});if(document.documentElement.getBoundingClientRect){o.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return o.offset.bodyOffset(this[0])}var G=this[0].getBoundingClientRect(),J=this[0].ownerDocument,F=J.body,E=J.documentElement,L=E.clientTop||F.clientTop||0,K=E.clientLeft||F.clientLeft||0,I=G.top+(self.pageYOffset||o.boxModel&&E.scrollTop||F.scrollTop)-L,H=G.left+(self.pageXOffset||o.boxModel&&E.scrollLeft||F.scrollLeft)-K;return{top:I,left:H}}}else{o.fn.offset=function(){if(!this[0]){return{top:0,left:0}}if(this[0]===this[0].ownerDocument.body){return o.offset.bodyOffset(this[0])}o.offset.initialized||o.offset.initialize();var J=this[0],G=J.offsetParent,F=J,O=J.ownerDocument,M,H=O.documentElement,K=O.body,L=O.defaultView,E=L.getComputedStyle(J,null),N=J.offsetTop,I=J.offsetLeft;while((J=J.parentNode)&&J!==K&&J!==H){M=L.getComputedStyle(J,null);N-=J.scrollTop,I-=J.scrollLeft;if(J===G){N+=J.offsetTop,I+=J.offsetLeft;if(o.offset.doesNotAddBorder&&!(o.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(J.tagName))){N+=parseInt(M.borderTopWidth,10)||0,I+=parseInt(M.borderLeftWidth,10)||0}F=G,G=J.offsetParent}if(o.offset.subtractsBorderForOverflowNotVisible&&M.overflow!=="visible"){N+=parseInt(M.borderTopWidth,10)||0,I+=parseInt(M.borderLeftWidth,10)||0}E=M}if(E.position==="relative"||E.position==="static"){N+=K.offsetTop,I+=K.offsetLeft}if(E.position==="fixed"){N+=Math.max(H.scrollTop,K.scrollTop),I+=Math.max(H.scrollLeft,K.scrollLeft)}return{top:N,left:I}}}o.offset={initialize:function(){if(this.initialized){return}var L=document.body,F=document.createElement("div"),H,G,N,I,M,E,J=L.style.marginTop,K='<div style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"><div></div></div><table style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;" cellpadding="0" cellspacing="0"><tr><td></td></tr></table>';M={position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"};for(E in M){F.style[E]=M[E]}F.innerHTML=K;L.insertBefore(F,L.firstChild);H=F.firstChild,G=H.firstChild,I=H.nextSibling.firstChild.firstChild;this.doesNotAddBorder=(G.offsetTop!==5);this.doesAddBorderForTableAndCells=(I.offsetTop===5);H.style.overflow="hidden",H.style.position="relative";this.subtractsBorderForOverflowNotVisible=(G.offsetTop===-5);L.style.marginTop="1px";this.doesNotIncludeMarginInBodyOffset=(L.offsetTop===0);L.style.marginTop=J;L.removeChild(F);this.initialized=true},bodyOffset:function(E){o.offset.initialized||o.offset.initialize();var G=E.offsetTop,F=E.offsetLeft;if(o.offset.doesNotIncludeMarginInBodyOffset){G+=parseInt(o.curCSS(E,"marginTop",true),10)||0,F+=parseInt(o.curCSS(E,"marginLeft",true),10)||0}return{top:G,left:F}}};o.fn.extend({position:function(){var I=0,H=0,F;if(this[0]){var G=this.offsetParent(),J=this.offset(),E=/^body|html$/i.test(G[0].tagName)?{top:0,left:0}:G.offset();J.top-=j(this,"marginTop");J.left-=j(this,"marginLeft");E.top+=j(G,"borderTopWidth");E.left+=j(G,"borderLeftWidth");F={top:J.top-E.top,left:J.left-E.left}}return F},offsetParent:function(){var E=this[0].offsetParent||document.body;while(E&&(!/^body|html$/i.test(E.tagName)&&o.css(E,"position")=="static")){E=E.offsetParent}return o(E)}});o.each(["Left","Top"],function(F,E){var G="scroll"+E;o.fn[G]=function(H){if(!this[0]){return null}return H!==g?this.each(function(){this==l||this==document?l.scrollTo(!F?H:o(l).scrollLeft(),F?H:o(l).scrollTop()):this[G]=H}):this[0]==l||this[0]==document?self[F?"pageYOffset":"pageXOffset"]||o.boxModel&&document.documentElement[G]||document.body[G]:this[0][G]}});o.each(["Height","Width"],function(H,F){var E=H?"Left":"Top",G=H?"Right":"Bottom";o.fn["inner"+F]=function(){return this[F.toLowerCase()]()+j(this,"padding"+E)+j(this,"padding"+G)};o.fn["outer"+F]=function(J){return this["inner"+F]()+j(this,"border"+E+"Width")+j(this,"border"+G+"Width")+(J?j(this,"margin"+E)+j(this,"margin"+G):0)};var I=F.toLowerCase();o.fn[I]=function(J){return this[0]==l?document.compatMode=="CSS1Compat"&&document.documentElement["client"+F]||document.body["client"+F]:this[0]==document?Math.max(document.documentElement["client"+F],document.body["scroll"+F],document.documentElement["scroll"+F],document.body["offset"+F],document.documentElement["offset"+F]):J===g?(this.length?o.css(this[0],I):null):this.css(I,typeof J==="string"?J:J+"px")}})})();promoPrev=0;
zIndex=200;

xHelp=0;
yHelp=0;

$(document).ready(function () 
{	
	
	$('#index_service1').animate({opacity: 0}, 0);
	$('#index_service2').animate({opacity: 0}, 0);
	$('#index_service3').animate({opacity: 0}, 0);
	$('#index_service4').animate({opacity: 0}, 0);
	$('#index_service5').animate({opacity: 0}, 0);
	$('#index_service6').animate({opacity: 0}, 0);
	$('#index_service7').animate({opacity: 0}, 0);
	$('#index_service8').animate({opacity: 0}, 0);

	
	liMenu=$('#list_services li');
	liMenu.click(function(){  
			labelClicked=$(this).attr('id').substr($(this).attr('id').length-1,$(this).attr('id').length);
			if(labelClicked!=promoPrev){
				$('#list_services').removeClass().addClass('pos'+labelClicked);
				$('#index_service'+labelClicked).animate({ opacity: 1}, 1000);
				zIndex++;
				$('#index_service'+labelClicked).css('z-index',zIndex);
				$('#index_service'+promoPrev).animate({ opacity: 0}, 1000);
				promoPrev=labelClicked;
			}
		return false;
	})
})


function show_panel(name) 
{
 	var expanded = document.getElementById(name);
    if(expanded.style.display == "none" || !expanded.style.display)
    {
         expanded.style.display = "block";
    return false;
	}
    else if(expanded.style.display == "block") 
    {
         expanded.style.display = "none";
    return false;
    }
    return false;
}


var max_width = 210;
var init_width = Array();
var width = Array();
var main_children = Array();
var id_show = Array();
var id_hide = Array();
var main_speed = 10;

function init_main(name) 
{
	if((width[name] != 0))
	{
	
			if(width[name] > 0)
			{
			
			}
			else
			{
			width[name] = 0;
			}
	}
	else
	{
	return false;
	}
	
}

function show(name) 
{
	init_main(name);
	expand(name);
	return false;
}

function hide(name) 
{
	
	contract(name);
	return false;
}





function expand(name)
{
	clearTimeout(id_hide[name]);
	if (width[name]==max_width+1)
	{
		return
	}
	else
	{
	if (document.all)
		document.getElementById(name).style.width=width[name]+'px'
	else if (document.getElementById)
		document.getElementById(name).style.width=width[name]+'px'
		width[name]+=main_speed;
	if (width[name]>max_width+1){
	width[name]-=main_speed;
	return
	}
	else
	
	  id_show[name] = setTimeout("expand('"+name+"')",50);
	}
}


function contract(name)
{
clearTimeout(id_show[name]);
if (document.all)
	document.getElementById(name).style.width=width[name] +'px'
else if (document.getElementById)
	document.getElementById(name).style.width=width[name] +'px'
	width[name]-=main_speed;
if (width[name]<0){

return
}
else
  id_hide[name] = setTimeout("contract('"+name+"')",50)
}





function show_main(name) 
{
if (document.all)
	test.style.width=width+'px'
else if (document.getElementById)
	document.getElementById("test").style.width=width+'px'
	width+=1
if (width>209){

return
}
else
	setTimeout("expand()",50)
}var slideMenu=function(){
	var sp,st,t,m,sa,l,w,sw,ot;
	return{
		build:function(sm,sw,mt,s,sl,h){
			sp=s; st=sw; t=mt;
			m=document.getElementById(sm);
			sa=m.getElementsByTagName('li');
			l=sa.length; w=m.offsetWidth; sw=w/l;
			ot=Math.floor((w-st)/(l-1)); var i=0;
			for(i;i<l;i++){s=sa[i]; s.style.width=sw+'px'; this.timer(s)}
			if(sl!=null){m.timer=setInterval(function(){slideMenu.slide(sa[sl-1])},t)}
		},
		timer:function(s){s.onmouseover=function(){clearInterval(m.timer);m.timer=setInterval(function(){slideMenu.slide(s)},t)}},
		slide:function(s){
			var cw=parseInt(s.style.width,'10');
			if(cw<st){
				var owt=0; var i=0;
				for(i;i<l;i++){
					if(sa[i]!=s){
						var o,ow; var oi=0; o=sa[i]; ow=parseInt(o.style.width,'10');
						if(ow>ot){oi=Math.floor((ow-ot)/sp); oi=(oi>0)?oi:1; o.style.width=(ow-oi)+'px'}
						owt=owt+(ow-oi)}}
				s.style.width=(w-owt)+'px';
			}else{clearInterval(m.timer)}
		}
	};
}();			   


function expandcontent(linkobj){
var ulid=linkobj.parentNode.parentNode.id //id of UL element
var ullist=document.getElementById(ulid).getElementsByTagName("li") //get list of LIs corresponding to the tab contents
for (var i=0; i<ullist.length; i++){
ullist[i].className=""  //deselect all tabs
if (typeof tabcontentIDs[ulid][i]!="undefined") //if tab content within this array index exists (exception: More tabs than there are tab contents)
	if(document.getElementById(tabcontentIDs[ulid][i]))
	{
	document.getElementById(tabcontentIDs[ulid][i]).style.display="none" //hide all tab contents
	}
}
linkobj.parentNode.className="selected"  //highlight currently clicked on tab
if(document.getElementById(linkobj.getAttribute("rel")))
{
document.getElementById(linkobj.getAttribute("rel")).style.display="block" //expand corresponding tab content
}
}


function initializetabcontent(tab_sel)
{
	if (document.getElementById(tab_sel))
	{
	document.getElementById(tab_sel).style.display="block" //expand corresponding tab content	
	}
	else
	{
	if (document.getElementById("default"))
	{	
	document.getElementById("default").style.display="block" //expand corresponding tab content
	}
	}

}


tabpanels = function(element, opts)
{
	this.element = this.getElement(element);
	this.defaultTab = 0; // Show the first panel by default.
	this.bindings = [];
	this.tabSelectedClass = "TabPanelsHeadSelected";
	this.tabHoverClass = "TabPanelsHeadHover";
	this.tabFocusedClass = "TabPanelsHeadFocused";
	this.panelVisibleClass = "TabPanelsContentVisible";
	this.focusElement = null;
	this.hasFocus = false;
	this.currentTabIndex = 0;
	this.enableKeyboardNavigation = true;

	tabpanels.setOptions(this, opts);

	// If the defaultTab is expressed as a number/index, convert
	// it to an element.

	if (typeof (this.defaultTab) == "number")
	{
		if (this.defaultTab < 0)
			this.defaultTab = 0;
		else
		{
			var count = this.getTabbedPanelCount();
			if (this.defaultTab >= count)
				this.defaultTab = (count > 1) ? (count - 1) : 0;
		}

		this.defaultTab = this.getTabs()[this.defaultTab];
	}

	// The defaultTab property is supposed to be the tab element for the tab content
	// to show by default. The caller is allowed to pass in the element itself or the
	// element's id, so we need to convert the current value to an element if necessary.

	if (this.defaultTab)
		this.defaultTab = this.getElement(this.defaultTab);

	this.attachBehaviors();
};

tabpanels.prototype.getElement = function(ele)
{
	if (ele && typeof ele == "string")
		return document.getElementById(ele);
	return ele;
}

tabpanels.prototype.getElementChildren = function(element)
{
	var children = [];
	var child = element.firstChild;
	while (child)
	{
		if (child.nodeType == 1 /* Node.ELEMENT_NODE */)
			children.push(child);
		child = child.nextSibling;
	}
	return children;
};

tabpanels.prototype.addClassName = function(ele, className)
{
	if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) != -1))
		return;
	ele.className += (ele.className ? " " : "") + className;
};

tabpanels.prototype.removeClassName = function(ele, className)
{
	if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) == -1))
		return;
	ele.className = ele.className.replace(new RegExp("\\s*\\b" + className + "\\b", "g"), "");
};

tabpanels.setOptions = function(obj, optionsObj, ignoreUndefinedProps)
{
	if (!optionsObj)
		return;
	for (var optionName in optionsObj)
	{
		if (ignoreUndefinedProps && optionsObj[optionName] == undefined)
			continue;
		obj[optionName] = optionsObj[optionName];
	}
};

tabpanels.prototype.getTabGroup = function()
{
	if (this.element)
	{
		var children = this.getElementChildren(this.element);
		if (children.length)
			return children[0];
	}
	return null;
};

tabpanels.prototype.getTabs = function()
{
	var tabs = [];
	var tg = this.getTabGroup();
	if (tg)
		tabs = this.getElementChildren(tg);
	return tabs;
};

tabpanels.prototype.getContentPanelGroup = function()
{
	if (this.element)
	{
		var children = this.getElementChildren(this.element);
		if (children.length > 1)
			return children[1];
	}
	return null;
};

tabpanels.prototype.getContentPanels = function()
{
	var panels = [];
	var pg = this.getContentPanelGroup();
	if (pg)
		panels = this.getElementChildren(pg);
	return panels;
};

tabpanels.prototype.getIndex = function(ele, arr)
{
	ele = this.getElement(ele);
	if (ele && arr && arr.length)
	{
		for (var i = 0; i < arr.length; i++)
		{
			if (ele == arr[i])
				return i;
		}
	}
	return -1;
};

tabpanels.prototype.getTabIndex = function(ele)
{
	var i = this.getIndex(ele, this.getTabs());
	if (i < 0)
		i = this.getIndex(ele, this.getContentPanels());
	return i;
};

tabpanels.prototype.getCurrentTabIndex = function()
{
	return this.currentTabIndex;
};

tabpanels.prototype.getTabbedPanelCount = function(ele)
{
	return Math.min(this.getTabs().length, this.getContentPanels().length);
};

tabpanels.addEventListener = function(element, eventType, handler, capture)
{
	try
	{
		if (element.addEventListener)
			element.addEventListener(eventType, handler, capture);
		else if (element.attachEvent)
			element.attachEvent("on" + eventType, handler);
	}
	catch (e) {}
};

tabpanels.prototype.onTabClick = function(e, tab)
{
	this.showPanel(tab);
};

tabpanels.prototype.onTabMouseOver = function(e, tab)
{
	this.addClassName(tab, this.tabHoverClass);
};

tabpanels.prototype.onTabMouseOut = function(e, tab)
{
	this.removeClassName(tab, this.tabHoverClass);
};

tabpanels.prototype.onTabFocus = function(e, tab)
{
	this.hasFocus = true;
	this.addClassName(this.element, this.tabFocusedClass);
};

tabpanels.prototype.onTabBlur = function(e, tab)
{
	this.hasFocus = false;
	this.removeClassName(this.element, this.tabFocusedClass);
};

tabpanels.ENTER_KEY = 13;
tabpanels.SPACE_KEY = 32;

tabpanels.prototype.onTabKeyDown = function(e, tab)
{
	var key = e.keyCode;
	if (!this.hasFocus || (key != tabpanels.ENTER_KEY && key != tabpanels.SPACE_KEY))
		return true;

	this.showPanel(tab);

	if (e.stopPropagation)
		e.stopPropagation();
	if (e.preventDefault)
		e.preventDefault();

	return false;
};

tabpanels.prototype.preorderTraversal = function(root, func)
{
	var stopTraversal = false;
	if (root)
	{
		stopTraversal = func(root);
		if (root.hasChildNodes())
		{
			var child = root.firstChild;
			while (!stopTraversal && child)
			{
				stopTraversal = this.preorderTraversal(child, func);
				try { child = child.nextSibling; } catch (e) { child = null; }
			}
		}
	}
	return stopTraversal;
};

tabpanels.prototype.addPanelEventListeners = function(tab, panel)
{
	var self = this;
	tabpanels.addEventListener(tab, "click", function(e) { return self.onTabClick(e, tab); }, false);
	tabpanels.addEventListener(tab, "mouseover", function(e) { return self.onTabMouseOver(e, tab); }, false);
	tabpanels.addEventListener(tab, "mouseout", function(e) { return self.onTabMouseOut(e, tab); }, false);

	if (this.enableKeyboardNavigation)
	{
		// XXX: IE doesn't allow the setting of tabindex dynamically. This means we can't
		// rely on adding the tabindex attribute if it is missing to enable keyboard navigation
		// by default.

		// Find the first element within the tab container that has a tabindex or the first
		// anchor tag.
		
		var tabIndexEle = null;
		var tabAnchorEle = null;

		this.preorderTraversal(tab, function(node) {
			if (node.nodeType == 1 /* NODE.ELEMENT_NODE */)
			{
				var tabIndexAttr = tab.attributes.getNamedItem("tabindex");
				if (tabIndexAttr)
				{
					tabIndexEle = node;
					return true;
				}
				if (!tabAnchorEle && node.nodeName.toLowerCase() == "a")
					tabAnchorEle = node;
			}
			return false;
		});

		if (tabIndexEle)
			this.focusElement = tabIndexEle;
		else if (tabAnchorEle)
			this.focusElement = tabAnchorEle;

		if (this.focusElement)
		{
			tabpanels.addEventListener(this.focusElement, "focus", function(e) { return self.onTabFocus(e, tab); }, false);
			tabpanels.addEventListener(this.focusElement, "blur", function(e) { return self.onTabBlur(e, tab); }, false);
			tabpanels.addEventListener(this.focusElement, "keydown", function(e) { return self.onTabKeyDown(e, tab); }, false);
		}
	}
};

tabpanels.prototype.showPanel = function(elementOrIndex)
{
	var tpIndex = -1;
	
	if (typeof elementOrIndex == "number")
		tpIndex = elementOrIndex;
	else // Must be the element for the tab or content panel.
		tpIndex = this.getTabIndex(elementOrIndex);
	
	if (!tpIndex < 0 || tpIndex >= this.getTabbedPanelCount())
		return;

	var tabs = this.getTabs();
	var panels = this.getContentPanels();

	var numTabPanels = Math.max(tabs.length, panels.length);

	for (var i = 0; i < numTabPanels; i++)
	{
		if (i != tpIndex)
		{
			if (tabs[i])
				this.removeClassName(tabs[i], this.tabSelectedClass);
			if (panels[i])
			{
				this.removeClassName(panels[i], this.panelVisibleClass);
				panels[i].style.display = "none";
			}
		}
	}

	this.addClassName(tabs[tpIndex], this.tabSelectedClass);
	this.addClassName(panels[tpIndex], this.panelVisibleClass);
	panels[tpIndex].style.display = "block";

	this.currentTabIndex = tpIndex;
};

tabpanels.prototype.attachBehaviors = function(element)
{
	var tabs = this.getTabs();
	var panels = this.getContentPanels();
	var panelCount = this.getTabbedPanelCount();

	for (var i = 0; i < panelCount; i++)
		this.addPanelEventListeners(tabs[i], panels[i]);

	this.showPanel(this.defaultTab);
};
vtabs = function(element, opts)
{
	this.element = this.getElement(element);
	this.defaultPanel = 0;
	this.hoverClass = "vtabsPanelTabHover";
	this.openClass = "vtabsPanelOpen";
	this.closedClass = "vtabsPanelClosed";
	this.enableAnimation = true;
	this.currentPanel = null;
	this.animator = null;
	this.hasFocus = null;
	this.duration = 500;


	this.useFixedPanelHeights = true;
	this.fixedPanelHeight = 0;

	vtabs.setOptions(this, opts, true);

	// Unfortunately in some browsers like Safari, the Stylesheets our
	// page depends on may not have been loaded at the time we are called.
	// This means we have to defer attaching our behaviors until after the
	// onload event fires, since some of our behaviors rely on dimensions
	// specified in the CSS.

	if (vtabs.onloadDidFire)
		this.attachBehaviors();
	else
		vtabs.loadQueue.push(this);
};

vtabs.onloadDidFire = false;
vtabs.loadQueue = [];

vtabs.addLoadListener = function(handler)
{
	if (typeof window.addEventListener != 'undefined')
		window.addEventListener('load', handler, false);
	else if (typeof document.addEventListener != 'undefined')
		document.addEventListener('load', handler, false);
	else if (typeof window.attachEvent != 'undefined')
		window.attachEvent('onload', handler);
};

vtabs.processLoadQueue = function(handler)
{
	vtabs.onloadDidFire = true;
	var q = vtabs.loadQueue;
	var qlen = q.length;
	for (var i = 0; i < qlen; i++)
		q[i].attachBehaviors();
};

vtabs.addLoadListener(vtabs.processLoadQueue);

vtabs.prototype.getElement = function(ele)
{
	if (ele && typeof ele == "string")
		return document.getElementById(ele);
	return ele;
};

vtabs.prototype.addClassName = function(ele, className)
{
	if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) != -1))
		return;
	ele.className += (ele.className ? " " : "") + className;
};

vtabs.prototype.removeClassName = function(ele, className)
{
	if (!ele || !className || (ele.className && ele.className.search(new RegExp("\\b" + className + "\\b")) == -1))
		return;
	ele.className = ele.className.replace(new RegExp("\\s*\\b" + className + "\\b", "g"), "");
};

vtabs.setOptions = function(obj, optionsObj, ignoreUndefinedProps)
{
	if (!optionsObj)
		return;
	for (var optionName in optionsObj)
	{
		if (ignoreUndefinedProps && optionsObj[optionName] == undefined)
			continue;
		obj[optionName] = optionsObj[optionName];
	}
};

vtabs.prototype.onPanelTabMouseOver = function(panel)
{
	if (panel)
		this.addClassName(this.getPanelTab(panel), this.hoverClass);
};

vtabs.prototype.onPanelTabMouseOut = function(panel)
{
	if (panel)
		this.removeClassName(this.getPanelTab(panel), this.hoverClass);
};

vtabs.prototype.openPanel = function(panel)
{
	var panelA = this.currentPanel;
	var panelB = panel;
	
	if (!panelB || panelA == panelB)	
		return;

	var contentA; 
	if( panelA )
		contentA = this.getPanelContent(panelA);
	var contentB = this.getPanelContent(panelB);

	if (! contentB)
		return;

	if (this.useFixedPanelHeights && !this.fixedPanelHeight)
	{
		this.fixedPanelHeight = (contentA.offsetHeight) ? contentA.offsetHeight : contentA.scrollHeight;
	}

	if (this.enableAnimation)
	{
		if (this.animator)
			this.animator.stop();
		this.animator = new vtabs.PanelAnimator(this, panelB, { duration: this.duration });
		this.animator.start();
	}
	else
	{
		if(contentA)
			contentA.style.height = "0px";
		contentB.style.height = (this.useFixedPanelHeights ? this.fixedPanelHeight : contentB.scrollHeight) + "px";
	}

	if(panelA)
	{
		this.removeClassName(panelA, this.openClass);
		this.addClassName(panelA, this.closedClass);
	}

	this.removeClassName(panelB, this.closedClass);
	this.addClassName(panelB, this.openClass);

	this.currentPanel = panelB;
};





vtabs.prototype.onPanelClick = function(panel)
{

	if (panel != this.currentPanel)
		this.openPanel(panel);
	this.focus();
};







vtabs.prototype.attachPanelHandlers = function(panel)
{
	if (!panel)
		return;

	var tab = this.getPanelTab(panel);

	if (tab)
	{
		var self = this;
		vtabs.addEventListener(tab, "click", function(e) { return self.onPanelClick(panel); }, false);
		vtabs.addEventListener(tab, "mouseover", function(e) { return self.onPanelTabMouseOver(panel); }, false);
		vtabs.addEventListener(tab, "mouseout", function(e) { return self.onPanelTabMouseOut(panel); }, false);
	}
};

vtabs.addEventListener = function(element, eventType, handler, capture)
{
	try
	{
		if (element.addEventListener)
			element.addEventListener(eventType, handler, capture);
		else if (element.attachEvent)
			element.attachEvent("on" + eventType, handler);
	}
	catch (e) {}
};

vtabs.prototype.initPanel = function(panel, isDefault)
{
	var content = this.getPanelContent(panel);
	if (isDefault)
	{
		this.currentPanel = panel;
		this.removeClassName(panel, this.closedClass);
		this.addClassName(panel, this.openClass);
	}
	else
	{
		this.removeClassName(panel, this.openClass);
		this.addClassName(panel, this.closedClass);
		content.style.height = "0px";
	}
	
	this.attachPanelHandlers(panel);
};

vtabs.prototype.attachBehaviors = function()
{
	var panels = this.getPanels();
	for (var i = 0; i < panels.length; i++)
	{
		this.initPanel(panels[i], i == this.defaultPanel);
	}

	
};

vtabs.prototype.getPanels = function()
{
	return this.getElementChildren(this.element);
};

vtabs.prototype.getCurrentPanel = function()
{
	return this.currentPanel;
};

vtabs.prototype.getCurrentPanelIndex = function()
{
	var panels = this.getPanels();
	for( var i = 0 ; i < panels.length; i++ )
	{
		if( this.currentPanel == panels[i] )
			return i;
	}
	return 0;
};

vtabs.prototype.getPanelTab = function(panel)
{
	if (!panel)
		return null;
	return this.getElementChildren(panel)[0];
};

vtabs.prototype.getPanelContent = function(panel)
{
	if (!panel)
		return null;
	return this.getElementChildren(panel)[1];
};

vtabs.prototype.getElementChildren = function(element)
{
	var children = [];
	var child = element.firstChild;
	while (child)
	{
		if (child.nodeType == 1 /* Node.ELEMENT_NODE */)
			children.push(child);
		child = child.nextSibling;
	}
	return children;
};

vtabs.prototype.focus = function()
{
	if (this.element && this.element.focus)
		this.element.focus();
};

/////////////////////////////////////////////////////

vtabs.PanelAnimator = function(accordion, panel, opts)
{
	this.timer = null;
	this.interval = 0;
	this.stepCount = 0;

	this.fps = 0;
	this.steps = 10;
	this.duration = 500;
	this.onComplete = null;

	this.panel = panel;
	this.panelToOpen = accordion.getElement(panel);
	this.panelData = [];

	vtabs.setOptions(this, opts, true);


	// If caller specified speed in terms of frames per second,
	// convert them into steps.

	if (this.fps > 0)
	{
		this.interval = Math.floor(1000 / this.fps);
		this.steps = parseInt((this.duration + (this.interval - 1)) / this.interval);
	}
	else if (this.steps > 0)
		this.interval = this.duration / this.steps;

	// Set up the array of panels we want to animate.

	var panels = accordion.getPanels();
	for (var i = 0; i < panels.length; i++)
	{
		var p = panels[i];
		var c = accordion.getPanelContent(p);
		if (c)
		{
			var h = c.offsetHeight;
			if (h == undefined)
				h = 0;
			if (p == panel || h > 0)
			{
				var obj = new Object;
				obj.panel = p;
				obj.content = c;
				obj.fromHeight = h;
				obj.toHeight = (p == panel) ? (accordion.useFixedPanelHeights ? accordion.fixedPanelHeight : c.scrollHeight) : 0;
				obj.increment = (obj.toHeight - obj.fromHeight) / this.steps;
				obj.overflow = c.style.overflow;
				this.panelData.push(obj);

				c.style.overflow = "hidden";
				c.style.height = h + "px";
			}
		}
	}
};

vtabs.PanelAnimator.prototype.start = function()
{
	var self = this;
	this.timer = setTimeout(function() { self.stepAnimation(); }, this.interval);
};

vtabs.PanelAnimator.prototype.stop = function()
{
	if (this.timer)
	{
		clearTimeout(this.timer);

		// If we're killing the timer, restore the overflow
		// properties on the panels we were animating!

		if (this.stepCount < this.steps)
		{
			for (i = 0; i < this.panelData.length; i++)
			{
				obj = this.panelData[i];
				obj.content.style.overflow = obj.overflow;
			}
		}
	}

	this.timer = null;
};

vtabs.PanelAnimator.prototype.stepAnimation = function()
{
	++this.stepCount;

	this.animate();

	if (this.stepCount < this.steps)
		this.start();
	else if (this.onComplete)
		this.onComplete();
};

vtabs.PanelAnimator.prototype.animate = function()
{
	var i, obj;

	if (this.stepCount >= this.steps)
	{
		for (i = 0; i < this.panelData.length; i++)
		{
			obj = this.panelData[i];
			if (obj.panel != this.panel)
				obj.content.style.height = "0px";
			obj.content.style.overflow = obj.overflow;
			obj.content.style.height = obj.toHeight + "px";
		}
	}
	else
	{
		for (i = 0; i < this.panelData.length; i++)
		{
			obj = this.panelData[i];
			obj.fromHeight += obj.increment;
			obj.content.style.height = obj.fromHeight + "px";
		}
	}
};

