mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2025-01-05 17:54:14 +00:00
dbc696124f
Temporarily disable prefer-const as this requires manual fixing. Change-Id: I477b69a57e8d33535c6fc71dba196a8605780725
88 lines
2.8 KiB
JavaScript
88 lines
2.8 KiB
JavaScript
/*!
|
|
* VisualEditor MWNumberedExternalLinkNodeContextItem class.
|
|
*
|
|
* @copyright See AUTHORS.txt
|
|
*/
|
|
|
|
/**
|
|
* Context item for a MWNumberedExternalLinkNode.
|
|
*
|
|
* @class
|
|
* @extends ve.ui.LinkContextItem
|
|
*
|
|
* @constructor
|
|
* @param {ve.ui.LinearContext} context Context the item is in
|
|
* @param {ve.dm.Model} model Model the item is related to
|
|
* @param {Object} [config]
|
|
*/
|
|
ve.ui.MWNumberedExternalLinkNodeContextItem = function VeUiMWNumberedExternalLinkNodeContextItem() {
|
|
// Parent constructor
|
|
ve.ui.MWNumberedExternalLinkNodeContextItem.super.apply( this, arguments );
|
|
|
|
// Initialization
|
|
this.$element.addClass( 've-ui-mwNumberedExternalLinkNodeContextItem' );
|
|
|
|
if ( this.context.isMobile() ) {
|
|
// Label editing button doesn't exist on mobile by default
|
|
this.labelButton = new OO.ui.ButtonWidget( {
|
|
label: OO.ui.deferMsg( 'visualeditor-linknodeinspector-add-label' ),
|
|
framed: false,
|
|
flags: [ 'progressive' ]
|
|
} );
|
|
this.labelButton.connect( this, { click: 'onLabelButtonClick' } );
|
|
this.$labelLayout.empty().append( this.labelButton.$element );
|
|
} else {
|
|
this.labelButton.setLabel( OO.ui.deferMsg( 'visualeditor-linknodeinspector-add-label' ) );
|
|
}
|
|
};
|
|
|
|
/* Inheritance */
|
|
|
|
OO.inheritClass( ve.ui.MWNumberedExternalLinkNodeContextItem, ve.ui.LinkContextItem );
|
|
|
|
/* Static Properties */
|
|
|
|
ve.ui.MWNumberedExternalLinkNodeContextItem.static.name = 'link/mwNumberedExternal';
|
|
|
|
ve.ui.MWNumberedExternalLinkNodeContextItem.static.modelClasses = [ ve.dm.MWNumberedExternalLinkNode ];
|
|
|
|
ve.ui.MWNumberedExternalLinkNodeContextItem.static.clearable = false;
|
|
|
|
/* Methods */
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
ve.ui.MWNumberedExternalLinkNodeContextItem.prototype.onLabelButtonClick = function () {
|
|
const surfaceModel = this.context.getSurface().getModel(),
|
|
surfaceView = this.context.getSurface().getView(),
|
|
doc = surfaceModel.getDocument(),
|
|
nodeRange = this.model.getOuterRange();
|
|
|
|
// TODO: this is very similar to part of
|
|
// ve.ui.MWLinkNodeInspector.prototype.getTeardownProcess, and should
|
|
// perhaps be consolidated into a reusable "replace node with annotated
|
|
// text and select that text" method somewhere appropriate.
|
|
|
|
const annotation = new ve.dm.MWExternalLinkAnnotation( {
|
|
type: 'link/mwExternal',
|
|
attributes: {
|
|
href: this.model.getHref()
|
|
}
|
|
} );
|
|
const annotations = doc.data.getAnnotationsFromOffset( nodeRange.start ).clone();
|
|
annotations.push( annotation );
|
|
const content = this.model.getHref().split( '' );
|
|
ve.dm.Document.static.addAnnotationsToData( content, annotations );
|
|
surfaceModel.change(
|
|
ve.dm.TransactionBuilder.static.newFromReplacement( doc, nodeRange, content )
|
|
);
|
|
setTimeout( () => {
|
|
surfaceView.selectAnnotation( ( view ) => view.model instanceof ve.dm.MWExternalLinkAnnotation );
|
|
} );
|
|
};
|
|
|
|
/* Registration */
|
|
|
|
ve.ui.contextItemFactory.register( ve.ui.MWNumberedExternalLinkNodeContextItem );
|