MediaWiki:Common.js
From Makerpedia
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. */
if (document) window.µ = function (id, elem) {
var ret;
var root = ((elem) ? elem : document);
switch (id.charAt(0)) {
case '|':
ret = root;
break;
case '+':
ret = document.createElement(id.substring(1));
if (elem) elem.appendChild(ret);
break;
case '#':
ret = root.querySelector(id);
break;
default:
ret = Array.prototype.slice.call(root.querySelectorAll(id));
break;
}
return ret;
};
/* add additional edit button (prioritize 'Edit' over 'Edit Source' when available) -- styled in Medik.css */
if(document.getElementById("ca-edit") != null || document.getElementById("ca-ve-edit") != null) {
let link = document.getElementById("ca-ve-edit") != null ? document.querySelector("#ca-ve-edit a").href : document.querySelector("#ca-edit a").href;
document.getElementById("content").innerHTML += '<a href='+link+'><button class="big-edit-button"><p>EDIT</p></button></a>';
}
$(document).ready(function () {
// Add filter buttons above the gallery
$("#tool-gallery").before('<div id="category-filter">' +
'<button class="filter-btn" data-filter="Tools">Show All</button>' +
'<button class="filter-btn" data-filter="Makerspace Tools">Makerspace Tools</button>' +
'<button class="filter-btn" data-filter="Wood Shop Tools">Wood Shop Tools</button>' +
'<button class="filter-btn" data-filter="Machine Shop Tools">Machine Shop Tools</button>' +
'</div>');
// Function to filter by category
function filterByCategory(selectedCategory) {
// Hide all items first
$("#tool-gallery .gallerybox").hide();
// Show only matching category items
$("#tool-gallery .gallerybox").each(function () {
// Find all links within the item and check if they contain the selected category
var categories = $(this).find("a[href^='/wiki/Category:']");
var matchFound = false;
// Check if any of the categories match the selectedCategory
categories.each(function () {
if ($(this).attr('href').includes(selectedCategory)) {
matchFound = true;
}
});
// If there's a match, show the tool
if (matchFound || selectedCategory === "Tools") {
$(this).show();
}
});
}
// Triggering the filter when a category button is clicked
$(".filter-btn").on("click", function () {
var selectedCategory = $(this).data("filter"); // Get the selected category
filterByCategory(selectedCategory); // Call the filter function with the selected category
});
// Optionally, trigger the "Show All" button by default
$(".filter-btn[data-filter='Tools']").click(); // Trigger the "Show All" button on page load
});