/* Copyright (c) 2008 Kean Loong Tan http://www.gimiti.com/kltan

 * Licensed under the MIT (http://www.opensource.org/licenses/mit-license.php)

 * jFlow

 * Version: 1.2 (July 7, 2008)

 * Requires: jQuery 1.2+

 */

(function($) {
    $.fn.jFlow = function(options) {
        var opts = $.extend({}, $.fn.jFlow.defaults, options);
        var randNum = Math.floor(Math.random()*11);
        var jFC = opts.controller;
        var jFS =  opts.slideWrapper;
		//var title = opts.title;
        var jSel = opts.selectedWrapper;
		var isPaused = !opts.auto;
        var cur = 0;
        var timer;
        var maxi = $(jFC).length;
   
        // sliding function
        var slide = function (dur, i) {
            $(opts.slides).children().css({
                overflow:"hidden"
            });

            $(opts.slides + " iframe").hide().addClass("temp_hide");

            $(opts.slides).animate({
                marginLeft: "-" + (i * $(opts.slides).find(":first-child").width() + "px")
            },

            opts.duration*(dur),
                opts.easing,
                function(){
                    $(opts.slides).children().css({
                        overflow:"hidden"
                    });

                    $(".temp_hide").show();

                });
        }

        $(this).find(jFC).each(function(i){

            $(this).click(function(){
                dotimer();
                if ($(opts.slides).is(":not(:animated)")) {
                    $(jFC).removeClass(jSel);
					//$(title).eq(cur).removeClass(jSel);
                    $(this).addClass(jSel);					
                    var dur = Math.abs(cur-i);
                    slide(dur,i);
                    cur = i;
					//$(title).eq(cur).addClass(jSel);
                }
            });
        });

        $(opts.slides).before('<div id="'+jFS.substring(1, jFS.length)+'"></div>').appendTo(jFS);
        $(opts.slides).find("div").each(function(){
            $(this).before('<div class="jFlowSlideContainer"></div>').appendTo($(this).prev());
        });
 
 		//initialize the controller
        $(jFC).eq(cur).addClass(jSel);
		//$(title).eq(cur).addClass(jSel);
        var resize = function (x){
            $(jFS).css({
                position:"relative",
                width: opts.width,
                height: opts.height,
                overflow: "hidden"
            });

            //opts.slides or #mySlides container
            $(opts.slides).css({
                position:"relative",
                width: $(jFS).width()*$(jFC).length+"px",
                height: $(jFS).height()+"px",
                overflow: "hidden"
            });
            // jFlowSlideContainer
            $(opts.slides).children().css({
                position:"relative",
                width: $(jFS).width()+"px",
                height: $(jFS).height()+"px",
                "float":"left",
                overflow:"hidden"
            });

            $(opts.slides).css({
                marginLeft: "-" + (cur * $(opts.slides).find(":eq(0)").width() + "px")
            });
        }

        // sets initial size
        resize();

		// resets size
        $(window).resize(function(){
            resize();						  
        });

        $(opts.prev).click(function(){
            dotimer();
            doprev();
        });

        $(opts.next).click(function(){
            dotimer();
            donext();
        });

        var doprev = function (x){
            if ($(opts.slides).is(":not(:animated)")) {
                var dur = 1;
                if (cur > 0)
                    cur--;
                else {
                    cur = maxi -1;
                    dur = cur;
                }
                $(jFC).removeClass(jSel);
				//$(title).removeClass(jSel);
                slide(dur,cur);
                $(jFC).eq(cur).addClass(jSel);
				//$(title).eq(cur).addClass(jSel);
            }
        }

        var donext = function (x){
            if ($(opts.slides).is(":not(:animated)")) {
                var dur = 1;
                if (cur < maxi - 1)
                    cur++;
                else {
                    cur = 0;
                    dur = maxi -1;
                }
                $(jFC).removeClass(jSel);
				//$(title).removeClass(jSel);
                //$(jFS).fadeOut("fast");
                slide(dur, cur);
                //$(jFS).fadeIn("fast");
                $(jFC).eq(cur).addClass(jSel);
				//$(title).eq(cur).addClass(jSel);
            }
        }

        var dotimer = function (x){
            if((opts.auto) == true) {
                if(timer != null) 
                    clearInterval(timer);
                timer = setInterval(function() {
                    $(opts.next).click();
                }, 7500);
            }
        }
        dotimer();
        //Pause/Resume at hover
        /*$(opts.slides).hover(
            function() {
                clearInterval(timer);
            },
		
            function() {
                dotimer();
            }
            );*/
		
		if(isPaused) {
			$(opts.pause).addClass('paused');
		}
		
		$(opts.pause).click(function() {
			if(isPaused) {
				isPaused = false;
				$(opts.pause).removeClass('paused');
				dotimer();
			} else {
				isPaused = true;
				$(opts.pause).addClass('paused');
				clearInterval(timer);
			}   
		});
    };

	

    $.fn.jFlow.defaults = {

        controller: ".jFlowControl", // must be class, use . sign

        slideWrapper : "#jFlowSlide", // must be id, use # sign

        selectedWrapper: "jFlowSelected",  // just pure text, no sign

        auto: false,

        easing: "swing",
		
		//title: ".TitleNum",

        duration: 100,

        width: "100%",
		
		pause: ".jFlowPause",

        prev: ".jFlowPrev", // must be class, use . sign

        next: ".jFlowNext" // must be class, use . sign

    };

	

})(jQuery);
