mediawiki-extensions-Visual.../modules/ve/dm/annotations/ve.dm.MWInternalLinkAnnotation.js
Catrope 613dd14332 New annotation API: convert existing annotations
This changes ve.dm.LinkAnnotation to be a generic annotation for <a>
tags, and adds ve.dm.MWInternalLinkAnnotation and
ve.dm.MWExternalLinkAnnotation as MW-specific subclasses. This nicely
splits out the MW-specific parts in LinkAnnotation, and ideally we'd
also move these files somewhere else to reflect their MW-specificity,
but I haven't gotten to that yet.

Similarly, ve.dm.TextStyleAnnotation is now a generic base class for
simple tag-only-no-metadata annotations, and it has 11 subclasses, one
for each tag we support. This is quite a bit more verbose than the
previous code, but I think it's cleaner and more flexible. I considered
writing a function that would generate a TextStyleAnnotation subclass,
then calling that 11 times, but that's not possible if we want to keep
named functions for the constructors.

Change-Id: Ifba10153eef40280e44025dd72d4e9d9f33b0632
2012-10-12 15:07:25 -07:00

47 lines
1.6 KiB
JavaScript

/**
* VisualEditor data model MWInternalLinkAnnotation class.
*
* @copyright 2011-2012 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
/**
* Annotation representing an internal link in MediaWiki, i.e. <a rel="mw:WikiLink">
*/
ve.dm.MWInternalLinkAnnotation = function VeDmMWInternalLinkAnnotation( element ) {
ve.dm.LinkAnnotation.call( this, element );
};
ve.inheritClass( ve.dm.MWInternalLinkAnnotation, ve.dm.LinkAnnotation );
ve.dm.MWInternalLinkAnnotation.static.name = 'link/MWinternal';
ve.dm.MWInternalLinkAnnotation.static.matchRdfaTypes = ['mw:WikiLink'];
ve.dm.MWInternalLinkAnnotation.prototype.getAnnotationData = function( element ) {
// Get title from href
// The href is simply the title, unless we're dealing with a page that
// has slashes in its name in which case it's preceded by one or more
// instances of "./" or "../", so strip those.
var matches = element.getAttribute( 'href' ).match( /^((?:\.\.?\/)*)(.*)$/ );
return {
// Store the ./ and ../ prefixes so we can restore them on the way out
'hrefPrefix': matches[1],
'title': matches[2].replace( /_/g, ' ' )
};
};
ve.dm.MWInternalLinkAnnotation.prototype.toHTML = function () {
var href,
parentResult = ve.dm.LinkAnnotation.prototype.toHTML.call( this );
// Set href to title
href = this.data.title.replace( / /g, '_' );
if ( this.data.hrefPrefix ) {
href = this.data.hrefPrefix + href;
}
parentResult.attributes.href = href;
parentResult.attributes.rel = 'mw:WikiLink';
return parentResult;
};
ve.dm.annotationFactory.register( 'link/MWinternal', ve.dm.MWInternalLinkAnnotation );