User:DR/UserInfoEN.js: Difference between revisions
< User:DR
(test) |
(clean up, test) |
||
Line 14: | Line 14: | ||
function UserinfoJsFormatDateRel(old) { | function UserinfoJsFormatDateRel(old) { | ||
var age = new Date().getTime() - old.getTime(); | |||
var ageNumber, ageRemainder, ageWords; | |||
if(age < 60000) { | |||
ageNumber = Math.floor(age / 1000); | |||
ageWords = UserinfoJsFormatQty(ageNumber, "second", "seconds"); | |||
} else if(age < 3600000) { | |||
ageNumber = Math.floor(age / 60000); | |||
ageWords = UserinfoJsFormatQty(ageNumber, "minute", "minutes"); | |||
} else if(age < 86400000) { | |||
ageNumber = Math.floor(age / 3600000); | |||
ageWords = UserinfoJsFormatQty(ageNumber, "hour", "hours"); | |||
ageRemainder = Math.floor((age - ageNumber * 3600000) / 60000); | |||
} else if(age < 604800000) { | |||
ageNumber = Math.floor(age / 86400000); | |||
ageWords = UserinfoJsFormatQty(ageNumber, "day", "days"); | |||
} else if(age < 2592000000) { | |||
ageNumber = Math.floor(age / 604800000); | |||
ageWords = UserinfoJsFormatQty(ageNumber, "week", "weeks"); | |||
} else if(age < 31536000000) { | |||
ageNumber = Math.floor(age / 2592000000); | |||
ageWords = UserinfoJsFormatQty(ageNumber, "month", "months"); | |||
} else { | |||
ageNumber = Math.floor(age / 31536000000); | |||
ageWords = UserinfoJsFormatQty(ageNumber, "year", "years"); | |||
ageRemainder = Math.floor((age - ageNumber * 31536000000) / 2592000000); | |||
if(ageRemainder) { | |||
ageWords += " " + UserinfoJsFormatQty(ageRemainder, "month", "months"); | |||
} | |||
} | |||
return ageWords; | |||
} | } | ||
if((mw.config.get("wgNamespaceNumber") == 2 || mw.config.get("wgNamespaceNumber") == 3) && !(/\//.test(mw.config.get("wgTitle")))) { | if((mw.config.get("wgNamespaceNumber") == 2 || mw.config.get("wgNamespaceNumber") == 3) && !(/\//.test(mw.config.get("wgTitle")))) { | ||
mw.loader.using( ['mediawiki.util'], function() { $(function(){ | mw.loader.using( ['mediawiki.util'], function() { $(function(){ | ||
var et = encodeURIComponent(mw.config.get("wgTitle")); | var et = encodeURIComponent(mw.config.get("wgTitle")); | ||
$.getJSON(mw.config.get("wgScriptPath") + "/api.php?format=json&action=query&list=users|usercontribs&usprop=blockinfo|editcount|gender|registration|groups&uclimit=1&ucprop=timestamp&ususers=" + et + "&ucuser=" + et + "&meta=allmessages&refix=grouppage-&amincludelocal=1") | $.getJSON(mw.config.get("wgScriptPath") + "/api.php?format=json&action=query&list=users|usercontribs&usprop=blockinfo|editcount|gender|registration|groups&uclimit=1&ucprop=timestamp&ususers=" + et + "&ucuser=" + et + "&meta=allmessages&refix=grouppage-&amincludelocal=1") | ||
.done(function(query) { | .done(function(query) { | ||
if(!query.query) { return; } | |||
if(!query.query) { return; } | |||
query = query.query; | query = query.query; | ||
var user, invalid, missing, groups, groupPages={}, editcount, registration, blocked, gender, lastEdited; | var user, invalid, missing, groups, groupPages={}, editcount, registration, blocked, gender, lastEdited; | ||
Line 84: | Line 69: | ||
new Date(query.usercontribs[0].timestamp) : null; | new Date(query.usercontribs[0].timestamp) : null; | ||
for (var am=0; am<query.allmessages.length; am++) { | for (var am=0; am<query.allmessages.length; am++) { | ||
groupPages[query.allmessages[am].name.replace("grouppage-","")] = query.allmessages[am]["*"].replace("{{ns:project}}:","Project:"); | |||
} | } | ||
} catch(e) { | } catch(e) { | ||
return; | return; | ||
} | } | ||
var userf, userf2, userf3; | var userf, userf2, userf3; | ||
switch(gender) { | |||
case "male": | |||
userf = "", userf2 = "er", userf3 = "er"; | |||
break; | |||
case "female": | |||
userf = "e", userf2 = "ress", userf3 = "ress"; | |||
break; | |||
default: | |||
userf = "", userf2 = "er", userf3 = "er"; | |||
} | |||
var statusText = ""; | var statusText = ""; | ||
var ipUser = false; | var ipUser = false; | ||
Line 115: | Line 98: | ||
ipUser = ipv4User || ipv6User; | ipUser = ipv4User || ipv6User; | ||
if (ipv4User) { | if (ipv4User) { | ||
statusText += "IPv4 | statusText += "anonymous IPv4 user"; | ||
} else if (ipv6User) { | } else if (ipv6User) { | ||
statusText += "IPv6 | statusText += "anonymous IPv6 user"; | ||
} else { | } else { | ||
statusText += "invalid username"; | statusText += "invalid username"; | ||
} | } | ||
} else { | } else { | ||
var friendlyGroupNames = { | var friendlyGroupNames = { | ||
'*': false, | '*': false, | ||
'user': false, | 'user': false, | ||
autoconfirmed: "autoconfirmed" + userf, | autoconfirmed: "autoconfirmed" + userf, | ||
sysop: "administrator" + userf2, | sysop: "administrator" + userf2, | ||
'interface-admin': " | 'interface-admin': "interface administrator" + userf2, | ||
bureaucrat: "bureaucrat", | bureaucrat: "bureaucrat", | ||
checkuser: "checkuser" + userf2, | |||
developer: "developer", | |||
accountcreator: "account creator", | |||
steward: "steward", | steward: "steward", | ||
autopatrol: "autopatrolled" + userf2, | |||
translateadmin: "translation" + userf2 + " admin", | |||
'import': "importer" + userf2, | 'import': "importer" + userf2, | ||
transwiki: "transwiki" + userf2 | transwiki: "transwiki importer" + userf2, | ||
'ipblock-exempt': " | 'ipblock-exempt': "IP block exempt", | ||
oversight: "oversighter" | oversight: "oversighter", | ||
confirmed: "confirmed | confirmed: "confirmed user", | ||
abusefilter: " | abusefilter: "abuse filter editor", | ||
'abusefilter-helper': " | 'abusefilter-helper': "abuse filter helper", | ||
autoreviewer: "autoreviewer" | autoreviewer: "autoreviewer", | ||
epcoordinator: "Education Program course coordinator", | epcoordinator: "Education Program course coordinator", | ||
epcampus: "Education Program campus volunteer", | epcampus: "Education Program campus volunteer", | ||
Line 155: | Line 135: | ||
extendedconfirmed: "extended confirmed user", | extendedconfirmed: "extended confirmed user", | ||
extendedmover: "page mover", | extendedmover: "page mover", | ||
'flow-bot': " | 'flow-bot': "Flow bot", | ||
reviewer: "pending changes reviewer", | reviewer: "pending changes reviewer", | ||
suppress: " | suppress: "suppress", | ||
bot: "bot", | bot: "bot", | ||
patroller: "patroller" | patroller: "patroller" | ||
}; | }; | ||
var friendlyGroups = []; | var friendlyGroups = []; | ||
for(var i = 0; i < groups.length; ++i) { | for(var i = 0; i < groups.length; ++i) { | ||
var s = groups[i]; | |||
var t = friendlyGroupNames.hasOwnProperty(s) ? friendlyGroupNames[s] : s; | var t = friendlyGroupNames.hasOwnProperty(s) ? friendlyGroupNames[s] : s; | ||
if (t) { | if (t) { | ||
if (groupPages.hasOwnProperty(s)) { | |||
friendlyGroups.push("<a href=\"/wiki/" + encodeURIComponent( groupPages[s] ) + "\">" + t + "</a>"); | |||
} else { | |||
friendlyGroups.push(t); | |||
} | |||
} | } | ||
} | } | ||
switch(friendlyGroups.length) { | switch(friendlyGroups.length) { | ||
case 0: | case 0: | ||
if(blocked) { | if(blocked) { | ||
statusText += "user" | statusText += "blocked user"; | ||
} else { | } else { | ||
statusText += "registered | statusText += "registered user"; | ||
} | } | ||
break; | break; | ||
Line 190: | Line 166: | ||
break; | break; | ||
case 2: | case 2: | ||
statusText += friendlyGroups[0] + " | statusText += friendlyGroups[0] + " and " + friendlyGroups[1]; | ||
break; | break; | ||
default: | default: | ||
statusText += friendlyGroups.slice(0, -1).join(", ") + | statusText += friendlyGroups.slice(0, -1).join(", ") + | ||
" and " + friendlyGroups[friendlyGroups.length - 1]; | ", and " + friendlyGroups[friendlyGroups.length - 1]; | ||
break; | break; | ||
} | } | ||
} | } | ||
if(blocked) { | if(blocked) { | ||
statusText += "<a href=\"" + mw.config.get("wgScriptPath") + | statusText += "<a href=\"" + mw.config.get("wgScriptPath") + | ||
"/index.php?title=Special:Log&page=" + | "/index.php?title=Special:Log&page=" + | ||
encodeURIComponent(mw.config.get("wgFormattedNamespaces")[2] + ":" + user.name) + | encodeURIComponent(mw.config.get("wgFormattedNamespaces")[2] + ":" + user.name) + | ||
"&type=block\"> | "&type=block\"> blocked</a>"; | ||
} | } | ||
if(registration) { | if(registration) { | ||
var firstLoggedUser = new Date("17:42, 22 January 2008"); | |||
if(registration >= firstLoggedUser) { | |||
statusText += ", registered " + UserinfoJsFormatDateRel(registration) + " ago"; | |||
} else { | |||
statusText += ", registered " + UserinfoJsFormatDateRel(registration) + " ago"; | |||
} | |||
} | } | ||
if(editcount !== null) { | if(editcount !== null) { | ||
statusText += " with " + | statusText += ", with " + | ||
"<a href=\"https:// | "<a href=\"https://en.wikipedia.org/wiki/Special:Contributions/" + | ||
encodeURIComponent(user.name) + "\">" + | encodeURIComponent(user.name) + "\">" + | ||
UserinfoJsFormatQty(editcount, "edit", "edits") + "</a>"; | UserinfoJsFormatQty(editcount, "edit", "edits") + "</a>"; | ||
} | } | ||
if("AEIOaeio".indexOf(statusText.charAt(statusText.indexOf('>')+1)) >= 0) { | if("AEIOaeio".indexOf(statusText.charAt(statusText.indexOf('>')+1)) >= 0) { | ||
statusText = "An | statusText = "An " + statusText; | ||
} else { | } else { | ||
statusText = "A | statusText = "A " + statusText; | ||
} | } | ||
if(lastEdited) { | if(lastEdited) { | ||
statusText += "."; | |||
} | } | ||
if(lastEdited) { | if(lastEdited) { | ||
statusText += " Last edited | statusText += " Last edited " + UserinfoJsFormatDateRel(lastEdited) + " ago"; | ||
} | }; | ||
var fh = document.getElementById("firstHeading") || | var fh = document.getElementById("firstHeading") || | ||
document.getElementById("section-0"); | document.getElementById("section-0"); | ||
var newClasses = []; | var newClasses = []; | ||
if(blocked) { | if(blocked) { | ||
Line 276: | Line 242: | ||
genderSpan.appendChild(document.createTextNode(genderSymbol)); | genderSpan.appendChild(document.createTextNode(genderSymbol)); | ||
fh.appendChild(genderSpan); | fh.appendChild(genderSpan); | ||
var ss = document.getElementById("siteSub"); | var ss = document.getElementById("siteSub"); | ||
Line 293: | Line 256: | ||
}); }); | }); }); | ||
} | } | ||
/* </nowiki> */ | /* </nowiki> */ |
Revision as of 11:17, 9 April 2024
/* {{Catégorisation JS}}<nowiki> */
/* imported from fr vikidia*/
// Basé sur [[wp:en:User:Fran Rogers/dimorphism.js]] et [[wp:en:User:Splarka/sysopdectector.js]] ;
// Modifié et retravaillé par Bulest85 et Matteo1234321.
// Traduction en --> fr par Matteo1234321
// (n'hésitez surtout pas à vous plaindre du fait qu'il ne sait pas parler anglais car c'est une vérité)
// Fonction qui met au pluriel au besoin.
function UserinfoJsFormatQty(qty, singular, plural) {
return String(qty).replace(/\d{1,3}(?=(\d{3})+(?!\d))/g, "$& ") + "\u00a0" + (qty == 1 ? singular : plural);
}
function UserinfoJsFormatDateRel(old) {
var age = new Date().getTime() - old.getTime();
var ageNumber, ageRemainder, ageWords;
if(age < 60000) {
ageNumber = Math.floor(age / 1000);
ageWords = UserinfoJsFormatQty(ageNumber, "second", "seconds");
} else if(age < 3600000) {
ageNumber = Math.floor(age / 60000);
ageWords = UserinfoJsFormatQty(ageNumber, "minute", "minutes");
} else if(age < 86400000) {
ageNumber = Math.floor(age / 3600000);
ageWords = UserinfoJsFormatQty(ageNumber, "hour", "hours");
ageRemainder = Math.floor((age - ageNumber * 3600000) / 60000);
} else if(age < 604800000) {
ageNumber = Math.floor(age / 86400000);
ageWords = UserinfoJsFormatQty(ageNumber, "day", "days");
} else if(age < 2592000000) {
ageNumber = Math.floor(age / 604800000);
ageWords = UserinfoJsFormatQty(ageNumber, "week", "weeks");
} else if(age < 31536000000) {
ageNumber = Math.floor(age / 2592000000);
ageWords = UserinfoJsFormatQty(ageNumber, "month", "months");
} else {
ageNumber = Math.floor(age / 31536000000);
ageWords = UserinfoJsFormatQty(ageNumber, "year", "years");
ageRemainder = Math.floor((age - ageNumber * 31536000000) / 2592000000);
if(ageRemainder) {
ageWords += " " + UserinfoJsFormatQty(ageRemainder, "month", "months");
}
}
return ageWords;
}
if((mw.config.get("wgNamespaceNumber") == 2 || mw.config.get("wgNamespaceNumber") == 3) && !(/\//.test(mw.config.get("wgTitle")))) {
mw.loader.using( ['mediawiki.util'], function() { $(function(){
var et = encodeURIComponent(mw.config.get("wgTitle"));
$.getJSON(mw.config.get("wgScriptPath") + "/api.php?format=json&action=query&list=users|usercontribs&usprop=blockinfo|editcount|gender|registration|groups&uclimit=1&ucprop=timestamp&ususers=" + et + "&ucuser=" + et + "&meta=allmessages&refix=grouppage-&amincludelocal=1")
.done(function(query) {
if(!query.query) { return; }
query = query.query;
var user, invalid, missing, groups, groupPages={}, editcount, registration, blocked, gender, lastEdited;
try {
user = query.users[0];
invalid = typeof user.invalid != "undefined";
missing = typeof user.missing != "undefined";
groups = (typeof user.groups == "object") ? user.groups : [];
editcount = (typeof user.editcount == "number") ? user.editcount : null;
registration = (typeof user.registration == "string") ?
new Date(user.registration) : null;
blocked = typeof user.blockedby != "undefined";
gender = (typeof user.gender == "string") ? user.gender : null;
lastEdited = (typeof query.usercontribs[0] == "object") &&
(typeof query.usercontribs[0].timestamp == "string") ?
new Date(query.usercontribs[0].timestamp) : null;
for (var am=0; am<query.allmessages.length; am++) {
groupPages[query.allmessages[am].name.replace("grouppage-","")] = query.allmessages[am]["*"].replace("{{ns:project}}:","Project:");
}
} catch(e) {
return;
}
var userf, userf2, userf3;
switch(gender) {
case "male":
userf = "", userf2 = "er", userf3 = "er";
break;
case "female":
userf = "e", userf2 = "ress", userf3 = "ress";
break;
default:
userf = "", userf2 = "er", userf3 = "er";
}
var statusText = "";
var ipUser = false;
var ipv4User = false;
var ipv6User = false;
if (missing) {
statusText += "unregistered username";
} else if (invalid) {
ipv4User = mw.util.isIPv4Address(user.name);
ipv6User = mw.util.isIPv6Address(user.name);
ipUser = ipv4User || ipv6User;
if (ipv4User) {
statusText += "anonymous IPv4 user";
} else if (ipv6User) {
statusText += "anonymous IPv6 user";
} else {
statusText += "invalid username";
}
} else {
var friendlyGroupNames = {
'*': false,
'user': false,
autoconfirmed: "autoconfirmed" + userf,
sysop: "administrator" + userf2,
'interface-admin': "interface administrator" + userf2,
bureaucrat: "bureaucrat",
checkuser: "checkuser" + userf2,
developer: "developer",
accountcreator: "account creator",
steward: "steward",
autopatrol: "autopatrolled" + userf2,
translateadmin: "translation" + userf2 + " admin",
'import': "importer" + userf2,
transwiki: "transwiki importer" + userf2,
'ipblock-exempt': "IP block exempt",
oversight: "oversighter",
confirmed: "confirmed user",
abusefilter: "abuse filter editor",
'abusefilter-helper': "abuse filter helper",
autoreviewer: "autoreviewer",
epcoordinator: "Education Program course coordinator",
epcampus: "Education Program campus volunteer",
epinstructor: "Education Program instructor",
eponline: "Education Program online volunteer",
filemover: "file mover",
'massmessage-sender': "mass message sender",
templateeditor: "template editor",
extendedconfirmed: "extended confirmed user",
extendedmover: "page mover",
'flow-bot': "Flow bot",
reviewer: "pending changes reviewer",
suppress: "suppress",
bot: "bot",
patroller: "patroller"
};
var friendlyGroups = [];
for(var i = 0; i < groups.length; ++i) {
var s = groups[i];
var t = friendlyGroupNames.hasOwnProperty(s) ? friendlyGroupNames[s] : s;
if (t) {
if (groupPages.hasOwnProperty(s)) {
friendlyGroups.push("<a href=\"/wiki/" + encodeURIComponent( groupPages[s] ) + "\">" + t + "</a>");
} else {
friendlyGroups.push(t);
}
}
}
switch(friendlyGroups.length) {
case 0:
if(blocked) {
statusText += "blocked user";
} else {
statusText += "registered user";
}
break;
case 1:
statusText += friendlyGroups[0];
break;
case 2:
statusText += friendlyGroups[0] + " and " + friendlyGroups[1];
break;
default:
statusText += friendlyGroups.slice(0, -1).join(", ") +
", and " + friendlyGroups[friendlyGroups.length - 1];
break;
}
}
if(blocked) {
statusText += "<a href=\"" + mw.config.get("wgScriptPath") +
"/index.php?title=Special:Log&page=" +
encodeURIComponent(mw.config.get("wgFormattedNamespaces")[2] + ":" + user.name) +
"&type=block\"> blocked</a>";
}
if(registration) {
var firstLoggedUser = new Date("17:42, 22 January 2008");
if(registration >= firstLoggedUser) {
statusText += ", registered " + UserinfoJsFormatDateRel(registration) + " ago";
} else {
statusText += ", registered " + UserinfoJsFormatDateRel(registration) + " ago";
}
}
if(editcount !== null) {
statusText += ", with " +
"<a href=\"https://en.wikipedia.org/wiki/Special:Contributions/" +
encodeURIComponent(user.name) + "\">" +
UserinfoJsFormatQty(editcount, "edit", "edits") + "</a>";
}
if("AEIOaeio".indexOf(statusText.charAt(statusText.indexOf('>')+1)) >= 0) {
statusText = "An " + statusText;
} else {
statusText = "A " + statusText;
}
if(lastEdited) {
statusText += ".";
}
if(lastEdited) {
statusText += " Last edited " + UserinfoJsFormatDateRel(lastEdited) + " ago";
};
var fh = document.getElementById("firstHeading") ||
document.getElementById("section-0");
var newClasses = [];
if(blocked) {
newClasses.push("ps-blocked");
}
if(ipUser) {
newClasses.push("ps-anonymous");
} else if(invalid) {
newClasses.push("ps-invalid");
} else {
newClasses.push("ps-registered");
}
fh.className += (fh.className.length ? " " : "") + groups.map(function(s) {
return "ps-group-" + s;
}).concat(newClasses).join(" ");
var genderSpan = document.createElement("span");
genderSpan.id = "ps-gender-" + (gender || "unknown");
genderSpan.style.paddingLeft = "0.25em";
genderSpan.style.fontFamily = '"Lucida Grande", "Lucida Sans Unicode", "sans-serif"';
genderSpan.style.fontSize = "75%";
var genderSymbol;
switch(gender) {
case "male": genderSymbol = "\u2642"; break;
case "female": genderSymbol = "\u2640"; break;
default: genderSymbol = "";
}
genderSpan.appendChild(document.createTextNode(genderSymbol));
fh.appendChild(genderSpan);
var ss = document.getElementById("siteSub");
if(!ss) {
ss = document.createElement("div");
ss.id = "siteSub";
ss.innerHTML = "";
var bc = document.getElementById("bodyContent");
bc.insertBefore(ss, bc.firstChild);
}
ss.innerHTML = '<span id="ps-userinfo">' + statusText + '</span>' + ss.innerHTML + '.';
ss.style.display = "block";
});
}); });
}
/* </nowiki> */