mediawiki-extensions-Visual.../modules/ve/dm/annotations/ve.dm.MWInternalLinkAnnotation.js
Trevor Parscal 42de94fc44 (bug 42298) Handle URL encoding in MWInternalLinkAnnotation
* Decode titles we get from Parsoid
* Encode titles we give to Parsoid
* Preserve the original encoded title if nothing meaningful changed (a.k.a. do not normalize unless we must)

Change-Id: If5d22e88904d6b2c438caac403ac2d78d440b017
2012-12-07 12:34:17 -08:00

87 lines
2.5 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
*/
/**
* MediaWiki internal link annotation.
*
* Example HTML sources:
* <a rel="mw:WikiLink">
*
* @class
* @constructor
* @extends {ve.dm.LinkAnnotation}
* @param {HTMLElement} element
*/
ve.dm.MWInternalLinkAnnotation = function VeDmMWInternalLinkAnnotation( element ) {
// Parent constructor
ve.dm.LinkAnnotation.call( this, element );
};
/* Inheritance */
ve.inheritClass( ve.dm.MWInternalLinkAnnotation, ve.dm.LinkAnnotation );
/* Static Members */
ve.dm.MWInternalLinkAnnotation.static.name = 'link/MWinternal';
ve.dm.MWInternalLinkAnnotation.static.matchRdfaTypes = ['mw:WikiLink'];
/* Methods */
/**
* Get annotation data, especially the href of the link.
*
* @method
* @param {HTMLElement} element
* @returns {Object} Annotation data, containing 'hrefPrefix' and 'title' properties
*/
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
/*jshint regexp:false */
var matches = element.getAttribute( 'href' ).match( /^((?:\.\.?\/)*)(.*)$/ );
return {
// Store the ./ and ../ prefixes so we can restore them on the way out
'hrefPrefix': matches[1],
'title': decodeURIComponent( matches[2] ).replace( /_/g, ' ' ),
'origTitle': matches[2]
};
};
/**
* Convert to an object with HTML element information.
*
* @method
* @returns {Object} HTML element information, including tag and attributes properties
*/
ve.dm.MWInternalLinkAnnotation.prototype.toHTML = function () {
var href,
parentResult = ve.dm.LinkAnnotation.prototype.toHTML.call( this );
if (
this.data.origTitle &&
decodeURIComponent( this.data.origTitle ).replace( /_/g, ' ' ) === this.data.title
) {
// Restore href from origTitle
href = this.data.origTitle;
// Only use hrefPrefix if restoring from origTitle
if ( this.data.hrefPrefix ) {
href = this.data.hrefPrefix + href;
}
} else {
href = encodeURIComponent( this.data.title );
}
parentResult.attributes.href = href;
parentResult.attributes.rel = 'mw:WikiLink';
return parentResult;
};
/* Registration */
ve.dm.annotationFactory.register( 'link/MWinternal', ve.dm.MWInternalLinkAnnotation );