Merge "Enable RCFilters app on Watchlist"
[lhc/web/wiklou.git] / resources / src / mediawiki.rcfilters / mw.rcfilters.init.js
1 /*!
2 * JavaScript for Special:RecentChanges
3 */
4 ( function ( mw, $ ) {
5 var rcfilters = {
6 /**
7 * @member mw.rcfilters
8 * @private
9 */
10 init: function () {
11 var toplinksTitle,
12 topLinksCookieName = 'rcfilters-toplinks-collapsed-state',
13 topLinksCookie = mw.cookie.get( topLinksCookieName ),
14 topLinksCookieValue = topLinksCookie || 'collapsed',
15 savedQueriesPreferenceName = mw.config.get( 'wgStructuredChangeFiltersSavedQueriesPreferenceName' ),
16 filtersModel = new mw.rcfilters.dm.FiltersViewModel(),
17 changesListModel = new mw.rcfilters.dm.ChangesListViewModel(),
18 savedQueriesModel = new mw.rcfilters.dm.SavedQueriesModel(),
19 controller = new mw.rcfilters.Controller(
20 filtersModel, changesListModel, savedQueriesModel,
21 {
22 savedQueriesPreferenceName: savedQueriesPreferenceName
23 }
24 ),
25 $overlay = $( '<div>' )
26 .addClass( 'mw-rcfilters-ui-overlay' ),
27 filtersWidget = new mw.rcfilters.ui.FilterWrapperWidget(
28 controller, filtersModel, savedQueriesModel, changesListModel, { $overlay: $overlay } );
29
30 // TODO: The changesListWrapperWidget should be able to initialize
31 // after the model is ready.
32 // eslint-disable-next-line no-new
33 new mw.rcfilters.ui.ChangesListWrapperWidget(
34 filtersModel, changesListModel, controller, $( '.mw-changeslist, .mw-changeslist-empty' ) );
35
36 controller.initialize(
37 mw.config.get( 'wgStructuredChangeFilters' ),
38 mw.config.get( 'wgFormattedNamespaces' ),
39 mw.config.get( 'wgRCFiltersChangeTags' )
40 );
41
42 // eslint-disable-next-line no-new
43 new mw.rcfilters.ui.FormWrapperWidget(
44 filtersModel, changesListModel, controller, $( 'fieldset.cloptions' ) );
45
46 $( '.rcfilters-container' ).append( filtersWidget.$element );
47 $( 'body' ).append( $overlay );
48 $( '.rcfilters-head' ).addClass( 'mw-rcfilters-ui-ready' );
49
50 $( 'a.mw-helplink' ).attr(
51 'href',
52 'https://www.mediawiki.org/wiki/Special:MyLanguage/Help:New_filters_for_edit_review'
53 );
54
55 controller.replaceUrl();
56
57 toplinksTitle = new OO.ui.ButtonWidget( {
58 framed: false,
59 indicator: topLinksCookieValue === 'collapsed' ? 'down' : 'up',
60 flags: [ 'progressive' ],
61 label: $( '<span>' ).append( mw.message( 'rcfilters-other-review-tools' ).parse() ).contents()
62 } );
63 $( '.mw-recentchanges-toplinks-title' ).replaceWith( toplinksTitle.$element );
64 // Move the top links to a designated area so it's near the
65 // 'saved filters' button and make it collapsible
66 $( '.mw-recentchanges-toplinks' )
67 .addClass( 'mw-rcfilters-ui-ready' )
68 .makeCollapsible( {
69 collapsed: topLinksCookieValue === 'collapsed',
70 $customTogglers: toplinksTitle.$element
71 } )
72 .on( 'beforeExpand.mw-collapsible', function () {
73 mw.cookie.set( topLinksCookieName, 'expanded' );
74 toplinksTitle.setIndicator( 'up' );
75 } )
76 .on( 'beforeCollapse.mw-collapsible', function () {
77 mw.cookie.set( topLinksCookieName, 'collapsed' );
78 toplinksTitle.setIndicator( 'down' );
79 } )
80 .appendTo( '.mw-rcfilters-ui-filterWrapperWidget-top-placeholder' );
81 }
82 };
83
84 $( rcfilters.init );
85
86 module.exports = rcfilters;
87
88 }( mediaWiki, jQuery ) );