/*********************
 *	Displays default text in comment form fields
 ********************/
var CommentForm = {
	init:function(){
		//Set default text
		var arrCommentsDefault = [];
		arrCommentsDefault[0] = 'Name';
		arrCommentsDefault[1] = 'Email';
		
		// Add '.defaultText' class if empty fields
		$('.signupDefaultText').each(function(index){
			if ($(this).val() == arrCommentsDefault[index]){
				$(this).addClass('defaultText');
			}
		});
		
		$('.signupDefaultText').each(function(index){
			// Remove default text upon focus
			$(this).focus(function(){
				if($(this).val() == arrCommentsDefault[index]){
					$(this).removeClass('defaultText');
					$(this).val('');
				}
			});
			
			// Add default text upon blur
			$(this).blur(function(){
				if ($(this).val() == ''){
					$(this).addClass('defaultText');
					$(this).val(arrCommentsDefault[index]);
				}
			});
			
			// Trigger blur
			$(this).blur();
		});
		
		// Clear any default text upon form submission
		$('#formSignup').submit(function(){
			$('.signupDefaultText').each(function(index){
				if($(this).val() == arrCommentsDefault[index]){
					$(this).val('');
				}
			});
		});
	}
};
CommentForm.init();


/*********************
 *	Displays default text for single text field forms
 *
 *  elemForm -- The parent form
 *  strDefault -- The default text to appear in the text field (set to exactly match HTML 'value' attribute)
 ********************/
DefaultText = {
	init:function(elemForm, strDefault){			
		// Get input text field
		var elemInput = $(elemForm).children('input[type="text"]');
		
		// Add default class if default text present
		if($(elemInput).val() == strDefault){
			$(elemInput).addClass('defaultText');
		}
		
		// Remove default text upon focus
		$(elemInput).focus(function(){
			if($(this).val() == strDefault){
					$(this).removeClass('defaultText');
					$(this).val('');
				}
		});
		
		// Add default text upon blur
		$(elemInput).blur(function(){
			if($(this).val() == ''){
				$(this).addClass('defaultText');
				$(this).val(strDefault);
			}
		});
		
		// Trigger blur
		$(elemInput).blur();
		
		// Clear any default text upon form submission
		$(elemForm).submit(function(){			
			if($(elemInput).val() == strDefault){
				$(elemInput).val('');
			}
		});
	}
};
var elemForm = $('#searchForm');
var strDefault = 'Search';
DefaultText.init(elemForm, strDefault);


/*********************
 *	Controls popup windows (http://swip.codylindley.com/jquery.popupWindow.js)
 ********************/
(function($){ 		  
	$.fn.popupWindow = function(instanceSettings){
		
		return this.each(function(){
		
		$(this).click(function(){
		
		$.fn.popupWindow.defaultSettings = {
			centerBrowser:0, // center window over browser window? {1 (YES) or 0 (NO)}. overrides top and left
			centerScreen:0, // center window over entire screen? {1 (YES) or 0 (NO)}. overrides top and left
			height:500, // sets the height in pixels of the window.
			left:0, // left position when the window appears.
			location:0, // determines whether the address bar is displayed {1 (YES) or 0 (NO)}.
			menubar:0, // determines whether the menu bar is displayed {1 (YES) or 0 (NO)}.
			resizable:0, // whether the window can be resized {1 (YES) or 0 (NO)}. Can also be overloaded using resizable.
			scrollbars:0, // determines whether scrollbars appear on the window {1 (YES) or 0 (NO)}.
			status:0, // whether a status line appears at the bottom of the window {1 (YES) or 0 (NO)}.
			width:500, // sets the width in pixels of the window.
			windowName:null, // name of window set from the name attribute of the element that invokes the click
			windowURL:null, // url used for the popup
			top:0, // top position when the window appears.
			toolbar:0 // determines whether a toolbar (includes the forward and back buttons) is displayed {1 (YES) or 0 (NO)}.
		};
		
		settings = $.extend({}, $.fn.popupWindow.defaultSettings, instanceSettings || {});
		
		var windowFeatures =    'height=' + settings.height +
								',width=' + settings.width +
								',toolbar=' + settings.toolbar +
								',scrollbars=' + settings.scrollbars +
								',status=' + settings.status + 
								',resizable=' + settings.resizable +
								',location=' + settings.location +
								',menuBar=' + settings.menubar;

				settings.windowName = this.name || settings.windowName;
				settings.windowURL = this.href || settings.windowURL;
				var centeredY,centeredX;
			
				if(settings.centerBrowser){
						
					if ($.browser.msie) {//hacked together for IE browsers
						centeredY = (window.screenTop - 120) + ((((document.documentElement.clientHeight + 120)/2) - (settings.height/2)));
						centeredX = window.screenLeft + ((((document.body.offsetWidth + 20)/2) - (settings.width/2)));
					}else{
						centeredY = window.screenY + (((window.outerHeight/2) - (settings.height/2)));
						centeredX = window.screenX + (((window.outerWidth/2) - (settings.width/2)));
					}
					window.open(settings.windowURL, settings.windowName, windowFeatures+',left=' + centeredX +',top=' + centeredY).focus();
				}else if(settings.centerScreen){
					centeredY = (screen.height - settings.height)/2;
					centeredX = (screen.width - settings.width)/2;
					window.open(settings.windowURL, settings.windowName, windowFeatures+',left=' + centeredX +',top=' + centeredY).focus();
				}else{
					window.open(settings.windowURL, settings.windowName, windowFeatures+',left=' + settings.left +',top=' + settings.top).focus();	
				}
				return false;
			});
			
		});	
	};
})(jQuery);


/*********************
 *	Popup window for Twitter Share and Facebook Share requests
 ********************/
var PopUp = {
	init:function(){
		$('.link-twitter').popupWindow({ 
			height:350, 
			width:550,
			top:50, 
			left:50 
		});
		
		$('.link-fb').popupWindow({ 
			height:350, 
			width:550,
			top:50, 
			left:50 
		});		
	}
};
