$(document).ready(function()
{
	PEPS.rollover.init();
});

PEPS = {};

PEPS.rollover =
{
	init: function()
	{
		this.preload();

		$(".ro").hover(
			function() { $(this).attr( 'src', PEPS.rollover.newimage($(this).attr('src')) ); },
			function() { $(this).attr( 'src', PEPS.rollover.oldimage($(this).attr('src')) ); }
		);
		
		$(".ro").click(
			function()
			{
				$(this).attr( 'src', PEPS.rollover.clickimage($(this).attr('src')) );
			}
		);
	},

	preload: function()
	{
		$(window).bind('load', function() {
			$('.ro').each( function( key, elm ) { $('<img>').attr( 'src', PEPS.rollover.newimage( $(this).attr('src') ) ); });
			$('.ro').each( function( key, elm ) { $('<img>').attr( 'src', PEPS.rollover.clickimage( $(this).attr('src') ) ); });
		});
	},

		newimage: function(src) { return src.substring( 0, src.search(/(\.[a-z]+)/) ) + '_Over' + src.match(/(\.[a-z]+)/)[0]; },
		oldimage: function(src) { return src.replace(/_Over/, ''); },
		clickimage: function(src)
		{
			src = src.replace(/_Over/, '');
			
			return src.substring(0, src.search(/(\.[a-z]+)/) ) + '_Click' + src.match(/(\.[a-z]+)/)[0];
		}
};
