2 * Animate patrol links to use asynchronous API requests to
3 * patrol pages, rather than navigating to a different URI.
6 * @author Marius Hoch <hoo@online.de>
9 if ( !mw.user.tokens.exists( 'patrolToken' ) ) {
10 // Current user has no patrol right, or an old cached version of user.tokens
11 // that didn't have patrolToken yet.
15 var $patrolLinks = $( '.patrollink[data-mw="interface"] a' );
16 $patrolLinks.on( 'click', function ( e ) {
17 var $spinner, rcid, apiRequest;
19 // Preload the notification module for mw.notify
20 mw.loader.load( 'mediawiki.notification' );
22 // Hide the link and create a spinner to show it inside the brackets.
23 $spinner = $.createSpinner( {
27 $( this ).hide().after( $spinner );
29 rcid = mw.util.getParamValue( 'rcid', this.href );
30 apiRequest = new mw.Api();
32 apiRequest.postWithToken( 'patrol', {
36 } ).done( function ( data ) {
38 // Remove all patrollinks from the page (including any spinners inside).
39 $patrolLinks.closest( '.patrollink' ).remove();
40 if ( data.patrol !== undefined ) {
42 title = new mw.Title( data.patrol.title );
43 mw.notify( mw.msg( 'markedaspatrollednotify', title.toText() ) );
45 // This should never happen as errors should trigger fail
46 mw.notify( mw.msg( 'markedaspatrollederrornotify' ), { type: 'error' } );
48 } ).fail( function ( error ) {
50 // Restore the patrol link. This allows the user to try again
51 // (or open it in a new window, bypassing this ajax module).
53 if ( error === 'noautopatrol' ) {
55 mw.notify( mw.msg( 'markedaspatrollederror-noautopatrol' ), { type: 'warn' } );
57 mw.notify( mw.msg( 'markedaspatrollederrornotify' ), { type: 'error' } );
64 }( mediaWiki, jQuery ) );