// 
//  v3.js
//  @author    Stephen Chai on 2010-06-15.
//  @copyright http://stephen.chai.name. All Rights Reserved.
//  @created   2010-06-15.
// 

// global var
var sc = {};
// tool tip defaults
sc.tool_tip_defaults = { defaultPosition: 'top', delay: 200, edgeOffset: 7, fadeIn: 250, fadeOut: 100, maxWidth: '200px' };

// on ready
$(document).ready(function() {
	// apply bindings
	sc.bind();
});

// apply bindings
sc.bind = function(context) {
	// contact form
	var $contact_form = $('#contact_form', context);
	// yup, there's a contact form, phew
	if ($contact_form.length) {
		// remove the #contact anchor
		$contact_form.attr('action', '/');
		// add in hidden AJAX var
		$contact_form.append('<input type="hidden" name="contact_form_ajax" id="contact_form_ajax" value="1" />');
		// remove the honey pot
		$('#sc_contact_form_honeypot').remove();
		// on submit
		$contact_form.submit(function() {
			// switch to loading
			$contact_form.find('.submit').css('display', 'none');
			$contact_form.find('.loading').css('display', 'inline');
			// disable and dim, make sure nothing has focus
			$contact_form.find('input, label, textarea').attr('disabled', 'disabled').attr('readonly', 'readonly').blur().animate({ opacity: 0 }, 1000, 'easeOutQuad');
			// get form data
			var data_string = '';
			$contact_form.find('input, textarea').each(function() { data_string += '&' + $(this).attr('name') + '=' + $(this).val(); });
			// submit via AJAX
			$.ajax({
				data: data_string,
				dataType: 'json',
				error: function(xml_http_request, text_status, error_thrown) { alert('Yikes. Something crazy happened and your message was not sent. Sorry.'); },
				success: sc.contactFormSuccess,
				type: 'POST',
				url: $(this).attr('action')
			});
			// and don't submit normal style
			return false;
		});
	}
	// the header nav
	var $header_nav = $('#header_nav', context);
	// header nav fixed positioning
	if ($header_nav.length) {
		// store position so we don't need to calculate all the time
		$header_nav.attr('y_pos', $header_nav.position().top);
		// add scroll listener
		$(window).bind('scroll', function(event) {
			// if we've scrolled to or past the header nav position, add the fixed class
			if ($header_nav.attr('y_pos') >= $(window).scrollTop()) $header_nav.removeClass('header_nav_fixed');
			// else remove it, let it flow!
			else $header_nav.addClass('header_nav_fixed');
		});
	}
	// header nav local scroll
	$header_nav.localScroll({ axis: 'y', duration: 500, easing: 'easeInQuad', offset: -131 });
	// portfolio tool tips
	$('.portfolio_tool_tip', context).each(function() {
		// get defaults
		var config = sc.tool_tip_defaults;
		// set content 
		config.content = '<img src="/img/gear.png" />' + $(this).attr('alt').replace(' / ', '<strong>') + '</strong>';
		// init
		$(this).tipTip(config);
		// and hide tool tip on click (to show fancy box)
		$(this).bind('click', function() {
			$(this).trigger('mouseout');
		});
	});
	// portfolio fancy box
	$('#portfolio_pieces a.fancybox', context).fancybox();
	// portfolio pieces w/ external links
	$('#portfolio_pieces li', context).each(function() {
		// if has external link
		if ($(this).find('.tir_ext_link').length) {
			// the external link
			var $ext_link = $(this).find('.tir_ext_link');
			// hide it by default
			$ext_link.fadeOut(0);
			// on hover show, mouse out hide (with a touch of delay for effect and usability)
			$(this).hover(function() {
				clearTimeout($ext_link.attr('timeout_id'));
				var timeout_id = setTimeout(function() { $ext_link.fadeIn(200); }, 1250);
				$ext_link.attr('timeout_id', timeout_id);
			}, function() {
				clearTimeout($ext_link.attr('timeout_id'));
				var timeout_id = setTimeout(function() { $ext_link.fadeOut(200); }, 500);
				$ext_link.attr('timeout_id', timeout_id);
			});
		}
	});
	// scroll controls
	$('#portfolio_pieces, #recognition_quotes', context).each(function() {
		// dont add controls if only one pane
		if ($(this).find('.pane').length < 2) return;
		// slidy dots target
		var target_id = $(this).attr('id');
		// start html
		var html = '<ul class="scroll_controls" id="' + target_id + '_controls">';
		// for each scroll pane
		$(this).find('.pane').each(function(index) {
			html += '<li><a href="javascript: sc.scrollPaneShow(\'' + target_id + '\', ' + index + ')" class="' + ($(this).hasClass('selected') ? 'selected' : '') + '"></a></li>';
		});
		// end html
		html += '</ul>';
		// write html
		$(this).closest('.section').append(html);
	});
	// recognition tool tips
	$('#recognition .tool_tip', context).each(function() {
		// get defaults
		var config = sc.tool_tip_defaults;
		// set content 
		config.content = '<img src="/img/star.png" />' + $(this).html();
		// init
		$(this).tipTip(config);
	});
	// skills tool tips
	$('#skills .tool_tip', context).each(function() {
		// get defaults
		var config = sc.tool_tip_defaults;
		// set content 
		config.content = '<img src="/img/check.png" />' + $(this).find('.skill_name').text() + '<strong>' + $(this).find('.skill_desc').text().replace(/ /g, '<br />') + '</strong>';
		// init
		$(this).tipTip(config);
	});
};

