mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-12-01 17:36:35 +00:00
2e36f1542b
This changes the node API to work with multiple elements, so we can support about groups. Instead of passing in and returning single DOM elements, we use arrays of DOM elements. ve.dm.Converter: * Pass modelRegistry into the constructor * Remove onNodeRegister handler and its data * Remove getDataElementFromDomElement() and getDataAnnotationFromDomElement(). Most logic moved into getDataFromDom(), some into createDataElement() * Remove createAlien(), replaced with createDataElement( ve.dm.AlienNode, ... ) * Replace doAboutGrouping() (which wrapped about groups) with getAboutGroup() (which returns an array of the nodes in the group) * Put in a hack so <meta>/<link> elements with an mw: property aren't alienated * Remove about group wrapping behavior in favor of just outputting multiple nodes ve.dm.AlienNode.js: * For multi-element aliens, only choose inline if all elements are inline, not just the first one ve.dm.example.js: * Add html/0 stuff for meta nodes * Fix test case to reflect new alien behavior Change-Id: I40dcc27430f778bc00a44b91b7d824bfb2718be6
59 lines
1.4 KiB
JavaScript
59 lines
1.4 KiB
JavaScript
/*!
|
|
* VisualEditor DataModel HeadingNode class.
|
|
*
|
|
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
|
|
* @license The MIT License (MIT); see LICENSE.txt
|
|
*/
|
|
|
|
/**
|
|
* DataModel heading node.
|
|
*
|
|
* @class
|
|
* @extends ve.dm.BranchNode
|
|
* @constructor
|
|
* @param {ve.dm.LeafNode[]} [children] Child nodes to attach
|
|
* @param {Object} [element] Reference to element in linear model
|
|
*/
|
|
ve.dm.HeadingNode = function VeDmHeadingNode( children, element ) {
|
|
// Parent constructor
|
|
ve.dm.BranchNode.call( this, 'heading', children, element );
|
|
};
|
|
|
|
/* Inheritance */
|
|
|
|
ve.inheritClass( ve.dm.HeadingNode, ve.dm.BranchNode );
|
|
|
|
/* Static Properties */
|
|
|
|
ve.dm.HeadingNode.static.name = 'heading';
|
|
|
|
ve.dm.HeadingNode.static.canContainContent = true;
|
|
|
|
ve.dm.HeadingNode.static.defaultAttributes = {
|
|
'level': 1
|
|
};
|
|
|
|
ve.dm.HeadingNode.static.matchTagNames = [ 'h1', 'h2', 'h3', 'h4', 'h5', 'h6' ];
|
|
|
|
ve.dm.HeadingNode.static.toDataElement = function ( domElements ) {
|
|
var levels = {
|
|
'h1': 1,
|
|
'h2': 2,
|
|
'h3': 3,
|
|
'h4': 4,
|
|
'h5': 5,
|
|
'h6': 6
|
|
},
|
|
level = levels[domElements[0].nodeName.toLowerCase()];
|
|
return { 'type': 'heading', 'attributes': { 'level': level } };
|
|
};
|
|
|
|
ve.dm.HeadingNode.static.toDomElements = function ( dataElement ) {
|
|
var level = dataElement.attributes && dataElement.attributes.level || 1;
|
|
return [ document.createElement( 'h' + level ) ];
|
|
};
|
|
|
|
/* Registration */
|
|
|
|
ve.dm.modelRegistry.register( ve.dm.HeadingNode );
|