/*

Default 1.0 - use this file to initialize any jQuery animations

*/

$(document).ready(function(){

	/* Image Tool Tip */
	imagePreview();
	
	/* Main Navigation Menu System */
    $('ul.sf-menu').superfish({ 
        delay:       500,                            // one second delay on mouseout 
        speed:       'fast',                          // faster animation speed 
        autoArrows:  true,                           // disable generation of arrow mark-up 
        dropShadows: true                            // disable drop shadows 
    }); 
	
	/*
	// Login pop-up
	$("#login-tip1").click(function() {
		$("#login-wrap").animate({opacity: "show", top: "180"}, "fast");
	});
		$(".#login-wrap img").click(function() {
		$("#login-wrap").animate({opacity: "hide", top: "200"}, "fast");
	});
	
	// Login pop-up
	$("#login-tip2").click(function() {
		$("#login-wrap").animate({opacity: "show", top: "180"}, "fast");
	});
		$(".#login-wrap img").click(function() {
		$("#login-wrap").animate({opacity: "hide", top: "200"}, "fast");
	});
	*/
	
	/* Back to Top of Page */
	$('a.top').click(function(){
	     $('html, body').animate({scrollTop: '0px'}, 300);
	     return false;
	});
	
	/* FAQ drop-down animation */
	$(".extendfaq").click(function(){
	$(this).next(".extendfaq-body").slideToggle("fast");
	$(this).toggleClass("active");
		});

	/* Extend block drop-down animation */
	$(".extendblock").click(function()
	{
	   $(this).next(".extendblock-body").slideToggle("fast");
	   $(this).toggleClass("active");
	   Alert("Got here");
	});
	
	//Full Caption Sliding (Hidden to Visible) - Used on HOME page
	$('.boxgrid.captionfull').hover(function(){
		$(".cover", this).stop().animate({top:'125px'},{queue:false,duration:160});
	}, function() {
		$(".cover", this).stop().animate({top:'260px'},{queue:false,duration:160});
	});
	
	//Stop scrolling Developments - Used on HOME page
	$('#sections').hover(function(){
		$("#sections").trigger( 'stop' );
	}, function() {
		$("#sections").trigger( 'start' );
	});
	
	/**
	 * Most jQuery.serialScroll's settings, actually belong to jQuery.ScrollTo, check it's demo for an example of each option.
	 * @see http://flesler.demos.com/jquery/scrollTo/
	 * You can use EVERY single setting of jQuery.ScrollTo, in the settings hash you send to jQuery.serialScroll.
	 */
	
	/**
	 * The plugin binds 6 events to the container to allow external manipulation.
	 * prev, next, goto, start, stop and notify
	 * You use them like this: $(your_container).trigger('next'), $(your_container).trigger('goto', [5]) (0-based index).
	 * If for some odd reason, the element already has any of these events bound, trigger it with the namespace.
	 */		
	
	/**
	 * IMPORTANT: this call to the plugin specifies ALL the settings (plus some of jQuery.ScrollTo)
	 * This is done so you can see them. You DON'T need to specify the commented ones.
	 * A 'target' is specified, that means that #screen is the context for target, prev, next and navigation.
	 */
	$('#screen').serialScroll({
		target:'#sections',
		items:'li', // Selector to the items ( relative to the matched elements, '#sections' in this case )
		prev:'.prev',// Selector to the 'prev' button (absolute!, meaning it's relative to the document)
		next:'.frwd',// Selector to the 'next' button (absolute too)
		axis:'y',// The default is 'y' scroll on both ways
		navigation:'#navigation li a',
		duration:450,// Length of the animation (if you scroll 2 axes and use queue, then each axis take half this time)
		force:true, // Force a scroll to the element specified by 'start' (some browsers don't reset on refreshes)
		
		//queue:false,// We scroll on both axes, scroll both at the same time.
		//event:'click',// On which event to react (click is the default, you probably won't need to specify it)
		//stop:false,// Each click will stop any previous animations of the target. (false by default)
		//lock:true, // Ignore events if already animating (true by default)		
		//start: 0, // On which element (index) to begin ( 0 is the default, redundant in this case )		
		//cycle:true,// Cycle endlessly ( constant velocity, true is the default )
		//step:1, // How many items to scroll each time ( 1 is the default, no need to specify )
		//jump:false, // If true, items become clickable (or w/e 'event' is, and when activated, the pane scrolls to them)
		//lazy:false,// (default) if true, the plugin looks for the items on each event(allows AJAX or JS content, or reordering)
		interval:7000, // It's the number of milliseconds to automatically go to the next
		//constant:true, // constant speed
		
		onBefore:function( e, elem, $pane, $items, pos ){
			/**
			 * 'this' is the triggered element 
			 * e is the event object
			 * elem is the element we'll be scrolling to
			 * $pane is the element being scrolled
			 * $items is the items collection at this moment
			 * pos is the position of elem in the collection
			 * if it returns false, the event will be ignored
			 */
			 //those arguments with a $ are jqueryfied, elem isn't.
			e.preventDefault();
			if( this.blur )
				this.blur();
		},
		onAfter:function( elem ){
			//'this' is the element being scrolled ($pane) not jqueryfied
		}
	});
	
	/* Tool-Tips */
	$('a[title]').qtip({ style: { name: 'red', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
    	}
		}
	})
	$('img[title]').qtip({ style: { name: 'red', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
    	}
		}
	})
	$('#frontleftpanel #tip').qtip({ style: { name: 'blue', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
     	}
		}
	})
	$('#customerService #tip').qtip({ style: { name: 'blue', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
     	}
		}
	})
	$('#frontleftpanel #login-tip1').qtip({ style: { name: 'blue', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
     	}
		}
	})
	$('#frontleftpanel #login-tip2').qtip({ style: { name: 'blue', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
     	}
		}
	})
	$('.prev').qtip({ style: { name: 'blue', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
    	}
		}
	})
	$('.frwd').qtip({ style: { name: 'blue', tip: true }, position: {
        corner: {
        tooltip: 'bottomMiddle', // Use the corner...
        target: 'topMiddle' // ...and opposite corner
    	}
		}
	})	
});