// contact form AJAX request succesful callback
sc.contactFormSuccess = function(json, text_status, xml_http_request) {
	// the contact form
	var $contact_form = $('#contact_form');
	// if form errors
	if (json.errors) {
		// fade out form content
		$contact_form.find('.form_content').animate({ opacity: 0, queue: false }, 500, 'easeInQuad', function() {
			// fade in new content
			$('#contact').replaceWith(json.html).find('.form_content');
			// if there's an error field, highlight it
			if ($('#contact label.error').length) $('#' + $('#contact label.error').eq(0).attr('for')).focus();
			// else just try for an input
			else $('#contact input').eq(0).focus();
			// apply bindings
			sc.bind($('#contact'));
		});
	}
	// else no errors, done and done
	else {
		// fade out form content
		$contact_form.find('.form_content').animate({ opacity: 0 }, 750, 'easeInQuad', function() {
			// animate form controls out
			$contact_form.find('.form_controls').animate({ top: '220px' }, 500, 'easeOutQuad', function() {
				// remove form controls
				$('#contact_form .form_controls').remove(); 
				// replace new content
				$('#contact_form .form_content').empty().append(json.html).css({ opacity: 1, top: '320px' }).animate({ top: 0 }, 1500, 'easeInOutBack');
			});
		});
	}
};

// show a scroll pane index
sc.scrollPaneShow = function(target_id, index_to_show) {
	// config, animation duration
	var animate_duration = 500;
	// the scroll controls
	var $controls = $('#' + target_id + '_controls');
	// if the controls are locked, do nothing
	if ($controls.hasClass('locked')) return;
	// the parent container
	var $target = $('#' + target_id);
	// scroll to position all nicely like
	$(window).scrollTo($target.closest('.section'), 500, { axis: 'y', easing: 'easeInQuad', offset: -131 });
	// currently selected index
	var index_shown = $target.find('.pane.selected').index();
	// if index_to_show is already shown, do nothing
	if (index_to_show == index_shown) return;
	// update controls
	$controls.find('a').removeClass('selected');
	$controls.find('a').eq(index_to_show).addClass('selected');
	// lock the controls
	$controls.addClass('locked');
	// and unlock them after the animation is complete
	setTimeout(function() { $controls.removeClass('locked'); }, animate_duration);
	// animation direction
	var animate_direction = index_shown < index_to_show ? -1 : 1;
	// hide currently selected
	var $selected = $target.find('.pane.selected');
	$selected.animate({ left: (($selected.outerWidth() + 25) * animate_direction) + 'px' }, animate_duration, 'easeOutQuad', function() { $(this).removeClass('selected'); });
	// show new
	var $to_select = $target.find('.pane').eq(index_to_show);
	$to_select.css('left', (animate_direction * -1 * ($to_select.outerWidth() + 25)) + 'px').addClass('selected').animate({ left: 0 }, animate_duration, 'easeOutQuad');
	// make sure all ext_link's are hidden
	$to_select.find('.tir_ext_link').fadeOut(0);
};

