mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/ConfirmEdit
synced 2024-12-24 13:52:55 +00:00
e7fc8fd290
The message 'fancycaptcha-imgcaptcha-ph' ("Enter the text you see on the image") should only be used as placeholder for FancyCaptcha. This affected editors using CaptchaInputWidget in JS, such as VisualEditor and DiscussionTools. Change-Id: Ica53b2f3149e9039c95e733e0e89ba62356844e4
108 lines
3.1 KiB
JavaScript
108 lines
3.1 KiB
JavaScript
mw.libs.confirmEdit = {};
|
|
|
|
/**
|
|
* @class
|
|
* @extends OO.ui.TextInputWidget
|
|
*
|
|
* @constructor
|
|
* @param {Object} [captchaData] Value of 'captcha' property returned from action=edit API
|
|
* @param {Object} [config] Configuration options
|
|
*/
|
|
mw.libs.confirmEdit.CaptchaInputWidget = function MwWidgetsCaptchaInputWidget( captchaData, config ) {
|
|
config = config || {};
|
|
|
|
// Parent constructor
|
|
mw.libs.confirmEdit.CaptchaInputWidget.parent.call( this, config );
|
|
|
|
// Properties
|
|
this.$captchaImg = null;
|
|
this.captchaId = null;
|
|
|
|
// Initialization
|
|
this.$element.addClass( 'mw-confirmEdit-captchaInputWidget' );
|
|
this.$element.prepend( this.makeCaptchaInterface( captchaData ) );
|
|
};
|
|
|
|
/* Setup */
|
|
|
|
OO.inheritClass( mw.libs.confirmEdit.CaptchaInputWidget, OO.ui.TextInputWidget );
|
|
|
|
/* Events */
|
|
|
|
/**
|
|
* @event load
|
|
*
|
|
* A load event is emitted when the CAPTCHA image loads.
|
|
*/
|
|
|
|
/* Methods */
|
|
|
|
mw.libs.confirmEdit.CaptchaInputWidget.prototype.makeCaptchaInterface = function ( captchaData ) {
|
|
var $captchaImg, msg, question,
|
|
$captchaDiv, $captchaParagraph;
|
|
|
|
$captchaParagraph = $( '<div>' ).append(
|
|
$( '<strong>' ).text( mw.msg( 'captcha-label' ) ),
|
|
document.createTextNode( mw.msg( 'colon-separator' ) )
|
|
);
|
|
$captchaDiv = $( '<div>' ).append( $captchaParagraph );
|
|
|
|
if ( captchaData.url ) {
|
|
// FancyCaptcha
|
|
// Based on FancyCaptcha::getFormInformation() and ext.confirmEdit.fancyCaptcha.js
|
|
this.$input.attr( 'placeholder', mw.msg( 'fancycaptcha-imgcaptcha-ph' ) );
|
|
mw.loader.load( 'ext.confirmEdit.fancyCaptcha' );
|
|
$captchaDiv.addClass( 'fancycaptcha-captcha-container' );
|
|
$captchaParagraph.append( mw.message( 'fancycaptcha-edit' ).parseDom() );
|
|
$captchaImg = $( '<img>' )
|
|
.attr( 'src', captchaData.url )
|
|
.data( 'captchaId', captchaData.id )
|
|
.addClass( 'fancycaptcha-image' )
|
|
.on( 'load', this.emit.bind( this, 'load' ) );
|
|
$captchaDiv.append(
|
|
$captchaImg,
|
|
' ',
|
|
$( '<a>' ).addClass( 'fancycaptcha-reload' ).text( mw.msg( 'fancycaptcha-reload-text' ) )
|
|
);
|
|
} else {
|
|
if ( captchaData.type === 'simple' || captchaData.type === 'math' ) {
|
|
// SimpleCaptcha and MathCaptcha
|
|
msg = 'captcha-edit';
|
|
} else if ( captchaData.type === 'question' ) {
|
|
// QuestyCaptcha
|
|
msg = 'questycaptcha-edit';
|
|
}
|
|
|
|
if ( msg ) {
|
|
switch ( captchaData.mime ) {
|
|
case 'text/html':
|
|
question = $.parseHTML( captchaData.question );
|
|
break;
|
|
case 'text/plain':
|
|
question = document.createTextNode( captchaData.question );
|
|
break;
|
|
}
|
|
// Messages documented above
|
|
// eslint-disable-next-line mediawiki/msg-doc
|
|
$captchaParagraph.append( mw.message( msg ).parseDom(), '<br>', question );
|
|
}
|
|
}
|
|
|
|
if ( $captchaImg ) {
|
|
this.$captchaImg = $captchaImg;
|
|
} else {
|
|
this.captchaId = captchaData.id;
|
|
}
|
|
|
|
return $captchaDiv;
|
|
};
|
|
|
|
mw.libs.confirmEdit.CaptchaInputWidget.prototype.getCaptchaId = function () {
|
|
// 'ext.confirmEdit.fancyCaptcha' can update this value if the "Refresh" button is used
|
|
return this.$captchaImg ? this.$captchaImg.data( 'captchaId' ) : this.captchaId;
|
|
};
|
|
|
|
mw.libs.confirmEdit.CaptchaInputWidget.prototype.getCaptchaWord = function () {
|
|
return this.getValue();
|
|
};
|