( function ( mw ) { /** * List displaying all filter groups * * @extends OO.ui.Widget * @mixins OO.ui.mixin.PendingElement * * @constructor * @param {mw.rcfilters.Controller} controller Controller * @param {mw.rcfilters.dm.FiltersViewModel} model View model * @param {mw.rcfilters.dm.SavedQueriesModel} savedQueriesModel Saved queries model * @param {mw.rcfilters.dm.ChangesListViewModel} changesListModel * @param {Object} [config] Configuration object * @cfg {Object} [filters] A definition of the filter groups in this list * @cfg {jQuery} [$overlay] A jQuery object serving as overlay for popups */ mw.rcfilters.ui.FilterWrapperWidget = function MwRcfiltersUiFilterWrapperWidget( controller, model, savedQueriesModel, changesListModel, config ) { var $bottom; config = config || {}; // Parent mw.rcfilters.ui.FilterWrapperWidget.parent.call( this, config ); // Mixin constructors OO.ui.mixin.PendingElement.call( this, config ); this.controller = controller; this.model = model; this.queriesModel = savedQueriesModel; this.changesListModel = changesListModel; this.$overlay = config.$overlay || this.$element; this.filterTagWidget = new mw.rcfilters.ui.FilterTagMultiselectWidget( this.controller, this.model, this.queriesModel, { $overlay: this.$overlay } ); this.liveUpdateButton = new mw.rcfilters.ui.LiveUpdateButtonWidget( this.controller, this.changesListModel ); this.numChangesAndDateWidget = new mw.rcfilters.ui.ChangesLimitAndDateButtonWidget( this.controller, this.model, { $overlay: this.$overlay } ); this.showNewChangesLink = new OO.ui.ButtonWidget( { icon: 'reload', framed: false, label: mw.msg( 'rcfilters-show-new-changes' ), flags: [ 'progressive' ], classes: [ 'mw-rcfilters-ui-filterWrapperWidget-showNewChanges' ] } ); // Events this.filterTagWidget.menu.connect( this, { toggle: [ 'emit', 'menuToggle' ] } ); this.changesListModel.connect( this, { newChangesExist: 'onNewChangesExist' } ); this.showNewChangesLink.connect( this, { click: 'onShowNewChangesClick' } ); this.showNewChangesLink.toggle( false ); // Initialize this.$top = $( '