// jQuery Easing v1.3 - http://gsgd.co.uk/sandbox/jquery/easing/
jQuery.easing['jswing'] = jQuery.easing['swing'];
jQuery.extend(jQuery.easing,{def:'easeOutQuad',swing:function(x,t,b,c,d){return jQuery.easing[jQuery.easing.def](x,t,b,c,d);},easeInQuad:function(x,t,b,c,d){return c*(t/=d)*t+b;},easeOutQuad:function(x,t,b,c,d){return-c*(t/=d)*(t-2)+b;},easeInOutQuad:function(x,t,b,c,d){if((t/=d/2)<1)return c/2*t*t+b;return-c/2*((--t)*(t-2)-1)+b;},easeInCubic:function(x,t,b,c,d){return c*(t/=d)*t*t+b;},easeOutCubic:function(x,t,b,c,d){return c*((t=t/d-1)*t*t+1)+b;},easeInOutCubic:function(x,t,b,c,d){if((t/=d/2)<1)return c/2*t*t*t+b;return c/2*((t-=2)*t*t+2)+b;},easeInQuart:function(x,t,b,c,d){return c*(t/=d)*t*t*t+b;},easeOutQuart:function(x,t,b,c,d){return-c*((t=t/d-1)*t*t*t-1)+b;},easeInOutQuart:function(x,t,b,c,d){if((t/=d/2)<1)return c/2*t*t*t*t+b;return-c/2*((t-=2)*t*t*t-2)+b;},easeInQuint:function(x,t,b,c,d){return c*(t/=d)*t*t*t*t+b;},easeOutQuint:function(x,t,b,c,d){return c*((t=t/d-1)*t*t*t*t+1)+b;},easeInOutQuint:function(x,t,b,c,d){if((t/=d/2)<1)return c/2*t*t*t*t*t+b;return c/2*((t-=2)*t*t*t*t+2)+b;},easeInSine:function(x,t,b,c,d){return-c*Math.cos(t/d*(Math.PI/2))+c+b;},easeOutSine:function(x,t,b,c,d){return c*Math.sin(t/d*(Math.PI/2))+b;},easeInOutSine:function(x,t,b,c,d){return-c/2*(Math.cos(Math.PI*t/d)-1)+b;},easeInExpo:function(x,t,b,c,d){return(t==0)?b:c*Math.pow(2,10*(t/d-1))+b;},easeOutExpo:function(x,t,b,c,d){return(t==d)?b+c:c*(-Math.pow(2,-10*t/d)+1)+b;},easeInOutExpo:function(x,t,b,c,d){if(t==0)return b;if(t==d)return b+c;if((t/=d/2)<1)return c/2*Math.pow(2,10*(t-1))+b;return c/2*(-Math.pow(2,-10*--t)+2)+b;},easeInCirc:function(x,t,b,c,d){return-c*(Math.sqrt(1-(t/=d)*t)-1)+b;},easeOutCirc:function(x,t,b,c,d){return c*Math.sqrt(1-(t=t/d-1)*t)+b;},easeInOutCirc:function(x,t,b,c,d){if((t/=d/2)<1)return-c/2*(Math.sqrt(1-t*t)-1)+b;return c/2*(Math.sqrt(1-(t-=2)*t)+1)+b;},easeInElastic:function(x,t,b,c,d){var s=1.70158;var p=0;var a=c;if(t==0)return b;if((t/=d)==1)return b+c;if(!p)p=d*.3;if(a<Math.abs(c)){a=c;var s=p/4;} else var s=p/(2*Math.PI)*Math.asin(c/a);return-(a*Math.pow(2,10*(t-=1))*Math.sin((t*d-s)*(2*Math.PI)/p))+b;},easeOutElastic:function(x,t,b,c,d){var s=1.70158;var p=0;var a=c;if(t==0)return b;if((t/=d)==1)return b+c;if(!p)p=d*.3;if(a<Math.abs(c)){a=c;var s=p/4;} else var s=p/(2*Math.PI)*Math.asin(c/a);return a*Math.pow(2,-10*t)*Math.sin((t*d-s)*(2*Math.PI)/p)+c+b;},easeInOutElastic:function(x,t,b,c,d){var s=1.70158;var p=0;var a=c;if(t==0)return b;if((t/=d/2)==2)return b+c;if(!p)p=d*(.3*1.5);if(a<Math.abs(c)){a=c;var s=p/4;}else var s=p/(2*Math.PI)*Math.asin(c/a);if(t<1)return-.5*(a*Math.pow(2,10*(t-=1))*Math.sin((t*d-s)*(2*Math.PI)/p))+b;return a*Math.pow(2,-10*(t-=1))*Math.sin((t*d-s)*(2*Math.PI)/p)*.5+c+b;},easeInBack:function(x,t,b,c,d,s){if(s==undefined)s=1.70158;return c*(t/=d)*t*((s+1)*t-s)+b;},easeOutBack:function(x,t,b,c,d,s){if(s==undefined)s=1.70158;return c*((t=t/d-1)*t*((s+1)*t+s)+1)+b;},easeInOutBack:function(x,t,b,c,d,s){if(s==undefined)s=1.70158;if((t/=d/2)<1)return c/2*(t*t*(((s*=(1.525))+1)*t-s))+b;return c/2*((t-=2)*t*(((s*=(1.525))+1)*t+s)+2)+b;},easeInBounce:function(x,t,b,c,d){return c-jQuery.easing.easeOutBounce(x,d-t,0,c,d)+b;},easeOutBounce:function(x,t,b,c,d){if((t/=d)<(1/2.75)){return c*(7.5625*t*t)+b;}else if(t<(2/2.75)){return c*(7.5625*(t-=(1.5/2.75))*t+.75)+b;}else if(t<(2.5/2.75)){return c*(7.5625*(t-=(2.25/2.75))*t+.9375)+b;}else{return c*(7.5625*(t-=(2.625/2.75))*t+.984375)+b;}},easeInOutBounce:function(x,t,b,c,d){if(t<d/2)return jQuery.easing.easeInBounce(x,t*2,0,c,d)*.5+b;return jQuery.easing.easeOutBounce(x,t*2-d,0,c,d)*.5+c*.5+b;}});

