/*! * VisualEditor UserInterface MWLinkAction class. * * @copyright 2011-2015 VisualEditor Team and others; see http://ve.mit-license.org */ /** * Link action. * * Opens either MWLinkAnnotationInspector or MWLinkNodeInspector depending on what is selected. * * @class * @extends ve.ui.LinkAction * @constructor * @param {ve.ui.Surface} surface Surface to act on */ ve.ui.MWLinkAction = function VeUiMWLinkAction( surface ) { // Parent constructor ve.ui.MWLinkAction.super.call( this, surface ); }; /* Inheritance */ OO.inheritClass( ve.ui.MWLinkAction, ve.ui.LinkAction ); /* Static Properties */ /** * List of allowed methods for the action. * * @static * @property */ ve.ui.MWLinkAction.static.methods = ve.ui.MWLinkAction.super.static.methods.concat( [ 'open' ] ); /* Methods */ /** * Match the trailing punctuation set used for autolinks in wikitext. * Closing parens are only stripped if open parens are missing from the * candidate text, so that URLs with embedded matched parentheses (like * wiki articles with disambiguation text) autolink nicely. * * @method * @inheritdoc */ ve.ui.MWLinkAction.prototype.getTrailingPunctuation = function ( candidate ) { return /\(/.test( candidate ) ? /[,;.:!?]+$/ : /[,;.:!?)]+$/; }; /** * @method * @inheritdoc * @return {ve.dm.MWExternalLinkAnnotation} The annotation to use. */ ve.ui.MWLinkAction.prototype.getLinkAnnotation = function ( href ) { return new ve.dm.MWExternalLinkAnnotation( { type: 'link/mwExternal', attributes: { href: href } } ); }; /** * Open either the 'link' or 'linkNode' window, depending on what is selected. * * @method * @return {boolean} Action was executed */ ve.ui.MWLinkAction.prototype.open = function () { var fragment = this.surface.getModel().getFragment(), windowName = 'link'; if ( fragment.getSelectedNode() instanceof ve.dm.MWNumberedExternalLinkNode ) { windowName = 'linkNode'; } this.surface.execute( 'window', 'open', windowName ); return true; }; /* Registration */ ve.ui.actionFactory.register( ve.ui.MWLinkAction );