/*! * VisualEditor UserInterface MWExternalLinkAnnotationWidget class. * * @copyright See AUTHORS.txt * @license The MIT License (MIT); see LICENSE.txt */ /** * Creates an ve.ui.MWExternalLinkAnnotationWidget object. * * @class * @extends ve.ui.LinkAnnotationWidget * * @constructor * @param {Object} [config] Configuration options */ ve.ui.MWExternalLinkAnnotationWidget = function VeUiMWExternalLinkAnnotationWidget() { // Parent constructor ve.ui.MWExternalLinkAnnotationWidget.super.apply( this, arguments ); }; /* Inheritance */ OO.inheritClass( ve.ui.MWExternalLinkAnnotationWidget, ve.ui.LinkAnnotationWidget ); /* Static Methods */ /** * @inheritdoc */ ve.ui.MWExternalLinkAnnotationWidget.static.getAnnotationFromText = function ( value ) { const href = value.trim(); // Keep annotation in sync with value if ( href === '' ) { return null; } else { return new ve.dm.MWExternalLinkAnnotation( { type: 'link/mwExternal', attributes: { href: href } } ); } }; /** * Create an external link input widget. * * @param {Object} [config] Configuration options * @return {OO.ui.TextInputWidget} Text input widget */ ve.ui.MWExternalLinkAnnotationWidget.static.createExternalLinkInputWidget = function ( config ) { const inputWidget = new OO.ui.TextInputWidget( ve.extendObject( {}, config, { icon: 'linkExternal', type: 'url', validate: ( text ) => !!ve.init.platform.getExternalLinkUrlProtocolsRegExp().exec( text.trim() ) } ) ); inputWidget.$input.attr( 'aria-label', mw.msg( 'visualeditor-linkinspector-button-link-external' ) ); return inputWidget; }; /* Methods */ /** * Create a text input widget to be used by the annotation widget * * @param {Object} [config] Configuration options * @return {OO.ui.TextInputWidget} Text input widget */ ve.ui.MWExternalLinkAnnotationWidget.prototype.createInputWidget = function ( config ) { return this.constructor.static.createExternalLinkInputWidget( config ); };