mediawiki-extensions-Visual.../modules/ve-mw/ui/contextitems/ve.ui.MWNumberedExternalLinkNodeContextItem.js

88 lines
2.8 KiB
JavaScript
Raw Permalink Normal View History

/*!
* 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 );