// fancy box v 1.3.1, modified to apply my defaults
(function(b){var m,u,x,g,D,i,z,A,B,p=0,e={},q=[],n=0,c={},j=[],E=null,s=new Image,G=/\.(jpg|gif|png|bmp|jpeg)(.*)?$/i,S=/[^\.]\.(swf)\s*$/i,H,I=1,k,l,h=false,y=b.extend(b("<div/>")[0],{prop:0}),v=0,O=!b.support.opacity&&!window.XMLHttpRequest,J=function(){u.hide();s.onerror=s.onload=null;E&&E.abort();m.empty()},P=function(){b.fancybox('<p id="fancybox_error">The requested content cannot be loaded.<br />Please try again later.</p>',{scrolling:"no",padding:20,transitionIn:"none",transitionOut:"none"})},K=function(){return[b(window).width(),b(window).height(),b(document).scrollLeft(),b(document).scrollTop()]},T=function(){var a=K(),d={},f=c.margin,o=c.autoScale,t=(20+f)*2,w=(20+f)*2,r=c.padding*2;if(c.width.toString().indexOf("%")>-1){d.width=a[0]*parseFloat(c.width)/100-40;o=false}else d.width=c.width+r;if(c.height.toString().indexOf("%")>-1){d.height=a[1]*parseFloat(c.height)/100-40;o=false}else d.height=c.height+r;if(o&&(d.width>a[0]-t||d.height>a[1]-w))if(e.type=="image"||e.type=="swf"){t+=r;w+=r;o=Math.min(Math.min(a[0]-t,c.width)/c.width,Math.min(a[1]-w,c.height)/c.height);d.width=Math.round(o*(d.width-r))+r;d.height=Math.round(o*(d.height-r))+r}else{d.width=Math.min(d.width,a[0]-t);d.height=Math.min(d.height,a[1]-w)}d.top=a[3]+(a[1]-(d.height+40))*0.5;d.left=a[2]+(a[0]-(d.width+40))*0.5;if(c.autoScale===false){d.top=Math.max(a[3]+f,d.top);d.left=Math.max(a[2]+f,d.left)}return d},U=function(a){if(a&&a.length)switch(c.titlePosition){case"inside":return a;case"over":return'<span id="fancybox-title-over">'+a+"</span>";default:return'<span id="fancybox-title-wrap"><span id="fancybox-title-left"></span><span id="fancybox-title-main">'+a+'</span><span id="fancybox-title-right"></span></span>'}return false},V=function(){var a=c.title,d=l.width-c.padding*2,f="fancybox-title-"+c.titlePosition;b("#fancybox-title").remove();v=0;if(c.titleShow!==false){a=b.isFunction(c.titleFormat)?c.titleFormat(a,j,n,c):U(a);if(!(!a||a==="")){b('<div id="fancybox-title" class="'+f+'" />').css({width:d,paddingLeft:c.padding,paddingRight:c.padding}).html(a).appendTo("body");switch(c.titlePosition){case"inside":v=b("#fancybox-title").outerHeight(true)-c.padding;l.height+=v;break;case"over":b("#fancybox-title").css("bottom",c.padding);break;default:b("#fancybox-title").css("bottom",b("#fancybox-title").outerHeight(true)*-1);break}b("#fancybox-title").appendTo(D).hide()}}},W=function(){b(document).unbind("keydown.fb").bind("keydown.fb",function(a){if(a.keyCode==27&&c.enableEscapeButton){a.preventDefault();b.fancybox.close()}else if(a.keyCode==37){a.preventDefault();b.fancybox.prev()}else if(a.keyCode==39){a.preventDefault();b.fancybox.next()}});if(b.fn.mousewheel){g.unbind("mousewheel.fb");j.length>1&&g.bind("mousewheel.fb",function(a,d){a.preventDefault();h||d===0||(d>0?b.fancybox.prev():b.fancybox.next())})}if(c.showNavArrows){if(c.cyclic&&j.length>1||n!==0)A.show();if(c.cyclic&&j.length>1||n!=j.length-1)B.show()}},X=function(){var a,d;if(j.length-1>n){a=j[n+1].href;if(typeof a!=="undefined"&&a.match(G)){d=new Image;d.src=a}}if(n>0){a=j[n-1].href;if(typeof a!=="undefined"&&a.match(G)){d=new Image;d.src=a}}},L=function(){i.css("overflow",c.scrolling=="auto"?c.type=="image"||c.type=="iframe"||c.type=="swf"?"hidden":"auto":c.scrolling=="yes"?"auto":"visible");if(!b.support.opacity){i.get(0).style.removeAttribute("filter");g.get(0).style.removeAttribute("filter")}b("#fancybox-title").show();c.hideOnContentClick&&i.one("click",b.fancybox.close);c.hideOnOverlayClick&&x.one("click",b.fancybox.close);c.showCloseButton&&z.show();W();b(window).bind("resize.fb",b.fancybox.center);c.centerOnScroll?b(window).bind("scroll.fb",b.fancybox.center):b(window).unbind("scroll.fb");b.isFunction(c.onComplete)&&c.onComplete(j,n,c);h=false;X()},M=function(a){var d=Math.round(k.width+(l.width-k.width)*a),f=Math.round(k.height+(l.height-k.height)*a),o=Math.round(k.top+(l.top-k.top)*a),t=Math.round(k.left+(l.left-k.left)*a);g.css({width:d+"px",height:f+"px",top:o+"px",left:t+"px"});d=Math.max(d-c.padding*2,0);f=Math.max(f-(c.padding*2+v*a),0);i.css({width:d+"px",height:f+"px"});if(typeof l.opacity!=="undefined")g.css("opacity",a<0.5?0.5:a)},Y=function(a){var d=a.offset();d.top+=parseFloat(a.css("paddingTop"))||0;d.left+=parseFloat(a.css("paddingLeft"))||0;d.top+=parseFloat(a.css("border-top-width"))||0;d.left+=parseFloat(a.css("border-left-width"))||0;d.width=a.width();d.height=a.height();return d},Q=function(){var a=e.orig?b(e.orig):false,d={};if(a&&a.length){a=Y(a);d={width:a.width+c.padding*2,height:a.height+c.padding*2,top:a.top-c.padding-20,left:a.left-c.padding-
20}}else{a=K();d={width:1,height:1,top:a[3]+a[1]*0.5,left:a[2]+a[0]*0.5}}return d},N=function(){u.hide();if(g.is(":visible")&&b.isFunction(c.onCleanup))if(c.onCleanup(j,n,c)===false){b.event.trigger("fancybox-cancel");h=false;return}j=q;n=p;c=e;i.get(0).scrollTop=0;i.get(0).scrollLeft=0;if(c.overlayShow){O&&b("select:not(#fancybox-tmp select)").filter(function(){return this.style.visibility!=="hidden"}).css({visibility:"hidden"}).one("fancybox-cleanup",function(){this.style.visibility="inherit"});x.css({"background-color":c.overlayColor,opacity:c.overlayOpacity}).unbind().show()}l=T();V();if(g.is(":visible")){b(z.add(A).add(B)).hide();var a=g.position(),d;k={top:a.top,left:a.left,width:g.width(),height:g.height()};d=k.width==l.width&&k.height==l.height;i.fadeOut(c.changeFade,function(){var f=function(){i.html(m.contents()).fadeIn(c.changeFade,L)};b.event.trigger("fancybox-change");i.empty().css("overflow","hidden");if(d){i.css({top:c.padding,left:c.padding,width:Math.max(l.width-c.padding*2,1),height:Math.max(l.height-c.padding*2-v,1)});f()}else{i.css({top:c.padding,left:c.padding,width:Math.max(k.width-c.padding*2,1),height:Math.max(k.height-c.padding*2,1)});y.prop=0;b(y).animate({prop:1},{duration:c.changeSpeed,easing:c.easingChange,step:M,complete:f})}})}else{g.css("opacity",1);if(c.transitionIn=="elastic"){k=Q();i.css({top:c.padding,left:c.padding,width:Math.max(k.width-c.padding*2,1),height:Math.max(k.height-c.padding*2,1)}).html(m.contents());g.css(k).show();if(c.opacity)l.opacity=0;y.prop=0;b(y).animate({prop:1},{duration:c.speedIn,easing:c.easingIn,step:M,complete:L})}else{i.css({top:c.padding,left:c.padding,width:Math.max(l.width-c.padding*2,1),height:Math.max(l.height-c.padding*2-v,1)}).html(m.contents());g.css(l).fadeIn(c.transitionIn=="none"?0:c.speedIn,L)}}},F=function(){m.width(e.width);m.height(e.height);if(e.width=="auto")e.width=m.width();if(e.height=="auto")e.height=m.height();N()},Z=function(){h=true;e.width=s.width;e.height=s.height;b("<img />").attr({id:"fancybox-img",src:s.src,alt:e.title}).appendTo(m);N()},C=function(){J();var a=q[p],d,f,o,t,w;e=b.extend({},b.fn.fancybox.defaults,typeof b(a).data("fancybox")=="undefined"?e:b(a).data("fancybox"));o=a.title||b(a).title||e.title||"";if(a.nodeName&&!e.orig)e.orig=b(a).children("img:first").length?b(a).children("img:first"):b(a);if(o===""&&e.orig)o=e.orig.attr("alt");d=a.nodeName&&/^(?:javascript|#)/i.test(a.href)?e.href||null:e.href||a.href||null;if(e.type){f=e.type;if(!d)d=e.content}else if(e.content)f="html";else if(d)if(d.match(G))f="image";else if(d.match(S))f="swf";else if(b(a).hasClass("iframe"))f="iframe";else if(d.match(/#/)){a=d.substr(d.indexOf("#"));f=b(a).length>0?"inline":"ajax"}else f="ajax";else f="inline";e.type=f;e.href=d;e.title=o;if(e.autoDimensions&&e.type!=="iframe"&&e.type!=="swf"){e.width="auto";e.height="auto"}if(e.modal){e.overlayShow=true;e.hideOnOverlayClick=false;e.hideOnContentClick=false;e.enableEscapeButton=false;e.showCloseButton=false}if(b.isFunction(e.onStart))if(e.onStart(q,p,e)===false){h=false;return}m.css("padding",20+e.padding+e.margin);b(".fancybox-inline-tmp").unbind("fancybox-cancel").bind("fancybox-change",function(){b(this).replaceWith(i.children())});switch(f){case"html":m.html(e.content);F();break;case"inline":b('<div class="fancybox-inline-tmp" />').hide().insertBefore(b(a)).bind("fancybox-cleanup",function(){b(this).replaceWith(i.children())}).bind("fancybox-cancel",function(){b(this).replaceWith(m.children())});b(a).appendTo(m);F();break;case"image":h=false;b.fancybox.showActivity();s=new Image;s.onerror=function(){P()};s.onload=function(){s.onerror=null;s.onload=null;Z()};s.src=d;break;case"swf":t='<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="'+e.width+'" height="'+e.height+'"><param name="movie" value="'+d+'"></param>';w="";b.each(e.swf,function(r,R){t+='<param name="'+r+'" value="'+R+'"></param>';w+=" "+r+'="'+R+'"'});t+='<embed src="'+d+'" type="application/x-shockwave-flash" width="'+e.width+'" height="'+e.height+'"'+w+"></embed></object>";m.html(t);F();break;case"ajax":a=d.split("#",2);f=e.ajax.data||{};if(a.length>1){d=a[0];if(typeof f=="string")f+="&selector="+a[1];else f.selector=a[1]}h=false;b.fancybox.showActivity();E=b.ajax(b.extend(e.ajax,{url:d,data:f,error:P,success:function(r){if(E.status==200){m.html(r);F()}}}));break;case"iframe":b('<iframe id="fancybox-frame" name="fancybox-frame'+(new Date).getTime()+'" frameborder="0" hspace="0" scrolling="'+e.scrolling+'" src="'+e.href+'"></iframe>').appendTo(m);N();break}},$=function(){if(u.is(":visible")){b("div",u).css("top",I*-40+"px");I=(I+1)%12}else clearInterval(H)},aa=function(){if(!b("#fancybox-wrap").length){b("body").append(m=b('<div id="fancybox-tmp"></div>'),u=b('<div id="fancybox-loading"><div></div></div>'),x=b('<div id="fancybox-overlay"></div>'),g=b('<div id="fancybox-wrap"></div>'));if(!b.support.opacity){g.addClass("fancybox-ie");u.addClass("fancybox-ie")}D=b('<div id="fancybox-outer"></div>').append('<div class="fancy-bg" id="fancy-bg-n"></div><div class="fancy-bg" id="fancy-bg-ne"></div><div class="fancy-bg" id="fancy-bg-e"></div><div class="fancy-bg" id="fancy-bg-se"></div><div class="fancy-bg" id="fancy-bg-s"></div><div class="fancy-bg" id="fancy-bg-sw"></div><div class="fancy-bg" id="fancy-bg-w"></div><div class="fancy-bg" id="fancy-bg-nw"></div>').appendTo(g);D.append(i=b('<div id="fancybox-inner"></div>'),z=b('<a id="fancybox-close"></a>'),A=b('<a href="javascript:;" id="fancybox-left"><span class="fancy-ico" id="fancybox-left-ico"></span></a>'),B=b('<a href="javascript:;" id="fancybox-right"><span class="fancy-ico" id="fancybox-right-ico"></span></a>'));z.click(b.fancybox.close);u.click(b.fancybox.cancel);A.click(function(a){a.preventDefault();b.fancybox.prev()});B.click(function(a){a.preventDefault();b.fancybox.next()});if(O){x.get(0).style.setExpression("height","document.body.scrollHeight > document.body.offsetHeight ? document.body.scrollHeight : document.body.offsetHeight + 'px'");u.get(0).style.setExpression("top","(-20 + (document.documentElement.clientHeight ? document.documentElement.clientHeight/2 : document.body.clientHeight/2 ) + ( ignoreMe = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop )) + 'px'");D.prepend('<iframe id="fancybox-hide-sel-frame" src="javascript:\'\';" scrolling="no" frameborder="0" ></iframe>')}}};b.fn.fancybox=function(a){b(this).data("fancybox",b.extend({},a,b.metadata?b(this).metadata():{})).unbind("click.fb").bind("click.fb",function(d){d.preventDefault();if(!h){h=true;b(this).blur();q=[];p=0;d=b(this).attr("rel")||"";if(!d||d==""||d==="nofollow")q.push(this);else{q=b("a[rel="+d+"], area[rel="+d+"]");p=q.index(this)}C();return false}});return this};b.fancybox=function(a,d){if(!h){h=true;d=typeof d!=="undefined"?d:{};q=[];p=d.index||0;if(b.isArray(a)){for(var f=0,o=a.length;f<o;f++)if(typeof a[f]=="object")b(a[f]).data("fancybox",b.extend({},d,a[f]));else a[f]=b({}).data("fancybox",b.extend({content:a[f]},d));q=jQuery.merge(q,a)}else{if(typeof a=="object")b(a).data("fancybox",b.extend({},d,a));else a=b({}).data("fancybox",b.extend({content:a},d));q.push(a)}if(p>q.length||p<0)p=0;C()}};b.fancybox.showActivity=function(){clearInterval(H);u.show();H=setInterval($,66)};b.fancybox.hideActivity=function(){u.hide()};b.fancybox.next=function(){return b.fancybox.pos(n+1)};b.fancybox.prev=function(){return b.fancybox.pos(n-
1)};b.fancybox.pos=function(a){if(!h){a=parseInt(a,10);if(a>-1&&j.length>a){p=a;C()}if(c.cyclic&&j.length>1&&a<0){p=j.length-1;C()}if(c.cyclic&&j.length>1&&a>=j.length){p=0;C()}}};b.fancybox.cancel=function(){if(!h){h=true;b.event.trigger("fancybox-cancel");J();e&&b.isFunction(e.onCancel)&&e.onCancel(q,p,e);h=false}};b.fancybox.close=function(){function a(){x.fadeOut("fast");g.hide();b.event.trigger("fancybox-cleanup");i.empty();b.isFunction(c.onClosed)&&c.onClosed(j,n,c);j=e=[];n=p=0;c=e={};h=false}
if(!(h||g.is(":hidden"))){h=true;if(c&&b.isFunction(c.onCleanup))if(c.onCleanup(j,n,c)===false){h=false;return}J();b(z.add(A).add(B)).hide();b("#fancybox-title").remove();g.add(i).add(x).unbind();b(window).unbind("resize.fb scroll.fb");b(document).unbind("keydown.fb");i.css("overflow","hidden");if(c.transitionOut=="elastic"){k=Q();var d=g.position();l={top:d.top,left:d.left,width:g.width(),height:g.height()};if(c.opacity)l.opacity=1;y.prop=1;b(y).animate({prop:0},{duration:c.speedOut,easing:c.easingOut,step:M,complete:a})}else g.fadeOut(c.transitionOut=="none"?0:c.speedOut,a)}};b.fancybox.resize=function(){var a,d;if(!(h||g.is(":hidden"))){h=true;a=i.wrapInner("<div style='overflow:auto'></div>").children();d=a.height();g.css({height:d+c.padding*2+v});i.css({height:d});a.replaceWith(a.children());b.fancybox.center()}};b.fancybox.center=function(){h=true;var a=K(),d=c.margin,f={};f.top=a[3]+(a[1]-(g.height()-v+40))*0.5;f.left=a[2]+(a[0]-(g.width()+40))*0.5;f.top=Math.max(a[3]+d,f.top);f.left=Math.max(a[2]+
d,f.left);g.css(f);h=false};b.fn.fancybox.defaults={padding:0,margin:20,opacity:false,modal:false,cyclic:true,scrolling:"auto",width:560,height:340,autoScale:true,autoDimensions:true,centerOnScroll:true,ajax:{},swf:{wmode:"transparent"},hideOnOverlayClick:true,hideOnContentClick:false,overlayShow:true,overlayOpacity:0.5,overlayColor:"#000000",titleShow:false,titlePosition:"inside",titleFormat:null,transitionIn:"fade",transitionOut:"fade",speedIn:300,speedOut:300,changeSpeed:300,changeFade:"fast",easingIn:"swing",easingOut:"swing",showCloseButton:true,showNavArrows:true,enableEscapeButton:true,onStart:null,onCancel:null,onComplete:null,onCleanup:null,onClosed:null};b(document).ready(function(){aa()})})(jQuery);

