(function(jQuery)
{
	//If the UI scope is not availalable, add it
	jQuery.ui = jQuery.ui || {};

	jQuery.fn.dialog = function(o) {
		return this.each(function() {
			if (!jQuery(this).is(".ui-dialog")) new jQuery.ui.dialog(this, o);
		});
	}
	jQuery.fn.dialogOpen = function() {
		return this.each(function() {
			var contentEl;
			if (jQuery(this).parents(".ui-dialog").length) contentEl = this;
			if (!contentEl && jQuery(this).is(".ui-dialog")) contentEl = jQuery('.ui-dialog-content', this)[0];
			jQuery.ui.dialogOpen(contentEl)
		});
	}
	jQuery.fn.dialogClose = function() {
		return this.each(function() {
			var contentEl;
			if (jQuery(this).parents(".ui-dialog").length) contentEl = this;
			if (!contentEl && jQuery(this).is(".ui-dialog")) contentEl = jQuery('.ui-dialog-content', this)[0];
			jQuery.ui.dialogClose(contentEl);
		});
	}

	jQuery.ui.dialog = function(el, o) {
		
		var options = {
			width: 300,
			height: 200,
			position: 'center',
			buttons: [],
			modal: false,
			drag: true,
			resize: true,
			titlebar: true,
			shadow: false // It's quite slow
		};
		var o = o || {}; jQuery.extend(options, o); //Extend and copy options
		this.element = el; var self = this; //Do bindings
		jQuery.data(this.element, "ui-dialog", this);

		var uiDialogContent = jQuery(el).addClass('ui-dialog-content')
			.wrap(document.createElement('div'))
			.wrap(document.createElement('div'));
		var uiDialogContainer = uiDialogContent.parent().addClass('ui-dialog-container').css({position: 'relative'});
		var uiDialog = uiDialogContainer.parent()
			.addClass('ui-dialog').addClass(uiDialogContent.attr('className'))
			.css({position: 'absolute', width: options.width, height: options.height});
    
        if (options.modal == false && options.resize == true) {
		    uiDialog.append("<div class='ui-resizable-n ui-resizable-handle'></div>")
                .append("<div class='ui-resizable-s ui-resizable-handle'></div>")
                .append("<div class='ui-resizable-e ui-resizable-handle'></div>")
                .append("<div class='ui-resizable-w ui-resizable-handle'></div>")
                .append("<div class='ui-resizable-ne ui-resizable-handle'></div>")
                .append("<div class='ui-resizable-se ui-resizable-handle'></div>")
                .append("<div class='ui-resizable-sw ui-resizable-handle'></div>")
                .append("<div class='ui-resizable-nw ui-resizable-handle'></div>");
      
		    uiDialog.resizable();
		}

    if (options.titlebar) {
		  uiDialogContainer.prepend('<div class="ui-dialog-titlebar"></div>');
  		var uiDialogTitlebar = jQuery('.ui-dialog-titlebar', uiDialogContainer);
  		var title = (options.title) ? options.title : (uiDialogContent.attr('title')) ? uiDialogContent.attr('title') : '';
  		uiDialogTitlebar.append('<span class="ui-dialog-title">' + title + '</span>');
  		uiDialogTitlebar.append('<div class="ui-dialog-titlebar-close"></div>');
  		jQuery('.ui-dialog-titlebar-close', uiDialogTitlebar)
  			.hover(function() { jQuery(this).addClass('ui-dialog-titlebar-close-hover'); }, 
  			       function() { jQuery(this).removeClass('ui-dialog-titlebar-close-hover'); })
  			.mousedown(function(ev) {
  				ev.stopPropagation();
  			})
  			.click(function() {
  				self.close();
  			});
		}
		var l = 0;
		jQuery.each(options.buttons, function() { l = 1; return false; });
        if (l == 1) {
		    uiDialog.append('<div class="ui-dialog-buttonpane"></div>');
		    var uiDialogButtonPane = jQuery('.ui-dialog-buttonpane', uiDialog);
		    jQuery.each(options.buttons, function(name, value) {
		    	var btn = jQuery(document.createElement('button')).text(name).click(value);
		    	uiDialogButtonPane.append(btn);
		    });
		}
        
        if (options.modal == false && options.drag == true) {
		    uiDialog.draggable({ handle: '.ui-dialog-titlebar' });
        }
        
		this.open = function() {
			var wnd = jQuery(window), top = 0, left = 0;
			switch (options.position) {
				case 'center':
					top = (wnd.height() / 2) - (uiDialog.height() / 2);
					left = (wnd.width() / 2) - (uiDialog.width() / 2);
					break;
				case 'left':
				    top = (wnd.height() / 2) - (uiDialog.height() / 2);
				    left = 0;
				    break;
				case 'top':
    			    top = 0;
					left = (wnd.width() / 2) - (uiDialog.width() / 2);
					break;
				case 'explicit':
				  top = options.top;
				  left = options.left;
				  break;
			}
			uiDialog.css({top: top, left: left});
			uiDialog.appendTo('body').show();
		};

		this.close = function() {
			uiDialog.hide();
		};

		uiDialog.show();
		this.open();
        if (options.shadow && jQuery.fn.shadow != undefined) {
            uiDialog.shadow();
        }
	}

	jQuery.ui.dialogOpen = function(el) {
		jQuery.data(el, "ui-dialog").open();
	}

	jQuery.ui.dialogClose = function(el) {
		jQuery.data(el, "ui-dialog").close();
	}

})(jQuery);
