/**
 * @author kyle.geske
 * 
 * JQuery Plugins
 */

var jqplugins = {
	animations: false,
	expandIcon: 'img/list-add.gif',
	expandIconGreyed: 'img/list-add-greyed.gif',
	collapseIcon: 'img/list-remove.gif'
};

/*******************************************
 * Rollover Plugin 
 */

$.fn.rollover = function(target) {
	return this.each(function() {
		var a = $("a",this).get(0);
		this.tooltip = $.attr(a,'title'); 	// Save the title for later use.
		$(a).attr("title",""); 			// Removes the default mouseover tooltip that was overlapping our custome output.
		$(this).mouseover(function() {
				this.was = target.html();
				target.html(this.tooltip);
				// target.html($.attr($("a",this).get(0),'title'));				
		});
		$(this).mouseout(function() {
				target.html(this.was);
		});
	});
};

/*******************************************
 * Zebra Plugin 
 */

$.fn.zebra = function(s, c){
	return this.each(function() {
		 $(s+":even",this).addClass(c);
	});
};

 
/*******************************************
 * Sizr Plugin
 */

$.fn.sizr = function() {
	return this.each(function() {
		var link = $.A({'href' : '#'},"Large Text");
		$(link).click(function() {
			if ($(this).html() == "Large Text")
			{
				$(this).html("Normal Text");
				$("div#page p").css("font-size","1.3em");
				$("div#page li").css("font-size","1.3em");
				$("div#page dt").css("font-size","1.5em");
				$("div#page h4").css("font-size","1.5em");
				$("div#page h3").css("font-size","1.8em");
	
			}
			else
			{
				$(this).html("Large Text");
				$("div#page p").css("font-size","1em");
				$("div#page li").css("font-size","1em");
				$("div#page dt").css("font-size","1.2em");
				$("div#page h4").css("font-size","1.2em");
				$("div#page h3").css("font-size","1.5em");
			}
		});
		/*var div = $.DIV({'style' : 'text-align: right; padding-right: 10px;'},link);
		$(this).before(div);*/
		$(this).prepend(link ,"-");

	});
};

/*******************************************
 * Accordian Plugin 
 */

$.fn.accordian = function() {
		return this.each(function(){
			$("li.section_level",this).each(function() {

				var thelist = $("ul",this);
				
				if (thelist.size() == 0)
				{
					//$("a",this).before($.IMG({'src':jqplugins.expandIconGreyed}));
				}
				else if ($.attr(this,"class").indexOf("active") == -1)
				{
					$("a",this).before($.IMG({'src':jqplugins.expandIcon}));
					thelist.hide();
				}
				else
				{
					$("a",this).before($.IMG({'src':jqplugins.collapseIcon}));
				}
				
				$("img",$("ul",this)).remove();
				
				if (thelist.size() != 0) $("img",this).click(function(){
					
					if (thelist.is(":hidden"))
					{
						if (jqplugins.animations)
							thelist.slideDown();
						else	
							thelist.show();
						this.src="img/list-remove.gif";
					}
					else
					{
						if (jqplugins.animations)
							thelist.slideUp();
						else
							thelist.hide();
						this.src="img/list-add.gif";

					}
				});
			});
		});
};

/*******************************************
 * Autocomplete Plugin 
 */

