mediawiki-extensions-Visual.../editcheck/modules/TextMatchEditCheck.js
Ed Sanders 4cd67004de editcheck: Remove mw.editcheck.Diff
This object just contained a pointer to the surface and dm,
and had one utility method.

Move the method to mw.editcheck, and pass around a surface model
or document model to other methods as appropriate.

Change-Id: Ie81d76dea2823b633328f982ee20027808bfc8e3
2024-10-17 17:10:02 +01:00

37 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.getFragment( new ve.dm.LinearSelection( range ) );
actions.push(
new mw.editcheck.EditCheckAction( {
highlight: fragment,
selection: fragment,
message: replacer.message,
check: this
} )
);
} );
} );
return actions;
};
mw.editcheck.editCheckFactory.register( mw.editcheck.TextMatchEditCheck );