MediaWiki:Common.js: Difference between revisions
No edit summary |
No edit summary |
||
Line 2: | Line 2: | ||
$('.cs-comment-form').show(); | $('.cs-comment-form').show(); | ||
}); | }); | ||
(function() { | (function() { | ||
// Utility function to shuffle an array | |||
function shuffleArray(array) { | |||
for (let i = array.length - 1; i > 0; i--) { | |||
const j = Math.floor(Math.random() * (i + 1)); | |||
[array[i], array[j]] = [array[j], array[i]]; | |||
} | |||
return array; | |||
} | |||
// Fetch random articles | // Fetch random articles | ||
fetch('http://localhost/wikidef/api.php?action=query&list=random&rnnamespace=0&rnlimit=10&format=json') | fetch('http://localhost/wikidef/api.php?action=query&list=random&rnnamespace=0&rnlimit=10&format=json') | ||
Line 40: | Line 50: | ||
// Create HTML structure for each category | // Create HTML structure for each category | ||
Object.keys(categories).forEach(category => { | Object.keys(categories).forEach(category => { | ||
// Shuffle the articles in each category | |||
const shuffledArticles = shuffleArray(categories[category]); | |||
const div = document.createElement('div'); | const div = document.createElement('div'); | ||
div.className = 'category-group'; | div.className = 'category-group'; | ||
Line 47: | Line 60: | ||
div.appendChild(categoryTitle); | div.appendChild(categoryTitle); | ||
shuffledArticles.forEach(articleTitle => { | |||
const articleTitleElement = document.createElement('h3'); | const articleTitleElement = document.createElement('h3'); | ||
const link = document.createElement('a'); | const link = document.createElement('a'); |
Revision as of 10:44, 5 August 2024
$(document).ready(function() {
$('.cs-comment-form').show();
});
(function() {
// Utility function to shuffle an array
function shuffleArray(array) {
for (let i = array.length - 1; i > 0; i--) {
const j = Math.floor(Math.random() * (i + 1));
[array[i], array[j]] = [array[j], array[i]];
}
return array;
}
// Fetch random articles
fetch('http://localhost/wikidef/api.php?action=query&list=random&rnnamespace=0&rnlimit=10&format=json')
.then(response => response.json())
.then(data => {
const articles = data.query.random;
const container = document.getElementById('random-articles');
container.innerHTML = ''; // Clear the loading text
// Collect page IDs for category fetch
const pageIds = articles.map(article => article.id).join('|');
// Fetch categories for the articles
return fetch(`http://localhost/wikidef/api.php?action=query&prop=categories&pageids=${pageIds}&format=json`);
})
.then(response => response.json())
.then(data => {
const container = document.getElementById('random-articles');
const pages = data.query.pages;
const categories = {};
// Group articles by category
Object.values(pages).forEach(page => {
if (page.categories) {
page.categories.forEach(cat => {
const categoryName = cat.title.replace('Category:', '');
if (!categories[categoryName]) {
categories[categoryName] = [];
}
categories[categoryName].push(page.title);
});
}
});
// Create HTML structure for each category
Object.keys(categories).forEach(category => {
// Shuffle the articles in each category
const shuffledArticles = shuffleArray(categories[category]);
const div = document.createElement('div');
div.className = 'category-group';
const categoryTitle = document.createElement('h2');
categoryTitle.textContent = category;
div.appendChild(categoryTitle);
shuffledArticles.forEach(articleTitle => {
const articleTitleElement = document.createElement('h3');
const link = document.createElement('a');
link.href = `http://localhost/wikidef/index.php/${articleTitle}`;
link.textContent = articleTitle;
articleTitleElement.appendChild(link);
div.appendChild(articleTitleElement);
});
container.appendChild(div);
});
})
.catch(error => {
console.error('Error fetching data:', error);
});
})();