
// 'stacks' is the Stacks global object.
// All of the other Stacks related Javascript will 
// be attatched to it.
var stacks = {};


// this call to jQuery gives us access to the globaal
// jQuery object. 
// 'noConflict' removes the '$' variable.
// 'true' removes the 'jQuery' variable.
// removing these globals reduces conflicts with other 
// jQuery versions that might be running on this page.
stacks.jQuery = jQuery.noConflict(true);

// Javascript for stacks_in_3_page60
// ---------------------------------------------------------------------

// Each stack has its own object with its own namespace.  The name of
// that object is the same as the stack's id.
stacks.stacks_in_3_page60 = {};

// A closure is defined and assigned to the stack's object.  The object
// is also passed in as 'stack' which gives you a shorthand for referring
// to this object from elsewhere.
stacks.stacks_in_3_page60 = (function(stack) {

	// When jQuery is used it will be available as $ and jQuery but only
	// inside the closure.
	var jQuery = stacks.jQuery;
	var $ = jQuery;
	
/* SymfoniP.com (c) 2010 - BlackOut Pro Stack Code 
 * 26-Oct-2010 Developed by Ronan Cashell & Kevin Burns
 * Version 1.7.1 - changed: options for H and V center on Target Image, cookie fix
*/
(function(a){a.fn.extend({symBlackOut:function(s){var j={timeBeforeFade:3,fadeOutDuration:800,offsetTop:0,offsetLeft:0,backgroundColor:"#000000",backgroundImage:true,expires:"",cookie:0,image2image:true,centerImageVertical:false,centerImageHorizontal:false,centerImageWindow:false};a.extend(j,s);var n=a(a(this)[0]);var i,l;if(j.image2image){i=a(".main img",n)}else{i=a(".main",n)}l=a(".symSplash",n);if(j.cookie>0&&d("symAdvert")=="1"){l.hide();a(".symBlackout").hide();return}if(j.expires!=""){var e=new Date();var m=e.getMonth()+1;if(m<10){m="0"+m}var f=e.getDate();if(f<10){f="0"+f}var f=e.getFullYear()+""+m+f;if(f>j.expires){l.hide();a(".symBlackout").hide();return}}if(j.backgroundImage&&j.image2image){var b=a("img",l);var p=0,o=0;if(j.centerImageVertical){o=(i.height()-b.height())/2}if(j.centerImageHorizontal){p=(i.width()-b.width())/2}l.css({width:a(document).width(),height:a(document).height(),backgroundImage:"url("+b.attr("src")+")",backgroundRepeat:"no-repeat",backgroundPosition:(i.offset().left+p)+"px "+(i.offset().top+o)+"px"});b.remove()}else{var b=a("div:first",l);var q=b.width();var k=b.height();var r=b.css("textAlign");b.wrap('<div id="contentContainer">');b.wrap('<div id="content">');l.offset({left:0,top:0}).css({left:"0",top:"0",width:a(document).width(),height:a(document).height()});b.css({textAlign:r}).parent().css({margin:0,padding:0,textAlign:"center",width:q,height:k}).parent().css({margin:0,padding:0,width:a(window).width()});if(j.centerImageWindow){b.parent().css({width:q,height:k,marginRight:"auto",marginLeft:"auto",marginTop:(a(window).height()-k)/2})}else{b.css({width:i.width(),height:i.height(),marginLeft:i.offset().left,marginTop:i.offset().top})}}a("body").append(l);var c=setTimeout(function(){l.fadeOut(j.fadeOutDuration)},j.timeBeforeFade*1000);a(document).keydown(function(h){if(h.which==27){clearTimeout(c);l.fadeOut(j.fadeOutDuration)}});var g=0;if(!j.centerImageWindow){g=i.offset().top-(a(window).height()-n.height())/2}a(document).scrollTop(g);a(".symBlackout").hide();if(j.cookie>0&&d("symAdvert")!="1"){d("symAdvert","1",{expires:j.cookie,path:"/"})}function d(t,A,D){if(typeof A!="undefined"){D=D||{};if(A===null){A="";D.expires=-1}var w="";if(D.expires&&(typeof D.expires=="number"||D.expires.toUTCString)){var x;if(typeof D.expires=="number"){x=new Date();x.setTime(x.getTime()+(D.expires*24*60*60*1000))}else{x=D.expires}w="; expires="+x.toUTCString()}var C=D.path?"; path="+(D.path):"";var y=D.domain?"; domain="+(D.domain):"";var h=D.secure?"; secure":"";document.cookie=[t,"=",encodeURIComponent(A),w,C,y,h].join("")}else{var v=null;if(document.cookie&&document.cookie!=""){var B=document.cookie.split(";");for(var z=0;z<B.length;z++){var u=jQuery.trim(B[z]);if(u.substring(0,t.length+1)==(t+"=")){v=decodeURIComponent(u.substring(t.length+1));break}}}return v}}}})})(jQuery);
/* Make BlackOut Pro go - SymfoniP.com */
jQuery(document).ready(function($) {
	$("#symBlackOutstacks_in_3_page60").symBlackOut({timeBeforeFade: 2, fadeOutDuration: 950, expires:'', cookie:0, image2image:true, centerImageVertical:false, centerImageHorizontal:false,centerImageWindow:false});
});
	return stack;
})(stacks.stacks_in_3_page60);


