User:TChin (WMF)/ActiveUsersDemo.js

$( function {	if ( !$( '.mw-activeusergadget-section' ).length ) {		return;	}

const RECENT = 'recent'; const THISYEAR = 'thisyear'; const OVERAYEAR = 'overayear'; const localizedUserNamespace = mw.config.get( 'wgFormattedNamespaces' )[2];

const messages = { en: { recent: 'Edited recently', thisyear: 'Edited this year', overayear: 'Edited over a year ago' },		de: { recent: 'kürzlich bearbeitet', thisyear: 'in diesem Jahr bearbeitet', overayear: 'vor über einem Jahr bearbeitet' }	};

const localizedMessages = function { const lang = mw.config.get( 'wgUserLanguage' ); if ( lang in messages ) { return messages[lang]; }		return messages.en; };

const getLastActiveMarker = function ( timestamp ) { const date = Date.parse( timestamp ); const now = Date.now; const diff = Math.floor( ( now - date ) / ( 1000 * 60 * 60 * 24 ) ); var timespan = RECENT; if ( diff > 365 ) { timespan = OVERAYEAR; } else if ( diff > 30 ) { timespan = THISYEAR; }		const iconPath = mw.config.get( 'wgServer' ) + mw.config.get( 'wgScriptPath' ) + '/resources/lib/ooui/themes/wikimediaui/images/icons/userContributions-ltr.svg'; const marker = "" + " " + localizedMessages[timespan] + " "; return $( marker ); };

mw.loader.using( [ 'mediawiki.api' ], function {		$( '.mw-activeusergadget-section a[title^="User:"]' ).each( function { const link = $( this ); const userRegex = new RegExp(`${localizedUserNamespace}:(.*?)(?=&|\/|$)`); // const userRegex = /User:(.*?)(?=&|\/|$)/g; const href = link.attr( 'href' ); const username = href.match(userRegex)[0]; const x = href.split(username); // console.log(username); console.log(decodeURI(username)) if (x[1].charAt(0) === '/') { return; }			const api = new mw.Api; api.get( {				format: 'json',				action: 'query',				list: 'usercontribs',				uclimit: '1',				ucuser: decodeURI(username)			} ).then( function ( result ) {				if ( result.query.usercontribs.length ) {					const timestamp = result.query.usercontribs[0].timestamp;					getLastActiveMarker( timestamp ).insertAfter( link );				}			} ); } );	} ); } );