/**
 * aka void main()
 */
$(function() {

    Vibor.initAjax();

    //if (Vibor.interfaceName === 'home_page'){

    //}
});


/**
 * Глобальный неймспейс
 */
Vibor = new Object();

/** @type {Object} неймспейс проекта */
Vibor = function(undef) {
    return {
        undefined : undef
    }
}();

//----- Общие настройки---------------------------------------------------------

/** @type {String} url для ajax запроса */
Vibor.AJAX_URI = '/json/';

/** @type {Number} Значение прозрачности для оверлея */
Vibor.overlayOpacity = 0.6;

/** @type {string} Значение цвета для оверлея */
Vibor.overlayColor = "#333333";

/** @type {String} id сессии из командной строки */
Vibor.SESS_ID = '';
if (window.location.toString().match(/SESS_ID=(\d+)/))
    Vibor.SESS_ID = RegExp.$1;

//------------------------------------------------------------------------------

//----- Общие функции ----------------------------------------------------------

/**
 * Выполняет Ajax запрос с JSON-ответом
 * @param {Object} data Данные
 * @param {Function} handler Обработчик
 */
Vibor.getJSON = function(data, handler) {
    if (Vibor.SESS_ID)
        data['SESS_ID'] = Vibor.SESS_ID;
    $.post(Vibor.AJAX_URI, data, handler, 'json');
}

/**
 * Настройки для Ajax запросов
 */
Vibor.initAjax = function() {
    var $body = $(document.body);
    function waitingState(state) {
        if (state) {
            $body.addClass('waiting');
        } else {
            $body.removeClass('waiting');
        }
    }

    $(document)
        .ajaxStart(function() {
            waitingState(true);
        })
        .ajaxStop(function() {
            waitingState(false);
        })
        .ajaxError(function(event, XMLHttpRequest, ajaxOptions, thrownError) {
            alert('Произошла ошибка при загрузки данных. Попробуйте перезагрузить страницу.');
            waitingState(false);
        });
}

/**
 *  Слой - оверлей
 */
Vibor.Overlay = function(){
    var $overlay = null;

    function _show(){
        if (!$overlay){
              $overlay = $(document.createElement('div'))
                         .addClass('overlay')
                         .css({
                              opacity: Vibor.overlayOpacity
                         }).hide()
                         .appendTo(document.body);
        }
        $overlay.show();
        if (Browser.isIE6)
            $overlay.css({
                position : 'absolute',
                height : document.body.scrollHeight
            });
    }

    function _hide(){
        $overlay.hide();
    }

    return {
        show: function(){
            _show();
        },
        hide: function(){
            _hide();
        },
        onclick: function(handler){
            $overlay.unbind("click");
            $overlay.click(handler);
        }
    }
}();

//------------------------------------------------------------------------------

//----- Интерфейсные функции ---------------------------------------------------

//------------------------------------------------------------------------------
