mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/ConfirmEdit
synced 2024-12-20 20:02:43 +00:00
9f2e976f10
In an attempt to be able to have easier code coverage... Bug: T377750 Change-Id: I556f5f2753fae77df4f34b64bccdb7d68f2825b0
36 lines
1.3 KiB
JavaScript
36 lines
1.3 KiB
JavaScript
/* eslint-disable no-jquery/no-global-selector */
|
|
$( document ).on( 'click', '.fancycaptcha-reload', function () {
|
|
const $this = $( this ),
|
|
$root = $this.closest( '.fancycaptcha-captcha-container' ),
|
|
$captchaImage = $root.find( '.fancycaptcha-image' );
|
|
|
|
$this.addClass( 'fancycaptcha-reload-loading' );
|
|
|
|
// AJAX request to get captcha index key
|
|
new mw.Api().post( { action: 'fancycaptchareload' } ).done( ( data ) => {
|
|
const captchaIndex = data.fancycaptchareload.index;
|
|
let imgSrc;
|
|
if ( typeof captchaIndex === 'string' ) {
|
|
// replace index key with a new one for captcha image
|
|
imgSrc = $captchaImage.attr( 'src' ).replace( /(wpCaptchaId=)\w+/, '$1' + captchaIndex );
|
|
$captchaImage.attr( 'src', imgSrc );
|
|
|
|
// replace index key with a new one for hidden tag
|
|
$( '#mw-input-captchaId' ).val( captchaIndex );
|
|
$( '#mw-input-captchaWord' ).val( '' ).trigger( 'focus' );
|
|
|
|
// now do the same with a selector that works for pre-1.27 login forms
|
|
$root.find( '[name="wpCaptchaId"]' ).val( captchaIndex );
|
|
$root.find( '[name="wpCaptchaWord"]' ).val( '' ).trigger( 'focus' );
|
|
|
|
// and make it accessible for other tools, e.g. VisualEditor
|
|
$captchaImage.data( 'captchaId', captchaIndex );
|
|
}
|
|
} )
|
|
.always( () => {
|
|
$this.removeClass( 'fancycaptcha-reload-loading' );
|
|
} );
|
|
|
|
return false;
|
|
} );
|