Keine Bearbeitungszusammenfassung
Markierung: Rückgängigmachung
Keine Bearbeitungszusammenfassung
Zeile 1: Zeile 1:
/* Eigene Sprachleiste: UI-Sprache + PageTranslation-Ziel umschalten */
/* Eigene Sprachleiste: manuelles Umschalten (ohne Auto-Logik), robust für Minerva/Vector */
mw.loader.using(['mediawiki.util', 'mediawiki.api'], function () {
mw.loader.using(['mediawiki.util', 'mediawiki.api'], function () {


   // ====== Automatische Anwendung der gespeicherten Sprache für Gäste ======
   // --- Nur im Lesemodus + im Haupt-Namensraum (0) anzeigen ---
   if (!mw.config.get('wgUserName')) {
   var action = mw.config.get('wgAction');
    try {
  var ns = mw.config.get('wgNamespaceNumber');
      var prefLang = localStorage.getItem('preferredLang');
  if (action !== 'view' || ns !== 0) return;
      var currentLang = mw.config.get('wgUserLanguage');
 
      if (
        prefLang &&
        prefLang.toLowerCase() !== currentLang.toLowerCase() &&
        !/[?&](?:use|set)lang=/.test(location.search)
      ) {
        var url = new URL(window.location.href);
        url.searchParams.set('uselang', prefLang);
        location.replace(url.toString());
        return; // Rest des Codes nicht mehr ausführen
      }
    } catch (e) {}
  }
  // ========================================================================


   // ---- deine Sprachen ----
   // --- Sprachen definieren ---
   var LANGS = [
   var LANGS = [
     { code: 'de', label: 'Deutsch' },
     { code: 'de', label: 'Deutsch' },
Zeile 28: Zeile 13:
     { code: 'fr', label: 'Français' }
     { code: 'fr', label: 'Français' }
   ];
   ];
  var ALLOWED = ['de', 'en', 'fr'];
  var FALLBACK = 'en';


  // Doppelte Einbindung vermeiden
   if (document.getElementById('custom-langbar')) return;
   if (document.getElementById('custom-langbar')) return;


   var userLang = (mw.config.get('wgUserLanguage') || mw.config.get('wgContentLanguage') || 'de').toLowerCase();
   var pageName = mw.config.get('wgPageName'); // mit _ statt Leerzeichen
   var pageName = mw.config.get('wgPageName');
   var baseTitle = pageName.replace(/\/[a-z]{2}(?:-[a-z]{2})?$/i, ''); // ggf. /de,/en,… abschneiden


   // Basis-Seitenname ohne evtl. Sprach-Suffix (/en, /fr, /pt-br, …)
   function normalize(code) {
  var baseTitle = pageName.replace(/\/[a-z]{2}(?:-[a-z]{2})?$/i, '');
    if (!code) return FALLBACK;
    code = String(code).toLowerCase().split('-')[0];
    return ALLOWED.indexOf(code) > -1 ? code : FALLBACK;
  }
 
  // Ziel-URL: gleiche Seite in gewünschter Sprache über Special:MyLanguage + uselang
  function targetUrl(code) {
    code = normalize(code);
    var title = 'Special:MyLanguage/' + baseTitle.replace(/_/g, ' ');
    var url = mw.util.getUrl(title);
    return url + (url.includes('?') ? '&' : '?') + 'uselang=' + code;
  }


   // Leiste bauen
   // Bar bauen
   var bar = document.createElement('div');
   var bar = document.createElement('div');
   bar.id = 'custom-langbar';
   bar.id = 'custom-langbar';
  var current = normalize(mw.config.get('wgUserLanguage') || mw.config.get('wgContentLanguage') || FALLBACK);


   LANGS.forEach(function (lang) {
   LANGS.forEach(function (lang) {
Zeile 45: Zeile 46:
     a.href = '#';
     a.href = '#';
     a.textContent = lang.label;
     a.textContent = lang.label;
    a.dataset.code = lang.code;
     if (current === lang.code) a.className = 'active-lang';
 
     if (userLang === lang.code.toLowerCase()) a.className = 'active-lang';
 
     a.addEventListener('click', function (e) {
     a.addEventListener('click', function (e) {
       e.preventDefault();
       e.preventDefault();
       switchLanguageAndGo(lang.code);
       switchLanguage(lang.code);
     });
     });
     bar.appendChild(a);
     bar.appendChild(a);
   });
   });


   // Unter die Minerva-Header-Bar hängen
   // Sicher ins DOM hängen (Minerva/Vector kompatibel)
   var header = document.querySelector('.minerva-header') || document.body;
   var mount =
  header.parentNode.insertBefore(bar, header.nextSibling);
    document.querySelector('.minerva-header') ||
    document.querySelector('.vector-header') ||
    document.getElementById('content') ||
    document.body;


   // ---- Logik: Sprache setzen + auf Übersetzung springen ----
   if (mount && mount.parentNode) {
  function targetUrlFor(code) {
     mount.parentNode.insertBefore(bar, mount.nextSibling);
     // Special:MyLanguage löst auf die passende /lang-Unterseite auf
  } else {
    var title = 'Special:MyLanguage/' + baseTitle;
     document.body.insertBefore(bar, document.body.firstChild);
    var url = mw.util.getUrl(title);
    // setlang damit Gäste UND eingeloggte sofort die richtige UI sehen
     var sep = url.indexOf('?') > -1 ? '&' : '?';
    return url + sep + 'setlang=' + encodeURIComponent(code);
   }
   }


   function switchLanguageAndGo(code) {
  // Sprachwechsel: eingeloggte speichern; Gäste nur per URL-Parameter
     code = code.toLowerCase();
   function switchLanguage(code) {
     code = normalize(code);


    // Eingeloggt: Preference setzen, dann auf MyLanguage weiterleiten
     if (mw.config.get('wgUserName')) {
     if (mw.config.get('wgUserName')) {
       new mw.Api().postWithToken('csrf', {
       new mw.Api().postWithToken('csrf', {
Zeile 80: Zeile 76:
         change: 'language=' + code
         change: 'language=' + code
       }).always(function () {
       }).always(function () {
         location.href = targetUrlFor(code);
         location.href = targetUrl(code);
       });
       });
       return;
    } else {
       location.href = targetUrl(code);
     }
     }
    // Gäste: direkt mit setlang auf MyLanguage gehen + in localStorage merken
    try { localStorage.setItem('preferredLang', code); } catch (e) {}
    location.href = targetUrlFor(code);
   }
   }


   // Anonyme erkennen und Flag auf <html> setzen
   // Anonyme markieren (falls du CSS darauf hast)
   if (!mw.config.get('wgUserName')) {
   if (!mw.config.get('wgUserName')) {
     document.documentElement.classList.add('bv-anon');
     document.documentElement.classList.add('bv-anon');
   }
   }


   // Gäste nicht auf Diskussionsseiten lassen → auf Inhaltsseite umleiten
   // Gäste nicht auf Diskussionsseiten lassen → zurück zur Inhaltseite
   if (!mw.config.get('wgUserName')) {
   if (!mw.config.get('wgUserName')) {
     var ns = mw.config.get('wgNamespaceNumber');
     var nsNum = mw.config.get('wgNamespaceNumber');
     if (ns % 2 === 1) { // ungerade Namespace-Nummern = Diskussions-Namespace
     if (nsNum % 2 === 1) {
       var subjectUrl = mw.util.getUrl(mw.config.get('wgPageName').replace(/^Talk:/, ''));
       var subject = mw.util.getUrl(mw.config.get('wgPageName').replace(/^Talk:/, ''));
       window.location.href = subjectUrl;
       window.location.href = subject;
     }
     }
   }
   }
});
});

