/**
 * jquery.scrollFollow.js v0.4.0
 */
//eval(function(p,a,c,k,e,d){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--){d[e(c)]=k[c]||e(c)}k=[function(e){return d[e]}];e=function(){return'\\w+'};c=1};while(c--){if(k[c]){p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c])}}return p}('(3($){$.u=3(2,1){2=$(2);6 J=2.c(\'J\');3 d(){2.Y([]);6 G=4($(O).16());6 s=4($(14).13());6 P=4(2.j.7().9);6 H=4(2.j.a(\'V\'));6 t=4(2.a(\'V\')+(4(2.c(\'11\'))||0)+(4(2.c(\'12\'))||0));6 f;5(b){5(1.C==\'9\'){5(2.A>=(s+1.7)){f=2.i}k{f=K.S((K.10((-P),(s-2.A+2.i))+1.7),(H-t-2.N))}}k 5(1.C==\'15\'){5((2.A+t)>=(s+1.7+G)){f=2.i}k{f=K.S((s+G-t-1.7),(H-t))}}5((y M().F()-2.B)>=(1.r-1j)){2.L({9:f},1.D,1.E)}}};6 b=n;5($.e!=1f){5($.e(\'q\'+2.a(\'l\'))==\'g\'){6 b=g;$(\'#\'+1.o).h(1.m).X(3(){b=n;$(8).h(1.p);$.e(\'q\'+2.a(\'l\'),n,{x:z,w:\'/\'});d()},3(){b=g;$(8).h(1.m);2.L({9:2.i},1.D,1.E);$.e(\'q\'+2.a(\'l\'),g,{x:z,w:\'/\'})})}k{$(\'#\'+1.o).h(1.p).X(3(){b=g;$(8).h(1.m);2.L({9:2.i},0);$.e(\'q\'+2.a(\'l\'),g,{x:z,w:\'/\'})},3(){b=n;$(8).h(1.p);$.e(\'q\'+2.a(\'l\'),n,{x:z,w:\'/\'});d()})}}5(1.v==\'\'){2.j=2.R()}k{2.j=$(\'#\'+1.v)}2.A=4(2.7().9);2.i=4(2.c(\'9\'))||0;5(2.c(\'J\')==\'1d\'){2.N=4(2.j.c(\'19\'))+4(2.j.c(\'1a\'))}k{2.N=0}$(O).1c(3(){$.I.u.T=U(3(){d()},1.r);2.B=y M().F()});$(O).1i(3(){$.I.u.T=U(3(){d()},1.r);2.B=y M().F()});2.B=0;d()};$.I.u=3(1){1=1||{};1.C=1.C||\'9\';1.D=1.D||1h;1.7=1.7||0;1.E=1.E||\'Z\';1.v=1.v||8.R().a(\'l\');1.o=1.o||\'o\';1.p=1.p||\'W Q 18\';1.m=1.m||\'W Q 1e\';1.r=1.r||0;8.17(3(){y $.u(8,1)});1g 8}})(1b);',62,82,'|options|box|function|parseInt|if|var|offset|this|top|attr|isActive|css|ani|cookie|aniTop|false|text|initialTop|cont|else|id|offText|true|killSwitch|onText|scrollFollowSetting|delay|pageScroll|boxHeight|scrollFollow|container|path|expires|new|365|initialOffsetTop|lastScroll|relativeTo|speed|easing|getTime|viewportHeight|parentHeight|fn|position|Math|animate|Date|paddingAdjustment|window|parentTop|Slide|parent|min|interval|setTimeout|offsetHeight|Turn|toggle|queue|swing|max|marginTop|marginBottom|scrollTop|document|bottom|height|each|Off|paddingTop|paddingBottom|jQuery|scroll|relative|On|undefined|return|500|resize|20'.split('|'),0,{}));

