2018-11-12 13:56:38 +00:00
|
|
|
( function () {
|
2016-05-20 04:22:41 +00:00
|
|
|
/**
|
|
|
|
* A select widget for notification read state: 'all', 'read' or 'unread'
|
|
|
|
*
|
|
|
|
* @class
|
|
|
|
* @extends OO.ui.ButtonSelectWidget
|
|
|
|
*
|
|
|
|
* @constructor
|
|
|
|
* @param {Object} [config] Configuration object
|
|
|
|
*/
|
|
|
|
mw.echo.ui.ReadStateButtonSelectWidget = function MwEchoUiReadStateButtonSelectWidget( config ) {
|
2018-05-22 14:56:46 +00:00
|
|
|
// Parent constructor
|
|
|
|
mw.echo.ui.ReadStateButtonSelectWidget.super.call( this, $.extend( config, {
|
2016-05-20 04:22:41 +00:00
|
|
|
items: [
|
|
|
|
new OO.ui.ButtonOptionWidget( {
|
|
|
|
data: 'all',
|
|
|
|
label: mw.msg( 'notification-inbox-filter-all' )
|
|
|
|
} ),
|
|
|
|
new OO.ui.ButtonOptionWidget( {
|
|
|
|
data: 'read',
|
|
|
|
label: mw.msg( 'notification-inbox-filter-read' )
|
|
|
|
} ),
|
|
|
|
new OO.ui.ButtonOptionWidget( {
|
|
|
|
data: 'unread',
|
|
|
|
label: mw.msg( 'notification-inbox-filter-unread' )
|
|
|
|
} )
|
|
|
|
]
|
|
|
|
} ) );
|
|
|
|
|
|
|
|
this.connect( this, { choose: 'onChoose' } );
|
|
|
|
|
|
|
|
this.$element
|
|
|
|
.addClass( 'mw-echo-ui-readStateButtonSelectWidget' );
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Initialization */
|
|
|
|
|
|
|
|
OO.inheritClass( mw.echo.ui.ReadStateButtonSelectWidget, OO.ui.ButtonSelectWidget );
|
|
|
|
|
|
|
|
/* Events */
|
|
|
|
|
|
|
|
/**
|
2024-04-30 14:21:54 +00:00
|
|
|
* @event mw.echo.ui.ReadStateButtonSelectWidget#filter
|
2016-05-20 04:22:41 +00:00
|
|
|
* @param {string} readState The chosen read state
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Methods */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Respond to choose event
|
|
|
|
*
|
|
|
|
* @param {OO.ui.ButtonOptionWidget} item Chosen item
|
2024-04-30 14:21:54 +00:00
|
|
|
* @fires mw.echo.ui.ReadStateButtonSelectWidget#filter
|
2016-05-20 04:22:41 +00:00
|
|
|
*/
|
|
|
|
mw.echo.ui.ReadStateButtonSelectWidget.prototype.onChoose = function ( item ) {
|
2024-06-03 12:22:48 +00:00
|
|
|
const data = item && item.getData();
|
2016-05-20 04:22:41 +00:00
|
|
|
|
|
|
|
if ( data ) {
|
|
|
|
this.emit( 'filter', data );
|
|
|
|
}
|
|
|
|
};
|
2018-11-12 13:56:38 +00:00
|
|
|
}() );
|