MediaWiki:Gadget-OnlineAdmins.js: Difference between revisions
From Test Wiki
Content deleted Content added
m MBisanz moved page User:1233thehongkonger/common.js to User:1233/common.js: Automatically moved page while renaming the user "1233thehongkonger" to "1233" |
No edit summary |
||
| Line 1: | Line 1: | ||
// About this program: |
|||
// This program was done with implementation of codes, and combined codes of both Alexander Misel and Vjudge1 |
|||
// Program was used for English Wikipedia only. For Chinese Wikipedia, please check in the Chinese Box |
|||
// Version: 1.2 |
|||
// Create Portlet Link |
|||
var portletLinkOnline = mw.util.addPortletLink( |
|||
'p-personal', |
|||
'#', |
|||
'Seek Help', |
|||
't-onlinehelp', |
|||
'Seek Help from Administrators, Rollbackers and Reviewers', |
|||
'', |
|||
'#pt-userpage' |
|||
); |
|||
var rcstart, rcend, time; |
|||
var users = []; |
|||
var admins = [], rollbackers = [], patrollers = []; |
|||
var api = new mw.Api(); |
|||
// Bind click handler |
|||
$(portletLinkOnline).click(function(e) { |
|||
e.preventDefault(); |
|||
users = []; |
|||
var usersExt = []; |
|||
admins = []; |
|||
rollbackers = []; |
|||
patrollers = []; |
|||
// Recent Changes Detector |
|||
time = new Date(); |
|||
rcstart = time.toISOString(); |
|||
time.setMinutes(time.getMinutes() - 15); |
|||
rcend = time.toISOSring(); |
|||
//API:RecentChanges, Remove Bots and others |
|||
api.get({ |
|||
format: 'json', |
|||
action: 'query', |
|||
list: 'recentchanges', |
|||
rcprop: 'user', |
|||
rcstart: rcstart, |
|||
rcend: rcend, |
|||
rcshow: '!bot|!anon', |
|||
rclimit: 500 |
|||
}).done(function(data) { |
|||
$.each(data.query.recentchanges, function(i, item) { |
|||
users[i] = item.user; |
|||
}); |
|||
api.get({ |
|||
format: 'json', |
|||
action: 'query', |
|||
list: 'logevents', |
|||
leprop: 'user', |
|||
lestart: rcstart, |
|||
leend: rcend, |
|||
lelimit: 500 |
|||
}).done(function(data) { |
|||
$.each(data.query.logevents, function(i, item) { |
|||
usersExt[i] = item.user; |
|||
}); |
|||
Array.prototype.push.apply(users, usersExt); |
|||
// Remove non-unique Usernames |
|||
users = $.unique(users.sort()); |
|||
var promises = []; |
|||
var mark = function(data) { |
|||
$.each(data.query.users, function(i, user) { |
|||
// 找到管理员,去除adminbot |
|||
if ($.inArray('bot', user.groups) === -1) { |
|||
if ($.inArray('sysop', user.groups) > -1) { |
|||
admins[i] = user.name; |
|||
} |
|||
if ($.inArray('rollbacker', user.groups) > -1) { |
|||
rollbackers[i] = user.name; |
|||
} |
|||
if ($.inArray('patroller', user.groups) > -1) { |
|||
patrollers[i] = user.name; |
|||
} |
|||
if ($.inArray('reviewer', user.groups) > -1) { |
|||
reviewers[i] = user.name; |
|||
} |
|||
} |
|||
}); |
|||
}; |
|||
for (var i=0; i<(users.length+50)/50; i++) { |
|||
promises.push(api.get({ |
|||
format: 'json', |
|||
action: 'query', |
|||
list: 'users', |
|||
ususers: users.slice(i*50, (i+1)*50).join('|'), |
|||
usprop: 'groups' |
|||
}).done(mark)); |
|||
} |
|||
// Check User Group |
|||
$.when.apply($, promises).done(function () { |
|||
// Remove Users without User Group |
|||
var filter = function(n) { |
|||
return n; |
|||
}; |
|||
admins = admins.filter(filter); |
|||
rollbackers = rollbackers.filter(filter); |
|||
patrollers = patrollers.filter(filter); |
|||
reviewers = reviewers.filter(filter); |
|||
var userlink = function(user) { |
|||
var user2 = user.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '<'); |
|||
return '<br><a href="/wiki/User:' + user2 + '" target="_blank">' + user2 + '</a> <small style="opacity:.75;">(<a href="/wiki/User talk:' + user2 + '" target="_blank">留言</a>)</small> '; |
|||
}; |
|||
if (admins.length + rollbackers.length + patrollers.length + reviewers.length > 0) { |
|||
var adminsstring = ['<p>Helpers Online</p>']; |
|||
if (admins.length > 0) { |
|||
adminsstring.push('<p style="word-break:break-all;">There are currently ' + admins.length + 'Administrators Online: '); |
|||
$.each(admins, function(i, e) { |
|||
adminsstring.push(userlink(e)); |
|||
}); |
|||
adminsstring.push('</p>'); |
|||
} |
|||
if (patrollers.length > 0) { |
|||
adminsstring.push('<p style="word-break:break-all;">There are currently' + patrollers.length + 'Patrollers Online:'); |
|||
$.each(patrollers, function(i, e) { |
|||
adminsstring.push(userlink(e)); |
|||
}); |
|||
adminsstring.push('</p>'); |
|||
} |
|||
if (rollbackers.length > 0) { |
|||
adminsstring.push('<p style="word-break:break-all;">There are currently' + rollbackers.length + 'Rollbackers Online:'); |
|||
$.each(rollbackers, function(i, e) { |
|||
adminsstring.push(userlink(e)); |
|||
}); |
|||
adminsstring.push('</p>'); |
|||
} |
|||
if (reviewers.length > 0) { |
|||
adminsstring.push('<p style="word-break:break-all;">There are currently' + reviewers.length + 'Pending Changes Reviewers Online:'); |
|||
$.each(reviewers, function(i, e) { |
|||
adminsstring.push(userlink(e)); |
|||
}); |
|||
adminsstring.push('</p>'); |
|||
} |
|||
mw.notify($(adminsstring.join(''))); |
|||
} else { |
|||
mw.notify('There are currently no Admins, Rollbacker, Reviewer and Rollbackers online'); |
|||
} |
|||
}).fail(function () { |
|||
mw.notify('Error at Query'); |
|||
}); |
|||
}); |
|||
}); |
|||
}); |
|||