( function($,mw) { $( function() { mw.echo.overlay = { 'updateCount' : function(newCount) { var newText; if ( newCount > 0 ) { newText = mw.msg('echo-link-new', newCount); } else { newText = mw.msg('echo-link-none'); } $('#pt-notifications a').text(newText); mw.echo.overlay.notification_count = newCount; console.log('Updated new notification count to '+newCount); }, 'configuration' : wgEchoOverlayConfiguration }; mw.echo.overlay.notification_count = mw.echo.overlay.configuration['notification-count']; var $link = $('#pt-notifications'); if ( ! $link.length ) { return; } function buildOverlay(callback) { var $overlay = $('
') .addClass('mw-echo-overlay'); $overlay.append( $('
') .addClass('mw-echo-overlay-title') .text(mw.msg('echo-overlay-title')) ); var Api = new mw.Api(); Api.get( { 'action' : 'query', 'meta' : 'notifications', 'notformat' : 'html', 'notprop' : 'index|list' }, { 'ok' : function(result) { var notifications = result.query.notifications; var $ul = $('').appendTo($overlay); $.each( notifications.index, function(index, id) { data = notifications[id]; var $li = $('
  • ') .data('details', data) .data('id', id) .addClass('mw-echo-notification') .append(data['*']) .append( $('
    ') .text(data.timestamp.pretty) .addClass('mw-echo-timestamp') ) .appendTo($ul); if (! data.read ) { $li.addClass('mw-echo-unread'); } }); if ( ! $ul.find('li').length ) { $ul.remove(); $overlay.append( $('
    ') .text(mw.msg('echo-none')) ); } $overlay.append( $('
    ') .addClass('mw-echo-overlay-link') .append($('') .attr('href', $('#pt-notifications a').attr('href')) .text( mw.msg('echo-overlay-link') ) ) ); callback($overlay); Api.get({ 'action' : 'query', 'meta' : 'notifications', 'notmarkread' : notifications.index.join('|'), 'notprop' : 'count' }, { 'ok' : function(result) { var count = result.query.notifications.count; mw.echo.overlay.updateCount(count); } }); }, 'err' : function() { window.location.href = $('#pt-notifications a').attr('href'); } } ); } $link.click( function(e) { e.preventDefault(); if ($(e.target).is('.mw-echo-overlay,.mw-echo-overlay *') ) { return; } var $overlay = $('.mw-echo-overlay'); if ( $overlay.length ) { $overlay.fadeOut( 'fast', function() { $overlay.remove(); } ); return; } $overlay = buildOverlay( function($overlay) { $overlay .hide() .appendTo($('body')) .slideDown('fast'); } ); } ); $('body').click( function(e) { if ( ! $(e.target).is('.mw-echo-overlay,.mw-echo-overlay *') ) { $('.mw-echo-overlay').fadeOut( 'fast', function() { $(this).remove(); } ); } }); }); })( jQuery, mediaWiki );