Version vom 8. August 2025, 13:51 Uhr

/* Eigene Sprachleiste: manuelles Umschalten (ohne Auto-Logik), robust für Minerva/Vector */
mw.loader.using(['mediawiki.util', 'mediawiki.api'], function () {

  // --- Nur im Lesemodus + im Haupt-Namensraum (0) anzeigen ---
  var action = mw.config.get('wgAction');
  var ns = mw.config.get('wgNamespaceNumber');
  if (action !== 'view' || ns !== 0) return;

  // --- Sprachen definieren ---
  var LANGS = [
    { code: 'de', label: 'Deutsch' },
    { code: 'en', label: 'English' },
    { code: 'fr', label: 'Français' }
  ];
  var ALLOWED = ['de', 'en', 'fr'];
  var FALLBACK = 'en';

  // Doppelte Einbindung vermeiden
  if (document.getElementById('custom-langbar')) return;

  var pageName = mw.config.get('wgPageName'); // mit _ statt Leerzeichen
  var baseTitle = pageName.replace(/\/[a-z]{2}(?:-[a-z]{2})?$/i, ''); // ggf. /de,/en,… abschneiden

  function normalize(code) {
    if (!code) return FALLBACK;
    code = String(code).toLowerCase().split('-')[0];
    return ALLOWED.indexOf(code) > -1 ? code : FALLBACK;
  }

  // Ziel-URL: gleiche Seite in gewünschter Sprache über Special:MyLanguage + uselang
  function targetUrl(code) {
    code = normalize(code);
    var title = 'Special:MyLanguage/' + baseTitle.replace(/_/g, ' ');
    var url = mw.util.getUrl(title);
    return url + (url.includes('?') ? '&' : '?') + 'uselang=' + code;
  }

  // Bar bauen
  var bar = document.createElement('div');
  bar.id = 'custom-langbar';

  var current = normalize(mw.config.get('wgUserLanguage') || mw.config.get('wgContentLanguage') || FALLBACK);

  LANGS.forEach(function (lang) {
    var a = document.createElement('a');
    a.href = '#';
    a.textContent = lang.label;
    if (current === lang.code) a.className = 'active-lang';
    a.addEventListener('click', function (e) {
      e.preventDefault();
      switchLanguage(lang.code);
    });
    bar.appendChild(a);
  });

  // Sicher ins DOM hängen (Minerva/Vector kompatibel)
  var mount =
    document.querySelector('.minerva-header') ||
    document.querySelector('.vector-header') ||
    document.getElementById('content') ||
    document.body;

  if (mount && mount.parentNode) {
    mount.parentNode.insertBefore(bar, mount.nextSibling);
  } else {
    document.body.insertBefore(bar, document.body.firstChild);
  }

  // Sprachwechsel: eingeloggte speichern; Gäste nur per URL-Parameter
  function switchLanguage(code) {
    code = normalize(code);

    if (mw.config.get('wgUserName')) {
      new mw.Api().postWithToken('csrf', {
        action: 'options',
        change: 'language=' + code
      }).always(function () {
        location.href = targetUrl(code);
      });
    } else {
      location.href = targetUrl(code);
    }
  }

  // Anonyme markieren (falls du CSS darauf hast)
  if (!mw.config.get('wgUserName')) {
    document.documentElement.classList.add('bv-anon');
  }

  // Gäste nicht auf Diskussionsseiten lassen → zurück zur Inhaltseite
  if (!mw.config.get('wgUserName')) {
    var nsNum = mw.config.get('wgNamespaceNumber');
    if (nsNum % 2 === 1) {
      var subject = mw.util.getUrl(mw.config.get('wgPageName').replace(/^Talk:/, ''));
      window.location.href = subject;
    }
  }
});