(function($) {
	var lib = window.lib = function($) {
		return {
			image : {
				preload : function(images) {
					var tImageArr = [];
					var tImages = images.split(",");
					$(tImages).each(function(i) {
			   			tImageArr[i] = new Image();
			   			tImageArr[i].src = tImages[i];
	 				});
	 			},
	 			isComplete : function( selector ) {
	 				var complete = true;
	 				$(selector).each(function() {
	 					if( !$(this).get(0).complete )
	 					{ complete = false; }
	 				});
	 				return complete;
	 			}
			},
			input : {
				defaultText : function(selector, settings) {
					settings = $.extend({
         				defaultText: "enter keyword or item"
        			}, settings);
        			
        			return $(selector).each(function(){
						$(this).focus( function() {
							if( $(this).val() == settings.defaultText )
							{ $(this).val(""); }
						});
			
						$(this).blur(function() {
							$(this).val( lib.utils.strTrim($(this).val()) );
							if( $(this).val() == "" )
							{ $(this).val( settings.defaultText ); }
						});
						$(this).blur();
					});
				},
				setMaxCharacters : function(selector, settings) {
					settings = $.extend({
         				limit: 500,
         				results : "#_donotplace"
        			}, settings);
        			
        			$(selector).bind("keyup.max_characters", function() {
        				if( $(this).val().length > settings.limit )
        				{ $(this).val( $(this).val().substring(0, settings.limit) ); }
        			
        				var remainingCount = ((settings.limit - $(this).val().length) == 0) ? "0" : settings.limit - $(this).val().length;
        				$(settings.results).html(remainingCount);
        			});
        			$(selector).keyup();
        		},
        		autoAdvance : function(selector) {
					$(selector).each(function(i) {
						$(this).keyup(function() {
							if( $(this).val().length >= $(this).attr("maxlength") )
							{ 
								$(this).blur();
								$(selector).eq(i+1).focus();
							 }
						});
					});
				}
			},
			link : {
				disable : function(selector) {
					$(selector).attr("href","#jsLink");
					$(selector).click(function(evt) {
						evt.preventDefault();
					}); 
				},
				popupWindow : function(selector, settings) {
					settings = jQuery.extend({
	          		width: 500,
	          		height: 500,
	          		toolbar: 0,
			  			menubar: 0,
			  			location: 0, 
			  			directories: 0,
			 			status: 0, 
			  			scrollbars: 0,
			 			resizable: 0,
			  			name: "Popup_Window"
	        		}, settings);
	        		
	        		return $(selector).each(function() {
	        			var features = 	"toolbar=" + settings.toolbar + "," +
										"menubar=" + settings.menubar + "," +
										"location=" + settings.location + "," +
										"directories=" + settings.directories + "," +
										"status=" + settings.status + "," +
										"scrollbars=" + settings.scrollbars + "," +
										"resizable=" + settings.resizable;
                           if (settings.top !== undefined ){
                           features = features +  ",top=" + settings.top;
                         }
                         if (settings.left !== undefined){
                           features = features +  ",left=" + settings.left;
                         }
	        			$(this).click(function(evt) {
	        				evt.preventDefault();
                                var newWindow = window.open($(this).attr("href"), settings.name, 'width=' + settings.width + ',height=' + settings.height + ',"' + features + '"');
							    newWindow.focus();
                        });
	        		});
				}
            },
			screen : {
				position : function() {
					if( typeof( window.pageYOffset ) == 'number' ) {
						//Netscape compliant
						return [ window.pageXOffset, window.pageYOffset ];
					} else if( document.body && ( document.body.scrollLeft || document.body.scrollTop ) ) {
					    //DOM compliant
					    return [ document.body.scrollLeft, document.body.scrollTop ];
					} else if( document.documentElement && ( document.documentElement.scrollLeft || document.documentElement.scrollTop ) ) {
					    //IE6 standards compliant mode
					    return [ document.documentElement.scrollLeft, document.documentElement.scrollTop ];
					} else {
						return [ -1, -1 ];
					}
				},
				size : function() {
					var vpW = 0, vpH = 0;
					if (typeof window.innerWidth != 'undefined')
					{ return [ window.innerWidth, window.innerHeight ]; }
					else if (typeof document.documentElement != 'undefined' && typeof document.documentElement.clientWidth != 'undefined' && document.documentElement.clientWidth != 0)
					{ return [ document.documentElement.clientWidth, document.documentElement.clientHeight ]; }
					else
					{ return [ document.getElementsByTagName('body')[0].clientWidth, document.getElementsByTagName('body')[0].clientHeight ]; }
				}
			},
			layer : {
				add : function(selector, defaultHTML, closeButton) {
					lib.layer.remove(selector);
					addHTML = '<div id="' + selector.split("#")[1] + '"></div>';
					$("body").append(addHTML);
					$(selector).append(defaultHTML);
					lib.layer.vCenter(selector);
					lib.layer.ie6Fix(selector, "a");
					lib.layer.closeButton(closeButton, selector);
				},
				remove : function(selector) {
					if( $(selector).size() > 0 )
					{
						$(selector).remove();
						lib.layer.ie6Fix(selector,"r");
					}
				},
				loadHTML : function(selector,page,closeButton) {
					$.get(page,function(data) {
						$(selector + " *").remove();
						$(selector).html("");
						$(selector).append(data);
						lib.layer.vCenter(selector);
						lib.layer.ie6Fix(selector,"u");
						lib.layer.closeButton(closeButton, selector);
					});
				},
				vCenter : function(selector) {
					var wPosition = lib.screen.position();
					var wSize = lib.screen.size();
					var top = ((wSize[1] / 2) - ($(selector).height() / 2)) + wPosition[1];
					top = (top < 0) ? 100 : top;
					$(selector).css("top",top+"px");
					lib.layer.ie6Fix(selector,"u");
				},
				closeButton : function( selector, layerSelector ) {
					lib.link.disable(layerSelector + " " + selector);
					$(layerSelector + " " + selector).unbind("click.lib.layer.close").bind("click.lib.layer.close", function() { lib.layer.remove(layerSelector); });
				},
				ie6Fix : function(selector,action) {
					if(lib.utils.isIE6())
					{  
						var fixId = selector.split("#")[1] + "-iframe";
						var exists = $("#" + fixId).size() > 0 ? true : false;
						
						if(action == "r" && exists)
						{ 	$("#" + fixId).remove(); }
						
						if(action == "a" && !exists)
						{
							fixHTML = '<div id="' + fixId + '"><iframe width="100%" height="100%" frameborder="0" src="/assets/blank.gif"><!-- --></iframe></div>';
							$("body").append(fixHTML);
							exists = $("#" + fixId).size() > 0 ? true : false;
						}
						
						if( (action == "a" || "u") && exists)
						{
							$("#" + fixId).css("position", $(selector).css("position"));
							$("#" + fixId).css("height", $(selector).height());
							$("#" + fixId).css("width", $(selector).width());
							$("#" + fixId).css("margin-left", $(selector).css("margin-left"));
							$("#" + fixId).css("margin-right", $(selector).css("margin-right"));
							$("#" + fixId).css("margin-top", $(selector).css("margin-top"));
							$("#" + fixId).css("margin-bottom", $(selector).css("margin-bottom"));
							$("#" + fixId).css("top", $(selector).css("top"));
							$("#" + fixId).css("left", $(selector).css("left"));
							$("#" + fixId).css("bottom", $(selector).css("bottom"));
							$("#" + fixId).css("right", $(selector).css("right"));
							$("#" + fixId).css("z-index", $(selector).css("z-index")-1);
						}
					}
				}
			},
			json : {
				get : function(url, data, func) {
					$.getJSON(url, data, function(data) { func(data); });
				}
			},
			utils : {
				isIE6 : function() {
					if($.browser.msie && (parseFloat($.browser.version) < 7))
					{ return true; }
					return false;
				},
				timestamp : function() {
					return new Date().getTime();
				},
				strTrim : function(s) {
					return s.replace(/^\s+|\s+$/g, "");
        		},
				getPosition : function( selector ) {
					var positions = [];
					$(selector).each(function(i) {
						thisObj = $(this).get(0);
						var curleft = curtop = 0;
						if (thisObj.offsetParent) {
							do {
							curleft += thisObj.offsetLeft;
							curtop += thisObj.offsetTop;
							} while (thisObj = thisObj.offsetParent);
						}
						positions[positions.length] = new Array(2);
						positions[i][0] = curleft;
						positions[i][1] = curtop;
					});
					return positions
        		}
			},
			func : {
				formSetup : function() { 
					/* Basicly Stylesheet Entries */
					/*
						div.FormArea {}
						div.FormArea div.FormEntry { border: 1px solid #fff; padding: 5px; margin-bottom: 15px; }
						div.FormArea div.FormEntry label { display: block; margin-bottom: 5px; font-weight: bold; }
						div.FormArea div.FormEntry label.optional { font-weight: normal; }
						div.FormArea div.FormError { border: 1px solid red; background-color: #fff; }
						div.FormArea div.FormError .ErrorText { display: block; margin-bottom: 5px; }
						.FormFieldHighlight { background-color: yellow; }
					*/
					
					var formSelector = ".FormArea";
					var globalErrorClass = "ErrorText";
					var formFieldHighlightClass = "FormFieldHighlight";
					var formEntryErrorClass = "FormError";
					var formEntryClass = "FormEntry";
					var inputs = "input, select, textarea";
					
					$(formSelector + " ." + globalErrorClass).each(function() {
						var formEntry = $(this).parent();
						while( !$(formEntry).is(".FormEntry") )
						{ formEntry = $(formEntry).parent(); }
						$(formEntry).addClass( formEntryErrorClass );
					});
					$(inputs, $(formSelector)).bind("focus.fields", function(evt) {
						if( (!$(evt.target).is("input[@type=image]")) && (!$(evt.target).is("input[@type=radio]")) )
						{ $(evt.target).addClass( formFieldHighlightClass ); }
					});
					$(inputs, $(formSelector)).bind("blur.fields", function(evt) {
						$(evt.target).removeClass( formFieldHighlightClass );
					});
					$("select", $(formSelector)).mousedown(function(evt) {
						$(evt.target).addClass( formFieldHighlightClass );
					});
				}
			},
			obj : {
				tabCollection : function(settings) {
					if(arguments.length > 0)
					{ this.init(settings); }
				},
				itemSlider : function(settings) {
					if(arguments.length > 0)
					{ this.init(settings); }	
				},
				buttonCollection : function(settings) {
					if(arguments.length > 0)
					{ this.init(settings); }
				}
			},
			about : function() {
				alert("Property: Fry, Inc.");
			}
		};
	}($);
	
	/* button Code */
	lib.obj.buttonCollection.prototype.init = function(settings) {
		settings = jQuery.extend({
        	off: "but-off.gif",
         	on: "but-on.gif",
         	hover: "but-hover.gif",
         	hasClick: false,
        	hasHover: true,
         	activeId: "but-active",
        	cssButton: false,
         	cssOff: "glo-but-css-off",
         	cssOn: "glo-but-css-on",
         	cssHover: "glo-but-css-hover",
         	buttonSelector: ".but-class"
      }	, settings);
	
	  this.buttonSelector = settings.buttonSelector;
	  this.activeId = settings.activeId;
	  this.hasClick = settings.hasClick;
	  this.hasHover = settings.hasHover;
	
	  if( settings.cssButton )
	  { 
	  	this.type = "CSSBUTTON";
	  	this.cssOff = settings.cssOff;
	  	this.cssOn = settings.cssOn;
	  	this.cssHover = settings.cssHover;
	  	var pObj = this;
	  	$(this.buttonSelector).each(function() {
	  		// make sure the right styles are on the button by default.
	  		if( $(this).attr("id") != pObj.activeId )
			{ $(this).addClass(pObj.cssOff);} 
			else
			{ 
				$(this).removeClass(pObj.cssOff);
				$(this).addClass(pObj.cssOn); 
			}
			//setup the hover
			if( pObj.hasHover )
			{
				$(this).unbind("mouseover.buttonCollection").bind("mouseover.buttonCollection", function() {
					if( $(this).attr("id") != pObj.activeId )
					{ 
						$(this).removeClass(pObj.cssOff); 
						$(this).addClass(pObj.cssHover); 
					}
				});
				$(this).unbind("mouseout.buttonCollection").bind("mouseout.buttonCollection", function() { 
					if( $(this).attr("id") != pObj.activeId )
					{ 
						$(this).removeClass(pObj.cssHover);
						$(this).addClass(pObj.cssOff);
					}
				});
			}
			//setup the click
			if( pObj.hasClick )
			{
				$(this).unbind("click.buttonCollection").bind("click.buttonCollection", function() { 
					if( $(this).attr("id") != pObj.activeId )
				 	{	
						$(pObj.buttonSelector).attr("id","");
						$(pObj.buttonSelector).removeClass(pObj.cssHover);
						$(pObj.buttonSelector).removeClass(pObj.cssOn);
						$(pObj.buttonSelector).trigger("mouseout.buttonCollection");
						$(this).removeClass(pObj.cssOff);
						$(this).addClass(pObj.cssOn);
						$(this).attr("id",pObj.activeId);
					}
				});
			}
		});
	  }
	  else
	  { 
	  	this.type = "IMAGEBUTTON"; 
	  	this.off = settings.off;
	  	this.on = settings.on;
	  	this.hover = settings.hover;
	  	var pObj = this;
	  	$(this.buttonSelector).each(function() {
	  		// always have the mouseout
	  		$(this).unbind("mouseout.buttonCollection").bind("mouseout.buttonCollection", function() { 
				if( $(this).attr("id") != pObj.activeId )
				{ $(this).attr("src",pObj.off); }
			});
	  		//setup the hover
			if( this.hasHover )
			{
				$(this).unbind("mouseover.buttonCollection").bind("mouseover.buttonCollection", function() {
					if( $(this).attr("id") != pObj.activeId )
					{ $(this).attr("src",pObj.hover); }
				});
			}
			//setup the click
			if( this.hasClick )
			{
				$(this).unbind("click.buttonCollection").bind("click.buttonCollection", function() { 
					if( $(this).attr("id") != pObj.activeId )
					{
						$(pObj.buttonSelector).attr("id","");
						$(pObj.buttonSelector).trigger("mouseout.buttonCollection");
						$(this).attr("src",pObj.on);
						$(this).attr("id",pObj.activeId);
					}
				});
			}
		});
	  
	  	lib.image.preload(pObj.off);
	  	if( pObj.hasClick )
	  	{lib.images.preload(pObj.on); }
	  	if (pObj.hasHover )
	  	{ lib.images.preload(pObj.hover); }
	  }
	};
	/* ------------- */
	
	/* itemSlider Object Code */
	lib.obj.itemSlider.prototype.init = function(settings) {
		settings = $.extend({
	         viewport: "#widget-slider-viewport",
	         content: "#widget-slider-content",
	         next: "#widget-slider-next",
	         prev: "#widget-slider-prev",
	         item: "div",
	         direction: "vertical",
	         showAmount: 3
	    }, settings);
	    
	    this.viewport = settings.viewport;
	    this.content = settings.content;
	    this.next = settings.next;
	    this.prev = settings.prev;
	    this.item = settings.item;
	    this.direction = settings.direction;
	    this.showAmount = settings.showAmount;
	    this.sliderInfo = new Object();
	    this.sliderInfo.index = 0;
	    
	    // fix overflwo for items not showing (should be FF only?)
	    $(this.item + " *").each(function(i) {
			 if( $(this).css("overflow") == "auto" )
			 { $(this).addClass("is__overflow"); }
		 });
		 $(".is__overflow", $(this.item).slice(this.sliderInfo.index+this.showAmount, $(this.item).size())).css("overflow", "hidden");
		 // --------------------------------
	    
	    if ( $(this.viewport).size() > 0 )
       {
        	$(this.next).hide();
        	$(this.prev).hide();
        	
        	if( $(this.item).size() > this.showAmount )
        	{ $(this.next).show(); }
        
        	if( this.direction == "vertical" )
        	{
        		this.sliderInfo.start = 0;
        		this.sliderInfo.end = ($(this.item).size() - this.showAmount) * $(this.item).eq(0).height() * -1;
        		this.sliderInfo.itemSize = $(this.item).eq(0).height();
        		this.sliderInfo.top = 0;
        	}
        	else
        	{ 
        		//setup the vars.
        		this.sliderInfo.start = 0;
        		this.sliderInfo.end = ($(this.item).size() - this.showAmount) * $(this.item).eq(0).width() * -1;
        		this.sliderInfo.itemSize = $(this.item).eq(0).width();
        		this.sliderInfo.left = 0;
        	}
        	
        	this.nextSetup();
        	this.prevSetup();
       
       }
	};
	lib.obj.itemSlider.prototype.nextSetup = function() {
		$(this.next).unbind("click");
		var currObj = this;
    	setTimeout(function() { 
    		$(".is__overflow", $(currObj.item).slice(currObj.sliderInfo.index, currObj.sliderInfo.index+currObj.showAmount)).css("overflow", "auto");
    		$(currObj.next).click(function(evt) {
    			evt.preventDefault();
    			$(".is__overflow", $(currObj.item).eq(currObj.sliderInfo.index)).css("overflow","hidden");
    			currObj.sliderInfo.index++;
    			if(currObj.direction == "vertical")
         		{
         			currObj.sliderInfo.top = parseInt($(currObj.content).css("top").split("px")[0]) - currObj.sliderInfo.itemSize;
         			$(currObj.content).animate( { top:currObj.sliderInfo.top+"px"}, 350 );
         			if( currObj.sliderInfo.top == currObj.sliderInfo.end )
         			{ $(currObj.next).hide(); }
         			if( currObj.sliderInfo.top != 0 )
         			{ $(currObj.prev).show();  }
         		}
         		else
         		{
    				currObj.sliderInfo.left = parseInt($(currObj.content).css("left").split("px")[0]) - currObj.sliderInfo.itemSize;
	         		$(currObj.content).animate( { left:currObj.sliderInfo.left+"px"}, 350 );
	         		if( currObj.sliderInfo.left == currObj.sliderInfo.end )
	         		{ $(currObj.next).hide(); }
	         		if( currObj.sliderInfo.left != 0 )
	         		{ $(currObj.prev).show();  }
	         	}
	         	currObj.nextSetup();
	         });
     	}, 351);
	};
	lib.obj.itemSlider.prototype.prevSetup = function() {
		$(this.prev).unbind("click");
		var currObj = this;
    	setTimeout(function() { 
    		$(".is__overflow", $(currObj.item).slice(currObj.sliderInfo.index, currObj.sliderInfo.index+currObj.showAmount)).css("overflow", "auto");
    		$(currObj.prev).click(function(evt) {
    			evt.preventDefault();
    			$(".is__overflow", $(currObj.item).eq(currObj.sliderInfo.index + currObj.showAmount-1)).css("overflow","hidden");
    			currObj.sliderInfo.index--;
    			if( currObj.direction == "vertical")
         		{
         			currObj.sliderInfo.top = parseInt($(currObj.content).css("top").split("px")[0]) + currObj.sliderInfo.itemSize;
         			$(currObj.content).animate( { top:currObj.sliderInfo.top+"px"}, 350 );
         			if( currObj.sliderInfo.top != currObj.sliderInfo.end )
         			{ $(currObj.next).show(); }
         			if( currObj.sliderInfo.top == 0 )
         			{ $(currObj.prev).hide();  }
         		}
         		else
         		{
    				currObj.sliderInfo.left = parseInt($(currObj.content).css("left").split("px")[0]) + currObj.sliderInfo.itemSize;
	         		$(currObj.content).animate( { left:currObj.sliderInfo.left+"px"}, 350 );
	         		if( currObj.sliderInfo.left != currObj.sliderInfo.end )
	         		{ $(currObj.next).show(); }
	         		if( currObj.sliderInfo.left == 0 )
	         		{ $(currObj.prev).hide();  }
         		}
         		
         		currObj.prevSetup();
         	});
        }, 351);
	};
	/* ----------------------- */
	
	/* tabCollection Object */
	lib.obj.tabCollection.prototype.init = function(settings) {
		settings = jQuery.extend({
        	selectorTabCollection: "#tcollection",
        	selectorTabContent: ".tcontent",
        	selectorTabNav: "#tnav",
  			activeTabClass: "tactive",
  			evtIdentifier: "a",
  			defaultTab: "tab1" 
  		}, settings);
		
		this.sTabCollection = settings.selectorTabCollection;
		this.sTabContent = settings.selectorTabContent;
		this.sTabNav = settings.selectorTabNav;
		this.activeTabClass = settings.activeTabClass;
		this.evtIdentifier = settings.evtIdentifier;
		this.evtName = "EV" + lib.utils.timestamp();
		
		// setup
		this.activateTab(settings.defaultTab);
		this.bindEvt();
	};
	lib.obj.tabCollection.prototype.activateTab = function(name) {
		$(this.sTabCollection  + " " + this.sTabNav + " a").removeClass(this.activeTabClass);
		$(this.sTabCollection + " " + this.sTabContent).hide();
		$(this.sTabCollection + " " + this.sTabNav + " a[@name="+name+"]").addClass(this.activeTabClass);
		$(this.sTabCollection + " " + this.sTabContent+"[@name="+name+"]").show();
	};
	lib.obj.tabCollection.prototype.bindEvt = function() {
		var tabObj = this;
		tabObj.unbindEvt();
		$(tabObj.sTabCollection + " " + tabObj.sTabNav).bind("click."+tabObj.evtName, function(evt) {
			var target = $(evt.target);
			if( $(target).is(tabObj.evtIdentifier) )
			{ 
			  evt.preventDefault();
			  tabObj.activateTab( $(target).attr("name") ); 
			}
		});
	};
	lib.obj.tabCollection.prototype.unbindEvt = function() {
		$(this.sTabCollection + " " + this.sTabNav).unbind("click."+this.evtName);
	};
	/* ------------------------------- */
})($);