User:Bosco/MediaWiki:Gadget-MarkRights.js: Difference between revisions

From Test Wiki
Content deleted Content added
+autoconfirmed,但不提供樣式,想要的人可自訂
mNo edit summary
 
(27 intermediate revisions by 4 users not shown)
Line 11: Line 11:
$(function () {
$(function () {
var groups = {
var groups = {
'abusefilter-admin': {list: [], class: "markrights-abusefilter-admin"},
// 全站管理型权限
'abusefilter-restricted': {list: [], class: "markrights-abusefilter-restricted"},
autopatrol: {list: [], class: "markrights-autopatrol"},
autoreview: {list: [], class: "markrights-autoreview"},
blockedfromchat: {list: [], class: "markrights-blockedfromchat"},
bot: {list: [], class: "markrights-bot"},
bureaucrat: {list: [], class: "markrights-bureaucrat"},
bureaucrat: {list: [], class: "markrights-bureaucrat"},
chatmod: {list: [], class: "markrights-chatmod"},
checkuser: {list: [], class: "markrights-checkuser"},
checkuser: {list: [], class: "markrights-checkuser"},
oversight: {list: [], class: "markrights-oversight"},
'checkuser-temporary-account': {list: [], class: "markrights-checkuser-temporary-account"},
sysop: {list: [], class: "markrights-sysop"},
confirmed: {list: [], class: "markrights-confirmed"},
electionadmin: {list: [], class: "markrights-electionadmin"},
'interface-admin': {list: [], class: "markrights-interface-admin"},
'interface-admin': {list: [], class: "markrights-interface-admin"},
'interwiki-admin': {list: [], class: "markrights-interwiki-admin"},
// 页面管理型权限
//'non-stewardsuppress': {list: [], class: "markrights-non-stewardsuppress"},
patroller: {list: [], class: "markrights-patroller"},
patroller: {list: [], class: "markrights-patroller"},
rollbacker: {list: [], class: "markrights-rollbacker"},
'push-subscription-manager': {list: [], class: "markrights-push-subscription-manager"},
autoreviewer: {list: [], class: "markrights-autoreviewer"},
reviewer: {list: [], class: "markrights-reviewer"},
suppress: {list: [], class: "markrights-suppress"},
// 大量操作型权限
accountcreator: {list: [], class: "markrights-accountcreator"},
sysop: {list: [], class: "markrights-sysop"},
'massmessage-sender': {list: [], class: "markrights-massmessage-sender"},
translationadmin: {list: [], class: "markrights-translationadmin"},
steward: {list: [], class: "markrights-steward"},
// 确认权限
confirmed: {list: [], class: "markrights-confirmed"},
sysadmin: {list: [], class: "markrights-sysadmin"},
autoconfirmed: {list: [], class: "markrights-autoconfirmed"},
autoconfirmed: {list: [], class: "markrights-autoconfirmed"},
// 机器权限
bot: {list: [], class: "markrights-bot"},
flood: {list: [], class: "markrights-flood"},
// IPBE
'ipblock-exempt': {list: [], class: "markrights-ipblock-exempt"},
};
};
var markUG = function () {
var markUG = function () {
Line 42: Line 45:
var queue1 = [];
var queue1 = [];
var queue2 = [];
var queue2 = [];
var i=0, n=0;
var i = 0, n = 0;
for (var user in users) {
for (var user in users) {
queue1.push(user);
queue1.push(user);
Line 57: Line 60:
n++;
n++;
}
}

var getUsername = function (url) {
var username = mw.util.getParamValue('title', url);
var decode1 = function (username) {
return decodeURIComponent((function (u) {
try {
return decodeURIComponent(u.replace('User:', '').replace(/_/g, ' '));
} catch (e) {
return u.replace('User:', '').replace(/_/g, ' ').replace(/%(?!\d+)/g, '%25');
}
})(username))
};
if (username) {
return decode1(username);
}
username = url.match(/\/wiki\/User:(.+?)$/);
var decode2 = function (username) {
return decodeURIComponent((function (u) {
try {
return decodeURIComponent(u.replace(/_/g, ' '));
} catch (e) {
return u.replace(/_/g, ' ').replace(/%(?!\d+)/g, '%25');
}
})(username))
};
if (username) {
return decode2(username[1]);
}
return null;
};


var done = function () {
var done = function () {
var group, user, j;
var group;
for (group in groups) {
$('a.mw-userlink:not(.mw-anonuserlink)').each(function (i, el) {
if (groups.hasOwnProperty(group)) {
var username = getUsername($(el).attr('href'));
for (j=0; j<groups[group].list.length; j++) {
if (username) {
$('a.mw-userlink[title="User:' + groups[group].list[j] + '"]').append('<sup class="' + groups[group].class + '"></sup>');
for (group in groups) {
if (groups.hasOwnProperty(group)) {
if (groups[group].list.indexOf(username) > -1) {
$(el).append('<sup class="' + groups[group].class + '"></sup>');
}
}
}
}
}
}
}
});
};
};


Line 76: Line 114:
users = [];
users = [];
}
}
for (var i=0; i<users.length; i++) {
for (var i = 0; i < users.length; i++) {
var user = users[i];
var user = users[i];
if (user.groups) {
if (user.groups) {
Line 91: Line 129:
}
}
};
};
var api = new mw.Api();
var api = new mw.Api({ userAgent: 'Gadget-MarkRights' });
for (var j=0; j<queue2.length; j++) {
for (var j = 0; j < queue2.length; j++) {
api.get({
api.get({
format: 'json',
format: 'json',
Line 102: Line 140:
}
}
};
};
mw.hook('wikipage.content').add(function(e) {
markUG();
if (e.attr('id') === 'mw-content-text') {
markUG();
return;
}
if (e.hasClass('mw-changeslist')) markUG();
});
});
});