User:Euphoria/common.js: Difference between revisions
From Test Wiki
Content deleted Content added
fix |
OOUI buttons |
||
Line 1:
// <nowiki>
mw.loader.using(['mediawiki.util', 'mediawiki.api', 'oojs-ui-core', 'oojs-ui-widgets'], function () {
const pagePrefix = 'User:Euphoria/Test VfD';
// Only run on relevant pages in view mode
const currentPage = mw.config.get('wgPageName').replace(/_/g, ' ');
if (
mw.config.get('wgAction') !== 'view'
$(function () {
$('#mw-content-text').find('h2, h3').each(function () {
const heading = this;
// Skip headings already inside a .vfd container or without links
if ($(heading).closest('.vfd').length) return;
if (!link.length) return;▼
▲ if (!href) return;
const container = document.createElement('span');
Line 25 ⟶ 22:
const actions = [
{ name: 'delete', color: '#e74c3c', flag: 'destructive' },
{ name: 'keep', color: '#27ae60', flag: 'progressive' },
{ name: 'no consensus', color: '#f1c40f', flag: '' }
];
actions.forEach(function (actionObj) {
const btn
title: 'Close as ' + actionObj.name,
flags: actionObj.flag ? [actionObj.flag] : [],
framed: false
//
btn.
btn.style.height = '16px';▼
▲ btn.style.padding = '0';
e.preventDefault();
if (!confirm('Are you sure you want to close as ' + actionObj.name + '?')) return;
btn.
const api = new mw.Api();
// Fetch discussion page content
api.get({
action: 'query',
prop: 'revisions',
titles:
rvslots: 'main',
rvprop: 'content',
format: 'json'
}).done(function (data) {
const pages = data.query.pages;
const pageId = Object.keys(pages)[0];
let content = pages[pageId].revisions[0].slots.main['*']
const discussionNewContent =
'{{subst:vt|' + actionObj.name + '. --~~~~}}\n' +
content.trim() +
'\n{{subst:vb}}';
// Edit discussion page
api.postWithToken('csrf', {
action: 'edit',
title:
text: discussionNewContent,
summary: 'Closed as ' + actionObj.name,
minor: true
}).done(function () {
const link = $(heading).find('a').first();
mw.notify('Cannot find target page link!', { title: 'VfDcloser', type: 'error', timeout: 1500 });
setTimeout(() => location.reload(), 1500);
return;
}
const targetPage = link.attr('title') || link.text().trim();
if (!targetPage) {
mw.notify('Cannot determine target page title!', { title: 'VfDcloser', type: 'error', timeout: 1500 });
setTimeout(() => location.reload(), 1500);
return;
}
if (actionObj.name === 'delete') {
// Delete target page
Line 86 ⟶ 89:
action: 'delete',
title: targetPage,
reason: '[[' +
}).done(() => {
const talkPage = 'Talk:' + targetPage;
api.get(
action: 'query',
titles: talkPage,
format: 'json'
}).done(data => {
const talkPages = data.query.pages;
const talkId = Object.keys(talkPages)[0];
Line 100 ⟶ 107:
reason: 'Parent page deleted via VfD'
}).done(() => {
mw.notify('Discussion closed. Page and talk page deleted.', { title: 'VfDcloser', type: 'success', timeout: 1500 });
setTimeout(() => location.reload(), 1500);
}).fail(err =>
mw.notify('Error deleting talk page: ' + JSON.stringify(err), { title: 'VfDcloser', type: 'error', timeout: 1500 })
);
} else {
mw.notify('Discussion closed. Page deleted.', { title: 'VfDcloser', type: 'success', timeout: 1500 });
setTimeout(() => location.reload(), 1500);
}
});
}).fail(err =>
mw.notify('Error deleting page: ' + JSON.stringify(err), { title: 'VfDcloser', type: 'error', timeout: 1500 })
);
} else {
// Keep / No consensus: update page and talk page
Line 118 ⟶ 129:
rvprop: 'content',
format: 'json'
}).done(function (articleData) {
const articlePages = articleData.query.pages;
const articleId = Object.keys(articlePages)[0];
let articleContent = articlePages[articleId].revisions[0].slots.main['*']
articleContent = articleContent.replace(/\{\{vfd-new\}\}/gi, '').trim();
Line 139 ⟶ 150:
rvprop: 'content',
format: 'json'
}).done(function (talkData) {
const talkPages = talkData.query.pages;
const talkId = Object.keys(talkPages)[0];
Line 157 ⟶ 168:
minor: true
}).done(() => {
mw.notify('Discussion closed. Page and talk page updated.', { title: 'VfDcloser', type: 'success', timeout: 1500 });
setTimeout(() => location.reload(), 1500);
}).fail(err =>
mw.notify('Error editing talk page: ' + JSON.stringify(err), { title: 'VfDcloser', type: 'error', timeout: 1500 })
);
});
}).fail(err =>
mw.notify('Error editing page: ' + JSON.stringify(err), { title: 'VfDcloser', type: 'error', timeout: 1500 })
);
});
}
}).fail(err =>
mw.notify('Error editing discussion page: ' + JSON.stringify(err), { title: 'VfDcloser', type: 'error', timeout: 1500 })
});
});
// Append OOUI button element to container
container.appendChild(btn.$element[0]);
});
Line 175 ⟶ 193:
});
});
// </nowiki>
| |||