מדיה ויקי:Common.js
הערה: לאחר הפרסום, ייתכן שיהיה צורך לנקות את זיכרון המטמון (cache) של הדפדפן כדי להבחין בשינויים.
- פיירפוקס / ספארי: להחזיק את המקש Shift בעת לחיצה על טעינה מחדש (Reload) או ללחוץ על צירוף המקשים Ctrl-F5 או Ctrl-R (במחשב מק: ⌘-R).
- גוגל כרום: ללחוץ על צירוף המקשים Ctrl-Shift-R (במחשב מק: ⌘-Shift-R).
- אדג': להחזיק את המקש Ctrl בעת לחיצה על רענן (Refresh) או ללחוץ על צירוף המקשים Ctrl-F5.
// קוד קיים - משאירים אותו
(function () {
var userLang = mw.config.get('wgUserLanguage');
var pageName = mw.config.get('wgPageName');
if (pageName === 'רבי_יואל_טייטלבוים' && userLang === 'yi') {
window.location.href = mw.util.getUrl('רבי_יואל_טייטלבוים/yi');
}
if (pageName === 'רבי_יואל_טייטלבוים/yi' && userLang === 'he') {
window.location.href = mw.util.getUrl('רבי_יואל_טייטלבוים');
}
})();
// תוכן עניינים - גרסה משופרת
mw.hook('wikipage.content').add(function ($content) {
var $toc = $('#toc');
if ($toc.length) {
var $window = $(window);
var $header = $('#firstHeading');
function updateTocPosition() {
var scrollTop = $window.scrollTop();
var headerHeight = $header.offset().top + $header.outerHeight();
$toc.css('top', scrollTop > headerHeight ? '0' : '220px');
}
$window.on('scroll resize', updateTocPosition);
updateTocPosition(); // קריאה ראשונית
}
});
// ========== בקרי מראה (Appearance Controls) ==========
(function() {
'use strict';
// פונקציות עזר לניהול העדפות
var AppearancePrefs = {
get: function(key, defaultVal) {
try {
var val = localStorage.getItem('otzar-' + key);
return val !== null ? val : defaultVal;
} catch(e) {
return defaultVal;
}
},
set: function(key, val) {
try {
localStorage.setItem('otzar-' + key, val);
} catch(e) {}
}
};
// טעינת העדפות שמורות
function loadPreferences() {
var fontSize = AppearancePrefs.get('fontSize', 'medium');
var contentWidth = AppearancePrefs.get('contentWidth', 'normal');
var fontFamily = AppearancePrefs.get('fontFamily', 'david');
var panelVisible = AppearancePrefs.get('panelVisible', 'true');
applyFontSize(fontSize);
applyContentWidth(contentWidth);
applyFontFamily(fontFamily);
// החלת מצב התפריט
if (panelVisible === 'false') {
$('#appearance-panel').addClass('hidden');
$('#appearance-toggle').addClass('panel-hidden');
}
}
// החלת גודל טקסט
function applyFontSize(size) {
var $content = $('#content, .mw-parser-output');
$content.removeClass('text-small text-medium text-large text-xlarge');
$content.addClass('text-' + size);
AppearancePrefs.set('fontSize', size);
$('.appearance-option[data-type="fontSize"]').removeClass('active');
$('.appearance-option[data-type="fontSize"][data-value="' + size + '"]').addClass('active');
}
// החלת רוחב תוכן
function applyContentWidth(width) {
var $content = $('#content');
var $body = $('.mw-body');
$content.removeClass('width-normal width-wide');
$body.removeClass('width-normal width-wide');
$content.addClass('width-' + width);
$body.addClass('width-' + width);
AppearancePrefs.set('contentWidth', width);
$('.appearance-option[data-type="contentWidth"]').removeClass('active');
$('.appearance-option[data-type="contentWidth"][data-value="' + width + '"]').addClass('active');
}
// החלת גופן
function applyFontFamily(font) {
var $content = $('#content, .mw-parser-output');
$content.removeClass('font-david font-frank font-arial');
$content.addClass('font-' + font);
AppearancePrefs.set('fontFamily', font);
$('.appearance-option[data-type="fontFamily"]').removeClass('active');
$('.appearance-option[data-type="fontFamily"][data-value="' + font + '"]').addClass('active');
}
// הצגה/הסתרת תפריט
function togglePanel() {
var $panel = $('#appearance-panel');
var $toggle = $('#appearance-toggle');
$panel.toggleClass('hidden');
$toggle.toggleClass('panel-hidden');
var isVisible = !$panel.hasClass('hidden');
AppearancePrefs.set('panelVisible', isVisible ? 'true' : 'false');
}
// יצירת כפתור הצגה/הסתרה
function createToggleButton() {
var html = '<div id="appearance-toggle" title="הצג/הסתר תפריט מראה">⚙</div>';
$('body').append(html);
$('#appearance-toggle').on('click', function() {
togglePanel();
});
}
// יצירת תפריט מראה
function createAppearanceMenu() {
var html =
'<div id="appearance-panel">' +
' <h3 class="appearance-heading">מראה</h3>' +
' <div class="appearance-content">' +
' <div class="appearance-section">גודל טקסט:</div>' +
' <div class="appearance-option" data-type="fontSize" data-value="small">קטן</div>' +
' <div class="appearance-option" data-type="fontSize" data-value="medium">בינוני</div>' +
' <div class="appearance-option" data-type="fontSize" data-value="large">גדול</div>' +
' <div class="appearance-option" data-type="fontSize" data-value="xlarge">גדול מאוד</div>' +
' <div class="appearance-divider"></div>' +
' <div class="appearance-section">רוחב תוכן:</div>' +
' <div class="appearance-option" data-type="contentWidth" data-value="normal">רגיל</div>' +
' <div class="appearance-option" data-type="contentWidth" data-value="wide">רחב</div>' +
' <div class="appearance-divider"></div>' +
' <div class="appearance-section">גופן:</div>' +
' <div class="appearance-option" data-type="fontFamily" data-value="david">דוד</div>' +
' <div class="appearance-option" data-type="fontFamily" data-value="frank">פרנק</div>' +
' <div class="appearance-option" data-type="fontFamily" data-value="arial">אריאל</div>' +
' </div>' +
'</div>';
$('body').append(html);
// מאזינים לאירועים
$('.appearance-option').on('click', function() {
var $this = $(this);
var type = $this.data('type');
var value = $this.data('value');
if (type === 'fontSize') {
applyFontSize(value);
} else if (type === 'contentWidth') {
applyContentWidth(value);
} else if (type === 'fontFamily') {
applyFontFamily(value);
}
});
}
// אתחול
$(function() {
createAppearanceMenu();
createToggleButton();
loadPreferences();
});
})();