MediaWiki:Gadget-rightsfilter.js

Uwaga: aby zobaczyć zmiany po opublikowaniu, może zajść potrzeba wyczyszczenia pamięci podręcznej przeglądarki.

  • Firefox / Safari: Przytrzymaj Shift podczas klikania Odśwież bieżącą stronę, lub naciśnij klawisze Ctrl+F5, lub Ctrl+R (⌘-R na komputerze Mac)
  • Google Chrome: Naciśnij Ctrl-Shift-R (⌘-Shift-R na komputerze Mac)
  • Edge: Przytrzymaj Ctrl, jednocześnie klikając Odśwież, lub naciśnij klawisze Ctrl+F5.
  • Opera: Naciśnij klawisze Ctrl+F5.
/**
 * Log filter script
 *
 * Created by [[w:User:Splarka|Splarka]]
 * Amended by [[b:User:Mike.lifeguard]] & [[User:Lupo]]
 * Partially rewritten by DieBuche
 *
 * <li> element Filter Script, version [0.2]
 * Should currently work on all known skins (with a #contentSub or #topbar)
 *
 * mw.util.getUrl( mw.config.get( 'wgPageName' ) ) + '?' +
 * 'withgadget=rightsfilter&lifilter=1&lifilterexpr=TEST&lifiltercase&lifilterhilight&lifilterinv'
 */
