let createReferencePreview; const previewTypes = { TYPE_REFERENCE: 'reference' }; ( mw.loader.getModuleNames().indexOf( 'ext.popups.main' ) !== -1 ? QUnit.module : QUnit.module.skip )( 'ext.cite.referencePreviews#renderer', { before() { createReferencePreview = require( 'ext.cite.referencePreviews' ).private.createReferencePreview; }, beforeEach: function () { this.sandbox.stub( mw, 'msg', ( key ) => `<${ key }>` ); this.sandbox.stub( mw, 'message', ( key ) => ( { exists: () => !key.endsWith( 'generic' ), text: () => `<${ key }>` } ) ); this.sandbox.stub( mw.html, 'escape', ( str ) => str && str.replace( /'/g, ''' ).replace( / { const model = { url: '#custom_id', extract: 'Custom extract with an internal and an external link', type: previewTypes.TYPE_REFERENCE, referenceType: 'web' }, preview = createReferencePreview( model ); assert.strictEqual( preview.hasThumbnail, false ); assert.strictEqual( preview.isTall, false ); assert.strictEqual( $( preview.el ).find( '.mwe-popups-title' ).text().trim(), '' ); assert.strictEqual( $( preview.el ).find( '.mw-parser-output' ).text().trim(), 'Custom extract with an internal and an external link' ); assert.strictEqual( $( preview.el ).find( 'a[target="_blank"]' ).length, 1, 'only external links open in new tabs' ); } ); QUnit.test( 'createReferencePreview default title', ( assert ) => { const model = { url: '', extract: '', type: previewTypes.TYPE_REFERENCE }, preview = createReferencePreview( model ); assert.strictEqual( $( preview.el ).find( '.mwe-popups-title' ).text().trim(), '' ); } ); QUnit.test( 'createReferencePreview updates fade-out effect on scroll', ( assert ) => { const model = { url: '', extract: '', type: previewTypes.TYPE_REFERENCE }, preview = createReferencePreview( model ), $extract = $( preview.el ).find( '.mwe-popups-extract' ); $extract.children()[ 0 ].dispatchEvent( new Event( 'scroll' ) ); assert.false( $extract.children()[ 0 ].isScrolling ); assert.false( $extract.hasClass( 'mwe-popups-fade-out' ) ); } ); QUnit.test( 'createReferencePreview collapsible/sortable handling', ( assert ) => { const model = { url: '', extract: '
' + '
', type: previewTypes.TYPE_REFERENCE }, preview = createReferencePreview( model ); assert.strictEqual( $( preview.el ).find( '.mw-collapsible, .sortable, .headerSort' ).length, 0 ); assert.strictEqual( $( preview.el ).find( 'th' ).attr( 'tabindex' ), undefined ); assert.strictEqual( $( preview.el ).find( 'th' ).attr( 'title' ), undefined ); assert.strictEqual( $( preview.el ).find( '.mwe-collapsible-placeholder' ).text(), '' ); } );