/**
 * Plugin: jquery.zRSSFeed
 * 
 * Version: 1.0.1
 * (c) Copyright 2010, Zazar Ltd
 * 
 * Description: jQuery plugin for display of RSS feeds via Google Feed API
 *              (Based on original plugin jGFeed by jQuery HowTo)
 * 
 * Modified for TTS by Leigh Smith
 *
 **/
 
(function($){
 
	var current = null; 
	
	$.fn.rssfeed = function(url, options) {	
	
		// Set pluign defaults
		var defaults = {
			limit: 10,
			header: true,
			titletag: 'h4',
			date: true,
			content: true,
			snippet: true,
			showerror: true,
			errormsg: '',
			key: null,
			type: "main"
		};  
		var options = $.extend(defaults, options); 
		
		// Functions
		return this.each(function(i, e) {
			var $e = $(e);
			
			// Add feed class to user div
			if (!$e.hasClass('rssFeed')) $e.addClass('rssFeed');
			
			// Check for valid url
			if(url == null) return false;
 
			// Create Google Feed API address
			var api = "http://ajax.googleapis.com/ajax/services/feed/load?v=1.0&callback=?&q=" + url;
			if (options.limit != null) api += "&num=" + options.limit;
			if (options.key != null) api += "&key=" + options.key;
 
			// Send request
		
			$.getJSON(api, function(data){
				
				// Check for error
				if (data.responseStatus == 200) {
					// Process the feeds
				
					_callback(e, data.responseData.feed, options);
				} else {
 
					// Handle error if required
					if (options.showerror)
						if (options.errormsg != '') {
							var msg = options.errormsg;
						} else {
							var msg = data.responseDetails;
						};
						$(e).html('<div class="rssError"><p>'+ msg +'</p></div>');
				};
			});				
		});
	};
	
	// Callback function to create HTML result
	var _callback = function(e, feeds, options) {
		if (!feeds) {
			return false;
		}
		var html = '';	
		var row = 'odd';	
		
		// Add header if required
		if (options.header)
			html +=	'<div class="rssHeader">' +
				'<a href="'+feeds.link+'" title="'+ feeds.description +'">'+ feeds.title +'</a>' +
				'</div>';
			
		// Add body
		html += '<div class="rssBody">' +
			'<ul>';
					
		// Add feeds
		for (var i=0; i<feeds.entries.length; i++) {
			
			// Get individual feed
			var entry = feeds.entries[i];	
			
			// Format published date
			var entryDate = new Date(entry.publishedDate);
			var pubDate = TTSDate(entryDate); //entryDate.toLocaleDateString();// + ' ' + entryDate.toLocaleTimeString();
			var title = entry.title;
			title = title.replace("'", "&#39;");
			title = title.replace("@", "&#64");
			
			// Add feed row - format depends on type
			
			switch (options.type){
				case "bbcnews": 
					if (i==0)
					{
						html += '<li id="#fp_news_item_' + i + '" class="fp_news_item rssRow '+row+'">';
					}
					else
					{
						html += '<li id="#fp_news_item_' + i + '" style="display:none;" class="fp_news_item rssRow '+row+'">';
					}
					if (options.content) {
					
						// Use feed snippet if available and optioned
						if (options.snippet && entry.contentSnippet != '') {
							var content = entry.contentSnippet;
						} else {
							var content = entry.content;
						}
						
						content = '<h4>' + title + '</h4><p>' + pubDate + '</p><p>' + content
						content = content.replace("'", "&#39;");
						content = content.replace("@", "&#64");
		
						html += '<div class="fp_item_content">' + content +'</p></div>';
						if (entry.link != ""){
							html += '<div class="fp_item_link"><a href="'+ entry.link +'"target="_blank" title="View this feed at'+ feeds.title +'">Click for more info</a></div>';
						}
					}
					
					html += '</li>';
				break;
			}
 
			
			// Alternate row classes
			if (row == 'odd') {
				row = 'even';
			} else {
				row = 'odd';
			}			
		}
		
		html += '</ul>' +
			'</div>'
		
		$(e).html(html);
	};
})(jQuery);
