mediawiki-extensions-Visual.../modules/ve/ce/nodes/ve.ce.TableSectionNode.js
Ed Sanders edcaaf9edc Use static.name once for ce and dm nodes
Add a static.name property to ce nodes and make sure both ce
and dm nodes always use the static.name property in constructors
and registration calls.

The result of this is that any given node type should now only
appear once in the code as a string.

Bug: 45701
Change-Id: Ibf31de16ab28ad58209c1443cd74f93dda278998
2013-03-07 17:19:39 -08:00

62 lines
1.3 KiB
JavaScript

/*!
* VisualEditor ContentEditable TableSectionNode class.
*
* @copyright 2011-2013 VisualEditor Team and others; see AUTHORS.txt
* @license The MIT License (MIT); see LICENSE.txt
*/
/**
* ContentEditable table section node.
*
* @class
* @extends ve.ce.BranchNode
* @constructor
* @param {ve.dm.TableSectionNode} model Model to observe
*/
ve.ce.TableSectionNode = function VeCeTableSectionNode( model ) {
// Parent constructor
ve.ce.BranchNode.call(
this, model, ve.ce.BranchNode.getDomWrapper( model, 'style' )
);
// Events
this.model.addListenerMethod( this, 'update', 'onUpdate' );
};
/* Inheritance */
ve.inheritClass( ve.ce.TableSectionNode, ve.ce.BranchNode );
/* Static Properties */
ve.ce.TableSectionNode.static.name = 'tableSection';
/**
* Mapping of list item style values and DOM wrapper element types.
*
* @static
* @property
*/
ve.ce.TableSectionNode.domWrapperElementTypes = {
'header': 'thead',
'body': 'tbody',
'footer': 'tfoot'
};
/* Methods */
/**
* Handle model update events.
*
* If the style changed since last update the DOM wrapper will be replaced with an appropriate one.
*
* @method
*/
ve.ce.TableSectionNode.prototype.onUpdate = function () {
this.updateDomWrapper( 'style' );
};
/* Registration */
ve.ce.nodeFactory.register( ve.ce.TableSectionNode );