Updated XHR binded events to work better in jQuery 1.4.1. Using

.live() for event delegation instead of jQuery.data() and checking to
see if an element was previously binded.
This commit is contained in:
Sarven Capadisli 2010-01-31 22:37:22 +00:00
parent 72037d6143
commit 9f36c10001
3 changed files with 38 additions and 46 deletions

View File

@ -143,38 +143,32 @@ var SN = { // StatusNet
SN.U.Counter(form); SN.U.Counter(form);
}, },
FormXHR: function(f) { FormXHR: function(form) {
if (jQuery.data(f[0], "ElementData") === undefined) { $.ajax({
jQuery.data(f[0], "ElementData", {Bind:'submit'}); type: 'POST',
f.bind('submit', function(e) { dataType: 'xml',
form_id = $(this)[0].id; url: form.attr('action'),
$.ajax({ data: form.serialize() + '&ajax=1',
type: 'POST', beforeSend: function(xhr) {
dataType: 'xml', form
url: $(this)[0].action, .addClass(SN.C.S.Processing)
data: $(this).serialize() + '&ajax=1', .find('.submit')
beforeSend: function(xhr) { .addClass(SN.C.S.Disabled)
$('#'+form_id).addClass(SN.C.S.Processing); .attr(SN.C.S.Disabled, SN.C.S.Disabled);
$('#'+form_id+' .submit').addClass(SN.C.S.Disabled); },
$('#'+form_id+' .submit').attr(SN.C.S.Disabled, SN.C.S.Disabled); error: function (xhr, textStatus, errorThrown) {
}, alert(errorThrown || textStatus);
error: function (xhr, textStatus, errorThrown) { },
alert(errorThrown || textStatus); success: function(data, textStatus) {
}, if (typeof($('form', data)[0]) != 'undefined') {
success: function(data, textStatus) { form_new = document._importNode($('form', data)[0], true);
if (typeof($('form', data)[0]) != 'undefined') { form.replaceWith(form_new);
form_new = document._importNode($('form', data)[0], true); }
$('#'+form_id).replaceWith(form_new); else {
$('#'+form_new.id).each(function() { SN.U.FormXHR($(this)); }); form.replaceWith(document._importNode($('p', data)[0], true));
} }
else { }
$('#'+form_id).replaceWith(document._importNode($('p', data)[0], true)); });
}
}
});
return false;
});
}
}, },
FormNoticeXHR: function(form) { FormNoticeXHR: function(form) {
@ -281,7 +275,6 @@ var SN = { // StatusNet
$('#'+notice.id).fadeIn(2500); $('#'+notice.id).fadeIn(2500);
SN.U.NoticeWithAttachment($('#'+notice.id)); SN.U.NoticeWithAttachment($('#'+notice.id));
SN.U.NoticeReplyTo($('#'+notice.id)); SN.U.NoticeReplyTo($('#'+notice.id));
SN.U.FormXHR($('#'+notice.id+' .form_favor'));
} }
} }
else { else {
@ -350,14 +343,15 @@ var SN = { // StatusNet
}, },
NoticeFavor: function() { NoticeFavor: function() {
$('.form_favor').each(function() { SN.U.FormXHR($(this)); }); $('.form_favor').live('click', function() { SN.U.FormXHR($(this)); return false; });
$('.form_disfavor').each(function() { SN.U.FormXHR($(this)); }); $('.form_disfavor').live('click', function() { SN.U.FormXHR($(this)); return false; });
}, },
NoticeRepeat: function() { NoticeRepeat: function() {
$('.form_repeat').each(function() { $('.form_repeat').live('click', function() {
SN.U.FormXHR($(this)); SN.U.FormXHR($(this));
SN.U.NoticeRepeatConfirmation($(this)); SN.U.NoticeRepeatConfirmation($(this));
return false;
}); });
}, },
@ -695,11 +689,11 @@ var SN = { // StatusNet
EntityActions: function() { EntityActions: function() {
if ($('body.user_in').length > 0) { if ($('body.user_in').length > 0) {
$('.form_user_subscribe').each(function() { SN.U.FormXHR($(this)); }); $('.form_user_subscribe').live('click', function() { SN.U.FormXHR($(this)); return false; });
$('.form_user_unsubscribe').each(function() { SN.U.FormXHR($(this)); }); $('.form_user_unsubscribe').live('click', function() { SN.U.FormXHR($(this)); return false; });
$('.form_group_join').each(function() { SN.U.FormXHR($(this)); }); $('.form_group_join').live('click', function() { SN.U.FormXHR($(this)); return false; });
$('.form_group_leave').each(function() { SN.U.FormXHR($(this)); }); $('.form_group_leave').live('click', function() { SN.U.FormXHR($(this)); return false; });
$('.form_user_nudge').each(function() { SN.U.FormXHR($(this)); }); $('.form_user_nudge').live('click', function() { SN.U.FormXHR($(this)); return false; });
SN.U.NewDirectMessage(); SN.U.NewDirectMessage();
} }

View File

@ -95,9 +95,7 @@ RealtimeUpdate = {
$("#notices_primary .notice:first").css({display:"none"}); $("#notices_primary .notice:first").css({display:"none"});
$("#notices_primary .notice:first").fadeIn(1000); $("#notices_primary .notice:first").fadeIn(1000);
SN.U.FormXHR($('#'+noticeItemID+' .form_favor'));
SN.U.NoticeReplyTo($('#'+noticeItemID)); SN.U.NoticeReplyTo($('#'+noticeItemID));
SN.U.FormXHR($('#'+noticeItemID+' .form_repeat'));
SN.U.NoticeWithAttachment($('#'+noticeItemID)); SN.U.NoticeWithAttachment($('#'+noticeItemID));
}, },
@ -132,7 +130,7 @@ RealtimeUpdate = {
user = data['user']; user = data['user'];
html = data['html'].replace(/&lt;/g,'<').replace(/&gt;/g,'>').replace(/&quot;/g,'"').replace(/&amp;/g,'&'); html = data['html'].replace(/&lt;/g,'<').replace(/&gt;/g,'>').replace(/&quot;/g,'"').replace(/&amp;/g,'&');
source = data['source'].replace(/&lt;/g,'<').replace(/&gt;/g,'>').replace(/&quot;/g,'"').replace(/&amp;/g,'&'); source = data['source'].replace(/&lt;/g,'<').replace(/&gt;/g,'>').replace(/&quot;/g,'"').replace(/&amp;/g,'&');
console.log(data);
ni = "<li class=\"hentry notice\" id=\"notice-"+unique+"\">"+ ni = "<li class=\"hentry notice\" id=\"notice-"+unique+"\">"+
"<div class=\"entry-title\">"+ "<div class=\"entry-title\">"+
"<span class=\"vcard author\">"+ "<span class=\"vcard author\">"+

View File

@ -208,8 +208,8 @@ class UserFlagPlugin extends Plugin
function onEndShowScripts($action) function onEndShowScripts($action)
{ {
$action->inlineScript('if ($(".form_entity_flag").length > 0) { '. $action->inlineScript('if ($(".form_entity_flag").length > 0) { '.
'SN.U.FormXHR($(".form_entity_flag")); '. '$(".form_entity_flag").bind("click", function() {'.
'}'); 'SN.U.FormXHR($(this)); return false; }); }');
return true; return true;
} }