MediaWiki:Common.js
Agros urbe non clamaten
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.
/* Any JavaScript here will be loaded for all users on every page load. */ mw.loader.using(['mediawiki.api', 'mediawiki.util'], function () { // Start the process by calling a function that returns a Promise fetchAndSimulateEdits().catch(function(error) { console.error("Error during fetch and simulate:", error); }); }); function fetchAndSimulateEdits() { const api = new mw.Api(); return new Promise(function(resolve, reject) { // Only run this script on a specific page if (mw.config.get('wgPageName') !== 'Wiki_Visualized') { return resolve(); // Stop if we're not on the correct page } let apcontinue = null; // Pagination token let simulatedEdits = []; // Store simulated edits locally let newContent = "{{#network:Main Page"; (function fetchBatch() { api.get({ action: 'query', list: 'allpages', aplimit: 'max', // Maximum number of pages per batch apcontinue: apcontinue, }).done(function(response) { const pages = response.query.allpages; // Iterate through each page let pagePromises = pages.map(function(page) { const title = page.title; return api.get({ action: 'query', prop: 'revisions', titles: title, rvslots: 'main', rvprop: 'content', }).done(function(contentResponse) { newContent += ("|" + title); console.log(`Simulated edit for ${title}:\n${newContent}`); }).fail(function(error) { console.error(`Error simulating edit for ${title}:`, error); }); }); // Wait for all page promises to finish before continuing Promise.all(pagePromises).then(function() { newContent += "}}"; // Now make the local edit to the page (not actual edit, just on the user's page) const contentArea = document.getElementById('mw-content-text'); if (contentArea) { // Save the original content (optional) const originalContent = contentArea.innerHTML; // Modify the content locally contentArea.innerHTML += ` <div style="border: 2px solid red; padding: 10px; margin-top: 20px;"> <p>${newContent}</p> </div> `; } // Get the next batch of pages if available apcontinue = (response.continue && response.continue.apcontinue) || null; // If there is more data to fetch, call the function again if (apcontinue) { fetchBatch(); } else { // Finished, resolve the promise console.log('Finished simulating edits. Here are the results:', simulatedEdits); resolve(); } }).fail(reject); // Reject the promise if the API request fails }).fail(reject); // Reject if the initial API request fails })(); }); }