67c113d75151f475da3acb12c9651ceab36a2913
3 * Widget for toggling live updates
5 * @extends OO.ui.ToggleButtonWidget
8 * @param {mw.rcfilters.Controller} controller
9 * @param {mw.rcfilters.dm.ChangesListViewModel} changesListModel
10 * @param {Object} [config] Configuration object
12 mw
.rcfilters
.ui
.LiveUpdateButtonWidget
= function MwRcfiltersUiLiveUpdateButtonWidget( controller
, changesListModel
, config
) {
13 config
= config
|| {};
16 mw
.rcfilters
.ui
.LiveUpdateButtonWidget
.parent
.call( this, $.extend( {
18 label
: mw
.message( 'rcfilters-liveupdates-button' ).text()
21 this.controller
= controller
;
22 this.model
= changesListModel
;
25 this.connect( this, { click
: 'onClick' } );
26 this.model
.connect( this, { liveUpdateChange
: 'onLiveUpdateChange' } );
28 this.$element
.addClass( 'mw-rcfilters-ui-liveUpdateButtonWidget' );
33 OO
.inheritClass( mw
.rcfilters
.ui
.LiveUpdateButtonWidget
, OO
.ui
.ToggleButtonWidget
);
38 * Respond to the button being clicked
40 mw
.rcfilters
.ui
.LiveUpdateButtonWidget
.prototype.onClick = function () {
41 this.controller
.toggleLiveUpdate();
45 * Respond to the 'live update' feature being turned on/off
47 * @param {boolean} enable Whether the 'live update' feature is now on/off
49 mw
.rcfilters
.ui
.LiveUpdateButtonWidget
.prototype.onLiveUpdateChange = function ( enable
) {
50 this.setValue( enable
);
51 this.setIcon( enable
? 'stop' : 'play' );