if (typeof BM == "undefined" || !BM) {
    var BM = {};
}

BM.log = function() {
    if (window.console) {
        window.console.log.apply(this, arguments);
    }
};

function handleValidationError(formId, key, error, globalErrors) {
    var form = $("#" + formId);
    var e = form.find("input[name=" + key + "],select[name=" + key + "],textarea[name=" + key + "]");
    if (e.length > 0) {
        e.addClass("error").attr("validation-error", error).tipsy({gravity: 'n', title: 'validation-error'});
    } else {
        if (globalErrors == null) {
            globalErrors = [];
        }

        globalErrors.push(error);
    }

    return globalErrors;
}

function handleGlobalValidationErrors(globalErrors) {
    if (globalErrors == null || globalErrors.length == 0) {
        return;
    }

    var string = "<ul>";
    $.each(globalErrors, function (k,v) {string += "\n<li>" + v + "</li>"});
    string += "</ul>";

    var div = $("<div style='display: none' class='global-errors'><p>" + string + "</p></div>");
    $("body").append(div);

    div.dialog({
        autoOpen: true,
        draggable: false,
        resizable: false,
        title: 'Errors Encountered',
        bgiframe: true,
        modal: true,
        width: 475,
        buttons: {
            OK: function () {
                $(this).dialog('close');
            }
        }
    });
}

/*wire up the page to show confirmation dialogs*/
function wireUpConfirmations(confirmationElement, buttonClass) {
    var confirmation = $("#" + confirmationElement);
    confirmation.dialog({
        autoOpen: false,
        draggable: false,
        resizable: false,
        title: 'Confirm Delete',
        bgiframe: true,
        modal: true,
        width: 475
    });

    $("." + buttonClass).click(function(event) {
        var button = $(event.target).closest("button");
        confirmation.dialog('option', 'buttons', {
            Yes: function() {
                var form = $(button.parents("form")[0]);
                form.append("<input name='" + button.attr('name') + "' value='' type='hidden'/>");
                button.unbind().click();
                form.submit();
            },
            No: function() {
                $(this).dialog('close');
            }
        });
        confirmation.dialog('open');

        return false;
    });
}


$(function() {
    // standard/generic "delete item" confirmation
    wireUpConfirmations("confirmation_delete_item", "confirm_delete_item");

    // wire up tooltips
    $(".tooltipable").tooltip();
});

jQuery.fn.incrementArrayIndex = function() {
    return $(this).find("*").andSelf().each(function() {
        var id = $(this).attr("id");
        var name = $(this).attr("name");

        var matchAgainst = null;
        if (id != null && id != "") {
            matchAgainst = id;
        } else if (name != null && name != "") {
            matchAgainst = name;
        } else {
            return;
        }

        var match = matchAgainst.match(/\[(\d)\]/);
        if (match == null || match.length != 2) {
            return;
        }

        var nextIndex = parseInt(match[1]) + 1;

        if (nextIndex == -1) {
            return;
        }

        if (id != null) {
            id = id.replace(/\[\d\]/, "[" + nextIndex + "]");
            $(this).attr("id", id);
        }

        if (name != null) {
            name = name.replace(/\[\d\]/, "[" + nextIndex + "]");
            $(this).attr("name", name);
        }
    });
};

/**
 * Cookie plugin
 *
 * Copyright (c) 2006 Klaus Hartl (stilbuero.de)
 * Dual licensed under the MIT and GPL licenses:
 * http://www.opensource.org/licenses/mit-license.php
 * http://www.gnu.org/licenses/gpl.html
 *
 */

/**
 * Create a cookie with the given name and value and other optional parameters.
 *
 * @example $.cookie('the_cookie', 'the_value');
 * @desc Set the value of a cookie.
 * @example $.cookie('the_cookie', 'the_value', { expires: 7, path: '/', domain: 'jquery.com', secure: true });
 * @desc Create a cookie with all available options.
 * @example $.cookie('the_cookie', 'the_value');
 * @desc Create a session cookie.
 * @example $.cookie('the_cookie', null);
 * @desc Delete a cookie by passing null as value. Keep in mind that you have to use the same path and domain
 *       used when the cookie was set.
 *
 * @param String name The name of the cookie.
 * @param String value The value of the cookie.
 * @param Object options An object literal containing key/value pairs to provide optional cookie attributes.
 * @option Number|Date expires Either an integer specifying the expiration date from now on in days or a Date object.
 *                             If a negative value is specified (e.g. a date in the past), the cookie will be deleted.
 *                             If set to null or omitted, the cookie will be a session cookie and will not be retained
 *                             when the the browser exits.
 * @option String path The value of the path atribute of the cookie (default: path of page that created the cookie).
 * @option String domain The value of the domain attribute of the cookie (default: domain of page that created the cookie).
 * @option Boolean secure If true, the secure attribute of the cookie will be set and the cookie transmission will
 *                        require a secure protocol (like HTTPS).
 * @type undefined
 *
 * @name $.cookie
 * @cat Plugins/Cookie
 * @author Klaus Hartl/klaus.hartl@stilbuero.de
 */

/**
 * Get the value of a cookie with the given name.
 *
 * @example $.cookie('the_cookie');
 * @desc Get the value of a cookie.
 *
 * @param String name The name of the cookie.
 * @return The value of the cookie.
 * @type String
 *
 * @name $.cookie
 * @cat Plugins/Cookie
 * @author Klaus Hartl/klaus.hartl@stilbuero.de
 */
jQuery.cookie = function(name, value, options) {
    if (typeof value != 'undefined') { // name and value given, set cookie
        options = options || {};
        if (value === null) {
            value = '';
            options.expires = -1;
        }
        var expires = '';
        if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {
            var date;
            if (typeof options.expires == 'number') {
                date = new Date();
                date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));
            } else {
                date = options.expires;
            }
            expires = '; expires=' + date.toUTCString(); // use expires attribute, max-age is not supported by IE
        }
        // CAUTION: Needed to parenthesize options.path and options.domain
        // in the following expressions, otherwise they evaluate to undefined
        // in the packed version for some reason...
        var path = options.path ? '; path=' + (options.path) : '';
        var domain = options.domain ? '; domain=' + (options.domain) : '';
        var secure = options.secure ? '; secure' : '';
        document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');
    } else { // only name given, get cookie
        var cookieValue = null;
        if (document.cookie && document.cookie != '') {
            var cookies = document.cookie.split(';');
            for (var i = 0; i < cookies.length; i++) {
                var cookie = jQuery.trim(cookies[i]);
                // Does this cookie string begin with the name we want?
                if (cookie.substring(0, name.length + 1) == (name + '=')) {
                    cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
                    break;
                }
            }
        }
        return cookieValue;
    }
};