mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2025-01-07 10:44:24 +00:00
e62327efe0
'selection' is only used by AddReferenceEditCheck but this can be done in the act method. Provide a method for getting highlight selections from these 'affected fragments' that can be overridden. Change-Id: Ida661682efd8ae99d945f0e310ea3ce12efc8770
36 lines
1.2 KiB
JavaScript
36 lines
1.2 KiB
JavaScript
mw.editcheck.TextMatchEditCheck = function MWTextMatchEditCheck( /* config */ ) {
|
|
// Parent constructor
|
|
mw.editcheck.TextMatchEditCheck.super.apply( this, arguments );
|
|
};
|
|
|
|
OO.inheritClass( mw.editcheck.TextMatchEditCheck, mw.editcheck.BaseEditCheck );
|
|
|
|
mw.editcheck.TextMatchEditCheck.static.name = 'textMatch';
|
|
|
|
mw.editcheck.TextMatchEditCheck.static.replacers = [
|
|
// TODO: Load text replacement rules from community config
|
|
{
|
|
query: 'unfortunately',
|
|
message: new OO.ui.HtmlSnippet( 'Use of adverbs such as "unfortunately" should usually be avoided so as to maintain an impartial tone. <a href="#">Read more</a>.' )
|
|
}
|
|
];
|
|
|
|
mw.editcheck.TextMatchEditCheck.prototype.onDocumentChange = function ( surfaceModel ) {
|
|
const actions = [];
|
|
this.constructor.static.replacers.forEach( ( replacer ) => {
|
|
surfaceModel.getDocument().findText( replacer.query ).forEach( ( range ) => {
|
|
const fragment = surfaceModel.getLinearFragment( range );
|
|
actions.push(
|
|
new mw.editcheck.EditCheckAction( {
|
|
fragments: [ fragment ],
|
|
message: replacer.message,
|
|
check: this
|
|
} )
|
|
);
|
|
} );
|
|
} );
|
|
return actions;
|
|
};
|
|
|
|
mw.editcheck.editCheckFactory.register( mw.editcheck.TextMatchEditCheck );
|