// Javascript for stacks_in_16_page60
// ---------------------------------------------------------------------

// Each stack has its own object with its own namespace.  The name of
// that object is the same as the stack's id.
stacks.stacks_in_16_page60 = {};

// A closure is defined and assigned to the stack's object.  The object
// is also passed in as 'stack' which gives you a shorthand for referring
// to this object from elsewhere.
stacks.stacks_in_16_page60 = (function(stack) {

	// When jQuery is used it will be available as $ and jQuery but only
	// inside the closure.
	var jQuery = stacks.jQuery;
	var $ = jQuery;
	
/*** danceSwitcher - A unique content switcher with a dazzling effect**** Copyright (C) 2011 by Adrian Sinclair http://forrst.me/adrusi**** This program is free software: you can redistribute it and/or modify** it under the terms of the GNU General Public License as published by** the Free Software Foundation, either version 3 of the License, or** (at your option) any later version.**** This program is distributed in the hope that it will be useful,** but WITHOUT ANY WARRANTY; without even the implied warranty of** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the** GNU General Public License for more details.**** You should have received a copy of the GNU General Public License** along with this program.  If not, see <http://www.gnu.org/licenses/>.*//* Adapted to Stacks by Mauricio Sabene at RWExtras.com version 2.0 */(function($) {  $.fn.extend({    danceSwitcher: function(options) {      var defaults = {        speed: 1,        collapsedWidth: 230,        collapsedHeight: 80,        collapsedMPB: [10, 10, 10, 10],        collapsedLineHeight: '80px',        activeLineHeight: '48px',        animationSequence: 'prevnext'      },      options = $.extend(defaults, options);      return $(this).each(function() {        var $this = $(this),            speed = options.speed,            first = $(this).children('div').eq(0), // the first child of the switcher, so that it is open by default            i;          $this.css('height', ($this.children('div').length - 1) * (options.collapsedHeight + options.collapsedMPB[0] + options.collapsedMPB[2]) + 'px'); // set the height of the switcher to the appropriate value        first.addClass('active'); // make the first box active        for (i = 1; i < $this.children('div').length; i++) { // position all of the boxes appropriately          $this.children('div').eq(i).css('top', (i - 1) * (options.collapsedHeight + options.collapsedMPB[0] + options.collapsedMPB[2]) + 'px');        }        if (options.animationSequence === 'prevnext') { // using the default animation          $this.children('div').click(function() { // bind a click event to all the boxes            var $$this = $(this);            if (!$$this.hasClass('active') && !$this.hasClass('inprogress')) { // if the box clicked isn't already active and there isn't already animation going on              var next, prev;              $this.addClass('inprogress'); // make sure 2 animations don't happen at once              $this.children('.active').children('.ds_content').animate({ // fade out the content of the active box                opacity: 0              }, 750 / speed);              $this.children('.active').children('h3').animate({ // animate the active header line height                lineHeight: options.collapsedLineHeight              }, 750 / speed);              if ($$this.next(':not(.active)').get(0)) { // if the clicked box isn't last                next = $(this).next();                prev = false;              }              else {                next = $$this.prev();                prev = true;              }              $$this.css({ // convert the height property of the clicked box to the bottom property                bottom: $this.height() - $$this.position().top - (options.collapsedHeight + options.collapsedMPB[0] + options.collapsedMPB[2]),                height: 'auto'              });              $this.children('.active').animate({                top: next.css('top'), // move the active box to the vertical position of its final destination                height: options.collapsedHeight // make its height the height of a collapsed box              }, 750 / speed, function() {                $$this.animate({ // move the clicked box out until it's the same dimensions as the previously active box                  left: 0,                  right: (options.collapsedWidth + options.collapsedMPB[1] + options.collapsedMPB[3])                }, 500 / speed, function() {                  next.animate({ // move the box next to the previously active box (to the right) to the place where the clicked box used to be                    top: $$this.css('top')                  }, 750 / speed, function() {                    $this.children('.active').animate({ // move the previously active box to where the last animated box just was                      left: next.position().left,                      right: 0                    }, 750 / speed, function() {                      $$this.children('h3').animate({ // animate the line height of the clicked box to the height of an active box                        lineHeight: options.activeLineHeight // , paddingBottom: 0                      }, 750 / speed );                      $$this.children('.ds_content').animate({ // and make its content opaque                        opacity: 1                      }, 1500 / speed ); // changed from 750 (MS)                      $$this.animate({ // and give it the dimensions of an active box                        top: 0,                        bottom: 0                      }, 750 / speed, function() {                        if (!prev) {                          $this.children('.active').insertAfter(next); // if the "next" box was the box underneath the now active box, mave its position in the DOM to where it now is visually on the page                        }                        else if (prev) {                          $this.children('.active').insertBefore(next); // same thing but if it was above the now active box                        }                        $this.children('.active').removeClass('active'); // remove the active class from the box that is no longer active                        $$this.addClass('active'); // and add it to the now active box                        $$this.prependTo($$this.parent()); // move the now active box to the top of the switcher DOM tree                        $this.removeClass('inprogress'); // and set the switcher to not animating                      });                    });                  });                });              });            }          });        }        else if (options.animationSequence === 'firstlast'){          $this.children('div').click(function() {            var $$this = $(this), active = $this.children('.active'), last = !$$this.next().get(0), alreadyCalled = false,                callback = function() {                  active.css('bottom', 'auto').animate({                    right: 0,                    left: $this.width() - (options.collapsedWidth + options.collapsedMPB[1] + options.collapsedMPB[3])                  }, 750 / speed, function() {                    $$this.animate({                      top: 0,                      bottom: 0                    }, 750 / speed).children('h3').animate({                      lineHeight: options.activeLineHeight // , paddingBottom: 0                    }, 750 / speed);					$$this.children('.ds_content').animate({                      opacity: 1                    }, 1500 / speed, function() { // changed from 750 (MS)                      if (!last) {                        active.appendTo($this).removeClass('active');					  }                      else {                        active.prependTo($this).removeClass('active');					  }	                      $$this.prependTo($this).addClass('active');                      $this.removeClass('inprogress');                    });                  });                };            if (!$$this.hasClass('active') && !$this.hasClass('inprogress')) {              $this.addClass('inprogress');              active.children('h3').animate({                lineHeight: options.collapsedLineHeight              }, 750 / speed);              active.children('.ds_content').animate({                opacity: 0              });              active.animate({                top: (!last) ? $this.height() - options.collapsedHeight - options.collapsedMPB[0] - options.collapsedMPB[2] : 0,                bottom: (!last) ? 0 : $this.height() - options.collapsedHeight - options.collapsedMPB[0] - options.collapsedMPB[2]              }, 750 / speed, function() {                active.css({                  top: (!last) ? $this.height() - active.height() - options.collapsedMPB[0] - options.collapsedMPB[2] : 0,                  height: active.height()                });                $$this.css({                  bottom: $this.height() - $$this.position().top - (options.collapsedHeight + options.collapsedMPB[0] + options.collapsedMPB[2]),                  height: 'auto'                });                $$this.animate({                  left: 0,                  right: (options.collapsedWidth + options.collapsedMPB[1] + options.collapsedMPB[3])                }, 500 / speed, function() {                  if (!last) {                    $$this.nextAll('div').each(function() {                      var $$$this = $(this);                      $$$this.animate({                        top: $$$this.position().top - (options.collapsedHeight + options.collapsedMPB[0] + options.collapsedMPB[2])                      }, 750 / speed, function() {                        if (!alreadyCalled) callback();                        alreadyCalled = true;                      });                    });                  }                  else {                    $$this.prevAll('div:not(.active)').each(function() {                      var $$$this = $(this);                      $$$this.animate({                        top: $$$this.position().top + (options.collapsedHeight + options.collapsedMPB[0] + options.collapsedMPB[2])                      }, 750 / speed, function() {                        if (!alreadyCalled) callback();                        alreadyCalled = true;                      });                    });                  }                });              });            }          });        }      });    }  });})(jQuery);jQuery(document).ready(function(){jQuery('#switcherstacks_in_16_page60').danceSwitcher({        speed: 3,        collapsedWidth: 55,        collapsedHeight: 260,        collapsedMPB: [5, 5, 5, 5],        collapsedLineHeight: '260px',        activeLineHeight: '48px',        animationSequence: 'firstlast'      });});
	return stack;
})(stacks.stacks_in_16_page60);



