//=============================================================================
var TBanners		= {};

//=============================================================================
TBanners.Data		= {};
TBanners.Pos		= -1;

TBanners.Running	= true;
TBanners.TimerHandle = null;

TBanners.Locked		= false;

//=============================================================================
TBanners.Start = function() {
	TBanners.Running = true;

	TBanners.LoadImage(TBanners.Pos + 1);
}

//-----------------------------------------------------------------------------
TBanners.LoadImage = function(Pos) {
	if(TBanners.Locked) return;

	TBanners.Pos = Pos;

	if(TBanners.Pos >= TBanners.Data.length) {
		TBanners.Pos = 0;
	}else
	if(TBanners.Pos < 0) {
		TBanners.Pos = TBanners.Data.length - 1;
	}

	TBanners.Locked = true;

	var Picture = new Image();

	Picture.onload = function() {
		$("#BannersImage2").css("background-image", "url('" + TBanners.Data[TBanners.Pos]["Filename"] + "')");

		TBanners.FadeIn();
	};

	Picture.src = TBanners.Data[TBanners.Pos]["Filename"];
}

//-----------------------------------------------------------------------------
TBanners.FadeIn = function() {
	for(var i = 0;i < TBanners.Data.length;i++) {
		$("#BannersNumber" + i).removeClass("BannersNumberActive");
	}

	var Num = TBanners.Pos;

	$("#BannersNumber" + Num).addClass("BannersNumberActive");

	$("#BannersCaption").animate({"opacity" : 0}, function() {
		$("#BannersCaption").css("display", "block");
	});	

	$("#BannersImage2").animate({
		"opacity" : 1
	}, 500, "swing", function() {
		$("#BannersCaption").html(TBanners.Data[TBanners.Pos]["Caption"]);
		$("#BannersCaption").animate({"opacity" : 0.85});

		$("#BannersImage1").css("background-image", $("#BannersImage2").css("background-image"));
		$("#BannersImage2").css("opacity", 0);		

		var Dur = TBanners.Data[TBanners.Pos]["Duration"];

		TBanners.Locked = false;

		if(TBanners.Running) {
			TBanners.TimerHandle = setTimeout(TBanners.Start, Dur);
		}else{
			TBanners.TimerHandle = setTimeout(TBanners.Start, 30000);
		}		
	});	
}

//-----------------------------------------------------------------------------
TBanners.Load = function(Pos) {
	TBanners.Pos = Pos;

	clearTimeout(TBanners.TimerHandle);

	TBanners.Running = false;

	TBanners.LoadImage(TBanners.Pos);
}

//-----------------------------------------------------------------------------
TBanners.Next = function() {
	clearTimeout(TBanners.TimerHandle);

	TBanners.Running = false;

	TBanners.LoadImage(TBanners.Pos + 1);
}

//-----------------------------------------------------------------------------
TBanners.Previous = function() {
	clearTimeout(TBanners.TimerHandle);

	TBanners.Running = false;

	TBanners.LoadImage(TBanners.Pos - 1);
}

//-----------------------------------------------------------------------------
TBanners.OnInit = function(Data) {
	TBanners.Data = [];

	$("#BannersNumbers").html("");

	for(var i = 0;i < Data.length;i++) {
		TBanners.Data[i] = Data[i];

		$("#BannersNumbers").append("<div class='BannersNumber' id='BannersNumber" + i + "'>" + Data[i]["Title"] + "</div>");

		$("#BannersNumber" + i).data("Pos", i).bind("click", function() {
			TBanners.Load($(this).data("Pos"));
		});
	}

	if(count(TBanners.Data) > 0) {
		TBanners.Start();
	}

	$("#BannersPrevious").bind("click", TBanners.Previous);
	$("#BannersNext").bind("click", TBanners.Next);

	/*$(window).bind("mousemove", function(e) {
		var MouseX = e.pageX;
		var MouseY = e.pageY;

		var PrevPos = $("#BannersPrevious").position();
		var NextPos = $("#BannersNext").position();

		var InRange = function(X, Y, Pos) {
			var Pad = 20;

			if(X > Pos.left - 20 && X < Pos.right + 20 &&
				Y > Pos.top - 20 && Y < Pos.bottom + 20) {
				return true;
			}

			return false;
		};

		if(InRange(MouseX, MouseY, PrevPos))	$("#BannersPrevious").fadeIn(500);
		else									$("#BannersPrevious").fadeOut(500);

		if(InRange(MouseX, MouseY, NextPos))	$("#BannersNext").fadeIn(500);
		else									$("#BannersNext").fadeOut(500);
	});*/
}

//=============================================================================

