MediaWiki:Common.js: Difference between revisions
No edit summary Tag: Reverted |
No edit summary Tag: Manual revert |
||
| Line 1: | Line 1: | ||
/* Any JavaScript here will be loaded for all users on every page load. */ | /* Any JavaScript here will be loaded for all users on every page load. */ | ||
/* | /****************************************/ | ||
/* sliders using jquery by User:Tierrie */ | |||
/****************************************/ | |||
mw.loader.using(['jquery.ui'] | mw.loader.using( ['jquery.cookie']); | ||
/****************************************/ | |||
/* sliders using jquery by User:Tierrie */ | |||
/****************************************/ | |||
mw.loader.using( ['jquery.ui'], function() { | |||
$( "[class^=portal_vtab]" ).tabs().addClass( "ui-tabs-vertical ui-helper-clearfix" ); | |||
$( "[class^=portal_vtab] li" ).removeClass( "ui-corner-top" ).addClass( "ui-corner-left" ); | |||
var $tabs = $("#portal_slider").tabs({ fx: {opacity:'toggle', duration:100} } ); | |||
$("[class*=portal_sliderlink]").click(function() { // bind click event to link | |||
$tabs.tabs('select', this.className.match(/portal_sliderlink-(\d+)/)[1]); | |||
console.log("Sliding to " + this.className.match(/portal_sliderlink-(\d+)/)[1]); | |||
return false; | |||
}); | |||
$('#portal_next').click(function() { | |||
$tabs.tabs('select', ($tabs.tabs('option', 'selected') == ($tabs.tabs('length'))-1) ? 0 : $tabs.tabs('option', 'selected') + 1 ); // switch to next tab | |||
return false; | |||
}); | |||
$('#portal_prev').click(function() { // bind click event to link | |||
$tabs.tabs('select', ($tabs.tabs('option', 'selected') == 0) ? ($tabs.tabs('length')-1) : $tabs.tabs('option', 'selected') - 1 ); // switch to previous tab | |||
return false; | |||
}); | |||
} | |||
}); | }); | ||
/* | /* lockdown for reference popup configuration */ | ||
((window.dev = window.dev || {}).ReferencePopups = dev.ReferencePopups || {}).lockdown = true; | ((window.dev = window.dev || {}).ReferencePopups = dev.ReferencePopups || {}).lockdown = true; | ||
/* Disable license check for multi upload */ | |||
mw.config.set('UMFBypassLicenseCheck', true); | mw.config.set('UMFBypassLicenseCheck', true); | ||
mw.loader.using('mediawiki.util').then(function () { | mw.loader.using('mediawiki.util').then(function () { | ||
var g = mw.config.get('wgUserGroups')||[]; | |||
var isAdmin = g.indexOf('sysop')!==-1 || g.indexOf('interface-admin')!==-1; | |||
if (!isAdmin) document.querySelectorAll('.only-sysop').forEach(el=>el.style.display='none'); | |||
}); | }); | ||
/* | /* Random Page Teaser on Main Page | ||
* Fetches a random page (namespace 0), shows title, extract and thumbnail. | |||
*/ | |||
mw.loader.using(['mediawiki.api', 'mediawiki.util']).then(function () { | mw.loader.using(['mediawiki.api', 'mediawiki.util']).then(function () { | ||
// Run only on main page (adjust if your main page title differs) | |||
var isMain = mw.config.get('wgIsMainPage') || mw.config.get('wgPageName') === 'Main_Page'; | |||
var box = document.getElementById('random-teaser'); | var box = document.getElementById('random-teaser'); | ||
if (!box) return; | if (!isMain || !box) return; | ||
var api = new mw.Api(); | var api = new mw.Api(); | ||
function | function renderCard(data) { | ||
var page = (data && data.query && data.query.pages && data.query.pages[0]) || null; | |||
if (!page) { | |||
box.innerHTML = '<div class="content"><h3>Random page</h3><p>Could not load a page.</p></div>'; | |||
box.classList.remove('loading'); | |||
return; | |||
} | |||
var title = page.title; | |||
var | var url = mw.util.getUrl(title); | ||
var extract = (page.extract || '').replace(/\n+/g, ' ').trim(); | |||
if (extract.length > 420) extract = extract.slice(0, 420).replace(/\s+\S*$/, '') + '…'; | |||
var | |||
var | |||
if ( | |||
var img = (page.thumbnail && page.thumbnail.source) ? page.thumbnail.source : null; | |||
box.innerHTML = | box.innerHTML = | ||
'<div class="thumb">' + | '<div class="thumb">' + | ||
( | (img ? '<img src="' + img + '" alt="">' : '<span>🡲</span>') + | ||
'</div>' + | '</div>' + | ||
'<div class="content">' + | '<div class="content">' + | ||
'<h3><a href="' + url + '">' + | '<h3><a href="' + url + '">' + mw.html.escape(title) + '</a></h3>' + | ||
'<p>' + | '<p>' + (extract || 'No description available.') + '</p>' + | ||
'<div class="actions">' + | '<div class="actions">' + | ||
'<a class="btn" href="' + url + '">Open</a>' + | '<a class="btn" href="' + url + '">Open</a>' + | ||
| Line 133: | Line 83: | ||
box.classList.remove('loading'); | box.classList.remove('loading'); | ||
var | var refreshBtn = document.getElementById('rand-refresh'); | ||
if ( | if (refreshBtn) refreshBtn.addEventListener('click', function () { | ||
box.classList.add('loading'); | box.classList.add('loading'); | ||
loadRandom(); | |||
}); | }); | ||
} | } | ||
function | function loadRandom() { | ||
api.get({ | api.get({ | ||
action: 'query', | action: 'query', | ||
formatversion: 2, | formatversion: 2, | ||
generator: 'random', | generator: 'random', | ||
grnnamespace: 0, | grnnamespace: 0, // only main/article namespace | ||
grnlimit: 1, | grnlimit: 1, | ||
prop: ' | prop: 'extracts|pageimages', | ||
exintro: 1, | |||
explaintext: 1, // plain text extract | |||
exchars: 600, // server-side clamp | |||
pithumbsize: 280, // thumbnail width | |||
pilicense: 'any' | |||
}).then(renderCard).catch(function () { | |||
// | renderCard(null); | ||
}); | }); | ||
} | } | ||
loadRandom(); | |||
}); | }); | ||