// Guard against double inclusions
if ( typeof filterLists === 'undefined' ) {
window.filterLists = {
	i18n: {
		'de': {
			'filter-portlet-text': 'Filtern',
			'filter-portlet-description': 'Filter-Eingabe aktivieren',
			'filter-rights-list-instructions': 'Komma-separierte Liste von Rechten filtern.',
			'filter-other-list-instructions': 'Listen-Text filtern.',
			'filter-legend': 'Gefilterte Liste',
			'filter-option-added': 'Ergänzte Rechte',
			'filter-option-removed': 'Entfernte Rechte',
			'filter-option-added-or-removed': 'Ergänzt ODER entfernt',
			'filter-option-added-removed-static': 'Ergänzt/entfernt/statisch',
			'filter-regex-label': ' Regex-String: ',
			'filter-invert-label': 'Invertieren',
			'filter-case-label': 'Case insensitiv ',
			'filter-filter-button': 'Filtern',
			'filter-highlight-button': 'Markieren',
			'filter-link-text': 'Link zur gefilterten Liste'
		},
		'en': {
			'filter-portlet-text': 'Filter',
			'filter-portlet-description': 'Open interactive log entry regex filter thingy',
			'filter-rights-list-instructions': 'Regex filter the space-delimited list of rights.',
			'filter-other-list-instructions': 'Regex filter the plain text representation of this list.',
			'filter-legend': 'Filter <li> list',
			'filter-option-added': 'Added rights',
			'filter-option-removed': 'Removed rights',
			'filter-option-added-or-removed': 'Added OR removed',
			'filter-option-added-removed-static': 'Added/removed/static',
			'filter-regex-label': 'Regex string:',
			'filter-invert-label': 'Invert',
			'filter-case-label': 'Case insensitive',
			'filter-filter-button': 'Filter',
			'filter-highlight-button': 'Highlight',
			'filter-link-text': 'Link to this filtered list'
		},
		'pl': {
			'filter-portlet-text': 'Filtr',
			'filter-portlet-description': 'Open interactive log entry regex filter thingy',
			'filter-rights-list-instructions': 'Regex filter the space-delimited list of rights.',
			'filter-other-list-instructions': 'Przefiltruj wyrażaniem regularnym tekstową reprezentację tej listy.',
			'filter-legend': 'Filtruj listę',
			'filter-option-added': 'Added rights',
			'filter-option-removed': 'Removed rights',
			'filter-option-added-or-removed': 'Added OR removed',
			'filter-option-added-removed-static': 'Added/removed/static',
			'filter-regex-label': 'Wyrażenie regularne:',
			'filter-invert-label': 'Odwróć',
			'filter-case-label': 'Rozróżnianie wielkości liter',
			'filter-filter-button': 'Filtruj',
			'filter-highlight-button': 'Podświetl',
			'filter-link-text': 'Link do przefiltrowanej listy'
		},
		'es': {
			'filter-portlet-text': 'Filtro',
			'filter-portlet-description': 'Abrir un filtro interactivo basado en expresiones regulares',
			'filter-rights-list-instructions': 'Filtra la lista de derechos, separados por espacios, mediante una expresión regular.',
			'filter-other-list-instructions': 'Filtra la representación de esta lista, en texto sin formato, mediante una expresión regular.',
			'filter-legend': 'Filtro para listas <li>',
			'filter-option-added': 'Derechos añadidos',
			'filter-option-removed': 'Derechos eliminados',
			'filter-option-added-or-removed': 'Añadido O eliminado',
			'filter-option-added-removed-static': 'Añadido/eliminado/estático',
			'filter-regex-label': 'Cadena de expresión regular:',
			'filter-invert-label': 'Invertir',
			'filter-case-label': 'Sin distinción entre mayúsculas y minúsculas',
			'filter-filter-button': 'Filtrar',
			'filter-highlight-button': 'Resaltar',
			'filter-link-text': 'Enlace a esta lista filtrada'
		},
		'fa': {
			'filter-portlet-text': 'پالایه',
			'filter-portlet-description': 'بازکردن سیاهه ورودی پالایه عبارات باقائده',
			'filter-rights-list-instructions': 'فهرست قوائد بدون فاصله‌ٔ عبارات باقائده.',
			'filter-other-list-instructions': 'فهرست قوائد بدون فاصله‌ٔ عبارات باقائده به صورت متنی.',
			'filter-legend': 'فهرست <li> پالایه',
			'filter-option-added': 'افزودن قائده',
			'filter-option-removed': 'برداشتن قائده',
			'filter-option-added-or-removed': 'افزودن با برداشتن',
			'filter-option-added-removed-static': 'افزوده/برداشته/ساکن',
			'filter-regex-label': 'متن عبارات باقائده:',
			'filter-invert-label': 'معکوس',
			'filter-case-label': 'عدم توجه به حروف بزرگ',
			'filter-filter-button': 'پالایه',
			'filter-highlight-button': 'پررنگ',
			'filter-link-text': 'پیوند به فهرست این پالایه'
		},
		'gl': {
			'filter-portlet-text': 'Filtro',
			'filter-portlet-description': 'Abrir un filtro interactivo baseado en expresións regulares',
			'filter-rights-list-instructions': 'Filtra a lista de dereitos, separados por espazos, mediante unha expresión regular.',
			'filter-other-list-instructions': 'Filtra a representación desta lista, en texto sen formato, mediante unha expresión regular.',
			'filter-legend': 'Filtro para listas <li>',
			'filter-option-added': 'Dereitos engadidos',
			'filter-option-removed': 'Dereitos eliminados',
			'filter-option-added-or-removed': 'Engadido OU eliminado',
			'filter-option-added-removed-static': 'Engadido/eliminado/estático',
			'filter-regex-label': 'Cadea de expresión regular:',
			'filter-invert-label': 'Inverter',
			'filter-case-label': 'Sen distinción entre maiúsculas e minúsculas',
			'filter-filter-button': 'Filtrar',
			'filter-highlight-button': 'Resaltar',
			'filter-link-text': 'Ligazón cara a esta lista filtrada'
		},
		'lv': {
			'filter-portlet-text': 'Filtrs',
			'filter-portlet-description': 'Atvērt interaktīvu filtrēšanas logu',
			'filter-rights-list-instructions': 'Regex filter the space-delimited list of rights.',
			'filter-other-list-instructions': 'Filtrēt vienkāršu tekstu.',
			'filter-legend': 'Filtrēt <li> sarakstu',
			'filter-option-added': 'Pievienotās tiesības',
			'filter-option-removed': 'Noņemtās tiesības',
			'filter-option-added-or-removed': 'Pievienots VAI noņemts',
			'filter-option-added-removed-static': 'Pievienots/noņemts/statisks',
			'filter-regex-label': 'Simbolu virkne:',
			'filter-invert-label': 'Izvēlēties pretēji',
			'filter-case-label': 'Bez reģistrjutības',
			'filter-filter-button': 'Filtrēt',
			'filter-highlight-button': 'Izcelt',
			'filter-link-text': 'Saite uz šo filtrēto sarakstu'
		},
		'pt': {
			'filter-portlet-text': 'Filtro',
			'filter-portlet-description': 'Abrir um filtro interativo baseado em expressões regulares',
			'filter-rights-list-instructions': 'Filtre a lista de privilégios separados por espaços usando uma expressão regular.',
			'filter-other-list-instructions': 'Filtre a representação desta lista em texto simples usando uma expressão regular.',
			'filter-legend': 'Filtro para listas <li>',
			'filter-option-added': 'Direitos adicionados',
			'filter-option-removed': 'Direitos removidos',
			'filter-option-added-or-removed': 'Adicionado OU removido',
			'filter-option-added-removed-static': 'Adicionado/removido/estático',
			'filter-regex-label': 'Expressão regular:',
			'filter-invert-label': 'Inverter',
			'filter-case-label': 'Não distinguir maiúsculas e minúsculas',
			'filter-filter-button': 'Filtrar',
			'filter-highlight-button': 'Destacar',
			'filter-link-text': 'Link para esta lista filtrada'
		}
	},
	rightsLogOnly: (document.location.href.indexOf( 'type=rights' ) !== -1 || document.location.href.indexOf( 'Log/rights' ) !== -1),
	lastClicked: false,
	load: function() {
		var portletlink, int = filterLists.i18n.pl;

		// Define language fallbacks (such as for zh-cn)
		// filterLists.i18n['pt-br'] = filterLists.i18n.pt;

		// Replace default English interface by translation if available
		$.extend( true, int, filterLists.i18n[ mw.config.get( 'wgUserLanguage' ).split('-')[0] ], filterLists.i18n[ mw.config.get( 'wgUserLanguage' ) ] );

		// Define interface messages
		mw.messages.set( int );

		// Create portlet link
		portletlink = mw.util.addPortletLink(
			'p-cactions',
			'#',
			mw.msg( 'filter-portlet-text' ),
			'ca-rxfilter',
			mw.msg( 'filter-portlet-description' )
		);
		// Bind click handler
		$(portletlink).click( function( e ) {
			e.preventDefault();
			filterLists.buildForm();
		});
		// Display form direclty ?
		if ( window.AutoLoadLogsFilter || mw.util.getParamValue( 'lifilter' ) || mw.util.getParamValue( 'lifilterexpr' ) ) {
			filterLists.buildForm();
		}
	},

	getURL: function( showPopUp ) {
		var	data = {
				withgadget: 'rightsfilter',
				lifilter: '1',
				lifilterexpr: $( '#rfRegex' ).val()
			},
			url = window.location.href;
		if ( !$( '#rfCase' ).prop( 'checked' ) ) {
			data.lifiltercase = '1';
		}
		if ( this.lastClicked == '1' ) {
			data.lifilterhilight = '1';
		}
		if ( $( '#rfInvert' ).prop( 'checked' ) ) {
			data.lifilterinv = '1';
		}
		url += ( url.indexOf( '?' ) !== -1 ? '&' : '?' ) + $.param( data );
		if ( showPopUp ) {
			prompt( '', url );
		} else {
			return url;
		}
	},

	buildForm: function() {
		var	value, casing, inverted, fieldsetHtml, oldInput,
			$pageTop, $fieldSet, $legend, $sel,
			instructions = this.rightsLogOnly ?
				mw.msg( 'filter-rights-list-instructions' )
				: mw.msg( 'filter-other-list-instructions' );

		$( '#ca-rxfilter' ).hide();
		$pageTop = $( '#contentSub, #topbar' );
		if ( !$pageTop.length ) {
			return;
		}

		// Set up config
		value = mw.util.getParamValue( 'lifilterexpr' );
		casing = mw.util.getParamValue( 'lifiltercase' ) == '1';
		inverted = mw.util.getParamValue( 'lifilterinv' ) == '1';

		// Generate the form
		$fieldSet = $( '<fieldset id="rightsFilter"></fieldset>' ).text( instructions );
		$legend = $( '<legend></legend>' ).text( mw.msg( 'filter-legend' ) );
		$fieldSet.append( $legend );
		fieldsetHtml = '';

		if ( this.rightsLogOnly ) {
			fieldsetHtml += '<select id=rfSelect>';
			fieldsetHtml += '<option>' + mw.html.escape(mw.msg( 'filter-option-added' )) + '</option>';
			fieldsetHtml += '<option>' + mw.html.escape(mw.msg( 'filter-option-removed' )) + '</option>';
			fieldsetHtml += '<option>' + mw.html.escape(mw.msg( 'filter-option-added-or-removed' )) + '</option>';
			fieldsetHtml += '<option>' + mw.html.escape(mw.msg( 'filter-option-added-removed-static' )) + '</option>';
			fieldsetHtml += '</select>';
		}
		fieldsetHtml += '<label for="rfRegex">' + mw.html.escape(mw.msg( 'filter-regex-label' )) + '</label><input id="rfRegex">';
		fieldsetHtml += '<input id="rfInvert" type="checkbox"><label for="rfInvert">' + mw.html.escape(mw.msg( 'filter-invert-label' )) + '</label>';

		fieldsetHtml += '<input id="rfCase" type="checkbox"><label for="rfCase">' + mw.html.escape(mw.msg( 'filter-case-label' )) + '</label>';
		fieldsetHtml += '<button type="button" value="0">' + mw.html.escape(mw.msg( 'filter-filter-button' )) + '</button>';
		fieldsetHtml += '<button type="button" value="1">' + mw.html.escape(mw.msg( 'filter-highlight-button' )) + '</button>';
		fieldsetHtml += '<br/><a href="javascript:filterLists.getURL(true)">' + mw.html.escape(mw.msg( 'filter-link-text' )) + '</a>';

		// Inject the html into the fieldset
		$fieldSet.append( fieldsetHtml );

		$pageTop.after( $fieldSet );

		// Set passed values
		$( '#rfRegex ' ).val( value );
		$( '#rfCase' ).prop( 'checked', !casing );
		$( '#rfInvert' ).prop( 'checked', inverted );
		$( '#rfRegex' ).focus();

		// Bind click and change handlers
		$( '#rightsFilter' ).find( 'input' ).on( 'keyup change', function(e) {
			var $this = $( this ),
				curInput;
			if( $this.attr( 'id' ) !== 'rfRegex' ) {
				filterLists.filterLi();
				return;
			}
			curInput = $this.val();
			if ( oldInput !== curInput ){
				oldInput = curInput;
				filterLists.filterLi();
			}
		});
		$fieldSet.find( 'button' ).click( function(e) {
			filterLists.lastClicked = $(this).val();
			filterLists.filterLi();
		});

		if ( value ) {
			this.filterLi( mw.util.getParamValue( 'lifilterhilight' ) == '1' );
		}
	},

	filterLi: function(hilight) {
		var type, invert, search, flags, rx, listItems, rightrx;

		// Grab options from form
		if ( this.rightsLogOnly ) {
			type = $( '#rfSelect' ).attr( 'selectedIndex' );
		}
		invert = $( '#rfInvert' ).prop( 'checked' );
		search = $( '#rfRegex' ).val();
		flags = $( '#rfCase' ).prop( 'checked' ) ? 'ig' : 'g';
		hilight = ( hilight || this.lastClicked == '1' ) ? true : false;

		try{
			rx = new RegExp( search, flags );
		} catch (err){
			mw.log( err );
		}

		// Grab the list of all <li> in the content
		listItems = $( '#bodyContent' ).find( 'li' );
		if ( !listItems.length ) {
			return;
		}

		// The regex used to grab the Special:Log/rights changes
		rightrx = /^.*?User\:.*? from (.*?) to (.*?) \u200E.*?$/i;

		// Iterate
		listItems.each(function() {
			var look, oldr, newr, oldrl, newrl, remr, addr,
				$this = $(this);

			if ( this.rightsLogOnly ) {
				// Special:Log/rights
				oldr = $this.text().replace(rightrx, '$1' );
				newr = $this.text().replace(rightrx, '$2' );
				oldrl = oldr.split( ', ' );
				newrl = newr.split( ', ' );
				for ( var j = 0; j < oldrl.length; j++ ) {
					for ( var k = 0; k < newrl.length; k++ ) {
						if ( oldrl[j] == newrl[k] ) {
							oldrl[j] = '';
							newrl[k] = '';
						}
					}
				}
				remr = oldrl.join();
				addr = newrl.join();
				switch (type) {
					case 0:
						look = addr;
						break;
					case 1:
						look = remr;
						break;
					case 2:
						look = remr + ' ' + addr;
						break;
					case 3:
						look = oldr + ' ' + newr;
						break;
				}
			} else {
				//Any other list of <li> objects
				look = $this.text();
			}
			$this.show();
			$this.css( 'background-color', '' );
			if ( ( look.search( rx ) !== -1 && !invert ) || ( look.search( rx ) === -1 && invert ) ) {
				if ( hilight ) {
					$this.css( 'background-color', '#ffff99' );
				}
			} else {
				if ( !hilight ) {
					$this.hide();
				}
			}
		});
	}
};

// When to enable all this
$( document ).ready( function() {
	if (
		mw.config.get( 'wgAction' ) === 'history'
		|| mw.util.getParamValue( 'lifilter' )
		|| (
			mw.config.get( 'wgCanonicalSpecialPageName' )
			&& mw.config.get( 'wgCanonicalSpecialPageName' ).match(/^(Activeusers|CheckUser|Contributions|Ipblocklist|LinkSearch|Log|Search|(Uncategoriz|Unus|Want)ed(categori|templat)es|Wantedfiles|(Short|Long|Ancient|Uncategorized|Unwatched|Wanted|Protected|Deadend|Lonely|New)pages|Fewestrevisions|Withoutinterwiki|(Double|Broken)Redirects|Protectedtitles|CrossNamespaceLinks|Recentchanges|Categories|Disambiguations|Listredirects|GlobalUsers|GlobalBlockList|Listusers|Watchlist|Most(linked|revisions|categories)|Nuke|Whatlinkshere)$/i)
		)
	) {
		filterLists.load();
	}

});

} // end if guard