/**
 * jquery.scrollFollow.js
 * Copyright (c) 2008 Net Perspective (http://kitchen.net-perspective.com/)
 * Licensed under the MIT License (http://www.opensource.org/licenses/mit-license.php)
 * 
 * @author R.A. Ray
 *
 * @projectDescription	jQuery plugin for allowing an element to animate down as the user scrolls the page.
 * 
 * @version 0.4.0
 * 
 * @requires jquery.js (tested with 1.2.6)
 * @requires ui.core.js (tested with 1.5.2)
 * 
 * @optional jquery.cookie.js (http://www.stilbuero.de/2006/09/17/cookie-plugin-for-jquery/)
 * @optional jquery.easing.js (http://gsgd.co.uk/sandbox/jquery/easing/ - tested with 1.3)
 * 
 * @param speed		int - Duration of animation (in milliseconds)
 * 								default: 500
 * @param offset			int - Number of pixels box should remain from top of viewport
 * 								default: 0
 * @param easing		string - Any one of the easing options from the easing plugin - Requires jQuery Easing Plugin < http://gsgd.co.uk/sandbox/jquery/easing/ >
 * 								default: 'linear'
 * @param container	string - ID of the containing div
 * 								default: box's immediate parent
 * @param killSwitch	string - ID of the On/Off toggle element
 * 								default: 'killSwitch'
 * @param onText		string - killSwitch text to be displayed if sliding is enabled
 * 								default: 'Turn Slide Off'
 * @param offText		string - killSwitch text to be displayed if sliding is disabled
 * 								default: 'Turn Slide On'
 * @param relativeTo	string - Scroll animation can be relative to either the 'top' or 'bottom' of the viewport
 * 								default: 'top'
 * @param delay			int - Time between the end of the scroll and the beginning of the animation in milliseconds
 * 								default: 0
 */

