/*
 * FeatureList - simple and easy creation of an interactive "Featured Items" widget
 * Examples and documentation at: http://jqueryglobe.com/article/feature_list/
 * Version: 1.0.0 (01/09/2009)
 * Copyright (c) 2009 jQueryGlobe
 * Licensed under the MIT License: http://en.wikipedia.org/wiki/MIT_License
 * Requires: jQuery v1.3+
*/
;(function($) {
	$.fn.featureList = function(options) {
		var tabs	= $(this);
		var output	= $(options.output);

		new jQuery.featureList(tabs, output, options);

		return this;	
	};

	$.featureList = function(tabs, output, options) {
		function slide(nr) {
			if (typeof nr == "undefined") {
				nr = visible_item + 1;
				nr = nr >= total_items ? 0 : nr;
			}

			tabs.removeClass('current').filter(":eq(" + nr + ")").addClass('current');

			output.stop(true, true).filter(":visible").fadeOut();
			output.filter(":eq(" + nr + ")").fadeIn(function() {
				visible_item = nr;	
			});
		}

                var options		= options || {};
		var total_items		= tabs.length;
		var visible_item	= options.start_item || 0;


                    options.pause_on_hover	= options.pause_on_hover	|| true;
                    options.transition_interval	= options.transition_interval	|| 5000;

                    output.hide().eq( visible_item ).show();
                    tabs.eq( visible_item ).addClass('current');

                    tabs.click(function() {
                            if ($(this).hasClass('current')) {
                                    return false;
                            }

                            slide( tabs.index( this) );
                    });
		if (total_items > 1) {
                    if (options.transition_interval > 0) {
                            var timer = setInterval(function () {
                                    slide();
                            }, options.transition_interval);

                            if (options.pause_on_hover) {
                                    tabs.mouseenter(function() {
                                            clearInterval( timer );

                                    }).mouseleave(function() {
                                            clearInterval( timer );
                                            timer = setInterval(function () {
                                                    slide();
                                            }, options.transition_interval);
                                    });
                            }
                    }
                }
	};
})(jQuery);
