MediaWiki:Gadget-markadmins.js: Difference between revisions
Jump to navigation
Jump to search
m Undo revision 20691 by Dmehus (talk) Reverting change; the administrator markers no longer display for me Tags: Undo Reverted |
Tag: Undo |
||
Line 1: | Line 1: | ||
// rewritten by [[m:User:Hoo man]]; 2012-08-26, adapted by [[User:Obersachse]], optimized by [[User:Jack who built the house]] | // rewritten by [[m:User:Hoo man]]; 2012-08-26, adapted by [[User:Obersachse]], optimized by [[User:Jack who built the house]] | ||
// For attribution: [[MediaWiki:Gadget-markadmins.js]] | |||
(function () { | (function () { | ||
var userSet; | var userSet; | ||
var userSetTips = { | var userSetTips = { | ||
'A' : 'administrator', | 'A' : 'administrator', | ||
'B' : ' | 'B' : 'bureaucrat', | ||
'C' : 'checkuser', | 'C' : 'checkuser', | ||
'F' : 'interface administrator', | 'F' : 'interface administrator', | ||
'S' : ' | 'S' : 'steward', | ||
'SA':' | 'SA': 'system administrator', | ||
}; | }; | ||
Line 31: | Line 30: | ||
); | ); | ||
} | } | ||
var $links = $content.find('a[title^="User"], a[title^="Talk"]'); | var $links = $content.find('a[title^="User"], a[title^="Talk"]'); | ||
if (runNum === 2) { | if (runNum === 2) { | ||
if ($links.length === prevLinksCount) { | if ($links.length === prevLinksCount) { | ||
Line 53: | Line 50: | ||
} | } | ||
new mw.Api().get({ | |||
action: 'query', | |||
list: 'allusers', | |||
}).done(function (ans) { | augroup: 'sysop|bureaucrat|checkuser|interface-admin|steward|sysadmin', | ||
userSet = | auprop: 'groups', | ||
aulimit: 500, | |||
format: 'json', | |||
formatversion: 2 | |||
}).done(function(ans) { | |||
var list = ans.query.allusers, | |||
groups = ['sysop', 'bureaucrat', 'checkuser', 'interface-admin', 'steward', 'sysadmin'], | |||
key = ['A', 'B', 'C', 'F', 'S', 'SA'], | |||
userSet = {}; | |||
for (let i = 0; i < key.length; i++) { | |||
userSet[key[i]] = []; | |||
} | |||
for (let i = 0; i < list.length; i++) { | |||
for (let j = 0; j < groups.length; j++) { | |||
if (list[i].groups.includes(groups[j])) { | |||
userSet[key[j]].push(list[i].name); | |||
} | |||
} | |||
} | |||
$links.each(function (i, link) { | $links.each(function (i, link) { | ||
if (!link.parentNode || | if (!link.parentNode || | ||
Line 70: | Line 87: | ||
matches = /^User:(.+)|Talk:(.+)/.exec(link.title); | matches = /^User:(.+)|Talk:(.+)/.exec(link.title); | ||
if (!matches) return; | if (!matches) return; | ||
if | if (matches[2]) { | ||
if ($(link).parent().hasClass('mw-usertoollinks') || link.textContent.match(/обс/i)) return; | if ($(link).parent().hasClass('mw-usertoollinks') || link.textContent.match(/обс/i)) return; | ||
matches[1] = matches[2]; | matches[1] = matches[2]; | ||
Line 77: | Line 93: | ||
return; | return; | ||
} | } | ||
user = decodeURIComponent(matches[1]); | user = decodeURIComponent(matches[1]); | ||
if (link.href.indexOf('redlink=1') !== -1) { | if (link.href.indexOf('redlink=1') !== -1) { | ||
user = user.replace(/ \([^\)]+\)$/, ''); | user = user.replace(/ \([^\)]+\)$/, ''); | ||
} | } | ||
for (flag in userSet) { | for (flag in userSet) { | ||
if (userSet[flag].indexOf(user) !== -1 && userSetTips[flag]) { | if (userSet[flag].indexOf(user) !== -1 && userSetTips[flag]) { | ||
Line 90: | Line 106: | ||
} | } | ||
if (!flags.length) return; | if (!flags.length) return; | ||
tips = ' (' + tips.join(', ') + ')'; | tips = ' (' + tips.join(', ') + ')'; | ||
var spanElem = document.createElement('span'); | var spanElem = document.createElement('span'); |