User:BZPN/Przeglądarka.js
From Test Wiki
Note: After publishing, you may have to bypass your browser's cache to see the changes.
- Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
- Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
- Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
- Opera: Press Ctrl-F5.
$(document).ready(function () {
var pageName = mw.config.get('wgCanonicalSpecialPageName');
if (pageName !== 'Contributions') {
return;
}
if ($('#mass-review-box').length === 0) {
var $reviewBox = $(`
<div id="mass-review-box" class="mw-htmlform-ooui-wrapper oo-ui-layout oo-ui-panelLayout oo-ui-panelLayout-padded oo-ui-panelLayout-framed">
<form id="review-form" class="mw-htmlform mw-htmlform-ooui oo-ui-layout oo-ui-formLayout">
<fieldset class="oo-ui-layout oo-ui-labelElement oo-ui-fieldsetLayout mw-collapsibleFieldsetLayout mw-collapsible mw-made-collapsible">
<legend role="button" class="oo-ui-fieldsetLayout-header mw-collapsible-toggle mw-collapsible-toggle-expanded" aria-expanded="true" tabindex="0">
<span class="oo-ui-iconElement-icon oo-ui-iconElement-noIcon"></span>
<span class="oo-ui-labelElement-label">Przeglądanie edycji</span>
<span class="oo-ui-widget oo-ui-widget-enabled oo-ui-iconElement-icon oo-ui-icon-expand oo-ui-iconElement oo-ui-labelElement-invisible oo-ui-iconWidget">Expand</span>
<span class="oo-ui-widget oo-ui-widget-enabled oo-ui-iconElement-icon oo-ui-icon-collapse oo-ui-iconElement oo-ui-labelElement-invisible oo-ui-iconWidget">Collapse</span>
</legend>
<div class="oo-ui-fieldsetLayout-group mw-collapsible-content" style="display: block;">
<div class="oo-ui-widget oo-ui-widget-enabled mw-htmlform-submit-buttons">
<button id="review-selected-button" class="oo-ui-inputWidget-input oo-ui-buttonElement-button oo-ui-buttonElement-framed oo-ui-flaggedElement-progressive" style="padding: 5px 10px; background-color: #007bff; color: #fff; border: none; cursor: pointer; border-radius: 4px;">Przejrzyj zaznaczone edycje</button>
<button id="review-all-button" class="oo-ui-inputWidget-input oo-ui-buttonElement-button oo-ui-buttonElement-framed oo-ui-flaggedElement-destructive" style="padding: 5px 10px; background-color: #ff4136; color: #fff; border: none; cursor: pointer; border-radius: 4px;">Przejrzyj wszystkie edycje</button>
<button id="cancel-review" class="oo-ui-inputWidget-input oo-ui-buttonElement-button oo-ui-buttonElement-framed" style="padding: 5px 10px; background-color: #aaa; color: #fff; border: none; cursor: pointer; border-radius: 4px;">Anuluj</button>
</div>
</div>
</fieldset>
</form>
</div>
`);
$('#mw-content-text').prepend($reviewBox);
$('#review-selected-button').click(function () {
var api = new mw.Api();
var selectedRevisions = $('input[type="checkbox"].review-checkbox:checked').map(function () {
return {
title: $(this).data('title'),
revid: $(this).data('revid')
};
}).get();
if (selectedRevisions.length === 0) {
alert('Nie zaznaczono żadnych edycji do przejrzenia.');
return;
}
var reviewPromises = selectedRevisions.map(function (contrib) {
return api.postWithToken('csrf', {
action: 'review',
revid: contrib.revid,
title: contrib.title
});
});
Promise.all(reviewPromises).then(function () {
alert('Zaznaczone edycje zostały przejrzane!');
location.reload();
}).catch(function (error) {
console.error('Wystąpił błąd podczas przeglądania edycji:', error);
alert('Wystąpił błąd podczas przeglądania edycji.');
});
});
$('#review-all-button').click(function () {
var userName = mw.config.get('wgRelevantUserName');
var api = new mw.Api();
api.get({
action: 'query',
list: 'usercontribs',
ucuser: userName,
uclimit: 'max',
ucprop: 'ids|title',
format: 'json'
}).done(function (data) {
var contributions = data.query.usercontribs;
if (contributions.length === 0) {
alert('Brak edycji do przejrzenia.');
return;
}
var reviewPromises = contributions.map(function (contrib) {
return api.postWithToken('csrf', {
action: 'review',
revid: contrib.revid,
title: contrib.title
});
});
Promise.all(reviewPromises).then(function () {
alert('Wszystkie edycje zostały przejrzane!');
location.reload();
}).catch(function (error) {
console.error('Wystąpił błąd podczas przeglądania:', error);
alert('Wystąpił błąd podczas przeglądania.');
});
}).fail(function (error) {
console.error('Błąd przy pobieraniu wkładu użytkownika:', error);
alert('Błąd przy pobieraniu wkładu użytkownika.');
});
});
$('#cancel-review').click(function () {
$('#mass-review-box').hide();
});
// Dodanie checkboxów
$('li[data-mw-revid]').each(function () {
var $this = $(this);
var revid = $this.data('mw-revid');
var title = $this.find('.mw-contributions-title').text();
var $checkbox = $('<input type="checkbox" class="review-checkbox" style="margin-right: 5px;">')
.data('revid', revid)
.data('title', title);
$this.prepend($checkbox);
// Dodaj przycisk podglądu edycji
var $previewButton = $('<button class="preview-edit-button" style="margin-left: 10px;">Podgląd</button>');
$this.append($previewButton);
$previewButton.click(function () {
var diffUrl = mw.util.getUrl(title, { diff: revid });
$.get(diffUrl, function (data) {
var diffHtml = $(data).find('#mw-diff-otitle2').html(); // Pobranie HTML różnic
// Wyświetlanie podglądu w modalnym oknie
var $modal = $('<div class="preview-modal" style="position: fixed; top: 10%; left: 50%; transform: translateX(-50%); background-color: #fff; border: 1px solid #ccc; padding: 20px; z-index: 9999; width: 80%; max-height: 80%; overflow-y: auto;"></div>');
var $closeButton = $('<button style="position: absolute; top: 10px; right: 10px;">Zamknij</button>');
$modal.append($closeButton);
$modal.append('<div class="diff-content">' + diffHtml + '</div>');
$('body').append($modal);
$closeButton.click(function () {
$modal.remove();
});
// Stylizacja zmian
$('.diff-addedline', $modal).css('background-color', '#e6f7ff'); // Dodane linie na niebiesko
$('.diff-deletedline', $modal).css('background-color', '#ffe6e6'); // Usunięte linie na pomarańczowo
});
});
});
}
});