/*
* jQuery Modal Dialog plugin 1.0
* Released: July 14, 2008
* 
* Copyright (c) 2008 Chris Winberry
* Email: transistech@gmail.com
* 
* Original Design: Michael Leigeber
* http://www.leigeber.com/2008/04/custom-javascript-dialog-boxes/
* 
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* 
* Dual licensed under the MIT and GPL licenses:
*   http://www.opensource.org/licenses/mit-license.php
*   http://www.gnu.org/licenses/gpl.html
*
* @license http://www.opensource.org/licenses/mit-license.php
* @license http://www.gnu.org/licenses/gpl.html
* @project jquery.modaldialog
*/
(function ($) {
    var modaldialog = {};

    // Creates and shows the modal dialog
    function showDialog(msg, options) {
        // Make sure the dialog type is valid. If not assign the default one (the first)
        if (!$.inArray(options.type, modaldialog.DialogTypes)) {
            options.type = modaldialog.DialogTypes[0];
        };

        // Merge default title (per type), default settings, and user defined settings
        var settings = $.extend({ title: modaldialog.DialogTitles[options.type] }, modaldialog.defaults, options);

        // If there's no timeout, make sure the close button is show (or the dialog can't close)
        settings.timeout = (typeof (settings.timeout) == "undefined") ? 0 : settings.timeout;
        //settings.showClose = ((typeof (settings.showClose) == "undefined") | !settings.timeout) ? true : !!settings.showClose;

        // Check if the dialog elements exist and create them if not
        if (!document.getElementById('dialog')) {
            dialog = document.createElement('div');
            dialog.id = 'dialog';
            $(dialog).html(
				"<div id='dialog-header'>" +
					"<div id='dialog-title'></div>" +
					"<div id='dialog-close'></div>" +
				"</div>" +
				"<div id='dialog-content'>" +
					"<div id='dialog-content-inner' />" +
					"<div id='dialog-button-container'>" +
						"<input type='button' id='dialog-button' value='" + (options.buttonText ? options.buttonText : "Close") + "'>" +
					"</div>" +
				"</div>"
				);

            dialogmask = document.createElement('div');
            dialogmask.id = 'dialog-mask';

            $(dialogmask).hide();
            $(dialog).hide();

            document.body.appendChild(dialogmask);
            document.body.appendChild(dialog);

            // Set the click event for the "x" and "Close" buttons			
            $("#dialog-close").click(modaldialog.hide);
            $("#dialog-button").click(modaldialog.hide);
        }

        var dl = $('#dialog');
        var dlh = $('#dialog-header');
        var dlc = $('#dialog-content');
        var dlb = $('#dialog-button');

        $('#dialog-title').html(settings.title);
        $('#dialog-content-inner').html(msg);

        // Center the dialog in the window but make sure it's at least 25 pixels from the top
        // Without that check, dialogs that are taller than the visible window risk
        // having the close buttons off-screen, rendering the dialog unclosable 
        dl.css('width', settings.width);
        var dialogTop = Math.abs($(window).height() - dl.height()) / 2;
        dl.css('left', ($(window).width() - dl.width()) / 2);
        dl.css('top', (dialogTop >= 25) ? dialogTop : 25);

        // Clear the dialog-type classes and add the current dialog-type class		
        $.each(modaldialog.DialogTypes, function () { dlh.removeClass(this + "header") });
        dlh.addClass(settings.type + "header")
        $.each(modaldialog.DialogTypes, function () { dlc.removeClass(this) });
        dlc.addClass(settings.type);
        $.each(modaldialog.DialogTypes, function () { dlb.removeClass(this + "button") });
        dlb.addClass(settings.type + "button")

        if (!settings.showClose) {
            $('#dialog-close').hide();
            $('#dialog-button-container').hide();
        } else {
            $('#dialog-close').show();
            $('#dialog-button-container').show();
        }

        if (settings.timeout) {
            window.setTimeout("$('#dialog').fadeOut('slow', 0); $('#dialog-mask').fadeOut('normal', 0);", (settings.timeout * 1000));
        }

        dl.fadeIn(0);
        $('#dialog-mask').fadeIn(10);
    };

    modaldialog.error = function $$modaldialog$error(msg, options) {
        if (typeof (options) == "undefined") {
            options = {};
        }
        options['type'] = "error";
        return (showDialog(msg, options));
    }
    modaldialog.warning = function $$modaldialog$error(msg, options) {
        if (typeof (options) == "undefined") {
            options = {};
        }
        options['type'] = "warning";
        return (showDialog(msg, options));
    }
    modaldialog.success = function $$modaldialog$error(msg, options) {
        if (typeof (options) == "undefined") {
            options = {};
        }
        options['type'] = "success";
        return (showDialog(msg, options));
    }
    modaldialog.progress = function $$modaldialog$error(msg, options) {
        if (typeof (options) == "undefined") {
            options = {};
        }
        options['type'] = "progress";
        return (showDialog(msg, options));
    }

    modaldialog.prompt = function $$modaldialog$error(msg, options) {
        if (typeof (options) == "undefined") {
            options = {};
        }
        options['type'] = "prompt";
        return (showDialog(msg, options));
    }

    modaldialog.remove = function $$modaldialog$remove() {
        $('#dialog').remove();
        $('#dialog-mask').remove();
    };

    modaldialog.hide = function $$modaldialog$hide() {
        $('#dialog').fadeOut("slow", function () { $(this).hide(0); });
        $('#dialog-mask').fadeOut("normal", function () { $(this).hide(0); });
    };

    modaldialog.DialogTypes = new Array("error", "warning", "success", "prompt");
    modaldialog.DialogTitles = {
        "error": "!! Error !!"
		, "warning": "Warning!"
		, "success": "Success"
		, "prompt": "Please Choose"
    };

    modaldialog.defaults = {
        timeout: 0
		, showClose: true
		, width: 525
    };

    $.extend({ modaldialog: modaldialog });
})(jQuery);