// jquery local scroll. Copyright (c) 2007-2009 Ariel Flesler - aflesler(at)gmail(dot)com | http://flesler.blogspot.com
;(function($){var l=location.href.replace(/#.*/,'');var g=$.localScroll=function(a){$('body').localScroll(a)};g.defaults={duration:1e3,axis:'y',event:'click',stop:true,target:window,reset:true};g.hash=function(a){if(location.hash){a=$.extend({},g.defaults,a);a.hash=false;if(a.reset){var e=a.duration;delete a.duration;$(a.target).scrollTo(0,a);a.duration=e}i(0,location,a)}};$.fn.localScroll=function(b){b=$.extend({},g.defaults,b);return b.lazy?this.bind(b.event,function(a){var e=$([a.target,a.target.parentNode]).filter(d)[0];if(e)i(a,e,b)}):this.find('a,area').filter(d).bind(b.event,function(a){i(a,this,b)}).end().end();function d(){return!!this.href&&!!this.hash&&this.href.replace(this.hash,'')==l&&(!b.filter||$(this).is(b.filter))}};function i(a,e,b){var d=e.hash.slice(1),f=document.getElementById(d)||document.getElementsByName(d)[0];if(!f)return;if(a)a.preventDefault();var h=$(b.target);if(b.lock&&h.is(':animated')||b.onBefore&&b.onBefore.call(b,a,f,h)===false)return;if(b.stop)h.stop(true);if(b.hash){var j=f.id==d?'id':'name',k=$('<a> </a>').attr(j,d).css({position:'absolute',top:$(window).scrollTop(),left:$(window).scrollLeft()});f[j]='';$('body').prepend(k);location=e.hash;k.remove();f[j]=d}h.scrollTo(f,b).trigger('notify.serialScroll',[f])}})(jQuery);

// jquery scrollTo. Copyright (c) 2007-2009 Ariel Flesler - aflesler(at)gmail(dot)com | http://flesler.blogspot.com
;(function(d){var k=d.scrollTo=function(a,i,e){d(window).scrollTo(a,i,e)};k.defaults={axis:'xy',duration:parseFloat(d.fn.jquery)>=1.3?0:1};k.window=function(a){return d(window)._scrollable()};d.fn._scrollable=function(){return this.map(function(){var a=this,i=!a.nodeName||d.inArray(a.nodeName.toLowerCase(),['iframe','#document','html','body'])!=-1;if(!i)return a;var e=(a.contentWindow||a).document||a.ownerDocument||a;return d.browser.safari||e.compatMode=='BackCompat'?e.body:e.documentElement})};d.fn.scrollTo=function(n,j,b){if(typeof j=='object'){b=j;j=0}if(typeof b=='function')b={onAfter:b};if(n=='max')n=9e9;b=d.extend({},k.defaults,b);j=j||b.speed||b.duration;b.queue=b.queue&&b.axis.length>1;if(b.queue)j/=2;b.offset=p(b.offset);b.over=p(b.over);return this._scrollable().each(function(){var q=this,r=d(q),f=n,s,g={},u=r.is('html,body');switch(typeof f){case'number':case'string':if(/^([+-]=)?\d+(\.\d+)?(px|%)?$/.test(f)){f=p(f);break}f=d(f,this);case'object':if(f.is||f.style)s=(f=d(f)).offset()}d.each(b.axis.split(''),function(a,i){var e=i=='x'?'Left':'Top',h=e.toLowerCase(),c='scroll'+e,l=q[c],m=k.max(q,i);if(s){g[c]=s[h]+(u?0:l-r.offset()[h]);if(b.margin){g[c]-=parseInt(f.css('margin'+e))||0;g[c]-=parseInt(f.css('border'+e+'Width'))||0}g[c]+=b.offset[h]||0;if(b.over[h])g[c]+=f[i=='x'?'width':'height']()*b.over[h]}else{var o=f[h];g[c]=o.slice&&o.slice(-1)=='%'?parseFloat(o)/100*m:o}if(/^\d+$/.test(g[c]))g[c]=g[c]<=0?0:Math.min(g[c],m);if(!a&&b.queue){if(l!=g[c])t(b.onAfterFirst);delete g[c]}});t(b.onAfter);function t(a){r.animate(g,j,b.easing,a&&function(){a.call(this,n,b)})}}).end()};k.max=function(a,i){var e=i=='x'?'Width':'Height',h='scroll'+e;if(!d(a).is('html,body'))return a[h]-d(a)[e.toLowerCase()]();var c='client'+e,l=a.ownerDocument.documentElement,m=a.ownerDocument.body;return Math.max(l[h],m[h])-Math.min(l[c],m[c])};function p(a){return typeof a=='object'?a:{top:a,left:a}}})(jQuery);

// jQuery TipTip v 1.3. Copyright 2010 Drew Wilson. code.drewwilson.com/entry/tiptip-jquery-plugin. Modified by me for animation effect. and trimmed out a bunch o stuff I didn't need
(function($){
	$.fn.tipTip = function(options) {
		var defaults = { 
			maxWidth: "200px",
			edgeOffset: 3,
			defaultPosition: "bottom",
			delay: 400,
			fadeIn: 200,
			fadeOut: 200,
			content: false,
			enter: function() {},
			exit: function() {}
		};
	 	var opts = $.extend(defaults, options);
	 	
		// setup tip tip elements and render them to the DOM
		if (!$("#tiptip_holder").length) {
			var tiptip_holder = $('<div id="tiptip_holder" style="max-width:'+ opts.maxWidth +';"></div>');
			var tiptip_content = $('<div id="tiptip_content"></div>');
			var tiptip_arrow = $('<div id="tiptip_arrow"></div>');
			$("body").append(tiptip_holder.html(tiptip_content).prepend(tiptip_arrow.html('<div id="tiptip_arrow_inner"></div>')));
		}
		// else just select tip tip elements
		else {
			var tiptip_holder = $("#tiptip_holder");
			var tiptip_content = $("#tiptip_content");
			var tiptip_arrow = $("#tiptip_arrow");
		}
		
		// apply to each element
		return this.each(function(){
			// the html element
			var org_elem = $(this);
			// tiptip title
			var org_title = opts.content;
			// timeout id
			var timeout = false;
			// attach to mouseover mouse out
			org_elem.hover(function(event){
				active_tiptip(org_elem, event);
			}, function(event){
				deactive_tiptip(org_elem, event);
			});
			// activate!
			function active_tiptip($target, event) {
				// call on enter bidings
				opts.enter.call();
				// set content
				tiptip_content.html(org_title);
				// hide holder, remove all class info
				tiptip_holder.hide().removeAttr("class").css("margin","0");
				// hide arrow
				tiptip_arrow.removeAttr("style");
				// calculate a bunch o shit
				var top = parseInt(org_elem.offset()['top']);
				var left = parseInt(org_elem.offset()['left']);
				var org_width = parseInt(org_elem.outerWidth());
				var org_height = parseInt(org_elem.outerHeight());
				var tip_w = tiptip_holder.outerWidth();
				var tip_h = tiptip_holder.outerHeight();
				var w_compare = Math.round((org_width - tip_w) / 2);
				var h_compare = Math.round((org_height - tip_h) / 2);
				var marg_left = Math.round(left + w_compare);
				var marg_top = Math.round(top + org_height + opts.edgeOffset);
				var t_class = "";
				var arrow_top = "";
				var arrow_left = Math.round(tip_w - 12) / 2;
				// apply classes
				if (opts.defaultPosition == "bottom") t_class = "_bottom";
				else if (opts.defaultPosition == "top") t_class = "_top";
				else if (opts.defaultPosition == "left") t_class = "_left";
				else if (opts.defaultPosition == "right") t_class = "_right";
				// more shit to compare, I honestly didn't read through this
				var right_compare = (w_compare + left) < parseInt($(window).scrollLeft());
				var left_compare = (tip_w + left) > parseInt($(window).width());
				// keep calculating
				if ((right_compare && w_compare < 0) || (t_class == "_right" && !left_compare) || (t_class == "_left" && left < (tip_w + opts.edgeOffset + 5))) {
					t_class = "_right";
					arrow_top = Math.round(tip_h - 13) / 2;
					arrow_left = -12;
					marg_left = Math.round(left + org_width + opts.edgeOffset);
					marg_top = Math.round(top + h_compare);
				}
				else if ((left_compare && w_compare < 0) || (t_class == "_left" && !right_compare)) {
					t_class = "_left";
					arrow_top = Math.round(tip_h - 13) / 2;
					arrow_left =  Math.round(tip_w);
					marg_left = Math.round(left - (tip_w + opts.edgeOffset + 5));
					marg_top = Math.round(top + h_compare);
				}
				// keep calculating (geez, it seems like there would be an easier way to do this)
				var top_compare = (top + org_height + opts.edgeOffset + tip_h + 8) > parseInt($(window).height() + $(window).scrollTop());
				var bottom_compare = ((top + org_height) - (opts.edgeOffset + tip_h + 8)) < 0;
				// keep calculating
				if(top_compare || (t_class == "_bottom" && top_compare) || (t_class == "_top" && !bottom_compare)) {
					if (t_class == "_top" || t_class == "_bottom") t_class = "_top";
					else t_class = t_class+"_top";
					arrow_top = tip_h;
					marg_top = Math.round(top - (tip_h + 5 + opts.edgeOffset));
				}
				else if (bottom_compare | (t_class == "_top" && bottom_compare) || (t_class == "_bottom" && !top_compare)) {
					if (t_class == "_top" || t_class == "_bottom") t_class = "_bottom";
					else t_class = t_class+"_bottom";
					arrow_top = -12;						
					marg_top = Math.round(top + org_height + opts.edgeOffset);
				}
				if (t_class == "_right_top" || t_class == "_left_top") marg_top = marg_top + 5;
				else if (t_class == "_right_bottom" || t_class == "_left_bottom") marg_top = marg_top - 5;
				if (t_class == "_left_top" || t_class == "_left_bottom") marg_left = marg_left + 5;
				tiptip_arrow.css({"margin-left": arrow_left+"px", "margin-top": arrow_top+"px"});
				tiptip_holder.css({"margin-left": marg_left+"px", "margin-top": marg_top+"px"}).attr("class","tip"+t_class);
				// clear timeout if a previous one
				if (timeout) { clearTimeout(timeout); }
				// new animate in
				timeout = tiptip_holder.stop(true,true).css({display:'block',marginTop:(marg_top+opts.edgeOffset-1),opacity:0}).animate({marginTop:marg_top,opacity:1}, opts.fadeIn, 'easeInQuad');
			}
			// decativate!	
			function deactive_tiptip($target, event) {
				// call the exit bindings
				opts.exit.call(this);
				// clear timeout if previous one
				if (timeout) { clearTimeout(timeout); }
				// new animate out
				var marg_top=parseInt(tiptip_holder.css('margin-top'));
				tiptip_holder.removeClass('tiptip_shown').animate({marginTop:marg_top-20,opacity:0},opts.fadeOut,'easeOutQuad',function(){$(this).css('display','none');});
			}
		});
	}
})(jQuery);
