$(document).ready( 
   function() { ROLL.rollover.init(); }
);

ROLL = {};

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