MediaWiki:WHAM/ru/code.2.js

/*
 * A variant of WHAM with a different modal
 * Includes functionality to delete forum/message wall threads and selective deleting of pages, which the original lacks
 * Original "WHAM" - http://dev.wikia.com/wiki/WHAM/code.js
 * @author Ozank Cx
 * @TODO i18n

mw.loader.using('mediawiki.api', function { var ug = mw.config.get("wgUserGroups");  if (mw.config.get("wgCanonicalSpecialPageName") === "Contributions" && (ug.indexOf('rollback') + ug.indexOf('content-moderator') + ug.indexOf('threadmoderator') + ug.indexOf('sysop') + ug.indexOf('vstf') + ug.indexOf('staff') + ug.indexOf('helper') > -7)) {

/*    var walls = [ "Message Wall",        // en        "Nachrichtenseite",     // de		"Muro",                 // es        "Viestiseinä",          // fi        "Mur",                  // fr        "Üzenőfal",             // hu        "Bacheca",              // it        "メッセージ ウォール",  // ja        "메시지_담벼락",        // ko        "Prikbord",             // nl        "Tablica wiadomości",   // pl        "Mural de mensagens",   // pt, pt-br "Стіна обговорення",   // uk        "Стена обсуждения",     // ru        "Tường tin nhắn",       // vi        "留言墙"                // zh    ], username = mw.config.get("wgPageName").split("/")[1], token = mw.user.tokens.get("editToken"), delay = window.WHAMDelay || 100, deleteReason, duration, blockReason, deleteArray, Api = new mw.Api, revDel = 0;
 * Message wall equivalents list, used to prevent deletion of message walls (causes glitches and not necessary)
 * Acquired from https://github.com/Wikia/app/blob/a0c00a44254d958fcd06514b12cb6b75c88da9c0/extensions/wikia/Wall/Wall.namespaces.php

if ($('.mw-revdelundel-link').length) revDel = 1; $("#contentSub").append(' Quick Tools');

$('#contribs-wham').click(function {     $.showCustomModal('WHAM!', '', { id: 'form-main', width: 660, buttons: [{ message: 'Удалить все страницы', defaultButton: true, handler: function { doDelete; }	       },{		           message: 'Удалить выбранное', defaultButton: true, handler: function { startSelectiveDelete; }       },{		           message: 'Откатить все правки', defaultButton: true, handler: function { doRollback; }       },{		           message: 'Заблокировать', defaultButton: true, handler: function { doBlock; }       },{		           message: 'Все опции', defaultButton: true, handler: function { doBlock; if (!duration || !blockReason) return; doDelete; if (!deleteReason) return; doRollback; }       },{          message: 'Закрыть', id: 'close-wham' }]     });      mw.util.addCSS('.modalWrapper .modalContent .modalToolbar {text-align:left;}');      $('#close-wham').after(' ');      $('#close-wham,.close').click(function { $('#form-main').closeModal; location.reload; });

//Бот if (window.WHAMBotMe == true || ug.indexOf('vstf') + ug.indexOf('staff') + ug.indexOf('helper') > -3) { $('#form-main .modalContent div .modalToolbar .wikia-button:nth-child(5)').after('Бот'); $('#form-main').css('width','800px');

if (ug.indexOf('bot') != -1) $('#wham-bot').text('НеБот');

$('#wham-bot').click(function {         var user = mw.config.get('wgUserName');	  $.getJSON("/api.php?action=query&list=users&ustoken=userrights&ususers=" + user + "&format=json", function(token) {

var config = { action: 'userrights', user: user, add: 'bot', reason: window.WHAMBotReason || 'Чистка', bot: true, token: token.query.users[0].userrightstoken };           if ($('#wham-bot').text == "Бот") { $('#wham-bot').text('НеБот'); } else { config.remove = config.add; delete config.add; $('#wham-bot').text('Бот'); }	   Api.post(config) .done(function(d) {              if (!d.error) {                console.log('Статус бота был изменён');              } else {                console.log('Не удалось изменить статус бота: '+ d.error.code);              }            }) .fail(function {             console.log('Не удалось изменить статус бота!');            }); });	});     }    });

function apiDelete(page,reason) { Api.post({     action: 'delete',      title: page,      reason: reason,      bot: true,      token: token      }) .done(function(d) {        if (!d.error) {          console.log('Удаление '+page+' прошло успешно!');        } else {          console.log('Не удалось удалить '+page+': '+ d.error.code);        }      }) .fail(function {       console.log('Не удалось удалить '+page+'!');      }); }

function doRollback { $('.mw-rollback-link a').each(function(i) {       var href = $(this).attr('href') + "&bot=1";        setTimeout(function { $.get(href); if ($('.mw-rollback-link a').length > 0) $('#status-wham').html('Откатываем... пожалуйста подождите '); if (i === $('.mw-rollback-link a').length - 1) $('#status-wham').html('Готово!'); }, i*delay);     }); }   function doDelete { deleteReason = prompt('Причина','Чистка'); if (!deleteReason) return; deleteArray = [];

$('#mw-content-text ul li').each(function {       var title = $(this).children('a').first.attr('title');	if (title.split('-').length == 1 || title.split('/@comment').length == 1) return;           deleteArray.push(title);      });

$('li .newpage ~ a').each(function {       var title = $(this).attr('title');        if (walls.indexOf(title.split(':')[0]) !== -1 || (title.split(':')[0] === "Thread" && title.split(':')[1].length < 8)) return;          deleteArray.push(title);      });

if (deleteArray) { $.each(deleteArray, function(i,v) {         setTimeout(function { $('#status-wham').html('Удаляем... подождите '); apiDelete(v,deleteReason); if (i === deleteArray.length - 1) $('#status-wham').html('Завершено!'); }, i*delay);       }); }   }

function doBlock { duration = prompt('Длительнось','2 недели'); if (!duration) return; blockReason = prompt('Причина','Вандализм'); if (!blockReason) return;

Api.post({     action: 'block',      user: username,      expiry: duration,      nocreate: 0,      autoblock: 0,      reason: blockReason,      bot: true,      token: token      }) .done(function(d) {        if (!d.error) {          console.log(username+' заблокирован!');        }         else {          alert('Не удалось заблокировать '+username+': '+ d.error.code);        }      }) .fail(function {       alert('Не удалось заблокировать '+username+'!');      }); }

function startSelectiveDelete { var chk = ' '; $('#form-main').closeModal; if ($('#btn-wham-del').length && $('#btn-wham-check').length) return; $('#mw-content-text').find('ul').last.before('Удалить выбранное Check All');

$('li .newpage ~ a').each(function {       if (!$(this).parent.find('input').length)          $(this).parent.prepend(chk);      });

$('#mw-content-text ul li').each(function {       var title = $(this).children('a').first.attr('title');	if (title.split('-').length != 1 && title.split('/@comment').length != 1 && !$(this).find('input').length && title.split(username) != -1)          $(this).prepend(chk);	      });

$('#btn-wham-del').click(function {       var deleteReason = prompt('Причина','Чистка');        if (!deleteReason) return;        $('.selectiveDel').each(function { var chkObj = $(this); if (revDel == 0) { var title = $(this).parent.find('a').first.attr('title'); }         else { var title = $(this).parent.children('a').eq(0).attr('title'); }         if (chkObj.attr('Checked') && walls.indexOf(title.split(':')[0]) == -1) { apiDelete(title,deleteReason); $(this).parent.css({'color':'grey','text-decoration':'line-through'}).children.removeAttr('href').css({'color':'grey','text-decoration':'line-through'}); }       });        setTimeout((function{          location.reload;        }), 5000);      });

$('#btn-wham-check').click(function {       var btn = $(this);        if (btn.text == 'Uncheck All') {          $('.selectiveDel').each(function { var chkObj = $(this); if (chkObj.attr('checked')) chkObj.removeAttr('checked'); });         btn.text('Просмотреть все');        }        else {          $('.selectiveDel').each(function { var chkObj = $(this); if (!chkObj.attr('checked')) chkObj.attr('checked', 'checked'); });         btn.text('Не просмотреть все ');         }      }); } }

});