Gebruiker:Felix2036/monobook.js
Opmerking: na het publiceren moet je misschien je browsercache legen om de veranderingen te zien.
- Firefox / Safari: houd Shift ingedrukt terwijl u:je op Vernieuwen klikt of druk op Ctrl-F5 of Ctrl-R (⌘-Shift-R op een Mac)
- Google Chrome: druk op Ctrl-Shift-R (⌘-Shift-R op een Mac)
- Edge: houd Ctrl ingedrukt terwijl u:je op Vernieuwen klikt of druk op Ctrl-F5.
// <pre>
// Dit script leest de meest recente bewerkingen van een pagina
// uit de MediaWiki API en plaatst die in een box in de zijbalk
// boven de navigatie na het indrukken van een knop. In de box staan de
// gebruikersnamen met een link naar de betreffende paragraaf.
// Voor de naam staat het tijdstip van de bewerking met een
// link die een diff met het verschil tussen de vorige bewerking
// boven de pagina plaatst. In de tooltip staat de bewerkingssamenvatting.
// Auteur: Gebruiker:JePe
function removeDiff()
{
var diffFrame = document.getElementById("revisionsBoxDiff");
if (diffFrame) diffFrame.parentNode.removeChild(diffFrame);
}
function processDiff()
{
if (diffReq.readyState != 4) return;
if (diffReq.status != 200) return;
var bodyContent = document.getElementById("bodyContent");
var diffFrame = document.createElement("div");
diffFrame.id = "revisionsBoxDiff";
diffFrame.innerHTML = diffReq.responseText;
diffTable = diffFrame.getElementsByTagName("table")[0];
if (!diffTable) return;
if (diffTable.className != "diff") return;
diffTable.style.border = "1px solid #ccc";
diffTable.style.width = "100%";
diffTable.style.paddingBottom = ".5em";
diffTable.style.marginBottom = "1em";
diffTable.style.marginTop = ".5em";
var closeButton = document.createElement("img");
closeButton.style.cssFloat = "left";
closeButton.style.styleFloat = "left";
closeButton.onclick = removeDiff;
closeButton.title = closeButtonTitle;
closeButton.src = "http://upload.wikimedia.org/wikipedia/commons/1/14/Red_x_small.PNG";
closeButton.height = "11";
closeButton.width = "11";
var otitle = diffTable.getElementsByTagName("td");
for (i=0; i < otitle.length; i++) {
if (otitle[i].className == "diff-otitle") {
otitle[i].insertBefore(closeButton, otitle[i].firstChild); }
}
var diffFrameOld = document.getElementById("revisionsBoxDiff");
if (diffFrameOld) diffFrameOld.parentNode.removeChild(diffFrameOld);
bodyContent.parentNode.insertBefore(diffFrame,bodyContent);
window.location.hash = "revisionsBoxDiff";
var prevLink = document.getElementById("differences-prevlink");
if (prevLink) {
var oldid = prevLink.href.replace(/[\s\S]+&oldid=(\d+)[\s\S]*/,"$1");
prevLink.href = "javascript:loadDiff("+oldid+",'prev')"; }
var nextLink = document.getElementById("differences-nextlink");
if (nextLink) {
var oldid = nextLink.href.replace(/[\s\S]+&oldid=(\d+)[\s\S]*/,"$1");
nextLink.href = "javascript:loadDiff("+oldid+",'next')"; }
}
function loadDiff(oldid,diffDir)
{
var url = "/w/index.php?title=" + wgPageName;
url += "&diff=" + diffDir;
url += "&oldid=" + oldid;
url += "&diffonly=1&action=render";
if (window.XMLHttpRequest) { // native XMLHttpRequest
diffReq = new XMLHttpRequest();
diffReq.onreadystatechange = processDiff;
diffReq.open("GET", url, true);
diffReq.send(null);
} else if (window.ActiveXObject) { // activeX version
diffReq = new ActiveXObject("Microsoft.XMLHTTP");
if (diffReq) {
diffReq.onreadystatechange = processDiff;
diffReq.open("GET", url, true);
diffReq.send("");
}
}
}
function nextRevisions()
{
var content = document.getElementById("recRevContent");
var divNode = content.appendChild(document.createElement("div"));
divNode.id = "revisionsButton";
divNode.style.textAlign = "center";
var button = divNode.appendChild(document.createElement("button"));
button.innerHTML = buttonNextText;
button.title = buttonNextTitle;
button.onclick = loadXMLDoc;
button.style.fontSize = "90%";
button.style.marginTop = ".3em";
button.style.padding = "0";
}
function writeResults(rev)
{
var revisionsButton = document.getElementById('revisionsButton');
if (revisionsButton) revisionsButton.parentNode.removeChild(revisionsButton);
var content = document.getElementById("recRevContent");
var date = new Date();
var dateNow = (date.getFullYear()*10000) + ((date.getMonth()+1)*100) + date.getDate();
for (i = 0; i < rev.length; i++) {
var time = rev[i].getAttribute("timestamp");
var year = time.replace(/^(\d\d\d\d)[\s\S]+/,"$1");
var month = time.replace(/^\d\d\d\d-(\d\d)[\s\S]+/,"$1");
var day = time.replace(/^\d\d\d\d-\d\d-(\d\d)[\s\S]+/,"$1");
var hours = time.replace(/[\s\S]+T(\d\d)[\s\S]+/,"$1");
var minutes = time.replace(/[\s\S]+T\d\d:(\d\d)[\s\S]+/,"$1");
date.setUTCFullYear(year,month-1,day);
date.setUTCHours(hours,minutes);
var dateRevision = (date.getFullYear()*10000) + ((date.getMonth()+1)*100) + date.getDate();
if (dateRevision < dateControl) {
var divNodeDate = content.appendChild(document.createElement("div"));
divNodeDate.style.fontSize = "95%";
divNodeDate.style.marginTop = ".3em";
divNodeDate.style.fontWeight = "bold";
divNodeDate.style.paddingLeft = ".5em";
divNodeDate.innerHTML = date.getDate() + " " + monthName[date.getMonth()];
if (dateNow - dateRevision > 10000) divNodeDate.innerHTML += " " + date.getFullYear();
dateControl = dateRevision;
}
var divNode = content.appendChild(document.createElement("div"));
divNode.style.marginLeft = "1em";
divNode.style.textIndent = "-1em";
divNode.style.fontSize = "95%";
divNode.style.marginTop = ".3em";
var aNodeTime = divNode.appendChild(document.createElement("a"));
aNodeTime.innerHTML = (date.getHours() < 10) ? "0" + date.getHours() : date.getHours();
aNodeTime.innerHTML += ":";
aNodeTime.innerHTML += (date.getMinutes() < 10) ? "0" + date.getMinutes() : date.getMinutes();
aNodeTime.style.fontSize = "90%";
var revid = rev[i].getAttribute("revid");
aNodeTime.href = "javascript:loadDiff("+revid+",'prev')";
aNodeTime.title = timeTitle;
divNode.appendChild(document.createTextNode(" "));
var aNodeUser = divNode.appendChild(document.createElement("a"));
aNodeUser.innerHTML = rev[i].getAttribute("user");
var anchorURL = rev[i].getAttribute("comment");
if (anchorURL == null) anchorURL = "";
aNodeUser.title = anchorURL;
// convert comment into a usable anchor link
if (anchorURL.search(/\/\*\s([\s\S]+)\s\*\/[\s\S]*/) != -1) {
var reg = [ [/\/\*\s([\s\S]+)\s\*\/[\s\S]*/,"$1"], [/\[\[[\s\S]*\|([\s\S]+)\]\]/g,"$1"],
[/\[\[\:?([\s\S]+)\]\]/g,"$1"], [/\s/g,"_"] ];
for (x = 0; x < reg.length; x++) {
anchorURL = anchorURL.replace(reg[x][0],reg[x][1]); }
anchorURL = encodeURIComponent(anchorURL);
var reg = [ [/%/g,"."], [/\(/g,".28"], [/\)/g,".29"], [/\!/g,".21"],
[/\'/g,".27"], [/\*/g,".2A"], [/.3A/g,":"] ];
for (x = 0; x < reg.length; x++) {
anchorURL = anchorURL.replace(reg[x][0],reg[x][1]); }
} else {
anchorURL = ""; }
aNodeUser.href = document.location.href + "#" + anchorURL;
aNodeUser.href = aNodeUser.href.replace(/##/,"#");
}
}
function processReq()
{
if (apiReq.readyState != 4) return;
if (apiReq.status != 200) return;
var xmlFile = apiReq.responseXML.documentElement;
var rev = xmlFile.getElementsByTagName("rev");
if (rev.length > 0) writeResults(rev);
queryContinue = xmlFile.getElementsByTagName("query-continue")[0];
if (queryContinue) {
rvStartId = queryContinue.getElementsByTagName("revisions")[0].getAttribute("rvstartid");
nextRevisions();
}
}
function loadXMLDoc()
{
var url = "/w/api.php?action=query&prop=revisions&format=xml";
url += "&titles=" + wgPageName + "&rvprop=timestamp|user|comment";
url += "&rvlimit=" + revCount;
if (rvStartId) url += "&rvstartid=" + rvStartId;
if (window.XMLHttpRequest) { // native XMLHttpRequest
apiReq = new XMLHttpRequest();
apiReq.onreadystatechange = processReq;
apiReq.open("GET", url, true);
apiReq.send(null);
} else if (window.ActiveXObject) { // activeX version
apiReq = new ActiveXObject("Microsoft.XMLHTTP");
if (apiReq) {
apiReq.onreadystatechange = processReq;
apiReq.open("GET", url, true);
apiReq.send("");
}
}
}
function recentRevisions()
{
var toolbox = document.getElementById('p-navigation');
var revbox = document.createElement("div");
var revbox = toolbox.parentNode.insertBefore(document.createElement("div"),toolbox);
revbox.id = "p-rev";
revbox.className = "portlet";
var h5Node = revbox.appendChild(document.createElement("h5"));
h5Node.innerHTML = revBoxTitle;
var content = revbox.appendChild(document.createElement("div"));
content.id = "recRevContent";
content.className = "pBody";
content.style.padding = "0 .3em .3em .3em";
content.style.lineHeight = "1.2em";
content.style.fontFamily = "Verdana, sans-serif";
var divNode = content.appendChild(document.createElement("div"));
divNode.id = "revisionsButton";
divNode.style.textAlign = "center";
var button = divNode.appendChild(document.createElement("button"));
button.innerHTML = buttonBeginText;
button.onclick = loadXMLDoc;
button.style.fontSize = "90%";
button.style.marginTop = ".3em";
button.style.padding = "0";
}
var diffReq;
var apiReq;
var rvStartId;
var revCount = 20;
var dateControl = 99999999; // must only be higher than today (yyyymmdd)
if (wgUserLanguage == "nl") {
var timeTitle = "Verschillen met de vorige bewerking";
var closeButtonTitle = "Sluit dit frame";
var revBoxTitle = "recente bewerkingen";
var buttonBeginText = "Toon bewerkingen";
var buttonNextText = "Volgende " + revCount;
var buttonNextTitle = "Toon de volgende "+revCount+" bewerkingen";
var monthName = ["januari", "februari", "maart", "april", "mei", "juni", "juli",
"augustus", "september", "oktober", "november", "december"];
} else {
var timeTitle = "Differences with the previous revision";
var closeButtonTitle = "Close this frame";
var revBoxTitle = "recent revisions";
var buttonBeginText = "Show revisions";
var buttonNextText = "Next " + revCount;
var buttonNextTitle = "Show the next "+revCount+" revisions";
var monthName = ["January", "February", "March", "April", "May", "June", "July",
"August", "September", "October", "November", "December"];
}
document.write('<style type="text/css">/*<![CDATA[*/ table.diff td {vertical-align:top;} /*]]>*/</style>');
if (wgNamespaceNumber != -1)
addOnloadHook(recentRevisions);
// </pre>