/* 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 jSel = opts.selectedWrapper;
         
         
 
 
 
        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);
 
                    $(this).addClass(jSel);
 
                    var dur = Math.abs(cur-i);
 
                    slide(dur,i);
 
                    cur = i;
 
                }
 
            });
 
        });
 
         
 
        $(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);
 
         
 
        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);
 
                slide(dur,cur);
 
                $(jFC).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);
 
                //$(jFS).fadeOut("fast");
 
                slide(dur, cur);
 
                //$(jFS).fadeIn("fast");
 
                $(jFC).eq(cur).addClass(jSel);
 
            }
 
        }
 
         
 
        var dotimer = function (x){
 
            if((opts.auto) == true) {
 
                if(timer != null)
 
                    clearInterval(timer);
 
                 
 
                timer = setInterval(function() {
 
                        $(opts.next).click();
 
                        }, 10000);
                 
 
            }
 
        }
 
 
 
        dotimer();
//Pause/Resume at hover
        $(opts.slides).hover(
        function() {
        clearInterval(timer);
        },
         
        function() {
        dotimer();
        }
        );
    };
 
     
 
    $.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: true,
 
        easing: "swing",
 
        duration: 400,
 
        width: "100%",
 
        prev: ".jFlowPrev", // must be class, use . sign
 
        next: ".jFlowNext" // must be class, use . sign
 
    };
 
     
 
})(jQuery);
