/*
News ticker plugin (BBC news style)
Bryan Gullan,2007-2010
version 2.2
updated 2010-04-04
Documentation at http://www.makemineatriple.com/news-ticker-documentation/
Demo at http://www.makemineatriple.com/jquery/?newsTicker
Use and distrubute freely with this header intact.
*/

(function($) {

	var name='newsTicker';

	function runTicker(settings) {

		tickerData = $(settings.newsList).data('newsTicker');

		if(tickerData.currentItem > tickerData.newsItemCounter){
			// if we've looped to beyond the last item in the list, start over
			tickerData.currentItem = 0;
		}
		else if (tickerData.currentItem < 0) {
			// if we've looped back before the first item, move to the last one
			tickerData.currentItem = tickerData.newsItemCounter;
		}

		if(tickerData.currentPosition == 0) {
			if(tickerData.newsLinks[tickerData.currentItem].length > 0) {
				$(tickerData.newsList).empty().append('<li><a target="_blank" href="'+ tickerData.newsLinks[tickerData.currentItem] +'"></a></li>');
				//$("#tickerReadMore").attr("href", tickerData.newsLinks[tickerData.currentItem]);

			}
			else {
				$(tickerData.newsList).empty().append('<li></li>');
			}
		}

		//only start the ticker itself if it's defined as animating: otherwise it's paused or under manual advance
		if (tickerData.animating) {

			if( tickerData.currentPosition % 2 == 0) {
					var placeHolder = tickerData.placeHolder1;
			}
			else {
				var placeHolder = tickerData.placeHolder2;
			}


			if( tickerData.currentPosition < tickerData.newsLengths[tickerData.currentItem]) {
				// we haven't completed ticking out the current item
				var tickerText = tickerData.newsItems[tickerData.currentItem].substring(0,tickerData.currentPosition);

				if (tickerData.newsItems[tickerData.currentItem].substring(0,tickerData.currentPosition).substring(tickerData.newsItems[tickerData.currentItem].substring(0,tickerData.currentPosition).length-1)!='<') {



					if(tickerData.newsLengths[tickerData.currentItem] > 0) {
						$(tickerData.newsList + ' li a').html(tickerText + placeHolder);
					}
					else {
						$(tickerData.newsList + ' li').html(tickerText + placeHolder);
					}
				}
				tickerData.currentPosition ++;

				setTimeout(function(){runTicker(settings); settings = null;},tickerData.tickerRate);


			}

			else {
				// we're on the last letter of the current item

				if(tickerData.newsLengths[tickerData.currentItem] > 0) {
					$(tickerData.newsList + ' li a').html(tickerData.newsItems[tickerData.currentItem]);
				}
				else {
					$(tickerData.newsList + ' li').html(tickerData.newsItems[tickerData.currentItem]);
				}

				setTimeout(function(){
					if (tickerData.animating) {
						tickerData.currentPosition = 0;
						tickerData.currentItem ++;
						runTicker(settings); settings = null;
					}
				},tickerData.loopDelay);

			}
		}

		else {// settings.animating == false

			// display the full text of the current item
			var tickerText = tickerData.newsItems[tickerData.currentItem];

			if(tickerData.newsLengths[tickerData.currentItem] > 0) {
				$(tickerData.newsList + ' li a').html(tickerText);
			}
			else {
				$(tickerData.newsList + ' li').html(tickerText);
			}

		}

	}


	// Core plugin setup and config
	jQuery.fn[name] = function(options) {

	    // Add or overwrite options onto defaults
	    var settings = jQuery.extend({}, jQuery.fn.newsTicker.defaults, options);

        var newsItems = new Array();
		var newsLinks = new Array();
		var newsLengths = new Array();
	//	var newsReadMore = new Array();
		var newsItemCounter = 0;

		// Hide the static list items
		$(settings.newsList + ' li').hide();

		// Store the items and links in arrays for output
		$(settings.newsList + ' li').each(function(){
			if($(this).children('a').length) {
				newsItems[newsItemCounter] = $(this).children('a').html(); //Changed from .text() to use HTML
				newsLinks[newsItemCounter] = $(this).children('a').attr('href');
				newsLengths[newsItemCounter] = $(this).children('a').text().length;
			}
			else {
				newsItems[newsItemCounter] = $(this).html();
				newsLinks[newsItemCounter] = '';
				newsLengths[newsItemCounter] = $(this).text().length;

			}
			newsItemCounter ++;
		});

        var tickerElement = $(settings.newsList); // for quick reference below

        tickerElement.data(name, {
        	newsList: settings.newsList,
			tickerRate: settings.tickerRate,
			startDelay: settings.startDelay,
			loopDelay: settings.loopDelay,
			placeHolder1: settings.placeHolder1,
			placeHolder2: settings.placeHolder2,
			controls: settings.controls,
			ownControls: settings.ownControls,
			stopOnHover: settings.stopOnHover,
            newsItems: newsItems,
			newsLinks: newsLinks,
			newsLengths: newsLengths,
			newsItemCounter: newsItemCounter - 1, // -1 because we've incremented even after the last item (above)
			currentItem: 0,
			currentPosition: 0,
			firstRun:1
        })
        .bind({
			stop: function(event) {
				// show remainder of the current item immediately
		    	tickerData = tickerElement.data(name);
		    	if (tickerData.animating) { // only stop if not already stopped
            		tickerData.animating = false;
               	}
		  	},
		  	play: function(event) {
		  		// show 1st item with startdelay
		    	tickerData = tickerElement.data(name);
		    	if (!tickerData.animating) { // if already animating, don't start animating again
	            	tickerData.animating = true;
	            	setTimeout(function(){runTicker(tickerData); tickerData = null;},tickerData.startDelay);
	            }
		  	},
		  	resume: function(event) {
		  		// start from next item, with no delay
		    	tickerData = tickerElement.data(name);
		    	if (!tickerData.animating) { // if already animating, don't start animating again
	            	tickerData.animating = true;
	            	// set the character position as 0 to ensure on resume we start at the right point
					tickerData.currentPosition = 0;
	            	tickerData.currentItem ++;
	            	runTicker(tickerData); // no delay when resuming.
		        }
		  	},
		  	next: function(event) {
		  		// show whole of next item
		  		tickerData = tickerElement.data(name);
		  		// stop (which sets as non-animating), and call runticker
		  		$(tickerData.newsList).trigger("stop");
		  		// set the character position as 0 to ensure on resume we start at the right point
				tickerData.currentPosition = 0;
	            tickerData.currentItem ++;
	            runTicker(tickerData);
		  	},
		  	previous: function(event) {
				// show whole of previous item
				tickerData = tickerElement.data(name);
		  		// stop (which sets as non-animating), and call runticker
		  		$(tickerData.newsList).trigger("stop");
		  		// set the character position as 0 to ensure on resume we start at the right point
				tickerData.currentPosition = 0;
	            tickerData.currentItem --;
	            runTicker(tickerData);
			}
		});
		if (settings.stopOnHover) {
	    	tickerElement.bind({
			  	mouseenter: function(event) {
			  		tickerData = tickerElement.data(name);
			    	if (tickerData.animating) { // stop if not already stopped
				  		$(tickerData.newsList).trigger("stop");
				  		if (tickerData.controls) { // ensure that the ticker can be resumed if controls are enabled
				  			$('#stop').hide();
			    			$('#play').show();
				  		}
			  		}
			  	}
			});
			tickerElement.bind({
			  	mouseleave: function(event) {
			  		$(tickerData.newsList).trigger("resume");
			       $('#play').hide();
				    $('#stop').show();
			  	}
			});
    	}

    	tickerData = tickerElement.data(name);

    	// set up control buttons if the option is on
		if (tickerData.controls || tickerData.ownControls) {
			if (!tickerData.ownControls) {
				$('<ul id="ticker-controls"><li id="play"><a href="#play" title="Play"></a></li><li id="stop"><a href="#stop" title="Pause"></a></li><li id="prev"><a id="prev" href="#previous" title="Previous"></a></li><li id="next"><a href="#next" title="Next"></a></li></ul>').insertAfter($(tickerData.newsList));
			}
			$('#play').hide();


			$("#stop, #play, #prev, #next").mouseenter(function() {
				$(this).addClass('over');
		  	});

		  	$("#stop, #play, #prev, #next").mouseleave (function() {
				$(this).removeClass('over');
		  	});


			$('#stop').click(function(event){
		        $(tickerData.newsList).trigger("stop");
		       $('#stop').hide();
			    $('#play').show();
		        event.preventDefault();
		    });
		    $('#play').click(function(event){
		        $(tickerData.newsList).trigger("resume");
		       $('#play').hide();
			    $('#stop').show();
		        event.preventDefault();
		    });
		    $('#prev').click(function(event){
				$(tickerData.newsList).trigger("previous");
		        $('#stop').hide();
			    $('#play').show();
		        event.preventDefault();
		    });
		    $('#next').click(function(event){
		        $(tickerData.newsList).trigger("next");
		        $('#stop').hide();
			    $('#play').show();
		        event.preventDefault();
		    });

	    };

    	// tell it to play
    	$(tickerData.newsList).trigger("play");
	};

	// News ticker defaults
	jQuery.fn[name].defaults = {
	    newsList: "#news",
		tickerRate: 80,
		startDelay: 100,
		loopDelay: 3000,
		placeHolder1: " |",
		placeHolder2: "_",
		controls: true,
		ownControls: false,
		stopOnHover: true
	}

})(jQuery);
