
function showOverlay( title, src ) {
	_overlay.setTitle( title );
	_overlay.setSource( src );
	_overlay.fadeIn();
}

if ( typeof MooTools == 'object' ) {

	var _overlay_Main = new Class( {

		initialize: function() {

			this.divOverlay = new Element( 'div', { 'id': 'overlay_DivMain' } );
			this.divOverlay.injectInside( document.body );
			this.divOverlayInfo = new Element( 'div', { 'id': 'overlay_DivInfo' } );
			this.divOverlayInfo.injectInside( document.body );
			this.AClose = new Element( 'a', { 'id': 'overlay_AClose', 'href': 'javascript:_overlay.fadeOut()' } );
			this.AClose.injectInside( this.divOverlayInfo );
			this.AClose.set( 'text', 'X' );
			this.pTitle = new Element( 'p', { 'id': 'overlay_PTitle' } );
			this.pTitle.injectInside( this.divOverlayInfo );
			this.Frame = new Element( 'iframe', { 'id': 'overlay_Frame', 'frameborder': 0 } );
			this.Frame.injectInside( this.divOverlayInfo );
		},

		setTitle: function( title ) {
			this.pTitle.set( 'text', title );
		},

		setSource: function( src ) {
			this.Frame.src = src;
		},

		fadeIn: function() {
			_overlay.divOverlay.setStyle( 'opacity', 0 );
			_overlay.divOverlay.style.display = 'block';
			var fx = new Fx.Tween( _overlay.divOverlay, { onComplete: _overlay.fadeIn2 } );
            fx.start( 'opacity', 0.7 );
		},

		fadeIn2: function() {
			_overlay.divOverlayInfo.style.left = 40 + 'px';
			_overlay.divOverlayInfo.style.top = 40 + 'px';
			_overlay.divOverlayInfo.style.width = ( document.body.clientWidth - 80 ) + 'px';
			_overlay.divOverlayInfo.style.height = ( document.body.clientHeight - 80 ) + 'px';
			_overlay.Frame.style.width = ( document.body.clientWidth - 80 ) + 'px';
			_overlay.Frame.style.height = ( document.body.clientHeight - 104 ) + 'px';
			_overlay.divOverlayInfo.setStyle( 'opacity', 0 );
			_overlay.divOverlayInfo.style.display = 'block';
			var fx = new Fx.Tween( _overlay.divOverlayInfo );
            fx.start( 'opacity', 1 );
		},

		fadeOut: function() {
			var fx = new Fx.Tween( _overlay.divOverlayInfo, { onComplete: _overlay.fadeOut2 } );
            fx.start( 'opacity', 0 );
		},

		fadeOut2: function() {
			var fx = new Fx.Tween( _overlay.divOverlay, { onComplete: _overlay.fadeDone } );
            fx.start( 'opacity', 0 );
			_overlay.setSource( '' );
		},

		fadeDone: function() {
			_overlay.divOverlay.style.display = 'none';
			_overlay.divOverlayInfo.style.display = 'none';
		}

	} );

	var _overlay;

	window.addEvent( 'domready', function() { _overlay = new _overlay_Main(); }  );

}
