mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2025-01-10 12:15:08 +00:00
3e23d78d32
Screen readers will read the collapsed content despite the fact that it is not visible due to the way it is hidden with CSS. The more button makes no sense for these users and is probably more confusing than helpfull. Bug: T291277 Change-Id: I71888d8b9565d5ee85c5e7a48965e9e9a76eb984
87 lines
2.3 KiB
JavaScript
87 lines
2.3 KiB
JavaScript
/**
|
|
* Container for textual elements, which should be collapsed to one line by default.
|
|
*
|
|
* A "more / less" button is used to toggle additional lines.
|
|
*
|
|
* @class
|
|
* @extends OO.ui.Element
|
|
* @mixins OO.EventEmitter
|
|
*
|
|
* @constructor
|
|
* @param {Object} config
|
|
* @cfg {jQuery} $content
|
|
*/
|
|
ve.ui.MWExpandableContentElement = function VeUiMWExpandableContentElement( config ) {
|
|
// Parent constructor
|
|
ve.ui.MWExpandableContentElement.super.call( this, config );
|
|
|
|
// Mixin constructors
|
|
OO.EventEmitter.call( this );
|
|
|
|
this.$content = config.$content;
|
|
|
|
this.collapsed = false;
|
|
this.toggle( false );
|
|
};
|
|
|
|
/* Inheritance */
|
|
|
|
OO.inheritClass( ve.ui.MWExpandableContentElement, OO.ui.Element );
|
|
|
|
OO.mixinClass( ve.ui.MWExpandableContentElement, OO.EventEmitter );
|
|
|
|
/* Methods */
|
|
|
|
ve.ui.MWExpandableContentElement.prototype.getLineHeight = function () {
|
|
return parseInt( this.$content.css( 'line-height' ) );
|
|
};
|
|
|
|
ve.ui.MWExpandableContentElement.prototype.makeCollapsible = function () {
|
|
this.$content.addClass( 've-ui-expandableContent-collapsible' );
|
|
|
|
var element = this,
|
|
collapsedHeight = this.getLineHeight(),
|
|
toggle = new OO.ui.ButtonWidget( {
|
|
framed: false,
|
|
flags: [ 'progressive' ],
|
|
label: ve.msg( 'visualeditor-expandable-more' ),
|
|
classes: [ 've-ui-expandableContent-toggle' ],
|
|
icon: 'expand'
|
|
} );
|
|
|
|
toggle.on( 'click', function () {
|
|
if ( element.collapsed ) {
|
|
toggle.setLabel( ve.msg( 'visualeditor-expandable-more' ) );
|
|
element.$content.css( { height: collapsedHeight } );
|
|
toggle.setIcon( 'expand' );
|
|
} else {
|
|
toggle.setLabel( ve.msg( 'visualeditor-expandable-less' ) );
|
|
element.$content.css( { height: element.$content.prop( 'scrollHeight' ) + collapsedHeight } );
|
|
toggle.setIcon( 'collapse' );
|
|
}
|
|
element.collapsed = !element.collapsed;
|
|
} );
|
|
|
|
toggle.$element.attr( 'aria-hidden', 'true' );
|
|
|
|
$( '<div>' )
|
|
.addClass( 've-ui-expandableContent-container' )
|
|
.append(
|
|
$( '<div>' )
|
|
.addClass( 've-ui-expandableContent-fade' )
|
|
)
|
|
.append( toggle.$element )
|
|
.height( collapsedHeight )
|
|
.appendTo( this.$element );
|
|
|
|
this.$content.height( collapsedHeight );
|
|
};
|
|
|
|
ve.ui.MWExpandableContentElement.prototype.updateSize = function () {
|
|
this.toggle( true );
|
|
|
|
if ( this.$content.outerHeight() / this.getLineHeight() >= 3 ) {
|
|
this.makeCollapsible();
|
|
}
|
|
};
|