MediaWiki:Common.js/file.js

/** * SVG images: adds links to rendered PNG images in different resolutions * @author: w:en:User:TheDJ * @source: w:en:MediaWiki:Common.js/file.js */ function SVGThumbs { var	file = document.getElementById( 'file' ), // might fail if MediaWiki can't render the SVG i18n = { 'en': 'This image rendered as PNG in other sizes: ', 'pt': 'Esta imagem pode ser renderizada em PNG em outros tamanhos: ' };	if ( file && mw.config.get( 'wgIsArticle' ) && mw.config.get( 'wgTitle' ).match( /\.svg$/i ) ) {

// Define language fallbacks i18n['en-gb'] = i18n.en; i18n['pt-br'] = i18n.pt; //i18n['zh-hant'] = i18n.zh;

// Define interface message mw.messages.set( {			'svg-thumbs-desc': i18n[ mw.config.get( 'wgUserLanguage' ) ] || i18n.en		} );

var thumbu = file.getElementsByTagName( 'IMG' )[0].getAttribute( 'src' ); if( !thumbu ) { return; }		var svgAltSize = function( w, title ) { var path = thumbu.replace( /\/\d+(px-[^\/]+$)/, '/' + w + '$1' ); var a = document.createElement( 'A' ); a.setAttribute( 'href', path ); a.appendChild( document.createTextNode( title ) ); return a;		};

var p = document.createElement( 'p' ); p.className = 'SVGThumbs'; p.appendChild( document.createTextNode( mw.msg( 'svg-thumbs-desc' ) ) ); var l = [ 200, 500, 1000, 2000 ]; for( var i = 0; i < l.length; i++ ) { p.appendChild( svgAltSize( l[i], l[i] + 'px' ) ); if( i < l.length-1 ) { p.appendChild( document.createTextNode( ', ' ) ); }               }		p.appendChild( document.createTextNode( '.' ) ); var info = getElementsByClassName( file.parentNode, 'div', 'fullMedia' )[0]; if( info ) { info.appendChild( p ); }	} } $( SVGThumbs );