/* -------------------------------------------------- *
 * ToggleVal 2.1
 * Updated: 1/16/09
 * -------------------------------------------------- *
 * Author: Aaron Kuzemchak
 * URL: http://aaronkuzemchak.com/
 * Copyright: 2008-2009 Aaron Kuzemchak
 * License: MIT License
** -------------------------------------------------- */

(function($) {
	$.fn.toggleVal = function(theOptions) {
		// check whether we want real options, or to destroy functionality
		if(!theOptions || typeof(theOptions) == "object") {
			theOptions = $.extend({
				focusClass: "tv-focused ", // class during focus
				changedClass: "tv-changed", // class after focus
				populateFrom: "default", // choose from: default, label, custom, or alt
				text: null, // text to use in conjunction with populateFrom: custom
				removeLabels: false // remove labels associated with the fields
			}, theOptions);
		}
		else if(typeof(theOptions) == "string" && theOptions.toLowerCase() == "destroy") {
			var destroy = true;
		}
		else if(typeof(theOptions) == "string" && theOptions.toLowerCase() == "active"){
			var focusClass = "tv-focused";
			var changedClass = "tv-changed";
		}
		
		return this.each(function() {
			// unbind everything if we're destroying, and stop executing the script
			if(destroy) {
				$(this).unbind("focus.toggleval").unbind("blur.toggleval").removeData("defText");
				return false;
			}
			
			// define our variables
			var defText = "";
			
			// let's populate the text, if not default
			if (typeof(theOptions) == "object") {
				switch(theOptions.populateFrom) {
					case "alt":
						defText = $(this).attr("alt");
						$(this).val(defText);
						break;
					case "label":
						defText = $("label[for='" + $(this).attr("id") + "']").text();
						$(this).val(defText);
						break;
					case "custom":
						defText = theOptions.text;
						$(this).val(defText);
						break;
					default:
						defText = $(this).val();
				}
			} else if(typeof(theOptions) == "string") {
				defText = $(this).val();
			}
			
			// let's give this field a special class, so we can identify it later
			// also, we'll give it a data attribute, which will help jQuery remember what the default value is
			$(this).addClass("toggleval").data("defText", defText);
			
			// now that fields are populated, let's remove the labels if applicable
			if(theOptions.removeLabels == true) { $("label[for='" + $(this).attr("id") + "']").remove(); }
			
			// on to the good stuff... the focus and blur actions
			$(this).bind("focus.toggleval", function() {
				if($(this).val() == $(this).data("defText")) { $(this).val(""); }

				// add the focusClass, remove changedClass
				var classToAdd = (typeof(theOptions) == "object") ? theOptions.focusClass: focusClass;
				var classToRemove = (typeof(theOptions) == "object") ? theOptions.changedClass: changedClass;
				$(this).addClass(classToAdd).removeClass(classToRemove);
			}).bind("blur.toggleval", function() {
				if($(this).val() == "") { $(this).val($(this).data("defText")); }
				
				// remove focusClass, add changedClass if, well, different
				var classToAdd = (typeof(theOptions) == "object") ? theOptions.changedClass: changedClass;
				var classToRemove = (typeof(theOptions) == "object") ? theOptions.focusClass: focusClass;
				$(this).removeClass(classToRemove);
				if($(this).val() != $(this).data("defText")) { $(this).addClass(classToAdd); }
					else { $(this).removeClass(classToRemove); }
			});
		});
	};
})(jQuery);