Merge "Improve sorting on SpecialWanted*-Pages"
[mediawiki.git] / resources / src / mediawiki.rcfilters / ui / mw.rcfilters.ui.FilterItemHighlightButton.js
blob889ba08cf40c06f2e61a2d94b1d91d92fdbe9e19
1 ( function ( mw, $ ) {
2 /**
3 * A button to configure highlight for a filter item
5 * @extends OO.ui.PopupButtonWidget
7 * @constructor
8 * @param {mw.rcfilters.Controller} controller RCFilters controller
9 * @param {mw.rcfilters.dm.FilterItem} model Filter item model
10 * @param {Object} [config] Configuration object
12 mw.rcfilters.ui.FilterItemHighlightButton = function MwRcfiltersUiFilterItemHighlightButton( controller, model, config ) {
13 config = config || {};
15 this.colorPickerWidget = new mw.rcfilters.ui.HighlightColorPickerWidget( controller, model );
17 // Parent
18 mw.rcfilters.ui.FilterItemHighlightButton.parent.call( this, $.extend( {}, config, {
19 icon: 'highlight',
20 indicator: 'down',
21 popup: {
22 // TODO: There is a bug in non-anchored popups in
23 // OOUI, so we set this popup to "anchored" until
24 // the bug is fixed.
25 // See: https://phabricator.wikimedia.org/T159906
26 anchor: true,
27 padded: true,
28 align: 'backwards',
29 horizontalPosition: 'end',
30 $floatableContainer: this.$element,
31 width: 290,
32 $content: this.colorPickerWidget.$element
34 } ) );
36 this.controller = controller;
37 this.model = model;
39 // Event
40 this.model.connect( this, { update: 'onModelUpdate' } );
41 this.colorPickerWidget.connect( this, { chooseColor: 'onChooseColor' } );
43 this.$element
44 .addClass( 'mw-rcfilters-ui-filterItemHighlightButton' );
47 /* Initialization */
49 OO.inheritClass( mw.rcfilters.ui.FilterItemHighlightButton, OO.ui.PopupButtonWidget );
51 /* Methods */
53 /**
54 * Respond to item model update event
56 mw.rcfilters.ui.FilterItemHighlightButton.prototype.onModelUpdate = function () {
57 var currentColor = this.model.getHighlightColor(),
58 widget = this;
60 this.$icon.toggleClass(
61 'mw-rcfilters-ui-filterItemHighlightButton-circle',
62 currentColor !== null
65 mw.rcfilters.HighlightColors.forEach( function ( c ) {
66 widget.$icon
67 .toggleClass(
68 'mw-rcfilters-ui-filterItemHighlightButton-circle-color-' + c,
69 c === currentColor
71 } );
74 mw.rcfilters.ui.FilterItemHighlightButton.prototype.onChooseColor = function () {
75 this.popup.toggle( false );
77 }( mediaWiki, jQuery ) );