MediaWiki:Common.js: відмінності між версіями
Перейти до навігації
Перейти до пошуку
Wiki (обговорення | внесок) Створена сторінка: →Розміщений тут код JavaScript буде завантажений всім користувачам при зверненні до будь-якої сторінки: $(function () { // Доступні теми та їхні CSS var themes = { light: '/w/index.php?title=MediaWiki:Light.css&action=raw&ctype=text/css', dark: '/w/index.php?title=MediaWiki:Dark.css&action=raw&ctype=text/css' }; // Зчит... |
Wiki (обговорення | внесок) Немає опису редагування |
||
| Рядок 23: | Рядок 23: | ||
// Створюємо кнопку перемикача | // Створюємо кнопку перемикача | ||
var $btn = $('<button>') | var $btn = $('<button>') | ||
.text(theme === 'dark' ? '☀️' : ' | .text(theme === 'dark' ? ' Світла тема ☀️' : ' Темна тема🌙') | ||
.attr('title', 'Змінити тему') | .attr('title', 'Змінити тему') | ||
.css({ | .css({ | ||
Версія за 14:19, 23 вересня 2025
/* Розміщений тут код JavaScript буде завантажений всім користувачам при зверненні до будь-якої сторінки */
$(function () {
// Доступні теми та їхні CSS
var themes = {
light: '/w/index.php?title=MediaWiki:Light.css&action=raw&ctype=text/css',
dark: '/w/index.php?title=MediaWiki:Dark.css&action=raw&ctype=text/css'
};
// Зчитуємо збережену тему
var theme = localStorage.getItem('selectedTheme');
// Якщо тема ще не збережена → визначаємо за налаштуванням ОС
if (!theme) {
theme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
}
// Підключаємо CSS вибраної теми
if (themes[theme]) {
mw.loader.load(themes[theme], 'text/css');
}
// Створюємо кнопку перемикача
var $btn = $('<button>')
.text(theme === 'dark' ? ' Світла тема ☀️' : ' Темна тема🌙')
.attr('title', 'Змінити тему')
.css({
position: 'fixed',
bottom: '10px',
right: '10px',
padding: '6px 10px',
border: '1px solid #aaa',
borderRadius: '6px',
background: '#f0f0f0',
cursor: 'pointer',
zIndex: 9999
})
.click(function () {
// Перемикаємо тему
var newTheme = theme === 'dark' ? 'light' : 'dark';
localStorage.setItem('selectedTheme', newTheme);
location.reload();
});
$('body').append($btn);
});