/*</pre>
== Batch Delete ==
<pre>*/
/* Ajax batch delete thingy, version [0.1.1b]
Originally from: http://en.wikipedia.org/wiki/User:Splarka/ajaxbatchdelete.js
Tradotto e ampliato da [[Utente:Wim_b]]
// Elenco dei tool da caricare.
Notes:
//<nowiki>
* It is a bit verbose, after debugging perhaps some output should be removed.
var myButtons = new Array([1,'{{F||{{subst\:CURRENTMONTHNAME}} {{subst\:CURRENTYEAR}}}}','0','+F',0,'senza fonti '],[2,'* \'\'\'[[]]\'\'\' \– ','','Dis',11,''],[1,'<noinclude>{{Protetta}}</noinclude>','0','Protetta',0,'+Protetta '], [1,'{{IPvandalismo}}','0','IP vandalismo',0,'IP vandalismo '],[1,'{{IPcondiviso\|}}','0','IP condiviso',0,'IP condiviso '],[1,'{{S\|centri abitati del}}','0','S comuni',0,''],[1,'[[Categoria\:IP statici]]','0','Statico',0,'Avviso'],[2,'{{subst\:CURRENTMONTHNAME}} {{subst\:CURRENTYEAR}}','','mese anno',0,''],[2,'*{{Collegamenti esterni}}','','coll. esterni',0,'collegamenti esterni'],[2,'*{{cita web\|\|}}','','cita web'],[2,'','','ping',0,'\@ [[utente\:]]'],[1,'\:\'\'\'8 ore\'\'\' --\~\~\~\~','1','8 ore',0,'']);
* It waits 1 second after every delete before starting the next.
//</nowiki>
* Can be aborted by simply deleting the contents of the textarea, or leaving the page.
//Link rossi che non si aprono in modifica, di [[User:Wim b]]
* Stops when it hits a blank line.
* Nonfatal errors (skip to next line):
** Bad character or malformed line
** Bad token
** Unexpected response
* Pauses in execution can be added with a blank line.
To do:
* Cache the token if two the same?
** Please note the delete token is not guaranteed to be static, but currently it always is.
*/
addOnloadHook(function() {
addPortletLink('p-tb','/wiki/Special:BlankPage?blankspecial=ajaxbd&useskin=monobook','Batch Delete');
});
if(wgCanonicalSpecialPageName && wgCanonicalSpecialPageName.toLowerCase() == 'blankpage' && queryString('blankspecial') == 'ajaxbd') {
document.title = 'Ajax Batch Deletion';
addOnloadHook(abdForm);
}
function abdForm() {
addPortletLink('p-tb','/wiki/Special:Log/delete?user=' + encodeURIComponent(wgUserName),'My delete log');
//subvert this Special: page to our own needs.
var con = document.getElementById('content') || document.getElementById('mw_content');
var bcon = document.getElementById('bodyContent') || document.getElementById('mw_contentholder');
var fh = getElementsByClassName(con,'h1','firstHeading')[0];
while(fh.firstChild) fh.removeChild(fh.firstChild)
fh.appendChild(document.createTextNode('Ajax Batch Deletion'));
for(var i=0;i<bcon.childNodes.length;i++) {
bcur = bcon.childNodes[i];
if(bcur.id != 'siteSub' && bcur.id != 'contentSub' && bcur.className != 'visualClear') {
while(bcur.firstChild) bcur.removeChild(bcur.firstChild)
if(bcur.nodeType == 3) bcur.nodeValue = '';
}
}
//generate content
var form = document.createElement('form');
form.appendChild(document.createTextNode('Lista delle pagine da cancellare:'));
form.appendChild(document.createElement('p'));
form.setAttribute('action','javascript:void(0);');
var txt = document.createElement('textarea');
txt.style.height = '20em';
txt.style.width = '50%';
txt.setAttribute('id','abd-textarea');
form.appendChild(txt);
form.appendChild(document.createElement('p'));
var lab1 = document.createElement('label');
lab1.setAttribute('for','abd-reason')
lab1.appendChild(document.createTextNode('Oggetto delle cancellazioni: '));
form.appendChild(lab1);
var inp1 = document.createElement('input');
inp1.style.width = '20em';
inp1.setAttribute('type','text');
inp1.setAttribute('id','abd-reason');
form.appendChild(inp1);
form.appendChild(document.createElement('p'));
var sub1 = document.createElement('input');
sub1.setAttribute('type','button');
sub1.setAttribute('id','abd-startbutton');
sub1.setAttribute('value','start');
sub1.setAttribute('onclick','abdStart()');
form.appendChild(sub1);
bcon.appendChild(form);
var pre = document.createElement('pre');
pre.setAttribute('id','abd-output');
bcon.appendChild(pre);
}
$('#abd-reason').next().prepend('<select id="wpBatchDeleteReasons"><option value="Altro">Altre ragioni</option>'
+'<option>([[WP:IMMEDIATA|C1]]) Pagina vuota, di prova, senza senso o tautologica</option>'
+'<option>([[WP:IMMEDIATA|C2]]) Pagina contenente solo frasi volgari, diffamatorie o denigratorie</option>'
+'<option>([[WP:IMMEDIATA|C3]]) Pagina scritta in un\'altra lingua o tradotta con traduttori automatici</option>'
+'<option>([[WP:IMMEDIATA|C4]]) Contenuto palesemente [[WP:E|non enciclopedico]] o [[WP:P|promozionale]], [[WP:WNCV|CV]]</option>'
+'<option>([[WP:IMMEDIATA|C6]]) Categoria vuota e/o sostituita</option>'
+'<option>([[WP:IMMEDIATA|C7]]) Pagina già cancellata per decisione comunitaria e reinserita senza valido motivo</option>'
+'<option>([[WP:IMMEDIATA|C9]]) Redirect non funzionante, con titolo errato o [[WP:Redirect|non conforme]] e orfano</option>'
+'<option>([[WP:IMMEDIATA|C13]]) Testo in [[WP:C|violazione di copyright]] da</option>'
+'<option>([[WP:IMMEDIATA|C15]]) Pagina utente [[WP:PU|non appropriata]]</option>'
+'<option>([[WP:IMMEDIATA|C16]]) Voce trasferita su un altro progetto Wikimedia</option>'
+'<option>([[WP:IMMEDIATA|C17]]) Come da richiesta dell\'utente al quale è riferita la sottopagina</option>'
+'<option>([[WP:IMMEDIATA|C19]]) Template obsoleto, sostituito e orfano</option>'
+'<option>Prova del gadget per le cancellazioni</option></select>');
$( document.body ).ready( function abdStart() {
$("a.new").each(function()
document.getElementById('abd-startbutton').setAttribute('disabled','disabled');
{
var out = document.getElementById('abd-output');
var txtlink = document$(this).getElementByIdattr('abd-textareahref');
var deletesarr = txt.valuelink.split('\n&action');
$(this).attr('href', arr[0]);
var page = deletes[0];
if(page == '') {
});
out.appendChild(document.createTextNode('* fatto! Non resta altro da fare, o la riga successiva è vuota.\n'));
});
document.getElementById('abd-startbutton').removeAttribute('disabled');
} else {
var badchars = /(\#|\<|\>|\[|\]|\{|\}|\|)/;
if(badchars.test(page)) {
out.appendChild(document.createTextNode('! trovato un carattere non ammesso, la pagina' + page + ' è stata ignorata\n'));
setTimeout('abdStart()',1000);
} else {
out.appendChild(document.createTextNode('> Tento di cancellare [[' + page + ']]\n'));
abdGetToken(page);
}
}
deletes = deletes.slice(1,deletes.length);
txt.value = deletes.join('\n');
}
function abdGetToken(page) {
var out = document.getElementById('abd-output');
out.appendChild(document.createTextNode(' > Recupero delete token per [[' + page + ']]\n'));
var url = wgScriptPath + '/api.php?action=query&prop=info&indexpageids=1&intoken=delete&format=json&titles=' + encodeURIComponent(page);
var req = sajax_init_object();
req.open('GET', url, true);
req.onreadystatechange = function() {
if(req.readyState == 4 && req.status == 200) {
eval("abdDelete(" + req.responseText + ",'" + req.responseText.replace(/\'/g,"`") + "','" + page + "')");
}
}
req.send(null);
}
function abdDelete(obj,txt,page) {
var out = document.getElementById('abd-output');
if(obj['error']) {
out.appendChild(document.createTextNode(' ! Errore nelle API: ' + obj['error']['code'] + ' - ' + obj['error']['info'] + '\n'));
return;
}
if(!obj['query'] || !obj['query']['pageids'] || !obj['query']['pages'][obj['query']['pageids'][0]] || !obj['query']['pages'][obj['query']['pageids'][0]]['deletetoken']) {
out.appendChild(document.createTextNode(' ? Unexpected response: ' + txt + '\n'));
return;
}
var token = obj['query']['pages'][obj['query']['pageids'][0]]['deletetoken'];
out.appendChild(document.createTextNode(' > Token trovato, attendere la cancellazione\n'));
var reason = document.getElementById('abd-reason').value;
var params = 'action=delete&format=json&token=' + encodeURIComponent(token) + '&title=' + encodeURIComponent(page) + '&reason=' + encodeURIComponent(reason);
var url = wgScriptPath + '/api.php';
var req = sajax_init_object();
req.open('POST', url, true);
req.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
req.setRequestHeader('Content-length', params.length);
req.setRequestHeader('Connection', 'close');
req.onreadystatechange = function() {
if(req.readyState == 4 && req.status == 200) {
eval("abdDeleteAftermath(" + req.responseText + ",'" + req.responseText.replace(/\'/g,"`") + "')");
}
}
req.send(params);
}
function abdDeleteAftermath(obj,txt) {
var out = document.getElementById('abd-output');
if(obj['error']) {
out.appendChild(document.createTextNode(' ! Api error: ' + obj['error']['code'] + ' - ' + obj['error']['info'] + '\n'));
} else if(obj['delete'] && obj['delete']['title']) {
out.appendChild(document.createTextNode(' > La pagina [[' + obj['delete']['title'] + ']] è stata cancellata\n'));
} else {
out.appendChild(document.createTextNode(' ? Unexpected response: ' + txt + '\n'));
return;
}
setTimeout('abdStart()',1000);
}
function queryString(p) {
var re = RegExp('[&?]' + p + '=([^&]*)');
var matches;
if (matches = re.exec(document.___location)) {
try {
return decodeURI(matches[1]);
} catch (e) {
}
}
return null;
}
|