$.autocomplete = function(wrapper, options) {

	var me = this;
	$(wrapper).removeClass(options.removeClass);
	var results = document.createElement("div");
	$(results).hide();
	results.style.zIndex = 20;
	wrapper.appendChild(results);
	$(results).attr("class", options.resultsClass);
	var input = $("input", wrapper)[0];
	input.autocompleter = this;
	input.lastSelected = $(input).val();

	var timeout = null;
	var prev = "";
	var active = -1;
	var cache = {};
	var cover = null;
	var keyb = false;

/*@cc_on
   cover = document.createElement("iframe");
   cover.style.src = "javascript:document.write('');";
   cover.style.display = "none";
   cover.style.zIndex = 10;
   cover.style.position = "absolute";
   cover.setAttribute("scrolling", "no");
   cover.setAttribute("frameborder", "0");
   cover.style.width = "100%";
   wrapper.appendChild(cover);

@*/

	$(input)
	.keydown(function(e) {
		switch(e.keyCode) {
			case 38: // up
				e.preventDefault();
				moveSelect(-1);
				break;
			case 40: // down
				e.preventDefault();
				moveSelect(1);
				break;
			case 9:  // tab
			case 13: // return
				if (selectCurrent()) {
					e.preventDefault();
				}
				break;
			default:
				active = -1;
				if (timeout) clearTimeout(timeout);
				timeout = setTimeout(onChange, options.delay);
				break;
		}
	})
	.blur(function() {
		hideResults();
	})
	.focus(function() {
		active = -1;
		prev = "";
		if (timeout) clearTimeout(timeout);
		timeout = setTimeout(onChange, options.delay);
	});

	hideResultsNow();

	function onChange() {
		var v = $(input).val();
		if (v == prev) return;
		prev = v;
		if (v.length >= options.minChars) {
			$(input).addClass(options.loadingClass);
			requestData(v);
		} else {
			$(input).removeClass(options.loadingClass);
			hideResultsNow();
		}
	};

	function moveSelect(step) {

		var lis = $("li", results);
		if (!lis) return;

		active += step;

		if (active < 0) {
			active = 0;
		} else if (active >= lis.size()) {
			active = lis.size() - 1;
		}

		lis.removeClass("over");

		$(lis[active]).addClass("over");

		if (lis[active] && lis[active].scrollIntoView) {
			lis[active].scrollIntoView(false);
		}

	};

	function selectCurrent() {
		var li = $("li.over", results)[0];
		if (!li) {
			var $li = $("li", results);
			if (options.selectOnly) {
				if ($li.length == 1) li = $li[0];
			} else if (options.selectFirst) {
				li = $li[0];
			}
		}
		if (li) {
			selectItem(li);
			return true;
		} else {
			return false;
		}
	};

	function selectItem(li) {
		if (!li) {
			li = document.createElement("li");
			li.extra = [];
			li.selectValue = "";
		}
		var v = $.trim(li.selectValue ? li.selectValue : li.innerHTML);
		input.lastSelected = v;
		prev = v;
		$(results).html("");
		$(input).val(v);
		hideResultsNow();
		if (options.onItemSelect) setTimeout(function() { options.onItemSelect(li) }, 1);
	};

	function hideResults() {
		if (timeout) clearTimeout(timeout);
		timeout = setTimeout(hideResultsNow, 200);
	};

	function hideResultsNow() {
		if (timeout) clearTimeout(timeout);
		$(input).removeClass(options.loadingClass);
		if ($(results).is(":visible")) {
			$(results).hide();
		}
		if (cover) $(cover).hide();
		if (options.mustMatch) {
			var v = $(input).val();
			if (v != input.lastSelected) {
				selectItem(null);
			}
		}
	};

	function receiveData(q, data) {
		if (data) {
			$(input).removeClass(options.loadingClass);
			results.innerHTML = "";
			results.appendChild(dataToDom(data));
			$(results).show();
			if (cover) {
				cover.style.top     = results.offsetTop;
				cover.style.left    = results.offsetLeft;
				cover.style.width   = results.clientWidth + 2;
				cover.style.height  = results.clientHeight + 2;
				$(cover).show();
			}
		} else {
			hideResultsNow();
		}
	};

	function parseData(data) {
		if (!data) return null;
		var parsed = [];
		var rows = data.split(options.lineSeparator);
		for (var i=0; i < rows.length; i++) {
			var row = $.trim(rows[i]);
			if (row) {
				parsed[parsed.length] = row.split(options.cellSeparator);
			}
		}
		return parsed;
	};

	function dataToDom(data) {
		var ul = document.createElement("ul");
		var num = data.length;
		for (var i=0; i < num; i++) {
			var row = data[i];
			if (!row) continue;
			var li = document.createElement("li");
			if (options.formatItem) {
				li.innerHTML = options.formatItem(row, i, num);
				li.selectValue = row[0];
			} else {
				li.innerHTML = row[0];
			}
			var extra = null;
			if (row.length > 1) {
				extra = [];
				for (var j=1; j < row.length; j++) {
					extra[extra.length] = row[j];
				}
			}
			li.extra = extra;
			ul.appendChild(li);
			$(li).hover(
				function() { $("li", ul).removeClass("over"); $(this).addClass("over"); },
				function() { $(this).removeClass("over"); }
			).click(function(e) { e.preventDefault(); e.stopPropagation(); selectItem(this) });
		}
		$("li:even",ul).addClass("even");
		return ul;
	};

	function requestData(q) {
		if (!options.matchCase) q = q.toLowerCase();
		var data = options.cacheLength ? loadFromCache(q) : null;
		if (data) {
			receiveData(q, data);
		} else if (options.fromFnc)	{
			data = options.fromFnc(q,options.matchCase);
			data = parseData(data);
			addToCache(q, data);
			receiveData(q, data);
		}
		else {
			$.get(makeUrl(q), function(data) {
				data = parseData(data)
				addToCache(q, data);
				receiveData(q, data);
			});
		}
	};

	function makeUrl(q) {
		var url = options.url + "?q=" + q;
		for (var i in options.extraParams) {
			url += "&" + i + "=" + options.extraParams[i];
		}
		return url;
	};

	function loadFromCache(q) {
		if (!q) return null;
		if (cache[q]) return cache[q];
		if (options.matchSubset) {
			for (var i = q.length - 1; i >= options.minChars; i--) {
				var qs = q.substr(0, i);
				var c = cache[qs];
				if (c) {
					var csub = [];
					for (var j = 0; j < c.length; j++) {
						var x = c[j];
						var x0 = x[0];
						if (matchSubset(x0, q)) {
							csub[csub.length] = x;
						}
					}
					return csub;
				}
			}
		}
		return null;
	};

	function matchSubset(s, sub) {
		if (!options.matchCase) s = s.toLowerCase();
		var i = s.indexOf(sub);
		if (i == -1) return false;
		return i == 0 || options.matchContains;
	};

	this.flushCache = function() {
		cache = {};
	};

	this.setExtraParams = function(p) {
		options.extraParams = p;
	};

	function addToCache(q, data) {
		if (!data || !q || !options.cacheLength) return;
		if (!cache.length || cache.length > options.cacheLength) {
			cache = {};
			cache.length = 1; // we know we're adding something
		} else if (!cache[q]) {
			cache.length++;
		}
		cache[q] = data;
	};
}