( function( $ ) {
	
	$.scrollFollow = function ( box, options )
	{ 
		// Convert box into a jQuery object
		box = $( box );
		
		// 'box' is the object to be animated
		var position = box.css( 'position' );
		
		function ani()
		{		
			// The script runs on every scroll which really means many times during a scroll.
			// We don't want multiple slides to queue up.
			box.queue( [ ] );
		
			// A bunch of values we need to determine where to animate to
			var viewportHeight = parseInt( $( window ).height() );	
			var pageScroll =  parseInt( $( document ).scrollTop() );
			var parentTop =  parseInt( box.cont.offset().top );
			//var parentHeight = parseInt( box.cont.attr( 'offsetHeight' ) );
			var parentHeight = parseInt( box.cont.get(0).offsetHeight);
			//console.log('box.cont '+parentHeight);
			var boxHeight = parseInt( box.get(0).offsetHeight + ( parseInt( box.css( 'marginTop' ) ) || 0 ) + ( parseInt( box.css( 'marginBottom' ) ) || 0 ) );
			var aniTop;
			
			// Make sure the user wants the animation to happen
			if ( isActive )
			{
				// If the box should animate relative to the top of the window
				if ( options.relativeTo == 'top' )
				{
					// Don't animate until the top of the window is close enough to the top of the box
					if ( box.initialOffsetTop >= ( pageScroll + options.offset ) )
					{
						aniTop = box.initialTop;
					}
					else
					{
						aniTop = Math.min( ( Math.max( ( -parentTop ), ( pageScroll - box.initialOffsetTop + box.initialTop ) ) + options.offset ), ( parentHeight - boxHeight - box.paddingAdjustment ) );
					}
				}
				// If the box should animate relative to the bottom of the window
				else if ( options.relativeTo == 'bottom' )
				{
					// Don't animate until the bottom of the window is close enough to the bottom of the box
					if ( ( box.initialOffsetTop + boxHeight ) >= ( pageScroll + options.offset + viewportHeight ) )
					{
						aniTop = box.initialTop;
					}
					else
					{
						aniTop = Math.min( ( pageScroll + viewportHeight - boxHeight - options.offset ), ( parentHeight - boxHeight ) );
					}
				}
				
				// Checks to see if the relevant scroll was the last one
				// "-20" is to account for inaccuracy in the timeout
				if ( ( new Date().getTime() - box.lastScroll ) >= ( options.delay - 20 ) )
				{
					box.animate(
						{
							top: aniTop
						}, options.speed, options.easing
					);
				}
			}
		};
		
		// For user-initiated stopping of the slide
		var isActive = true;
		
		if ( $.cookie != undefined )
		{
			if( $.cookie( 'scrollFollowSetting' + box.attr( 'id' ) ) == 'false' )
			{
				var isActive = false;
				
				$( '#' + options.killSwitch ).text( options.offText )
					.toggle( 
						function ()
						{
							isActive = true;
							
							$( this ).text( options.onText );
							
							$.cookie( 'scrollFollowSetting' + box.attr( 'id' ), true, { expires: 365, path: '/'} );
							
							ani();
						},
						function ()
						{
							isActive = false;
							
							$( this ).text( options.offText );
							
							box.animate(
								{
									top: box.initialTop
								}, options.speed, options.easing
							);	
							
							$.cookie( 'scrollFollowSetting' + box.attr( 'id' ), false, { expires: 365, path: '/'} );
						}
					);
			}
			else
			{
				$( '#' + options.killSwitch ).text( options.onText )
					.toggle( 
						function ()
						{
							isActive = false;
							
							$( this ).text( options.offText );
							
							box.animate(
								{
									top: box.initialTop
								}, 0
							);	
							
							$.cookie( 'scrollFollowSetting' + box.attr( 'id' ), false, { expires: 365, path: '/'} );
						},
						function ()
						{
							isActive = true;
							
							$( this ).text( options.onText );
							
							$.cookie( 'scrollFollowSetting' + box.attr( 'id' ), true, { expires: 365, path: '/'} );
							
							ani();
						}
					);
			}
		}
		
		// If no parent ID was specified, and the immediate parent does not have an ID
		// options.container will be undefined. So we need to figure out the parent element.
		if ( typeof options.container == 'undefined')
		{
			box.cont = box.parent();
		}
		else
		{
			box.cont = $( '#' + options.container );
		}
		
		// Finds the default positioning of the box.
		box.initialOffsetTop =  parseInt( box.offset().top );
		box.initialTop = parseInt( box.css( 'top' ) ) || 0;
		
		// Hack to fix different treatment of boxes positioned 'absolute' and 'relative'
		if ( box.css( 'position' ) == 'relative' )
		{
			box.paddingAdjustment = parseInt( box.cont.css( 'paddingTop' ) ) + parseInt( box.cont.css( 'paddingBottom' ) );
		}
		else
		{
			box.paddingAdjustment = 0;
		}
		
		// Animate the box when the page is scrolled
		$( window ).scroll( function ()
			{
				// Sets up the delay of the animation
				$.fn.scrollFollow.interval = setTimeout( function(){ ani();} , options.delay );
				
				// To check against right before setting the animation
				box.lastScroll = new Date().getTime();
			}
		);
		
		// Animate the box when the page is resized
		$( window ).resize( function ()
			{
				// Sets up the delay of the animation
				$.fn.scrollFollow.interval = setTimeout( function(){ ani();} , options.delay );
				
				// To check against right before setting the animation
				box.lastScroll = new Date().getTime();
			}
		);

		// Run an initial animation on page load
		box.lastScroll = 0;
		
		ani();
	};
	
	$.fn.scrollFollow = function ( options )
	{
		options = options || {};
		options.relativeTo = options.relativeTo || 'top';
		options.speed = options.speed || 500;
		options.offset = options.offset || 0;
		options.easing = options.easing || 'swing';
		options.container = options.container || this.parent().attr( 'id' );
		options.killSwitch = options.killSwitch || 'killSwitch';
		options.onText = options.onText || 'Turn Slide Off';
		options.offText = options.offText || 'Turn Slide On';
		options.delay = options.delay || 0;
		
		this.each( function() 
			{
				new $.scrollFollow( this, options );
			}
		);
		
		return this;
	};
})( jQuery );







