/*! * VisualEditor DataModel AlienNode, AlienBlockNode and AlienInlineNode classes. * * @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt * @license The MIT License (MIT); see LICENSE.txt */ /** * DataModel alien node. * * @class * @abstract * @extends ve.dm.LeafNode * @constructor * @param {string} name Node name * @param {number} [length] Length of content data in document; ignored and overridden to 0 * @param {Object} [element] Reference to element in linear model */ ve.dm.AlienNode = function VeDmAlienNode( name, length, element ) { // Parent constructor ve.dm.LeafNode.call( this, name, 0, element ); }; /* Inheritance */ ve.inheritClass( ve.dm.AlienNode, ve.dm.LeafNode ); /* Static members */ ve.dm.AlienNode.static.name = 'alien'; ve.dm.AlienNode.static.matchTagNames = []; ve.dm.AlienNode.static.enableAboutGrouping = true; ve.dm.AlienNode.static.storeHtmlAttributes = false; ve.dm.AlienNode.static.toDataElement = function ( domElements, context ) { var i, isInline, allTagsInline, type, html; // Check whether all elements are inline elements allTagsInline = true; for ( i = 0; i < domElements.length; i++ ) { if ( ve.isBlockElement( domElements[i] ) ) { allTagsInline = false; break; } } // We generate alienBlock elements for block tags and alienInline elements for // inline tags; unless we're in a content location, in which case we have no choice // but to generate an alienInline element. isInline = // Force inline in content locations (but not wrappers) ( context.expectingContent && !context.inWrapper ) || // Also force inline in wrappers that we can't close ( context.inWrapper && !context.canCloseWrapper ) || // Look at the tag names otherwise allTagsInline; type = isInline ? 'alienInline' : 'alienBlock'; html = $( '