$.fn.autocomplete = function(url, options) {
	// Make sure options exists
	options = options || {};
	// Set url as option
	options.url = url;
	// Set removeClass as option
	options.removeClass = "ac___remove___this___class";
	// Set default values for required options
	options.wrapperClass = options.wrapperClass || "ac_wrapper";
	options.resultsClass = options.resultsClass || "ac_results";
	options.lineSeparator = options.lineSeparator || "\n";
	options.cellSeparator = options.cellSeparator || "|";
	options.minChars = options.minChars || 1;
	options.delay = options.delay || 400;
	options.matchCase = options.matchCase || 0;
	options.matchSubset = options.matchSubset || 1;
	options.matchContains = options.matchContains || 0;
	options.cacheLength = options.cacheLength || 1;
	options.mustMatch = options.mustMatch || 0;
	options.extraParams = options.extraParams || {};
	options.loadingClass = options.loadingClass || "ac_loading";
	options.selectFirst = options.selectFirst || false;
	options.selectOnly = options.selectOnly || false;
	options.fromFnc = options.fromFnc || false;
	// Wrap our input elements with a DIV
	this.wrap("<div class='" + options.wrapperClass + " " + options.removeClass + "'></div>");
	// Find all the newly created DIVs and create an autocompleter for each of them
	$("div." + options.removeClass).each(function() { new $.autocomplete(this, options); });
	// Don't break the chain
	return this;
}

