Код:
(function($) {
var default_options = {
zIndex: 1000, // Базовый z-index
type: 'html', // ajax или html
content: '',
url: '',
ajax: {},
ajax_request: null,
closeOnEsc: true,
closeOnOverlayClick: true,
overlay: {
block: undefined,
tpl: '<div class="payment_modal-overlay"></div>',
css: {
backgroundColor: '#000',
opacity: .6
}
},
container: {
block: undefined,
tpl: '<div class="payment_modal-container"><table class="payment_modal-container_i"><tr><td class="payment_modal-container_i2"></td></tr></table></div>'
},
wrap: undefined,
body: undefined,
errors: {
tpl: '<div class="payment_modal-error payment_modal-close"></div>',
autoclose_delay: 2000,
ajax_unsuccessful_load: 'Error'
},
openEffect: {
type: 'fade',
speed: 400
},
closeEffect: {
type: 'fade',
speed: 400
},
beforeOpen: $.noop,
afterOpen: $.noop,
beforeClose: $.noop,
afterClose: $.noop,
afterLoading: $.noop,
errorLoading: $.noop
};
var modals = $();
var utils = {
// Определяет произошло ли событие e вне блока block
isEventOut: function(blocks, e) {
var r = true;
$(blocks).each(function() {
if ($(e.target).get(0)==$(this).get(0)) r = false;
if ($(e.target).closest('HTML', $(this).get(0)).length==0) r = false;
});
return r;
}
};
var modal = {
// Переход
transition: function(el, action, options, callback) {
callback = callback==undefined ? $.noop : callback;
switch (options.type) {
case 'fade':
action=='show' ? el.fadeIn(options.speed, callback) : el.fadeOut(options.speed, callback);
break;
case 'none':
action=='show' ? el.show() : el.hide();
callback();
break;
}
},
// Подготвка содержимого окна
prepare_body: function(D, $this) {
// Показать содержимое
$('>*', D.body).show();
// Обработчик закрытия
$('.payment_modal-close', D.body).click(function() {
$this.payment_modal('close');
return false;
});
},
// Инициализация элемента
init_el: function($this, options) {
var D = $this.data('payment_modal');
if (D) return;
D = options;
// Overlay
D.overlay.block = $(D.overlay.tpl);
D.overlay.block.css(D.overlay.css);
// Container
D.container.block = $(D.container.tpl);
// BODY
D.body = $('.payment_modal-container_i2', D.container.block);
D.body.html($this.clone(true));
// Подготовка содержимого
modal.prepare_body(D, $this);
// Закрытие при клике на overlay
if (D.closeOnOverlayClick)
D.overlay.block.add(D.container.block).click(function(e) {
if (utils.isEventOut($('>*', D.body), e))
$this.payment_modal('close');
});
// Запомним настройки
$this.data('payment_modal', D);
modals = modals.add($this);
// Показать
$.proxy(actions.show, $this)();
if (D.type=='html') return $this;
// Ajax-загрузка
if (D.ajax.beforeSend!=undefined) {
var fn_beforeSend = D.ajax.beforeSend;
delete D.ajax.beforeSend;
}
if (D.ajax.success!=undefined) {
var fn_success = D.ajax.success;
delete D.ajax.success;
}
if (D.ajax.error!=undefined) {
var fn_error = D.ajax.error;
delete D.ajax.error;
}
var o = $.extend(true, {
url: D.url,
beforeSend: function() {
if (fn_beforeSend==undefined) {
D.body.html('<div class="payment_modal-loading" />');
} else {
fn_beforeSend(D, $this);
}
},
success: function(responce) {
// Событие после загрузки
$this.trigger('afterLoading');
D.afterLoading(D, $this, responce);
if (fn_success==undefined) {
D.body.html(responce);
} else {
fn_success(D, $this, responce);
}
modal.prepare_body(D, $this);
},
error: function() {
// Событие при ошибке загрузки
$this.trigger('errorLoading');
D.errorLoading(D, $this);
if (fn_error==undefined) {
D.body.html(D.errors.tpl);
$('.payment_modal-error', D.body).html(D.errors.ajax_unsuccessful_load);
$('.payment_modal-close', D.body).click(function() {
$this.payment_modal('close');
return false;
});
if (D.errors.autoclose_delay)
setTimeout(function() {
$this.payment_modal('close');
}, D.errors.autoclose_delay);
} else {
fn_success(D, $this);
}
}
}, D.ajax);
D.ajax_request = $.ajax(o);
// Запомнить настройки
$this.data('payment_modal', D);
},
// Инициализация
init: function(options) {
options = $.extend(true, {}, default_options, options);
if ($.isFunction(this)) {
if (options==undefined) {
$.error('jquery.payment_modal: Uncorrect parameters');
return;
}
if (options.type=='') {
$.error('jquery.payment_modal: Don\'t set parameter "type"');
return;
}
switch (options.type) {
case 'html':
if (options.content=='') {
$.error('jquery.payment_modal: Don\'t set parameter "content"');
return
}
var c = options.content;
options.content = '';
return modal.init_el($(c), options);
break;
case 'ajax':
if (options.url=='') {
$.error('jquery.payment_modal: Don\'t set parameter "url"');
return;
}
return modal.init_el($('<div />'), options);
break;
}
} else {
return this.each(function() {
modal.init_el($(this), options);
});
}
}
};
var actions = {
// Показать
show: function() {
var $this = $(this);
var D = $this.data('payment_modal');
if (!D) {
$.error('jquery.payment_modal: Uncorrect call');
return;
}
// Добавить overlay и container
D.overlay.block.css('zIndex', default_options.zIndex++).hide();
D.container.block.css('zIndex', default_options.zIndex++).hide();
$('BODY').append(D.overlay.block);
$('BODY').append(D.container.block);
// Событие
D.beforeOpen(D, $this);
$this.trigger('beforeOpen');
// Wrap
if (D.wrap.css('overflow')!='hidden') {
D.wrap.data('payment_modalOverflow', D.wrap.css('overflow'));
D.wrap.css('overflow', 'hidden');
}
// Показать
modal.transition(D.container.block, 'show', D.openEffect);
modal.transition(D.overlay.block, 'show', D.openEffect, function() {
D.afterOpen(D, $this);
$this.trigger('afterOpen');
});
return $this;
},
// Закрыть
close: function() {
if ($.isFunction(this)) {
modals.each(function() {
$(this).payment_modal('close');
});
} else {
return this.each(function() {
var $this = $(this);
var D = $this.data('payment_modal');
if (!D) {
$.error('jquery.payment_modal: Uncorrect call');
return;
}
// Событие перед закрытием
if (D.beforeClose(D, $this)===false) return;
$this.trigger('beforeClose');
default_options.zIndex = default_options.zIndex - 2;
modal.transition(D.overlay.block, 'hide', D.closeEffect);
modal.transition(D.container.block, 'hide', D.closeEffect, function() {
// Событие после закрытия
D.afterClose(D, $this);
$this.trigger('afterClose');
D.overlay.block.remove();
D.container.block.remove();
$this.data('payment_modal', null);
if (!$('.payment_modal-container').length)
if (D.wrap.data('payment_modalOverflow'))
D.wrap.css('overflow', D.wrap.data('payment_modalOverflow'));
});
$('#my_payment_invoices_new_form_pay_one').show();
if (D.type=='ajax')
D.ajax_request.abort();
modals = modals.not($this);
});
}
}
};
$(function() {
default_options.wrap = $((document.all && !document.querySelector) ? 'html' : 'body');
});
// Закрытие при нажатии Escape
$(document).bind('keyup.payment_modal', function(e) {
var m = modals.last();
if (!m.length) return;
var D = m.data('payment_modal');
if (D.closeOnEsc && (e.keyCode===27))
m.payment_modal('close');
});
$.payment_modal = $.fn.payment_modal = function(method) {
if (actions[method]) {
return actions[method].apply(this, Array.prototype.slice.call(arguments, 1));
} else if (typeof method==='object' || !method) {
return modal.init.apply(this, arguments);
} else {
$.error('jquery.payment_modal: Method ' + method + ' does not exist');
}
};
})(jQuery);
Спустя 3 часа, 6 минут, 16 секунд (8.08.2012 - 21:00) Игорь_Vasinsky написал(а):
блин.. так это много разбирать.
у JQ есть fadeOut() - поставь его вместо hide() или что там срабатывает при клику по "закрыть"
у JQ есть fadeOut() - поставь его вместо hide() или что там срабатывает при клику по "закрыть"
Спустя 11 часов, 40 минут, 10 секунд (9.08.2012 - 08:40) johniek_comp написал(а):
Игорь_Vasinsky
В хайд тоже можно указать скорость
В хайд тоже можно указать скорость
$("#id").hide("slow",500)
Спустя 34 минуты, 22 секунды (9.08.2012 - 09:15) Игорь_Vasinsky написал(а):
hide и fadeOut - совершенно разные эффекты
![wink.gif](http://phpforum.su/html/emoticons/wink.gif)