var menu=function(){
    var t=15,z=50,s=6,a;
    function dd(n){this.n=n; this.h=[]; this.c=[]}
    dd.prototype.init=function(p,c){
        a=c; var w=document.getElementById(p), s=w.getElementsByTagName('ul'), l=s.length, i=0;
        for(i;i<l;i++){
            var h=s[i].parentNode; this.h[i]=h; this.c[i]=s[i];
            h.onmouseover=new Function(this.n+'.st('+i+',true)');
            h.onmouseout=new Function(this.n+'.st('+i+')');
        }
    }
    dd.prototype.st=function(x,f){
        var c=this.c[x], h=this.h[x], p=h.getElementsByTagName('a')[0];
        clearInterval(c.t); c.style.overflow='hidden';
        if(f){
            p.className+=' '+a;
            if(!c.mh){c.style.display='block'; c.style.height=''; c.mh=c.offsetHeight; c.style.height=0}
            if(c.mh==c.offsetHeight){c.style.overflow='visible'}
            else{c.style.zIndex=z; z++; c.t=setInterval(function(){sl(c,1)},t)}
        }else{p.className=p.className.replace(a,''); c.t=setInterval(function(){sl(c,-1)},t)}
    }
    function sl(c,f){
        var h=c.offsetHeight;
        if((h<=0&&f!=1)||(h>=c.mh&&f==1)){
            if(f==1){c.style.filter=''; c.style.opacity=1; c.style.overflow='visible'}
            clearInterval(c.t); return
        }
        var d=(f==1)?Math.ceil((c.mh-h)/s):Math.ceil(h/s), o=h/c.mh;
        c.style.opacity=o; c.style.filter='alpha(opacity='+(o*100)+')';
        c.style.height=h+(d*f)+'px'
    }
    return{dd:dd}
}();

/*
 * Image preview script 
 * powered by jQuery (http://www.jquery.com)
 * 
 * written by Alen Grakalic (http://cssglobe.com)
 * 
 * for more info visit http://cssglobe.com/post/1695/easiest-tooltip-and-image-preview-using-jquery
 *
 */
 
this.imagePreview = function(){	
	/* CONFIG */
		
		xOffset = -30;
		yOffset = -170;
		
		// these 2 variable determine popup's distance from the cursor
		// you might want to adjust to get the right result
		
	/* END CONFIG */
	$("a.preview").hover(function(e){
		this.t = this.title;
		this.title = "";	
		var c = (this.t != "") ? "<br/>" + this.t : "";
		$("body").append("<p id='preview'><img src='"+ this.name +"' alt='Image preview' />"+ c +"</p>");								 
		$("#preview")
			.css("top",(e.pageY - xOffset) + "px")
			.css("left",(e.pageX + yOffset) + "px")
			.fadeIn("fast");						
    },
	function(){
		this.title = this.t;	
		$("#preview").remove();
    });	
	$("a.preview").mousemove(function(e){
		$("#preview")
			.css("top",(e.pageY - xOffset) + "px")
			.css("left",(e.pageX + yOffset) + "px");
	});			
};



