2014-10-03 09:15:28 +00:00
|
|
|
/*
|
|
|
|
* This file is part of the MediaWiki extension MediaViewer.
|
|
|
|
*
|
|
|
|
* MediaViewer is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* MediaViewer is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with MediaViewer. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2018-11-12 16:33:24 +00:00
|
|
|
( function () {
|
2014-10-03 09:15:28 +00:00
|
|
|
QUnit.module( 'mmv.ui.tipsyDialog', QUnit.newMwEnvironment( {
|
2022-05-13 20:41:15 +00:00
|
|
|
beforeEach: function () {
|
2014-10-03 09:15:28 +00:00
|
|
|
// remove tipsy elements left behind by other tests so these tests don't find them by accident
|
|
|
|
// tipsy puts its elements to the end of the body so clearing the fixture doesn't get rid of them
|
|
|
|
$( '.mw-mmv-tipsy-dialog' ).remove();
|
|
|
|
}
|
|
|
|
} ) );
|
|
|
|
|
2017-07-25 23:38:21 +00:00
|
|
|
QUnit.test( 'Open/close', function ( assert ) {
|
2014-10-03 09:15:28 +00:00
|
|
|
var $qf = $( '#qunit-fixture' ),
|
|
|
|
$anchor = $( '<div>' ).appendTo( $qf ),
|
|
|
|
dialog = new mw.mmv.ui.TipsyDialog( $anchor );
|
|
|
|
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is not shown' );
|
2014-10-03 09:15:28 +00:00
|
|
|
dialog.open();
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 1, 'dialog is shown' );
|
2014-10-03 09:15:28 +00:00
|
|
|
dialog.close();
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is not shown' );
|
2014-10-03 09:15:28 +00:00
|
|
|
} );
|
|
|
|
|
2017-07-25 23:38:21 +00:00
|
|
|
QUnit.test( 'setContent', function ( assert ) {
|
2014-10-03 09:15:28 +00:00
|
|
|
var $qf = $( '#qunit-fixture' ),
|
|
|
|
$anchor = $( '<div>' ).appendTo( $qf ),
|
|
|
|
titleText = 'This is a title',
|
|
|
|
bodyText = 'This is the <b class="typsyDialogTest-123">body</b>',
|
|
|
|
dialog = new mw.mmv.ui.TipsyDialog( $anchor );
|
|
|
|
|
|
|
|
dialog.setContent( titleText, bodyText );
|
|
|
|
dialog.open();
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.notStrictEqual( $( '.mw-mmv-tipsy-dialog' ).text().match( titleText ), null, 'Title is included' );
|
|
|
|
assert.notStrictEqual( $( '.mw-mmv-tipsy-dialog' ).html().match( bodyText ), null, 'Body is included' );
|
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).find( '.typsyDialogTest-123' ).length, 1, 'Body is HTML' );
|
2014-10-03 09:15:28 +00:00
|
|
|
} );
|
|
|
|
|
2017-07-25 23:38:21 +00:00
|
|
|
QUnit.test( 'Close on click', function ( assert ) {
|
2014-10-03 09:15:28 +00:00
|
|
|
var $qf = $( '#qunit-fixture' ),
|
|
|
|
$anchor = $( '<div>' ).appendTo( $qf ),
|
|
|
|
dialog = new mw.mmv.ui.TipsyDialog( $anchor );
|
|
|
|
|
|
|
|
dialog.open();
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 1, 'dialog is shown initially' );
|
2018-04-24 14:47:41 +00:00
|
|
|
dialog.getPopup().trigger( 'click' );
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 1, 'dialog is not hidden when clicked' );
|
2018-04-24 14:47:41 +00:00
|
|
|
dialog.getPopup().find( '.mw-mmv-tipsy-dialog-disable' ).trigger( 'click' );
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is hidden when close icon is clicked' );
|
2014-10-03 09:15:28 +00:00
|
|
|
dialog.open();
|
2018-04-24 14:47:41 +00:00
|
|
|
$qf.trigger( 'click' );
|
2022-05-20 00:18:43 +00:00
|
|
|
assert.strictEqual( $( '.mw-mmv-tipsy-dialog' ).length, 0, 'dialog is hidden when clicked outside' );
|
2014-10-03 09:15:28 +00:00
|
|
|
} );
|
2018-11-12 16:33:24 +00:00
|
|
|
}() );
|