מדיה ויקי:Common.js: הבדלים בין גרסאות בדף
קפיצה לניווט
קפיצה לחיפוש
אין תקציר עריכה |
אין תקציר עריכה |
||
| שורה 100: | שורה 100: | ||
} | } | ||
// יצירת תפריט מראה | // יצירת תפריט מראה - ממוקם בצד שמאל של התוכן | ||
function createAppearanceMenu() { | function createAppearanceMenu() { | ||
var html = | var html = | ||
'<div id="appearance-panel | '<div id="appearance-panel">' + | ||
' <h3 class=" | ' <h3 class="appearance-heading">מראה</h3>' + | ||
' <div class=" | ' <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="theme" data-value="light">בהיר</div>' + | ||
' | ' <div class="appearance-option" data-type="theme" data-value="dark">כהה</div>' + | ||
' | ' <div class="appearance-option" data-type="theme" data-value="sepia">ספיה</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>' + | ||
'</div>'; | '</div>'; | ||
// הוספת התפריט | // הוספת התפריט לגוף הדף (יוצב בצד שמאל באמצעות CSS) | ||
$('body').append(html); | |||
// הוספת מאזינים לאירועים | // הוספת מאזינים לאירועים | ||
גרסה מ־21:37, 1 בנובמבר 2025
// קוד קיים - משאירים אותו
(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 theme = AppearancePrefs.get('theme', 'light');
var fontFamily = AppearancePrefs.get('fontFamily', 'david');
applyFontSize(fontSize);
applyTheme(theme);
applyFontFamily(fontFamily);
}
// החלת גודל טקסט - רק על אזור התוכן
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 applyTheme(theme) {
var $content = $('#content, .mw-parser-output, .mw-body');
$content.removeClass('theme-light theme-dark theme-sepia');
$content.addClass('theme-' + theme);
AppearancePrefs.set('theme', theme);
// עדכון בחירה בתפריט
$('.appearance-option[data-type="theme"]').removeClass('active');
$('.appearance-option[data-type="theme"][data-value="' + theme + '"]').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 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="theme" data-value="light">בהיר</div>' +
' <div class="appearance-option" data-type="theme" data-value="dark">כהה</div>' +
' <div class="appearance-option" data-type="theme" data-value="sepia">ספיה</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>';
// הוספת התפריט לגוף הדף (יוצב בצד שמאל באמצעות CSS)
$('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 === 'theme') {
applyTheme(value);
} else if (type === 'fontFamily') {
applyFontFamily(value);
}
});
}
// אתחול
$(function() {
createAppearanceMenu();
loadPreferences();
});
})();