Ajuda:Página de testes/1
/** Anti-vandal tool
* Monitorização de mudanças recentes * @source: Wikipedia:Software/antivandaltool.js * @see: Wikipédia:Software/Anti-vandal tool * @author: w:en:User:Lupin * @author: w:en:User:Cacycle */
recent2 = { // Edit these to your liking. // Make sure there's a comma at the end of each line. badwordsUrl: 'Wikipédia:Software/Anti-vandal_tool/badwords', filterPage: 'Wikipédia:Software/Anti-vandal_tool/Filtro_de_mudan%C3%A7as_recentes', allRecentPage: 'Wikipédia:Software/Anti-vandal_tool/Todas_mudan%C3%A7as_recentes', recentIPPage: 'Wikipédia:Software/Anti-vandal_tool/Edi%C3%A7%C3%B5es_IP_recentes', monitorWatchlistPage: 'Wikipédia:Software/Anti-vandal_tool/Monitorizar_vigiados', spelldictUrl: 'Wikipédia:Software/Anti-vandal_tool/Ortografia', spelldictPage: 'Wikipédia:Software/Anti-vandal_tool/Monitorizar_ortografia', safePages: '([Ww]ikipédia:([Ee]splanada[/](anúncios|propostas|geral)|' + '[Cc]afé[ _]d[oa]s[ _](categorizadores|tradutores|exatas|humanas|biomédicas|novatos)|' + '[Cc]oordenação[ _]robótica|[Cc]ontato[/][Ll]inha[ _]direta|[Pp]ágina[ _]de[ _]testes)|' + '[Ee]special[:][Ll]og[/](move|delete|newusers|block))', linkify: true, // leave this alone dummy: null };
recent2.download = function (bundle) {
// mandatory: bundle.url
// optional: bundle.onSuccess (xmlhttprequest, bundle)
// optional: bundle.onFailure (xmlhttprequest, bundle)
// optional: bundle.otherStuff OK too, passed to onSuccess and onFailure
var x = window.XMLHttpRequest ? new XMLHttpRequest()
: window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP")
: false;
if (x) { x.onreadystatechange = function () { //FIXME: Expected an assignment or function call and instead saw an expression. x.readyState == 4 && recent2.downloadComplete(x, bundle); }; x.open("GET", bundle.url, true); x.send(null); } return x; };
recent2.downloadComplete = function (x, bundle) { //FIXME: Expected an assignment or function call and instead saw an expression. x.status == 200 && ( bundle.onSuccess && bundle.onSuccess(x, bundle) || true) || ( bundle.onFailure && bundle.onFailure(x, bundle) || alert(x.statusText)); };
if (!recent2.outputPosition) { recent2.outputPosition = ; } window.gettingBadWords = false; window.badWords = null;
// paths if (typeof (mw.config.get('wgServer')) != 'string' || typeof (mw.config.get('wgArticlePath')) != 'string' || typeof (mw.config.get('wgScriptPath')) != 'string') { recent2.articlePath = 'http://' + document.location.hostname + '/wiki/'; recent2.scriptPath = 'http://' + document.location.hostname + '/w/'; } else { recent2.articlePath = mw.config.get('wgServer') + mw.config.get('wgArticlePath').replace(/\$1/, ); recent2.scriptPath = mw.config.get('wgServer') + mw.config.get('wgScriptPath') + '/'; } //TODO: Use jQuery recent2.getBadWords = function () { window.gettingBadWords = true; recent2.download({ url: recent2.scriptPath + 'index.php?title=' + recent2.badwordsUrl + '&action=raw&ctype=text/css', onSuccess: recent2.processBadWords, onFailure: function () { setTimeout(recent2.getBadWords, 15000); return true; } }); };
window.diffCellRe = RegExp("\\+<\\/td>\\s*" + "<td\\b[^>]*>\\s*
// processBadWords: generate the badWords RegExp from
// the downloaded data.
// d is the xmlhttprequest object from the download
recent2.processBadWords = function (d) {
var data = d.responseText.split('\n');
var ret = [];
for (var i = 0; i < data.length; ++i) {
var s = data[i];
// ignore empty lines, whitespace-only lines and lines starting with '<' if (/^\s*$|^</.test(s)) { continue; }
// lines beginning and ending with a slash (and possibly trailing // whitespace) are treated as regexps if (RegExp('^/.*/\\s*$').test(s)) { // remove slashes and trailing whitespace s = s.replace(RegExp('^/'), ).replace(RegExp('/\\s*$'), ); // escape opening parens: ( -> (?: s = s.replace(RegExp('[(]([^?])', 'g'), '(?:$1');
// check that s represents a valid regexp try { var r = new RegExp(s); } catch (err) { var errDiv = newOutputDiv('recent2_error', recent2.outputPosition); errDiv.innerHTML = 'Aviso: a ignorar expressão regular na linha ' + i + ' da lista <a href="/wiki/' + recent2.badwordsUrl +
'">badwords</a>:' + s + '';
continue; }
ret.push(s);
} else { // treat this line as a non-regexp - // have to escape it. ret.push(s.replace(RegExp('([-|.()\\+:!,?*^${}\\[\\]])', 'g'), '\\$1')); } }
// 123 3 2|4 45 56 61 // ((( repeatedchar ) )|( )( ... | ... | ... )( )) window.badWords = RegExp("((([^-{}\\].\\s'=wI:*#0-9A-F])\\3{2,})|(^|[^\\/\\w])(" + ret.join('|') + ")(?![\\/\\w]))", 'gi'); };
window.gettingWatchlist = false; recent2.watchlist = null;
recent2.getWatchlist = function () { window.gettingWatchlist = true; recent2.download({ url: recent2.articlePath + 'Special:Watchlist/edit', onSuccess: recent2.processWatchlist, onFailure: function () { setTimeout(getWatchlist, 15000); return true; } }); };
recent2.processWatchlist = function (req, bundle) { var watchlist = {}; var lines = req.responseText.split('\n'); for (var i = 0; i < lines.length; ++i) {
if (lines[i].indexOf('';
recent2.delayedLines = {}; recent2.delay = 0; recent2.namespaces = { 'Media': 1, "Especial": 1, "Usuário": 1, "Usuário Discussão": 1, "Wikipédia": 1, "Wikipédia Discussão": 1, "Imagem": 1, "Imagem Discussão": 1, "MediaWiki": 1, "MediaWiki Discussão": 1, "Predefinição": 1, "Predefinição Discussão": 1, "Ajuda": 1, "Ajuda Discussão": 1, "Categoria": 1, "Categoria Discussão": 1, "Portal": 1, "Portal Discussão": 1 };
window.processRecentChanges = function (req, bundle) { recent2.initialId = processRecentChanges.id; recent2.latest = processRecentChanges.lastDate; var doc = req.responseXML.documentElement; if (doc) { recent2.items = doc.getElementsByTagName('item'); if (recent2.items) { recent2.itemsCurrent = recent2.items.length; if (recent2.itemsCurrent > 0) { recent2.bundleRef = bundle; processRecentChangesSingle(); // start processing one diff every 50 ms return; } } } processRecentChangesDisplay(bundle); return; };
recent2.safePagesRe = new RegExp('^' + recent2.safePages + '$'); recent2.changeDelay = 50; // delay between processing each diff, in ms window.nextChangeSoon = function (rightNow) { setTimeout(processRecentChangesSingle, rightNow ? 0 : recent2.changeDelay); };
// process single diff items delayed by a short timespan window.processRecentChangesSingle = function () { recent2.itemsCurrent--; var i = recent2.itemsCurrent, items = recent2.items, diffCell, badWord; if (i < 0) { processRecentChangesDisplay(recent2.bundleRef); return; }
var timestamp = Date.parse(getFirstTagContent(items[i], 'pubDate')); if (timestamp <= processRecentChanges.lastDate) { nextChangeSoon(true); return; } recent2.latest = (timestamp > recent2.latest) ? timestamp : recent2.latest;
var diffText = getFirstTagContent(items[i], 'description').split('').join('\n'); var editSummary = diffText.replace(RegExp('^(.*?)
[\\s\\S]*'), '$1');var editor = getFirstTagContent(items[i], 'creator') || getFirstTagContent(items[i], 'dc:creator');
if (recent2.ignore_my_edits && mw.config.get('wgUserName') == editor) { return; }
// NB article is the link attribute - a fully qualified URL var article = getFirstTagContent(items[i], 'link'); if (recent2.delayedLines[article] && recent2.delayedLines[article].editor != editor) { delete recent2.delayedLines[article]; }
if (recent2.filter_anonsOnly && !recent2.ipUserRegex.test(editor)) { nextChangeSoon(true); return; }
// articleTitle is the wgTitle thingy with spaces and all that var articleTitle = getFirstTagContent(items[i], 'title'); //console.info('articleTitle=%s', articleTitle); if (recent2.ignore_safe_pages && recent2.safePagesRe.test(articleTitle)) { //console.warn('Ignoring safe page %s', article); nextChangeSoon(true); return; }
if (recent2.hideNonArticles) { var namespace = articleTitle.replace(/:.*/, ); if (recent2.namespaces[namespace]) { nextChangeSoon(true); return; } }
// perhaps ignore talk pages if (!recent2.show_talkpages && articleTitle && /^Discussão:|^[^:]*?[_ ]discussão:/.test(articleTitle)) { nextChangeSoon(true); return; }
// perhaps restrict to watchlist articles if (recent2.filter_watchlist && articleTitle && !window.watchlist[ articleTitle .replace(/^Discussão:/, ) .replace(/[ _]discussão:/, ':') ]) { nextChangeSoon(true); return; }
// filter against badwords regexp if (recent2.filter_badwords) { var badMatch = null; var previousVandal = window.vandals[editor]; var matchesRe = ; var matchesPlain = ; diffCellRe.lastIndex = 0; diffCell = diffCellRe.exec(diffText); while (diffCell) { // get content of addition table cells, faster than direct fulltext search badWords.lastIndex = 0; // .test() is meant to be faster than a full match badMatch = badWords.test(diffCell[1]); if (badMatch) { break; } diffCell = diffCellRe.exec(diffText); } if (badMatch === true || previousVandal) { badWords.lastIndex = 0; var reMatch; while (diffCell && (reMatch = badWords.exec(diffCell[1]))) { badWord = reMatch[2] || reMatch[5]; // avoid legit article title occurrences if (articleTitle.toLowerCase().indexOf(badWord.toLowerCase()) < 0) { badWord = badWord.replace(/^\s+|\s+$/g, ); if (badWord !== ) { matchesPlain += badWord + ', '; badWord = badWord.replace(/([^\w ])/g, '\\$1'); matchesRe += badWord + '|'; } } } matchesRe = matchesRe.replace(/\|$/, ); matchesPlain = matchesPlain.replace(/, $/, ); if (!previousVandal && matchesRe === ) { nextChangeSoon(); return; } // highlighting var highlighted = diffCell && diffCell[1]; if (matchesRe) { highlighted = highlighted.replace( RegExp('(' + matchesRe + ')', 'g'), '$1'); } articleTitle = getFirstTagContent(items[i], 'title'); // linkify if (recent2.linkify) { highlighted = recent2.doLinkify(highlighted); diffText = recent2.doLinkify(diffText); }
if (previousVandal) { matchesPlain = '[Previously rolled back this editor] ' + matchesPlain; }
recent2.delayedLines[article] = { timestamp: timestamp, article: article, count: recent2.count, articleTitle: articleTitle, editor: editor, badWord: matchesPlain, badDiffFragment: highlighted, diff: diffText, summary: editSummary }; } } else if (recent2.filter_spelling) { var splMatch = null; diffCell = diffCellRe.exec(diffText); while (diffCell) { splMatch = spellRe.test(diffCell[1]); if (splMatch) { break; } diffCell = diffCellRe.exec(diffText); } if (splMatch) { splMatch = diffCell[1].match(spellRe); var misspelling = splMatch[1]; //.replace(/^\s*/, ); badWord = '<a href=\'javascript:recent2.correctSpelling("' + articleTitle.split("'").join("%27") + '","' + misspelling.split("'").join("%27") + '")\'>' + misspelling + '</a>'; diffText = diffText.replace( RegExp('(' + misspelling + ')', 'gi'), '$1' ); // linkify if (recent2.linkify) { diffText = recent2.doLinkify(diffText); } recent2.delayedLines[article] = { timestamp: timestamp, article: article, count: recent2.count, articleTitle: articleTitle, editor: editor, badWord: badWord, badDiffFragment: , diff: diffText, summary: editSummary }; } } else { article = getFirstTagContent(items[i], 'link'); articleTitle = getFirstTagContent(items[i], 'title'); if (recent2.CustomFilter && !recent2.CustomFilter({ timestamp: timestamp, article: article, articleTitle: articleTitle, editor: editor, diff: diffText, summary: editSummary })) { nextChangeSoon(); return; } // linkify if (recent2.linkify) { diffText = recent2.doLinkify(diffText); } recent2.delayedLines[article] = { timestamp: timestamp, article: article, count: recent2.count, articleTitle: articleTitle, editor: editor, diff: diffText, summary: editSummary }; } // schedule next iteration nextChangeSoon(); return; };
window.processRecentChangesDisplay = function (bundle) {
var output = recent2.getDelayedLineOutput();
//console.log(output);
var outputString = ;
if (recent2.outputPosition == 'top') {
outputString = output.join(recent2.outputSeparator);
} else {
for (var i = output.length - 1; i >= 0; --i) {
outputString += output[i] + (i > 0 ? recent2.outputSeparator : );
}
}
bundle.output.innerHTML += outputString;
if (recent2.wait_for_output) {
recent2.pauseOutput();
}
setTimeout(function () {
recent2.doPopups(bundle.output);
}, 300);
// overlap better than missing some out, i think; FIXME do this properly
processRecentChanges.lastDate = recent2.latest; // - 1;
var statusTail = greyFont + 'feito até às ' + formatTime(recent2.latest) + '';
if (processRecentChanges.id > recent2.initialId) {
statusTail += ' <a href="javascript:showHideDetailRange(' + recent2.initialId +
',' + processRecentChanges.id + ')">alternar detalhes</a> |';
if (recent2.autoexpand) {
setTimeout(function () { /* document.title=initialId+' '+processRecentChanges.id; */
showHideDetailRange(recent2.initialId, processRecentChanges.id);
}, 250);
}
}
statusTail += ' <a href="javascript:deleteEarlierOutputDivs(' + bundle.status.id +
')">limpar lista anterior</a>';
if (recent2.wait_for_output) {
statusTail += ' | <a href="javascript:recent2.unpauseOutputOnce()">mostrar novas edições</a>';
}
statusTail += '
';
bundle.status.innerHTML += statusTail;
return;
};
// linkify and popupsify wikilinks recent2.doLinkify = function (txt) { if (!txt) { return txt; } txt = txt.replace(/((https?|ftp):(\/\/[^\[\]\{\}\(\)<>\s]+|<[^>]*>)+)/g, function (p, p1) { p1 = p1.replace(/<[^>]*>/g, ); var url = encodeURI(p1); url = url.replace(/\"/g, '%22'); url = url.replace(/\'/g, '%27'); url = url.replace(/#/g, '%23'); var ti = p1.replace(/\"/g, '"'); return ('<a href="' + url + '" style="text-decoration:none;color:inherit;' + 'color:expression(parentElement.currentStyle.color);" title="' + ti + '">' + p + '</a>'); }); txt = txt.replace(/((\[\[)([^\|\[\]\{\}\n]*)([^\]\n]*)(\]\]))/g, function (p, p1, p2, p3) { p3 = p3.replace(/<[^>]*>/g, ); var url = encodeURI(p3); url = url.replace(/\"/g, '%22'); url = url.replace(/\'/g, '%27'); url = url.replace(/#/g, '%23'); url = recent2.articlePath + url; var ti = p3.replace(/\"/g, '"'); return ('<a href="' + url + '" style="text-decoration:none;color:inherit;' + 'color:expression(parentElement.currentStyle.color)" title="' + ti + '">' + p + '</a>'); }); return (txt); };
processRecentChanges.lastDate = 0; processRecentChanges.id = 0;
recent2.getDelayedLineOutput = function () { var ret = []; var id = processRecentChanges.id; for (var a in recent2.delayedLines) { if (recent2.delayedLines[a] && typeof recent2.delayedLines[a].count == typeof 1 && recent2.count - recent2.delayedLines[a].count >= recent2.delay) { recent2.delayedLines[a].id = id++; var line = (recent2.doLine(recent2.delayedLines[a])); if (line) { ret.push(line); } delete recent2.delayedLines[a]; } } processRecentChanges.id = id; return ret; };
window.deleteEarlierOutputDivs = function (cur) { for (var i = 0; i < outputDivs.length; ++i) { if (!outputDivs[i] || !outputDivs[i].id) { continue; } if (outputDivs[i].id >= 0 && outputDivs[i].id < cur) { // FIXME BUG: if we go from the bottom up, then we'll delete one too many or too few, or something :-) outputDivs[i].parentNode.removeChild(outputDivs[i]); outputDivs[i] = null; } } // scroll to the top if we're appending output to the bottom, to keep the div we've clicked visible after the deletions if (recent2.outputPosition != 'top') { document.location = '#'; } };
window.showHideDetailRange = function (start, end) { // use the first div to see if we should show or hide var div = document.getElementById('diff_div_' + start); if (!div) { alert('no such div: diff_div_' + start); return; } var state = false; // hide if (div.style.display == 'none') { state = true; } // show for (var i = start; i < end; ++i) { showHideDetail(i, true, state); } };
window.toggleSysopEdits = function () { var divs = document.getElementsByTagName('div'); for (var i = 0; i < divs.length; ++i) { if (divs[i].className == 'sysop_edit_line') { divs[i].style.display = (toggleSysopEdits.hidden ? 'none' : 'inline'); } } toggleSysopEdits.hidden = !toggleSysopEdits.hidden; };
window.bundles = {};
window.vandalColour = function (vandal) { var num = window.vandals[vandal]; if (!num) { return ; } switch (num) { case 1: return '#DDFFDD'; case 2: return '#BBFFBB'; } var i = 9 - (num - 3) * 2; if (i < 0) { i = 0; } return '#' + i + i + 'FF' + i + i; };
window.clickDetails = function (action, max) { if (!action) { action = 'show'; } if (!max) { max = document.links.length; } var count = 0; for (var i = 0; i < document.links.length && count < max; ++i) { if (document.links[i].innerHTML == action + ' details' && document.links[i].href.indexOf('javascript:') === 0) { ++count; eval(document.links[i].href.replace('javascript:', )); } } };
recent2.pendingLines = [];
recent2.unpauseOutputOnce = function () { //console.log('unpausing once'); if (recent2.pausedOutput) { recent2.togglePausedOutput(); recent2.togglePausedOutput(); } };
recent2.pauseOutput = function () { //console.log('pausing'); if (!recent2.pausedOutput) { recent2.togglePausedOutput(); } //console.log(recent2.pausedOutput); }; recent2.unpauseOutput = function () { //console.log('unpausing'); if (recent2.pausedOutput) { recent2.togglePausedOutput(); } //console.log(recent2.pausedOutput); };
recent2.togglePausedOutput = function () { if (!recent2.pausedOutput) { recent2.pausedOutput = true; return true; } else { recent2.pausedOutput = false; } var outputBuffer = ; while (recent2.pendingLines.length) { outputBuffer += recent2.doLine(recent2.pendingLines.pop()); if (recent2.pendingLines.length) { outputBuffer += recent2.outputSeparator; } } var pos = recent2.outputPosition; var output = newOutputDiv('recent2.lines', pos); output.innerHTML = outputBuffer; setTimeout(function () { recent2.doPopups(output); }, 300); return false; };
recent2.togglePaused = function () { if (!recent2.paused) { recent2.paused = true; return true; } recent2.paused = false; loopRecentChanges(loopRecentChanges.url, loopRecentChanges.iterations); return false; };
recent2.doLine = function (bundle) { if (recent2.pausedOutput) { recent2.pendingLines.push(bundle); return ; } //if (recent2.filter_spelling) { return recent2.doSpellLine(bundle); } var sysop = null; if (typeof sysops != 'undefined') { sysop = sysops.test(bundle.editor); } var lastDiffPage = bundle.article + '?diff=cur&oldid=prev'; bundle.url = lastDiffPage; saveBundle(bundle); var div = ; if (window.vandals[bundle.editor]) { if (window.vandals[bundle.editor] > 0) {
div = '} } else if (sysop) {
div = '}
return div + '' : );
};
recent2.correctSpelling = function (article, badword) { var url = recent2.articlePath + article + '?action=edit&autoclick=wpDiff&autominor=true'; var wl = badword.toLowerCase(); var cor = spelldict[wl]; if (!cor || !cor.length) { alert('Could not find an entry for ' + wl); return; } if (cor.length > 1) { var q = 'Que correcção deve ser usada?\nDigite um número ou outra correcção.\n'; for (var i = 0; i < cor.length; ++i) { q += '\n' + i + ': ' + cor[i]; } var ans = prompt(q); if (!ans) { return; } var num = parseInt(ans, 10); if (num > -1 && num < cor.length) { cor = cor[num]; } else { cor = ans; } } else { cor = cor[0]; } cor = cor.replace(/^ *| *$/g, ); url += '&autosummary=Corrigir%20ortografia:%20' + wl + '->' + cor; url += '&autoedit='; c0 = cor.charAt(0); wl0 = wl.charAt(0); b = '\\b'; url += ['s', b + wl + b, cor, 'g;'].join('#'); wl = wl0.toUpperCase() + wl.substring(1); cor = c0.toUpperCase() + cor.substring(1); url += ['s', b + wl + b, cor, 'g;'].join('#'); wl = wl.toUpperCase(); cor = cor.toUpperCase(); url += ['s', b + wl + b, cor, 'g;'].join('#'); window.open(url); };
window.saveBundle = function (bundle) { var z = {}; for (var prop in bundle) { z[prop] = bundle[prop]; } window.bundles[bundle.id] = z; };
window.vandals = {};
window.tryRollback = function (id) { if (recent2.non_admin_rollback) { recent2.tryNonAdminRollback(id); } else { recent2.tryAdminRollback(id); } };
recent2.getBundleVandal = function (id) { var b = window.bundles[id]; if (!b) { alert('No bundle! Please tell Lupin how to reproduce this error - it should not really happen.'); return null; } var vandal = b.editor; if (window.vandals[vandal] === null) { window.vandals[vandal] = 1; } else { window.vandals[vandal]++; } return b; };
recent2.tryAdminRollback = function (id) { var b = recent2.getBundleVandal(id); if (!b) { return; } var vandal = b.editor; var onSuccess = function (x, bundle) { //FIXME: This may not work depending on wgServer and wgScript
var rollRe = RegExp('<a href="(/w/index.php[^"]*?action=rollback[^"]*?from=([^&]*)[^"]*?)".*?
(<span[^>]*>)?(.*?)()?
[^<>]*?');
// match[0]: useless
// match[1]: url (escaped)
// match[2]: last editor (escaped)
// match[4]: last edit summary (wikiText - FIXME strip this to plain text)
var match = rollRe.exec(x.responseText);
if (!match) {
alert(
'A ferramenta de reversão não foi encontrada.' +
'\nSe não é um administrador, active a opção usar reversão para não administradores.\n' +
'Também é possível ter ocorrido um bug.'
);
return;
}
var lastEditor = match[2].split('+').join(' ');
var lastSummary = match[4];
// var vandal=b.editor; // from the closure
if (lastEditor != vandal) {
var summary = lastSummary.replace(RegExp('<[^>]*?>', 'g'), );
if (!summary) {
summary = lastSummary;
}
alert(
'Não foi possível reverter. Alguém editou entretanto a página.\n\nPágina: ' +
b.articleTitle + '\nVandal: ' + vandal + '\nLast editor: ' +
lastEditor + '\nEdit summary: ' + summary
);
return;
}
var rollbackUrl = match[1].split('&').join('&');
// confirm('Rollback edits by '+vandal + ' to '+b.articleTitle+'?') &&
window.open(rollbackUrl, '_blank');
};
var onFailure = function (x, bundle) {
alert(
'HTTP failed when trying to get rollback link in url\n' +
bundle.url + '\n\nHTTP status text: ' + x.statusText
);
return true;
};
recent2.download({
url: b.url,
onSuccess: onSuccess,
id: b.id,
onFailure: onFailure
});
};
recent2.tryNonAdminRollback = function (id) {
if (typeof (autoEdit) == 'undefined') {
alert(
'Para dispôr da funcionalidade de reversão para não administradores' +
' precisa do script Popups de navegação.'
);
return;
}
var b = recent2.getBundleVandal(id);
if (!b) {
return;
}
var vandal = b.editor;
var url = recent2.scriptPath + 'query.php?format=json&titles=' +
b.articleTitle + '&what=revisions&rvlimit=100&rvcomments';
var onSuccess = function (x, y) {
recent2.processHistoryQuery(x, y, b);
};
recent2.download({
url: url,
onSuccess: onSuccess,
id: b.id
}); // fixme: onFailure
};
recent2.processHistoryQuery = function (x, downloadBundle, bundle) {
var json = x.responseText,
edits;
try {
eval('var o=' + json);
var p = o.pages;
edits = recent2.anyChild(p).revisions;
} catch (someError) {
alert(
'JSON business failed.\n\n' + json.substring(0, 100) +
'\n\nCannot rollback.'
);
return;
}
var i;
for (i = 0; i < edits.length; ++i) {
if (edits[i].user != bundle.editor) {
break;
}
}
if (i === 0) {
alert(
'Não foi possível reverter. Alguém editou entretanto a página.\n\nPágina: ' +
bundle.articleTitle + '\nVandal: ' + bundle.editor + '\nLast editor: ' +
edits[0].user + '\nEdit summary: ' + edits[0].comment
);
return;
}
if (i == edits.length) {
alert(
bundle.editor + ' parece ser o único editor do artigo ' +
bundle.articleTitle + '.\n\nReversão interrompida.'
);
return;
}
var prevEditor = edits[i].user;
var prevRev = edits[i].revid;
var summary = 'Revertida a edição de [[Special:Contributions/' +
escape(bundle.editor) + '|' + escape(bundle.editor) + ']] para a edição de ' +
escape(prevEditor) + 'usando AVT';
summary = summary.split(' ').join('%20');
var url = bundle.article + '?action=edit&autosummary=' + summary + '&oldid=' +
prevRev + '&autoclick=wpSave&autominor=true';
window.open(url, '_blank');
};
//recent2.non_admin_rollback=true;
recent2.anyChild = function (obj) {
for (var p in obj) {
return obj[p];
}
return null;
};
recent2.doPopups = function (div) {
if (typeof (window.setupTooltips) != 'undefined') {
setupTooltips(div);
}
};
window.formatTime = function (timestamp) {
var date = new Date(timestamp);
var nums = [date.getHours(), date.getMinutes(), date.getSeconds()];
for (var i = 0; i < nums.length; ++i) {
if (nums[i] < 10) {
nums[i] = '0' + nums[i];
}
}
return nums.join(':');
};
window.showHideDetail = function (id, force, state) {
var div = document.getElementById('diff_div_' + id);
var lk = document.getElementById('showdiff_link_' + id);
if (!div) {
return;
}
var bundle = window.bundles[id];
if (!div.innerHTML) {
div.innerHTML = (bundle.badDiffFragment ? bundle.badDiffFragment : ) + bundle.diff;
}
if ((force && state === true) || (!force && div.style.display == 'none')) {
div.style.display = 'inline';
lk.innerHTML = 'esconder ';
} else {
div.style.display = 'none';
lk.innerHTML = 'expandir ';
}
};
window.getFirstTagContent = function (parent, tag) {
var e = parent.getElementsByTagName(tag);
if (e && (e = e[0])) {
var ret = e.firstChild.nodeValue || e.nodeValue;
if (typeof ret != typeof ) {
return ;
}
return ret;
}
};
recent2.newCheckbox = function (label, state, action, internalName) {
// checkbox
var ret = document.createElement('input');
ret.type = 'checkbox';
ret.checked = state;
ret.onclick = function () {
recent2.setBoxCookies();
this.setVariables();
};
ret.setVariables = action;
recent2.controls.appendChild(ret);
if (internalName) {
recent2.controls[internalName] = ret;
}
// label
var l = document.createElement('label');
l.innerHTML = label;
l.onclick = function () {
ret.click();
};
recent2.controls.appendChild(l);
recent2.checkboxes.push(ret);
return ret;
};
recent2.checkboxes = [];
recent2.setBoxCookies = function () {
var n = 1;
var val = 0;
for (var i = 0; i < recent2.checkboxes.length; ++i) {
val += n * (recent2.checkboxes[i].checked ? 1 : 0);
n = n << 1;
}
document.cookie = 'recent2_checkboxes=' + val +
"; expires=Tue, 31-Dec-2030 23:59:59 GMT; path=/";
};
recent2.setCheckboxValuesFromCookie = function () {
var val = recent2.readCookie('recent2_checkboxes');
if (!val) {
return;
}
val = parseInt(val, 10);
for (var i = 0; i < recent2.checkboxes.length; ++i) {
if (recent2.checkboxes[i].checked != (val & 1)) {
recent2.checkboxes[i].checked = (val & 1);
recent2.checkboxes[i].setVariables();
}
val = val >> 1;
}
};
recent2.readCookie = function (name) {
var nameEQ = name + "=";
var ca = document.cookie.split(';');
for (var i = 0; i < ca.length; i++) {
var c = ca[i];
while (c.charAt(0) == ' ') {
c = c.substring(1, c.length);
}
if (c.indexOf(nameEQ) === 0) {
return c.substring(nameEQ.length, c.length);
}
}
return null;
};
recent2.controlUI = function () {
recent2.controls = newOutputDiv('recent2.controls', 'top', true);
recent2.controls.newline = function () {
recent2.controls.appendChild(document.createElement('br'));
};
var line = function (a, b, c, d) {
recent2.newCheckbox(a, b, c, d);
recent2.controls.newline();
};
line('Ignorar páginas de discussão de todos os domínios', !recent2.show_talkpages, function () {
recent2.show_talkpages = !this.checked;
}, 'talk');
line('Mostrar apenas artigos e respectivas páginas de discussão do domínio principal', false, function () {
recent2.hideNonArticles = this.checked;
}, 'hidenonarticles');
line('Expandir automaticamente o novo conteúdo', recent2.autoexpand, function () {
recent2.autoexpand = this.checked;
}, 'autoexpand');
line('Mostrar apenas edições não modificadas após 4 actualizações (2 minutos)', false, function () {
recent2.delay = (this.checked) ? 4 : 0;
}, 'delayby4');
line('Usar reversão (para não administradores é necessário ter instalado o' +
' script Popups de navegação)', false, function () {
recent2.non_admin_rollback = this.checked;
}, 'nonadminrollback');
line('Ignorar as minhas edições', false, function () {
recent2.ignore_my_edits = this.checked;
}, 'ignoremyedits');
line('Ignorar: página de teste, esplanadas, cafés, contato linha direta e' +
' registos (movimentação, eliminação, bloqueio e novos usuários)', false, function () {
recent2.ignore_safe_pages = this.checked;
}, 'ignoresafepages');
// line('Only show output when I ask for it', false,
// function() {
// recent2.wait_for_output = this.checked;
// if (this.checked) { recent2.pauseOutput(); }
// else {recent2.unpauseOutput(); }
// }, 'waitforoutput');
var b = document.createElement('input');
b.type = 'button';
b.value = 'pausa';
b.onclick = function () {
b.value = (recent2.paused) ? 'pausa' : 'continuar';
recent2.togglePaused();
};
recent2.controls.appendChild(b);
recent2.setCheckboxValuesFromCookie();
};
recent2.count = 0;
window.loopRecentChanges = function (url, iterations) {
if (!iterations) {
iterations = 20;
}
loopRecentChanges.iterations = iterations;
loopRecentChanges.url = url;
grabRecentChanges(url);
setTimeout(function () {
if (recent2.paused) {
++recent2.count;
return;
}
if (++recent2.count >= iterations &&
!confirm('Continuar a monitorizar as mudanças recentes?')) {
return;
}
recent2.count %= iterations;
loopRecentChanges(url, iterations);
}, 30000);
};
window.marvin = function () {
// this isn't really used (not accessible from the UI), so don't worry about it
window.sysops = RegExp("^(Adailton|Agil|Alexg|Amorim Parga|Angeloleithold" +
"|Angrense|Arges|Arouck|Bonás|Daniel Candido|Dantadd|Diotti|Dpc01|Dvulture" +
"|E2m|EMP|Epinheiro|Fernando S\\. Aldado|Gabrielt4e|Gaf\\.arq|Get It" +
"|Giro720|Ikescs|Indech|Jcmo|Jic|JoaoMiranda|Joaotg|Jorge|João Carvalho" +
"|Jurema Oliveira|Lampiao|Leonardo\\.stabile|LeonardoG|Leslie|Lijealso" +
"|Loge|Lusitana|Luís Felipe Braga|Maddox|Malafaya|Manuel Anastácio" +
"|Mateus Hidalgo|Mschlindwein|Muriel Gottrop|N\\&n\\'s|OS2Warp|Ozymandias" +
"|PARG|Patrick|PatríciaR|PedroPVZ|Rangelpalma|Rei\\-artur|Reynaldo" +
"|Rui Malheiro|Rui Silva|SallesNeto BR|Salvadorjo|Santana\\-freitas" +
"|Severino666|Slade|Sturm|Thrasher|Whooligan|Xadai|Xandi)$"
);
recent2.show_talkpages = true;
recent2.controlUI();
loopRecentChanges(recent2.feed, 200);
};
// **************************************************
// Installation
// **************************************************
recent2.addlilink = function (tabs, url, name, id, title, key) {
var na = document.createElement('a');
na.href = url;
na.appendChild(document.createTextNode(name));
var li = document.createElement('li');
if (id) {
li.id = id;
}
li.appendChild(na);
tabs.appendChild(li);
if (id) {
if (key && title) {
ta[id] = [key, title];
} else if (key) {
ta[id] = [key, ];
} else if (title) {
ta[id] = [, title];
}
}
// re-render the title and accesskeys from existing code in wikibits.js
akeytt();
return li;
};
recent2.addToolboxLink = function (url, name, id) {
var tb = document.getElementById('p-tb').getElementsByTagName('ul')[0];
recent2.addlilink(tb, url, name, id);
};
window.addMarvin = function () {
recent2.addToolboxLink(recent2.articlePath + recent2.filterPage, 'Monitorizar filtro', 'toolbox_filter_changes');
recent2.addToolboxLink(recent2.articlePath + recent2.allRecentPage, 'Monitorizar tudo', 'toolbox_all_changes');
recent2.addToolboxLink(recent2.articlePath + recent2.recentIPPage, 'Monitorizar IPs', 'toolbox_IP_edits');
recent2.addToolboxLink(recent2.articlePath + recent2.monitorWatchlistPage, 'Monitorizar vigiados', 'toolbox_watchlist_edits');
recent2.addToolboxLink(recent2.articlePath + recent2.spelldictPage, 'Monitorizar ortografia', 'toolbox_spelling');
//document.getElementById('toolbox_filter_changes').onclick=marvin;
};
recent2.testPage = function (str) {
return RegExp(str.split(/[_ ]/).join('[_ ]'), 'i').test(document.location.href);
};
window.maybeStart = function () {
var loc = document.location.href;
if (recent2.testPage(recent2.filterPage)) {
recent2.filter_badwords = true;
} else if (recent2.testPage(recent2.allRecentPage)) {
recent2.filter_badwords = false;
} else if (recent2.testPage(recent2.recentIPPage)) {
recent2.filter_anonsOnly = true;
} else if (recent2.testPage(recent2.monitorWatchlistPage)) {
recent2.filter_watchlist = true;
} else if (recent2.testPage(recent2.spelldictPage)) {
recent2.filter_spelling = true;
} else {
return;
}
setTimeout(marvin, 1000);
};
// onload
$(maybeStart);
$(addMarvin);
//// testing code
//recent2.filter_badwords=true;
//recent2.filter_spelling=true;
//setTimeout(marvin,1000);
/*
- /