/*******************************************
 * Editable Plugin 
 */

$.fn.editable = function(url, options) {
    // Options
    options = arrayMerge({
        "url": url,
        "paramName": "Value",
        "callback": null,
        "saving": "saving ...",
        "type": "text",
	"buttonClass": "",
        "submitButton": 0,
        "extraParams": {},
	"describe": 0,
	"preFilter": null,
	"postAppend": "",
        "editClass": null
    }, options);
    // Set up

    this.each(function() {
	this.myTitle = $.attr(this,"title");
	$(this).attr("title","");
    });

    this.click (function(e) {
	    e.preventDefault();
            if (this.editing) return;
            if (!this.editable) this.editable = function() {
                var me = this;
                me.editing = true;
		$("tr",$(me)).removeClass("zebra_even");
		me.orgHTML = $(me).html();
		me.filterHTML = options.preFilter ? options.preFilter($(me).html()) : $(me).html();
		me.filterHTML = me.filterHTML.replace(/class=""/g,"");	
                me.innerHTML = "";
                if (options.editClass) $(me).addClass(options.editClass);
                var f = document.createElement("form");
                var i = createInputElement( me.filterHTML);
		$(i).addClass("edit");
                f.appendChild(i);
                if (options.submitButton) {
			var br = document.createElement("br");
			f.appendChild(br);
			var b = document.createElement("input");
			b.type = "submit";
			b.value = "OK";
			var c = document.createElement("input");
			c.type = "button";
			c.value = "CANCEL";
						
			f.appendChild(b);
			f.appendChild(c);
			$(c).click(function(){reset();})
						
			if (options.buttonClass != "") {
				$(c).addClass(options.buttonClass);
				$(b).addClass(options.buttonClass);
			}
		}
		if (options.type == "textarea")	{
		    var p = document.createElement("p");
		    p.appendChild(f);
		    me.appendChild(p);
		} else {
		    me.appendChild(f);
		}
				    
		if (options.describe) {
		    $(f).before("Editing " + me.myTitle + ":");
		}
				    
		i.focus();
                $(b).click(function(e) {
                	e.preventDefault();
			var p = {};
			p[i.name] = $(i).val();
			p["Action"] = "ManagePages";
			p["SubAction"] = "EditPage";
			p["Type"] = me.myTitle;
					
					
			
                        $(me).html(options.saving).load(options.url, arrayMerge(options.extraParams, p), function() {
                        // Remove script tags
						
			if (p["Type"] == "Title")
				me.innerHTML = options.postAppend + me.innerHTML.replace(/<\s*script\s*.*>.*<\/\s*script\s*.*>/gi, "");
			else
				me.innerHTML = me.innerHTML.replace(/<\s*script\s*.*>.*<\/\s*script\s*.*>/gi, "");
							
                        // Callback if necessary
                        if (options.callback ) options.callback(me);
                        // Release
                        me.editing = false;                       
                    });

		  reset();
                });
                function reset() {
                    me.innerHTML = me.orgHTML;
                    if (options.editClass) $(me).removeClass(options.editClass);
                    me.editing = false;
                }
            };
            this.editable();
        })
    ;
    // Don't break the chain
    return this;
    // Helper functions
    function arrayMerge(a, b) {
        if (a) {
            if (b) for(var i in b) a[i] = b[i];
            return a;
        } else {
            return b;       
        }
    };
    function createInputElement(v) {
        if (options.type == "textarea") {
            var i = document.createElement ("textarea");
            options.submitButton = true;
        } else {
            var i = document.createElement("input");
            i.type = "text";
        }
        $(i).val(v);
        i.name = options.paramName;
        return i;
    }
};


