MediaWiki:Gadget-tradLink.js
Questa pagina definisce alcuni parametri di aspetto e comportamento generale di tutte le pagine. Per personalizzarli vedi Aiuto:Stile utente.
Nota: dopo aver salvato è necessario pulire la cache del proprio browser per vedere i cambiamenti (per le pagine globali è comunque necessario attendere qualche minuto). Per Mozilla / Firefox / Safari: fare clic su Ricarica tenendo premuto il tasto delle maiuscole, oppure premere Ctrl-F5 o Ctrl-R (Command-R su Mac); per Chrome: premere Ctrl-Shift-R (Command-Shift-R su un Mac); per Konqueror: premere il pulsante Ricarica o il tasto F5; per Opera può essere necessario svuotare completamente la cache dal menù Strumenti → Preferenze; per Internet Explorer: mantenere premuto il tasto Ctrl mentre si preme il pulsante Aggiorna o premere Ctrl-F5.
/** 
 * Considera il testo selezionato come il titolo di una voce straniera, e lo
 * trasforma nel titolo dell'equivalente voce italiana
 */
/* global mediaWiki, jQuery, OO */
( function( mw, $ ) {
	'use strict';
	
	var cookieName = 'tradLinkLangs';
	var windowManager, optDialog;
	/**
	 * Mostra un errore relativo al dialog. Non possiamo usare OO.ui.alert() perché
	 * quello usa la sua window che viene messa sotto a quella del dialog.
	 * Codice basato sull'implementazione di OO.ui.alert()
	 *
	 * @param {string} text Messaggio di errore
	 */
	function showDialogError( text ) {
		windowManager.openWindow( 'message', {
			message: text,
			actions: [ OO.ui.MessageDialog.static.actions[ 0 ] ]
		} ).closed.then( function () {
			return undefined;
		} );
	}
	/** 
	 * Basato su [[Special:Permalink/109422525]] e gli esempi su mw.org
	 */
	function showDialog() {
		if ( optDialog ) {
			windowManager.openWindow( optDialog );
			return;
		}
		mw.util.addCSS( '.tradlinks-buttons { width: 100%; text-align: center; margin-top: 10px }' );
		function OptDialog( config ) {
			OptDialog.parent.call( this, config );
		}
		// TODO Valutare se sia possibile usare un ProcessDialog
		OO.inheritClass( OptDialog, OO.ui.Dialog );
		OptDialog.static.name = 'optDialog';
		// XXX Questo non viene visualizzato nei Dialog di base
		OptDialog.static.title = 'Configurazione del tool TradLink';
		OptDialog.prototype.initialize = function () {
			var self = this;
			OptDialog.parent.prototype.initialize.call( this );
			this.fields = [];
			var lingue = getLingue();
			var count = 1;
			lingue.forEach( function( val ) {
				var input = new OO.ui.TextInputWidget( { 
					value: val || '',
					maxLength: 3
				} );
				var field = new OO.ui.FieldLayout(
					input,
					{
						label: 'Alt+' + count + ':',
						align: 'left'
					}
				);
				self.fields.push( field );
				count++;
			} );
			
			var fieldsetLayout = new OO.ui.FieldsetLayout( {
				items: this.fields,
				label: 'Elenco delle lingue da utilizzare per il tool TradLink'
			} );
			var submitButton = new OO.ui.ButtonWidget(
				{ label: 'Imposta' }
			).on( 'click', function () { submitDialogHandler( self.fields ); } );
			var cancelButton = new OO.ui.ButtonWidget(
				{ label: 'Annulla' }
			).on( 'click', function () { optDialog.close(); } );
			var buttonsLayout = new OO.ui.HorizontalLayout( {
				items: [ submitButton, cancelButton ],
				classes: [ 'tradlinks-buttons' ]
			} );
			this.panelLayout = new OO.ui.PanelLayout( { padded: true, expanded: false } );
			this.panelLayout.$element.append( fieldsetLayout.$element, buttonsLayout.$element );
			this.$body.append( this.panelLayout.$element );
		};
		OptDialog.prototype.getBodyHeight = function () {
			return this.panelLayout.$element.outerHeight( true );
		};
		optDialog = new OptDialog( {
			size: 'small'
		} );
		windowManager = new OO.ui.WindowManager();
		$( 'body' ).append( windowManager.$element );
		windowManager.addWindows( [ optDialog, new OO.ui.MessageDialog() ] );
		windowManager.openWindow( optDialog );
	}
	/**
	 * Valida l'aggiunta di nuove lingue
	 * @param {array} formFields
	 */
	function submitDialogHandler( formFields ) {
		new mw.Api().get( {
			action: "sitematrix",
			smtype: "language",
			smlangprop: "code|site",
			smsiteprop: "url",
			smlimit: 5000,
			format: "json"
		} ).done( function ( data ) {
			var lingue = formFields.map( function( f ) {
				return f.fieldWidget.getValue().trim();
			} );
			var filteredMatrix = {};
			for ( var i in data.sitematrix ) {
				var siteData = data.sitematrix[i];
				if ( lingue.indexOf( siteData.code ) > -1 ) {
					filteredMatrix[siteData.code] = siteData;
				}
			}
					
			for ( var j in lingue ) {
				var code = lingue[j];
				if ( code === 'it' ) {
					showDialogError( 'Il codice "it" non può essere usato' );
					return;
				}
				if ( !( code in filteredMatrix ) ) {
					showDialogError( 'Codice lingua non riconosciuto: ' + code );
					return;
				}
				var found = false;
				for ( var s in filteredMatrix[code] ) {
					if ( filteredMatrix[code][s].url.indexOf( '.wikipedia.org' ) > -1 ) {
						found = true;
						break;
					}
				}
				if ( !found ) {
					showDialogError( 'Non esiste una Wikipedia nella seguente lingua: ' + code );
					return;
				}
			}
			mw.cookie.set( cookieName, lingue.join(), 20 * 365 * 24 * 60 * 60 * 1000 );
			optDialog.close();
		} ).fail( function ( e ) {
			console.error( 'Impossibile ottenere sitematrix: ' + e );
		} );
	}
	/**
	 * @return {array} Di codici lingua
	 */
	function getLingue() {
		var value = mw.cookie.get( cookieName );
		return value !== null
			? value.split( ',' ).slice( 0, 9 )
			: [ 'en', 'nl', 'de', 'sv', 'fr', 'ru', 'es', 'war', 'vi' ];
	}
	/**
	 * Routine principale
	 * @param {int} cod Indice della lingua (0-based)
	 */
	function tradLink( cod ) {
		var lingue = getLingue();
		if ( lingue[cod] === 'it' ) {
			// TODO Validare l'input per evitare questo caso
			return;
		}
		new mw.ForeignApi( '//' + lingue[cod] + '.wikipedia.org/w/api.php' ).get( {
			action: "query",
			prop: "langlinks",
			lllang: "it",
			titles: $( '#wpTextbox1' ).textSelection( 'getSelection' ),
			format: "json",
			redirects: ""
		} ).done( function( data ) {
			var selStart = document.getElementById( 'wpTextbox1' ).selectionStart,
				selEnd = document.getElementById( 'wpTextbox1' ).selectionEnd;
			if (
				typeof( data.query ) != "undefined" &&
				typeof( data.query.pages ) != "undefined"
			) {
				for ( var key in data.query.pages ) {
					if ( typeof( data.query.pages[ key ] ) != "undefined" &&
						typeof( data.query.pages[ key ].langlinks ) != "undefined" &&
						typeof( data.query.pages[ key ].langlinks[ 0 ] ) != "undefined" &&
						typeof( data.query.pages[ key ].langlinks[ 0 ][ "*" ] ) != "undefined"
					) {
						var trad = data.query.pages[ key ].langlinks[ 0 ][ "*" ];
						$( '#wpTextbox1' ).textSelection( 'encapsulateSelection', {
							pre: trad + "[",
							post: "]"
						} );
						document.getElementById( 'wpTextbox1' ).selectionStart = selStart + trad.length;
						document.getElementById( 'wpTextbox1' ).selectionEnd = selEnd + trad.length + 2;
						return;
					}
				}
			}
			var noLinkLabel = "[NO LINK]";
			$( '#wpTextbox1' ).textSelection( 'encapsulateSelection', {
				pre: "",
				post: noLinkLabel
			} );
			document.getElementById( 'wpTextbox1' ).selectionStart = selEnd;
			document.getElementById( 'wpTextbox1' ).selectionEnd = selEnd + noLinkLabel.length;
		} );
	}
	// setup hotkeys
	$( '#wpTextbox1' ).keydown( function( event ) {
		if ( event.altKey && !event.shiftKey && !event.ctrlKey && !event.metaKey ) {
			if ( event.which === 48 ) {
				event.preventDefault();
				mw.loader.using( [ 'oojs-ui-core', 'oojs-ui-widgets', 'oojs-ui-windows', 'mediawiki.widgets' ] )
					.done( showDialog )
					.fail( function() { console.error( 'Errore configurazione tradLink' ); } );
			} else if ( event.which >= 49 && event.which < 57 ) {
				event.preventDefault();
				tradLink( event.which - 49 );
			}
		}
	} );
}( mediaWiki, jQuery ) );