mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2024-12-12 06:27:01 +00:00
52 lines
1.9 KiB
JavaScript
52 lines
1.9 KiB
JavaScript
QUnit.module( 've.ui.MWTransclusionOutlineParameterSelectWidget' );
|
|
|
|
QUnit.test( 'static item constructor', ( assert ) => {
|
|
const item = ve.ui.MWTransclusionOutlineParameterSelectWidget.static.createItem( { data: 'p1' } );
|
|
|
|
assert.ok( item instanceof OO.ui.OptionWidget, 'items use correct base class' );
|
|
assert.strictEqual( item.getData(), 'p1', 'config is forwarded to base class' );
|
|
assert.notOk( item.isSelected() );
|
|
} );
|
|
|
|
QUnit.test( 'interaction with items', ( assert ) => {
|
|
const item = ve.ui.MWTransclusionOutlineParameterSelectWidget.static.createItem( {} ),
|
|
widget = new ve.ui.MWTransclusionOutlineParameterSelectWidget( { items: [ item ] } );
|
|
|
|
assert.strictEqual( widget.getItemCount(), 1, 'item is added' );
|
|
|
|
// Note this triggers a chain of events that bubbles up to the SelectWidget. The individual
|
|
// OptionWidgets just store their state, but the outer SelectWidget manages it!
|
|
item.checkbox.setSelected( true );
|
|
assert.ok( item.isSelected(), 'clicking the checkbox selects the item' );
|
|
|
|
let eventsFired = 0;
|
|
widget.connect( this, { choose: () => eventsFired++ } );
|
|
|
|
widget.onMouseDown( {
|
|
which: OO.ui.MouseButtons.LEFT,
|
|
target: item.$element[ 0 ]
|
|
} );
|
|
|
|
widget.highlightItem( item );
|
|
widget.onDocumentKeyDown( {
|
|
keyCode: OO.ui.Keys.ENTER,
|
|
preventDefault: () => undefined
|
|
} );
|
|
|
|
assert.strictEqual( eventsFired, 2 );
|
|
} );
|
|
|
|
QUnit.test( 'interaction with required parameter', ( assert ) => {
|
|
const item = ve.ui.MWTransclusionOutlineParameterSelectWidget.static.createItem( { required: true } ),
|
|
widget = new ve.ui.MWTransclusionOutlineParameterSelectWidget( { items: [ item ] } );
|
|
|
|
assert.strictEqual( widget.getItems()[ 0 ], item, 'item is used as is' );
|
|
assert.ok( item.isSelected(), 'selected by default' );
|
|
|
|
item.setSelected( false );
|
|
assert.ok( item.isSelected(), 'can not unselect' );
|
|
|
|
item.checkbox.setSelected( false );
|
|
assert.ok( item.isSelected(), 'can not unselect via the checkbox as well' );
|
|
} );
|