X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=include%2Fmain.js;h=5b9dae46104839524c60713a8e2fd90bdee8043e;hb=655f5c7b9fe138de5566047e79ada034647fd6f2;hp=8779f84134325cc568bc612fad3085183e487f2f;hpb=85f709320b588f3231875d097217bd9abd223c9f;p=friendica.git diff --git a/include/main.js b/include/main.js index 8779f84134..5b9dae4610 100644 --- a/include/main.js +++ b/include/main.js @@ -27,11 +27,35 @@ var liking = 0; var in_progress = false; var langSelect = false; + var commentBusy = false; - $(document).ready(function() { + $(function() { $.ajaxSetup({cache: false}); msie = $.browser.msie ; + + + /* nav update event */ + $('nav').bind('nav-update', function(e,data){; + var net = $(data).find('net').text(); + if(net == 0) { net = ''; $('#net-update').hide() } else { $('#net-update').show() } + $('#net-update').html(net); + var home = $(data).find('home').text(); + if(home == 0) { home = ''; $('#home-update').hide() } else { $('#home-update').show() } + $('#home-update').html(home); + var mail = $(data).find('mail').text(); + if(mail == 0) { mail = ''; $('#mail-update').hide() } else { $('#mail-update').show() } + $('#mail-update').html(mail); + var intro = $(data).find('intro').text(); + var register = $(data).find('register').text(); + if(intro == 0) { intro = ''; } + if(register != 0 && intro != '') { intro = intro+'/'+register; } + if(register != 0 && intro == '') { intro = '0/'+register; } + if (intro == '') { $('#notify-update').hide() } else { $('#notify-update').show() } + $('#notify-update').html(intro); + }); + + NavUpdate(); // Allow folks to stop the ajax page updates with the pause/break key $(document).keypress(function(event) { @@ -46,26 +70,6 @@ $('#pause').html(''); } } - // F8 - show/hide language selector - if(event.keyCode == '119') { - if(langSelect) { - langSelect = false; - $('#language-selector').hide(); - } - else { - langSelect = true; - $('#language-selector').show(); - } - } - -// this is shift-home on FF, but $ on IE, disabling until I figure out why the diff. -// update: incompatible usage of onKeyDown vs onKeyPress -// if(event.keyCode == '36' && event.shiftKey == true) { -// if(homebase !== undefined) { -// event.preventDefault(); -// document.location = homebase; -// } -// } }); }); @@ -89,27 +93,12 @@ if(! stopped) { $.get("ping",function(data) { $(data).find('result').each(function() { - var net = $(this).find('net').text(); - if(net == 0) { net = ''; } - $('#net-update').html(net); - var home = $(this).find('home').text(); - if(home == 0) { home = ''; } - $('#home-update').html(home); - var mail = $(this).find('mail').text(); - if(mail == 0) { mail = ''; } - $('#mail-update').html(mail); - var intro = $(this).find('intro').text(); - var register = $(this).find('register').text(); - if(intro == 0) { intro = ''; } - if(register != 0 && intro != '') { intro = intro+'/'+register; } - if(register != 0 && intro == '') { intro = '0/'+register; } - $('#notify-update').html(intro); - + // send nav-update event + $('nav').trigger('nav-update', this); }); }) ; } timer = setTimeout(NavUpdate,30000); - } function liveUpdate() { @@ -128,13 +117,16 @@ in_progress = false; $('.ccollapse-wrapper',data).each(function() { var ident = $(this).attr('id'); + var is_hidden = $('#' + ident).is(':hidden'); if($('#' + ident).length) { $('#' + ident).replaceWith($(this)); + if(is_hidden) + $('#' + ident).hide(); } }); $('.wall-item-outside-wrapper',data).each(function() { var ident = $(this).attr('id'); - if($('#' + ident).length == 0) { + if($('#' + ident).length == 0) { $('img',this).each(function() { $(this).attr('src',$(this).attr('dst')); }); @@ -153,20 +145,19 @@ prev = ident; }); $('.like-rotator').hide(); + if(commentBusy) { + commentBusy = false; + $('body').css('cursor', 'auto'); + } }); - } function imgbright(node) { - $(node).attr("src",$(node).attr("src").replace('hide','show')); - $(node).css('width',24); - $(node).css('height',24); + $(node).removeClass("drophide").addClass("drop"); } function imgdull(node) { - $(node).attr("src",$(node).attr("src").replace('show','hide')); - $(node).css('width',16); - $(node).css('height',16); + $(node).removeClass("drop").addClass("drophide"); } // Since our ajax calls are asynchronous, we will give a few @@ -232,6 +223,8 @@ } function post_comment(id) { + commentBusy = true; + $('body').css('cursor', 'wait'); $.post( "item", $("#comment-edit-form-" + id).serialize(), @@ -248,7 +241,6 @@ if(data.reload) { window.location.href=data.reload; } - }, "json" ); @@ -277,4 +269,44 @@ } return a.join(''); - } \ No newline at end of file + } + + function groupChangeMember(gid,cid) { + $('body .fakelink').css('cursor', 'wait'); + $.get('group/' + gid + '/' + cid, function(data) { + $('#group-update-wrapper').html(data); + $('body .fakelink').css('cursor', 'auto'); + }); + } + + function profChangeMember(gid,cid) { + $('body .fakelink').css('cursor', 'wait'); + $.get('profperm/' + gid + '/' + cid, function(data) { + $('#prof-update-wrapper').html(data); + $('body .fakelink').css('cursor', 'auto'); + }); + } + +function checkboxhighlight(box) { + if($(box).is(':checked')) { + $(box).addClass('checkeditem'); + } + else { + $(box).removeClass('checkeditem'); + } +} + + + +/** + * sprintf in javascript + * "{0} and {1}".format('zero','uno'); + **/ +String.prototype.format = function() { + var formatted = this; + for (var i = 0; i < arguments.length; i++) { + var regexp = new RegExp('\\{'+i+'\\}', 'gi'); + formatted = formatted.replace(regexp, arguments[i]); + } + return formatted; +};