diff --git a/jquery.nivo.slider.js b/jquery.nivo.slider.js index 8b0a774..eebca62 100644 --- a/jquery.nivo.slider.js +++ b/jquery.nivo.slider.js @@ -24,14 +24,14 @@ }; // Get this slider - var slider = $(element); - slider.data('nivo:vars', vars).addClass('nivoSlider'); + var $slider = $(element); + $slider.data('nivo:vars', vars).addClass('nivoSlider'); // Find our slider children - var kids = slider.children(); + var kids = $slider.children(); kids.each(function() { - var child = $(this); - var link = ''; + var child = $(this), + link = ''; if(!child.is('img')){ if(child.is('a')){ child.addClass('nivo-imageLink'); @@ -44,105 +44,101 @@ childHeight = (childHeight === 0) ? child.attr('height') : child.height(); if(link !== ''){ - link.css('display','none'); + link.hide(); } - child.css('display','none'); + child.hide(); vars.totalSlides++; }); - + // If randomStart if(settings.randomStart){ settings.startSlide = Math.floor(Math.random() * vars.totalSlides); } - + // Set startSlide if(settings.startSlide > 0){ - if(settings.startSlide >= vars.totalSlides) { settings.startSlide = vars.totalSlides - 1; } + if(settings.startSlide >= vars.totalSlides) { + settings.startSlide = vars.totalSlides - 1; + } vars.currentSlide = settings.startSlide; } - - // Get initial image - if($(kids[vars.currentSlide]).is('img')){ - vars.currentImage = $(kids[vars.currentSlide]); - } else { - vars.currentImage = $(kids[vars.currentSlide]).find('img:first'); + + // Get initial image + vars.currentImage = $(kids[vars.currentSlide]); + if(! vars.currentImage.is('img')){ + vars.currentImage = vars.currentImage.find('img:first'); } - + // Show initial link - if($(kids[vars.currentSlide]).is('a')){ - $(kids[vars.currentSlide]).css('display','block'); - } - + vars.currentImage.is('a') && vars.currentImage.show(); + // Set first background - var sliderImg = $('').addClass('nivo-main-image'); - sliderImg.attr('src', vars.currentImage.attr('src')).show(); - slider.append(sliderImg); + var $sliderImg = $('').addClass('nivo-main-image'); + $sliderImg.attr('src', vars.currentImage.attr('src')).show().appendTo($slider); // Detect Window Resize $(window).resize(function() { - slider.children('img').width(slider.width()); - sliderImg.attr('src', vars.currentImage.attr('src')); - sliderImg.stop().height('auto'); - $('.nivo-slice').remove(); - $('.nivo-box').remove(); + $slider.children('img').width($slider.width()); + $sliderImg.attr('src', vars.currentImage.attr('src')).stop().height('auto'); + $('.nivo-slice, .nivo-box').remove(); }); //Create caption - slider.append($('
')); - + var $caption = $('', {class : 'nivo-caption'}); + $slider.append($caption); + // Process caption function var processCaption = function(settings){ - var nivoCaption = $('.nivo-caption', slider); + var nivoCaption = $('.nivo-caption', $slider); if(vars.currentImage.attr('title') != '' && vars.currentImage.attr('title') != undefined){ var title = vars.currentImage.attr('title'); - if(title.substr(0,1) == '#') title = $(title).html(); + if(title.substr(0,1) == '#') title = $(title).html(); - if(nivoCaption.css('display') == 'block'){ + if(nivoCaption.is(':visible')){ setTimeout(function(){ nivoCaption.html(title); }, settings.animSpeed); } else { - nivoCaption.html(title); - nivoCaption.stop().fadeIn(settings.animSpeed); + nivoCaption.html(title).stop().fadeIn(settings.animSpeed); } } else { nivoCaption.stop().fadeOut(settings.animSpeed); } } - - //Process initial caption + + //Process initial caption processCaption(settings); - + // In the words of Super Mario "let's a go!" var timer = 0; if(!settings.manualAdvance && kids.length > 1){ - timer = setInterval(function(){ nivoRun(slider, kids, settings, false); }, settings.pauseTime); + timer = setInterval(function(){ + nivoRun($slider, kids, settings, false); + }, settings.pauseTime); } - + // Add Direction nav if(settings.directionNav){ - slider.append(''); - - $(slider).on('click', 'a.nivo-prevNav', function(){ + $slider.append('') + .on('click', 'a.nivo-prevNav', function(){ if(vars.running) { return false; } clearInterval(timer); timer = ''; vars.currentSlide -= 2; - nivoRun(slider, kids, settings, 'prev'); - }); - - $(slider).on('click', 'a.nivo-nextNav', function(){ + nivoRun($slider, kids, settings, 'prev'); + }) + .on('click', 'a.nivo-nextNav', function(){ if(vars.running) { return false; } clearInterval(timer); timer = ''; - nivoRun(slider, kids, settings, 'next'); + nivoRun($slider, kids, settings, 'next'); }); } - + // Add Control nav if(settings.controlNav){ vars.controlNavEl = $(''); - slider.after(vars.controlNavEl); + $slider.after(vars.controlNavEl); for(var i = 0; i < kids.length; i++){ if(settings.controlNavThumbs){ vars.controlNavEl.addClass('nivo-thumbs-enabled'); @@ -150,7 +146,9 @@ if(!child.is('img')){ child = child.find('img:first'); } - if(child.attr('data-thumb')) vars.controlNavEl.append(''); + if(child.attr('data-thumb')) { + vars.controlNavEl.append(''); + } } else { vars.controlNavEl.append(''+ (i + 1) +''); } @@ -158,21 +156,20 @@ //Set initial active link $('a:eq('+ vars.currentSlide +')', vars.controlNavEl).addClass('active'); - + $('a', vars.controlNavEl).bind('click', function(){ - if(vars.running) return false; - if($(this).hasClass('active')) return false; + if(vars.running || $(this).hasClass('active')) return false; clearInterval(timer); timer = ''; - sliderImg.attr('src', vars.currentImage.attr('src')); + $sliderImg.attr('src', vars.currentImage.attr('src')); vars.currentSlide = $(this).attr('rel') - 1; - nivoRun(slider, kids, settings, 'control'); + nivoRun($slider, kids, settings, 'control'); }); } - + //For pauseOnHover setting if(settings.pauseOnHover){ - slider.hover(function(){ + $slider.hover(function(){ vars.paused = true; clearInterval(timer); timer = ''; @@ -180,24 +177,24 @@ vars.paused = false; // Restart the timer if(timer === '' && !settings.manualAdvance){ - timer = setInterval(function(){ nivoRun(slider, kids, settings, false); }, settings.pauseTime); + timer = setInterval(function(){ nivoRun($slider, kids, settings, false); }, settings.pauseTime); } }); } - + // Event when Animation finishes - slider.bind('nivo:animFinished', function(){ - sliderImg.attr('src', vars.currentImage.attr('src')); - vars.running = false; + $slider.bind('nivo:animFinished', function(){ + $sliderImg.attr('src', vars.currentImage.attr('src')); + vars.running = false; // Hide child links $(kids).each(function(){ if($(this).is('a')){ - $(this).css('display','none'); + $(this).hide(); } }); // Show current link if($(kids[vars.currentSlide]).is('a')){ - $(kids[vars.currentSlide]).css('display','block'); + $(kids[vars.currentSlide]).show(); } // Restart the timer if(timer === '' && !vars.paused && !settings.manualAdvance){ @@ -205,31 +202,34 @@ } // Trigger the afterChange callback settings.afterChange.call(this); - }); - + }); + // Add slices for slice animations var createSlices = function(slider, settings, vars) { - if($(vars.currentImage).parent().is('a')) $(vars.currentImage).parent().css('display','block'); + var $currentParent = $(vars.currentImage).parent(); + if($currentParent.is('a')){ + $currentParent.show(); + } $('img[src="'+ vars.currentImage.attr('src') +'"]', slider).not('.nivo-main-image,.nivo-control img').width(slider.width()).css('visibility', 'hidden').show(); var sliceHeight = ($('img[src="'+ vars.currentImage.attr('src') +'"]', slider).not('.nivo-main-image,.nivo-control img').parent().is('a')) ? $('img[src="'+ vars.currentImage.attr('src') +'"]', slider).not('.nivo-main-image,.nivo-control img').parent().height() : $('img[src="'+ vars.currentImage.attr('src') +'"]', slider).not('.nivo-main-image,.nivo-control img').height(); for(var i = 0; i < settings.slices; i++){ var sliceWidth = Math.round(slider.width()/settings.slices); - + if(i === settings.slices-1){ slider.append( - $('').css({ - left:(sliceWidth*i)+'px', + $('').css({ + left:(sliceWidth*i)+'px', width:(slider.width()-(sliceWidth*i))+'px', - height:sliceHeight+'px', + height:sliceHeight+'px', opacity:'0', overflow:'hidden' }) ); } else { slider.append( - $('').css({ - left:(sliceWidth*i)+'px', + $('').css({ + left:(sliceWidth*i)+'px', width:sliceWidth+'px', height:sliceHeight+'px', opacity:'0', @@ -238,39 +238,39 @@ ); } } - + $('.nivo-slice', slider).height(sliceHeight); - sliderImg.stop().animate({ + $sliderImg.stop().animate({ height: $(vars.currentImage).height() }, settings.animSpeed); }; - + // Add boxes for box animations var createBoxes = function(slider, settings, vars){ - if($(vars.currentImage).parent().is('a')) $(vars.currentImage).parent().css('display','block'); + if($(vars.currentImage).parent().is('a')) $(vars.currentImage).parent().show(); $('img[src="'+ vars.currentImage.attr('src') +'"]', slider).not('.nivo-main-image,.nivo-control img').width(slider.width()).css('visibility', 'hidden').show(); var boxWidth = Math.round(slider.width()/settings.boxCols), boxHeight = Math.round($('img[src="'+ vars.currentImage.attr('src') +'"]', slider).not('.nivo-main-image,.nivo-control img').height() / settings.boxRows); - - + + for(var rows = 0; rows < settings.boxRows; rows++){ for(var cols = 0; cols < settings.boxCols; cols++){ if(cols === settings.boxCols-1){ slider.append( - $('').css({ + $('').css({ opacity:0, - left:(boxWidth*cols)+'px', + left:(boxWidth*cols)+'px', top:(boxHeight*rows)+'px', width:(slider.width()-(boxWidth*cols))+'px' - + }) ); $('.nivo-box[name="'+ cols +'"]', slider).height($('.nivo-box[name="'+ cols +'"] img', slider).height()+'px'); } else { slider.append( - $('').css({ + $('').css({ opacity:0, - left:(boxWidth*cols)+'px', + left:(boxWidth*cols)+'px', top:(boxHeight*rows)+'px', width:boxWidth+'px' }) @@ -279,43 +279,43 @@ } } } - - sliderImg.stop().animate({ + + $sliderImg.stop().animate({ height: $(vars.currentImage).height() }, settings.animSpeed); }; // Private run method - var nivoRun = function(slider, kids, settings, nudge){ + var nivoRun = function(slider, kids, settings, nudge){ // Get our vars var vars = slider.data('nivo:vars'); - + // Trigger the lastSlide callback - if(vars && (vars.currentSlide === vars.totalSlides - 1)){ + if(vars && (vars.currentSlide === vars.totalSlides - 1)){ settings.lastSlide.call(this); } - + // Stop if((!vars || vars.stop) && !nudge) { return false; } - + // Trigger the beforeChange callback settings.beforeChange.call(this); // Set current background before change if(!nudge){ - sliderImg.attr('src', vars.currentImage.attr('src')); + $sliderImg.attr('src', vars.currentImage.attr('src')); } else { if(nudge === 'prev'){ - sliderImg.attr('src', vars.currentImage.attr('src')); + $sliderImg.attr('src', vars.currentImage.attr('src')); } if(nudge === 'next'){ - sliderImg.attr('src', vars.currentImage.attr('src')); + $sliderImg.attr('src', vars.currentImage.attr('src')); } } - + vars.currentSlide++; // Trigger the slideshowEnd callback - if(vars.currentSlide === vars.totalSlides){ + if(vars.currentSlide === vars.totalSlides){ vars.currentSlide = 0; settings.slideshowEnd.call(this); } @@ -326,25 +326,25 @@ } else { vars.currentImage = $(kids[vars.currentSlide]).find('img:first'); } - + // Set active links if(settings.controlNav){ $('a', vars.controlNavEl).removeClass('active'); $('a:eq('+ vars.currentSlide +')', vars.controlNavEl).addClass('active'); } - + // Process caption - processCaption(settings); - + processCaption(settings); + // Remove any slices from last transition $('.nivo-slice', slider).remove(); - + // Remove any boxes from last transition $('.nivo-box', slider).remove(); - + var currentEffect = settings.effect, anims = ''; - + // Generate random effect if(settings.effect === 'random'){ anims = new Array('sliceDownRight','sliceDownLeft','sliceUpRight','sliceUpLeft','sliceUpDown','sliceUpDownLeft','fold','fade', @@ -352,45 +352,50 @@ currentEffect = anims[Math.floor(Math.random()*(anims.length + 1))]; if(currentEffect === undefined) { currentEffect = 'fade'; } } - + // Run random effect from specified set (eg: effect:'fold,fade') if(settings.effect.indexOf(',') !== -1){ anims = settings.effect.split(','); currentEffect = anims[Math.floor(Math.random()*(anims.length))]; - if(currentEffect === undefined) { currentEffect = 'fade'; } + if(currentEffect === undefined) { + currentEffect = 'fade'; + } } - + // Custom transition as defined by "data-transition" attribute if(vars.currentImage.attr('data-transition')){ currentEffect = vars.currentImage.attr('data-transition'); } - + // Run effects vars.running = true; var timeBuff = 0, i = 0, slices = '', - firstSlice = '', totalBoxes = '', boxes = ''; - + + var firstSlice = $('.nivo-slice:first', slider); + if(currentEffect === 'sliceDown' || currentEffect === 'sliceDownRight' || currentEffect === 'sliceDownLeft'){ createSlices(slider, settings, vars); timeBuff = 0; i = 0; slices = $('.nivo-slice', slider); if(currentEffect === 'sliceDownLeft') { slices = $('.nivo-slice', slider)._reverse(); } - + slices.each(function(){ var slice = $(this); - slice.css({ 'top': '0px' }); - if(i === settings.slices-1){ + slice.css({ 'top': 0 }); + if(i === settings.slices - 1){ setTimeout(function(){ - slice.animate({opacity:'1.0' }, settings.animSpeed, '', function(){ slider.trigger('nivo:animFinished'); }); + slice.animate({opacity: 1 }, settings.animSpeed, '', function(){ + slider.trigger('nivo:animFinished'); + }); }, (100 + timeBuff)); } else { setTimeout(function(){ - slice.animate({opacity:'1.0' }, settings.animSpeed); + slice.animate({opacity: 1 }, settings.animSpeed); }, (100 + timeBuff)); } timeBuff += 50; @@ -401,18 +406,22 @@ timeBuff = 0; i = 0; slices = $('.nivo-slice', slider); - if(currentEffect === 'sliceUpLeft') { slices = $('.nivo-slice', slider)._reverse(); } - + if(currentEffect === 'sliceUpLeft') { + slices = $('.nivo-slice', slider)._reverse(); + } + slices.each(function(){ var slice = $(this); - slice.css({ 'bottom': '0px' }); - if(i === settings.slices-1){ + slice.css({ 'bottom': 0 }); + if(i === settings.slices - 1){ setTimeout(function(){ - slice.animate({opacity:'1.0' }, settings.animSpeed, '', function(){ slider.trigger('nivo:animFinished'); }); + slice.animate({opacity: 1 }, settings.animSpeed, '', function(){ + slider.trigger('nivo:animFinished'); + }); }, (100 + timeBuff)); } else { setTimeout(function(){ - slice.animate({opacity:'1.0' }, settings.animSpeed); + slice.animate({opacity: 1 }, settings.animSpeed); }, (100 + timeBuff)); } timeBuff += 50; @@ -424,25 +433,29 @@ i = 0; var v = 0; slices = $('.nivo-slice', slider); - if(currentEffect === 'sliceUpDownLeft') { slices = $('.nivo-slice', slider)._reverse(); } - + if(currentEffect === 'sliceUpDownLeft') { + slices = $('.nivo-slice', slider)._reverse(); + } + slices.each(function(){ var slice = $(this); if(i === 0){ - slice.css('top','0px'); + slice.css(top, 0); i++; } else { - slice.css('bottom','0px'); + slice.css(bottom, 0); i = 0; } - - if(v === settings.slices-1){ + + if(v === settings.slices - 1){ setTimeout(function(){ - slice.animate({opacity:'1.0' }, settings.animSpeed, '', function(){ slider.trigger('nivo:animFinished'); }); + slice.animate({opacity: 1 }, settings.animSpeed, '', function(){ + slider.trigger('nivo:animFinished'); + }); }, (100 + timeBuff)); } else { setTimeout(function(){ - slice.animate({opacity:'1.0' }, settings.animSpeed); + slice.animate({opacity: 1 }, settings.animSpeed); }, (100 + timeBuff)); } timeBuff += 50; @@ -452,18 +465,22 @@ createSlices(slider, settings, vars); timeBuff = 0; i = 0; - + $('.nivo-slice', slider).each(function(){ - var slice = $(this); - var origWidth = slice.width(); - slice.css({ top:'0px', width:'0px' }); - if(i === settings.slices-1){ + var slice = $(this), + origWidth = slice.width(); + + slice.css({ top: 0, width: 0 }); + + if(i === settings.slices - 1){ setTimeout(function(){ - slice.animate({ width:origWidth, opacity:'1.0' }, settings.animSpeed, '', function(){ slider.trigger('nivo:animFinished'); }); + slice.animate({ width:origWidth, opacity: 1 }, settings.animSpeed, '', function(){ + slider.trigger('nivo:animFinished'); + }); }, (100 + timeBuff)); } else { setTimeout(function(){ - slice.animate({ width:origWidth, opacity:'1.0' }, settings.animSpeed); + slice.animate({ width:origWidth, opacity: 1 }, settings.animSpeed); }, (100 + timeBuff)); } timeBuff += 50; @@ -471,45 +488,42 @@ }); } else if(currentEffect === 'fade'){ createSlices(slider, settings, vars); - - firstSlice = $('.nivo-slice:first', slider); + firstSlice.css({ - 'width': slider.width() + 'px' + width: slider.width() + }).animate({ opacity: 1 }, (settings.animSpeed*2), '', function(){ + slider.trigger('nivo:animFinished'); }); - - firstSlice.animate({ opacity:'1.0' }, (settings.animSpeed*2), '', function(){ slider.trigger('nivo:animFinished'); }); + } else if(currentEffect === 'slideInRight'){ createSlices(slider, settings, vars); - - firstSlice = $('.nivo-slice:first', slider); + firstSlice.css({ - 'width': '0px', - 'opacity': '1' + width: 0, + opacity: 1 + }).animate({width: slider.width() }, (settings.animSpeed*2), '', function(){ + slider.trigger('nivo:animFinished'); }); - firstSlice.animate({ width: slider.width() + 'px' }, (settings.animSpeed*2), '', function(){ slider.trigger('nivo:animFinished'); }); } else if(currentEffect === 'slideInLeft'){ createSlices(slider, settings, vars); - - firstSlice = $('.nivo-slice:first', slider); - firstSlice.css({ - 'width': '0px', - 'opacity': '1', - 'left': '', - 'right': '0px' - }); - firstSlice.animate({ width: slider.width() + 'px' }, (settings.animSpeed*2), '', function(){ + firstSlice.css({ + width: 0, + opacity: 1, + left: '', + right: 0 + }).animate({ width: slider.width() }, (settings.animSpeed*2), '', function(){ // Reset positioning firstSlice.css({ - 'left': '0px', - 'right': '' + left: 0, + right: '' }); - slider.trigger('nivo:animFinished'); + slider.trigger('nivo:animFinished'); }); } else if(currentEffect === 'boxRandom'){ createBoxes(slider, settings, vars); - + totalBoxes = settings.boxCols * settings.boxRows; i = 0; timeBuff = 0; @@ -519,11 +533,13 @@ var box = $(this); if(i === totalBoxes-1){ setTimeout(function(){ - box.animate({ opacity:'1' }, settings.animSpeed, '', function(){ slider.trigger('nivo:animFinished'); }); + box.animate({ opacity: 1 }, settings.animSpeed, '', function(){ + slider.trigger('nivo:animFinished'); + }); }, (100 + timeBuff)); } else { setTimeout(function(){ - box.animate({ opacity:'1' }, settings.animSpeed); + box.animate({ opacity: 1 }, settings.animSpeed); }, (100 + timeBuff)); } timeBuff += 20; @@ -531,15 +547,16 @@ }); } else if(currentEffect === 'boxRain' || currentEffect === 'boxRainReverse' || currentEffect === 'boxRainGrow' || currentEffect === 'boxRainGrowReverse'){ createBoxes(slider, settings, vars); - + totalBoxes = settings.boxCols * settings.boxRows; i = 0; timeBuff = 0; - + // Split boxes into 2D array - var rowIndex = 0; - var colIndex = 0; - var box2Darr = []; + var rowIndex = 0, + colIndex = 0, + box2Darr = []; + box2Darr[rowIndex] = []; boxes = $('.nivo-box', slider); if(currentEffect === 'boxRainReverse' || currentEffect === 'boxRainGrowReverse'){ @@ -554,29 +571,29 @@ box2Darr[rowIndex] = []; } }); - + // Run animation for(var cols = 0; cols < (settings.boxCols * 2); cols++){ var prevCol = cols; for(var rows = 0; rows < settings.boxRows; rows++){ if(prevCol >= 0 && prevCol < settings.boxCols){ - /* Due to some weird JS bug with loop vars + /* Due to some weird JS bug with loop vars being used in setTimeout, this is wrapped with an anonymous function call */ (function(row, col, time, i, totalBoxes) { - var box = $(box2Darr[row][col]); - var w = box.width(); - var h = box.height(); + var box = $(box2Darr[row][col]), + w = box.width(), + h = box.height(); if(currentEffect === 'boxRainGrow' || currentEffect === 'boxRainGrowReverse'){ box.width(0).height(0); } if(i === totalBoxes-1){ setTimeout(function(){ - box.animate({ opacity:'1', width:w, height:h }, settings.animSpeed/1.3, '', function(){ slider.trigger('nivo:animFinished'); }); + box.animate({ opacity: 1, width:w, height:h }, settings.animSpeed/1.3, '', function(){ slider.trigger('nivo:animFinished'); }); }, (100 + time)); } else { setTimeout(function(){ - box.animate({ opacity:'1', width:w, height:h }, settings.animSpeed/1.3); + box.animate({ opacity: 1, width:w, height:h }, settings.animSpeed/1.3); }, (100 + time)); } })(rows, prevCol, timeBuff, i, totalBoxes); @@ -586,53 +603,55 @@ } timeBuff += 100; } - } + } }; - + // Shuffle an array var shuffle = function(arr){ for(var j, x, i = arr.length; i; j = parseInt(Math.random() * i, 10), x = arr[--i], arr[i] = arr[j], arr[j] = x); return arr; }; - + // For debugging var trace = function(msg){ if(this.console && typeof console.log !== 'undefined') { console.log(msg); } }; - + // Start / Stop + var nivoVarStop = $(element).data('nivo:vars').stop; this.stop = function(){ - if(!$(element).data('nivo:vars').stop){ - $(element).data('nivo:vars').stop = true; + if(!nivoVarStop){ + nivoVarStop = true; trace('Stop Slider'); } }; - this.start = function(){ - if($(element).data('nivo:vars').stop){ - $(element).data('nivo:vars').stop = false; + if(nivoVarStop){ + nivoVarStop = false; trace('Start Slider'); } }; - + // Trigger the afterLoad callback settings.afterLoad.call(this); - + return this; }; - + $.fn.nivoSlider = function(options) { return this.each(function(key, value){ var element = $(this); // Return early if this element already has a plugin instance - if (element.data('nivoslider')) { return element.data('nivoslider'); } + if (element.data('nivoslider')) { + return element.data('nivoslider'); + } // Pass options to plugin constructor var nivoslider = new NivoSlider(this, options); // Store plugin object in this element's data element.data('nivoslider', nivoslider); }); }; - + //Default settings $.fn.nivoSlider.defaults = { effect: 'random', @@ -658,5 +677,5 @@ }; $.fn._reverse = [].reverse; - -})(jQuery); \ No newline at end of file + +})(jQuery); diff --git a/jquery.nivo.slider.pack.js b/jquery.nivo.slider.pack.js index f18e2f9..ffb6c57 100644 --- a/jquery.nivo.slider.pack.js +++ b/jquery.nivo.slider.pack.js @@ -7,4 +7,4 @@ * http://www.opensource.org/licenses/mit-license.php */ -(function(e){var t=function(t,n){var r=e.extend({},e.fn.nivoSlider.defaults,n);var i={currentSlide:0,currentImage:"",totalSlides:0,running:false,paused:false,stop:false,controlNavEl:false};var s=e(t);s.data("nivo:vars",i).addClass("nivoSlider");var o=s.children();o.each(function(){var t=e(this);var n="";if(!t.is("img")){if(t.is("a")){t.addClass("nivo-imageLink");n=t}t=t.find("img:first")}var r=r===0?t.attr("width"):t.width(),s=s===0?t.attr("height"):t.height();if(n!==""){n.css("display","none")}t.css("display","none");i.totalSlides++});if(r.randomStart){r.startSlide=Math.floor(Math.random()*i.totalSlides)}if(r.startSlide>0){if(r.startSlide>=i.totalSlides){r.startSlide=i.totalSlides-1}i.currentSlide=r.startSlide}if(e(o[i.currentSlide]).is("img")){i.currentImage=e(o[i.currentSlide])}else{i.currentImage=e(o[i.currentSlide]).find("img:first")}if(e(o[i.currentSlide]).is("a")){e(o[i.currentSlide]).css("display","block")}var u=e("").addClass("nivo-main-image");u.attr("src",i.currentImage.attr("src")).show();s.append(u);e(window).resize(function(){s.children("img").width(s.width());u.attr("src",i.currentImage.attr("src"));u.stop().height("auto");e(".nivo-slice").remove();e(".nivo-box").remove()});s.append(e(''));var a=function(t){var n=e(".nivo-caption",s);if(i.currentImage.attr("title")!=""&&i.currentImage.attr("title")!=undefined){var r=i.currentImage.attr("title");if(r.substr(0,1)=="#")r=e(r).html();if(n.css("display")=="block"){setTimeout(function(){n.html(r)},t.animSpeed)}else{n.html(r);n.stop().fadeIn(t.animSpeed)}}else{n.stop().fadeOut(t.animSpeed)}};a(r);var f=0;if(!r.manualAdvance&&o.length>1){f=setInterval(function(){d(s,o,r,false)},r.pauseTime)}if(r.directionNav){s.append('");e(s).on("click","a.nivo-prevNav",function(){if(i.running){return false}clearInterval(f);f="";i.currentSlide-=2;d(s,o,r,"prev")});e(s).on("click","a.nivo-nextNav",function(){if(i.running){return false}clearInterval(f);f="";d(s,o,r,"next")})}if(r.controlNav){i.controlNavEl=e('');s.after(i.controlNavEl);for(var l=0;l