mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-11-05 22:22:54 +00:00
316fdab450
It's been passed in for a while, but nothing ever used it. As we know some browsers don't like it when we create elements in the wrong document, and this ensures we always use the correct document for createElement(). Change-Id: Ia3d2fabe0516956105ad2b5625ed2f76c015c26e
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, 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, doc ) {
|
|
var level = dataElement.attributes && dataElement.attributes.level || 1;
|
|
return [ doc.createElement( 'h' + level ) ];
|
|
};
|
|
|
|
/* Registration */
|
|
|
|
ve.dm.modelRegistry.register( ve.dm.HeadingNode );
|