mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-12-02 01:46:47 +00:00
fd28fff50f
* Also fixed calls to addListenerMethod * Also routed adding children in the constructor of ve.dm.BranchNode to the splice method * Renamed types of ve.dm stub nodes to avoid collisions (since we have to register ce nodes by the same names for them to be generated by onSplice) Change-Id: Ia2e75cf0a62186cc0e214683feb25c619590318a
38 lines
1.3 KiB
JavaScript
38 lines
1.3 KiB
JavaScript
module( 've.ce.BranchNode' );
|
|
|
|
/* Stubs */
|
|
|
|
ve.ce.BranchNodeStub = function( model, $element ) {
|
|
// Inheritance
|
|
ve.ce.BranchNode.call( this, model, $element );
|
|
};
|
|
|
|
ve.extendClass( ve.ce.BranchNodeStub, ve.ce.BranchNode );
|
|
|
|
ve.ce.factory.register( 'branch-stub', ve.ce.BranchNodeStub );
|
|
|
|
/* Tests */
|
|
|
|
test( 'replaceDomWrapper', 4, function() {
|
|
var $oldWrapper = $( '<h1 class="test">hello</h1>' ),
|
|
$newWrapper = $( '<h2></h2>' ),
|
|
node = new ve.ce.BranchNodeStub( new ve.dm.BranchNodeStub(), $oldWrapper );
|
|
equal( node.$, $oldWrapper, 'this.$ references wrapper given to constructor' );
|
|
node.replaceDomWrapper( $newWrapper );
|
|
equal( node.$, $newWrapper, 'this.$ references new wrapper after replaceDomWrapper is called' );
|
|
equal( node.$.attr( 'class' ), 'test', 'old classes are added to new wrapper' );
|
|
equal( node.$.text(), 'hello', 'contents are added to new wrapper' );
|
|
} );
|
|
|
|
test( 'onSplice', 3, function() {
|
|
var modelA = new ve.dm.BranchNodeStub(),
|
|
modelB = new ve.dm.BranchNodeStub(),
|
|
modelC = new ve.dm.BranchNodeStub(),
|
|
viewA = new ve.ce.BranchNodeStub( modelA );
|
|
|
|
modelA.splice( 0, 0, modelB, modelC );
|
|
equal( viewA.getChildren().length, 2 );
|
|
deepEqual( viewA.getChildren()[0].getModel(), modelB );
|
|
deepEqual( viewA.getChildren()[1].getModel(), modelC );
|
|
} );
|