MediaWiki:Common.js: Unterschied zwischen den Versionen

Aus Wikikama
Keine Bearbeitungszusammenfassung
Markierung: Zurückgesetzt
Keine Bearbeitungszusammenfassung
 
(19 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
/* Das folgende JavaScript wird für alle Benutzer geladen. */
/* Das folgende JavaScript wird für alle Benutzer geladen. */
// Support-Banner anzeigen, falls noch nicht geschlossen
$(function () {
$(function () {
  if (mw.config.get('wgNamespaceNumber') >= 0) {
    if (mw.config.get('wgNamespaceNumber') >= 0) {
    $('body').append(
        if (!sessionStorage.getItem('supportBannerClosed')) {
      '<div id="support-banner">❤️ <b>WIKIKAMA und Mimikama sind unabhängig und werbefrei – hilf mit, das möglich zu machen!</b> <a href="https://www.wikikama.org/index.php/Unterstützen">Jetzt unterstützen!</a></div>'
 
    );
            const bannerHTML = `
  }
                <div id="support-banner" style="display: none;">
                  <button id="support-banner-close" aria-label="Banner schließen" title="Schließen"></button>
                  <div class="sb-text">❤️ WIKIKAMA und Mimikama sind unabhängig und werbefrei – hilf mit, das möglich zu machen!</div>
                  <a class="sb-link" href="/index.php/Unterstützen" target="_blank" rel="noopener">Jetzt unterstützen!</a>
                </div>
            `;
 
            $('body').append(bannerHTML);
            $('#support-banner').fadeIn(400);
            $('body').css('padding-bottom', '120px');
 
            $('#support-banner-close').on('click', function () {
                $('#support-banner').fadeOut(300, function () {
                    $(this).remove();
                });
                sessionStorage.setItem('supportBannerClosed', 'true');
                $('body').css('padding-bottom', '0');
            });
        }
    }
});
});
// === Meta-Tags in den <head> einfügen ===
// === Meta-Tags in den <head> einfügen ===
$(function() {
$(function() {
  var og = '';
    var og = '';
  og += '<meta property="og:title" content="' + mw.config.get('wgTitle') + ' – Wikikama" />';
    og += '<meta property="og:title" content="' + mw.config.get('wgTitle') + ' – Wikikama" />';
  og += '<meta property="og:description" content="' + $('p').first().text().substr(0, 150) + '…" />';
    og += '<meta property="og:description" content="' + $('p').first().text().substr(0, 150) + '…" />';
  og += '<meta property="og:image" content="https://www.wikikama.org/images/default-og-image.png" />';
    og += '<meta property="og:image" content="https://www.wikikama.org/images/default-og-image.png" />';
  $('head').append( og );
    $('head').append( og );
});
});


mw.loader.using('mediawiki.util', function () {
// === ShareButtons ===
  // jQuery-ready: läuft auch, wenn DOM schon geladen ist
$(document).ready(function() {
  $(function () {
    var shareBox = `
    var container = document.getElementById('link-scanner');
      <div class="a2a_kit a2a_kit_size_32 a2a_default_style wikikama-sharebox" style="margin-top: 40px; font-family: Arial, sans-serif;">
     if (!container) return;
        <strong style="display:block; margin-bottom: 10px;">🔗 Teile diesen Artikel:</strong>
        <a class="a2a_button_facebook" title="Teilen auf Facebook"></a>
        <a class="a2a_button_mastodon" title="Teilen auf Threads" href="#"></a>
        <a class="a2a_button_x" title="Teilen auf X (Twitter)"></a>
        <a class="a2a_button_telegram" title="Teilen auf Telegram"></a>
        <a class="a2a_button_whatsapp" title="Teilen auf WhatsApp"></a>
        <a class="a2a_button_linkedin" title="Teilen auf LinkedIn"></a>
        <a class="a2a_button_reddit" title="Teilen auf Reddit"></a>
        <a class="a2a_button_email" title="Teilen per E-Mail"></a>
        <div style="clear: both;"></div>
      </div>
      <script async src="https://static.addtoany.com/menu/page.js"></script>
     `;


     // 1) Formular-HTML per JS erzeugen
     if (mw.config.get("wgNamespaceNumber") === 0) {
    container.innerHTML = '\
         $(".mw-parser-output").append(shareBox);
      <div style="background:#F7FAFC; padding:16px; border-left:5px solid #2C5282; border-radius:8px; margin:1em 0;">\
         $(".a2a_button_mastodon").attr(
        <strong>🔗 Mini-Link-Scanner:</strong><br><br>\
          "href",
        <input type="url" id="linkScannerInput" placeholder="https://example.com" \
          "https://threads.net/share?text=" +
          style="width:70%; padding:8px; border:1px solid #ccc; border-radius:4px;" />\
            encodeURIComponent(document.title) +
         <button id="linkScannerBtn" \
            "&url=" +
          style="padding:8px 12px; margin-left:8px; background:#2C5282; color:#fff; \
            encodeURIComponent(window.location.href)
                border:none; border-radius:4px; cursor:pointer;">\
        );
          Scan-Link\
    }
        </button>\
});
        <div id="linkScannerResult" \
/* ──────────────────────────────────────────────────────────────────────────── */
            style="margin-top:12px; font-size:95%; line-height:1.4em;"></div>\
/*  Dieser Block hängt bei eingeloggten Nutzer:innen die Klasse "logged-in" */
      </div>';
/*  an den <body>, damit unsere CSS-Regeln (siehe Common.css) das Menü ein-  */
 
/*  bzw. ausblenden können.                                                   */
    // 2) Event-Listener für die Schaltfläche
/* ──────────────────────────────────────────────────────────────────────────── */
    var btn    = document.getElementById('linkScannerBtn'),
$(function() {
         input  = document.getElementById('linkScannerInput'),
    // mw.user.isAnon() ist false, sobald ein Konto angemeldet ist
        result = document.getElementById('linkScannerResult');
    if (!mw.user.isAnon()) {
 
        document.body.classList.add('logged-in');
    btn.addEventListener('click', function () {
    }
      var url = input.value.trim();
    // Optional: Wenn jemand anonym ist, könnt ihr auch body.classList.add('anon') hinzufügen
      if (!url) {
        result.innerHTML = '<span style="color:#c53030;">Bitte gib eine URL ein.</span>';
        return;
      }
      result.innerHTML = '🔄 Scanne ' + mw.html.escape(url) + ' …';
 
      fetch('https://api.allorigins.win/raw?url=' + encodeURIComponent(url))
        .then(function(res){
          if (!res.ok) throw new Error(res.statusText);
          return res.text();
        })
        .then(function(html){
          var doc      = new DOMParser().parseFromString(html,'text/html'),
              title    = doc.querySelector('title') ? doc.querySelector('title').textContent : '',
              descMeta = doc.querySelector('meta[name=\"description\"]'),
              desc    = descMeta ? descMeta.content : '',
              ogImg    = doc.querySelector('meta[property=\"og:image\"]'),
              img      = ogImg ? ogImg.content : '',
              out      = '';
 
          if (title) out += '<b>Titel:</b> ' + mw.html.escape(title) + '<br>';
          if (desc)  out += '<b>Beschreibung:</b> ' + mw.html.escape(desc) + '<br>';
          if (img)   out += '<b>Vorschaubild:</b><br>'
                        + '<img src=\"' + mw.html.escape(img) + '\" style=\"max-width:100%; \
                                margin-top:8px; border:1px solid #ddd; border-radius:4px;\" />';
          if (!title && !desc && !img) out = '<span style=\"color:#c53030;\">Keine Metadaten gefunden.</span>';
 
          result.innerHTML = out;
        })
        .catch(function(err){
          result.innerHTML = '<span style=\"color:#c53030;\">Fehler: '
                            + mw.html.escape(err.message) + '</span>';
        });
    });
  });
});
});

Aktuelle Version vom 2. Juni 2025, 10:34 Uhr

/* Das folgende JavaScript wird für alle Benutzer geladen. */

// Support-Banner anzeigen, falls noch nicht geschlossen
$(function () {
    if (mw.config.get('wgNamespaceNumber') >= 0) {
        if (!sessionStorage.getItem('supportBannerClosed')) {

            const bannerHTML = `
                <div id="support-banner" style="display: none;">
                  <button id="support-banner-close" aria-label="Banner schließen" title="Schließen">✖</button>
                  <div class="sb-text">❤️ WIKIKAMA und Mimikama sind unabhängig und werbefrei – hilf mit, das möglich zu machen!</div>
                  <a class="sb-link" href="/index.php/Unterstützen" target="_blank" rel="noopener">Jetzt unterstützen!</a>
                </div>
            `;

            $('body').append(bannerHTML);
            $('#support-banner').fadeIn(400);
            $('body').css('padding-bottom', '120px');

            $('#support-banner-close').on('click', function () {
                $('#support-banner').fadeOut(300, function () {
                    $(this).remove();
                });
                sessionStorage.setItem('supportBannerClosed', 'true');
                $('body').css('padding-bottom', '0');
            });
        }
    }
});

// === Meta-Tags in den <head> einfügen ===
$(function() {
    var og = '';
    og += '<meta property="og:title" content="' + mw.config.get('wgTitle') + ' – Wikikama" />';
    og += '<meta property="og:description" content="' + $('p').first().text().substr(0, 150) + '…" />';
    og += '<meta property="og:image" content="https://www.wikikama.org/images/default-og-image.png" />';
    $('head').append( og );
});

// === ShareButtons ===
$(document).ready(function() {
    var shareBox = `
      <div class="a2a_kit a2a_kit_size_32 a2a_default_style wikikama-sharebox" style="margin-top: 40px; font-family: Arial, sans-serif;">
        <strong style="display:block; margin-bottom: 10px;">🔗 Teile diesen Artikel:</strong>
        <a class="a2a_button_facebook" title="Teilen auf Facebook"></a>
        <a class="a2a_button_mastodon" title="Teilen auf Threads" href="#"></a>
        <a class="a2a_button_x" title="Teilen auf X (Twitter)"></a>
        <a class="a2a_button_telegram" title="Teilen auf Telegram"></a>
        <a class="a2a_button_whatsapp" title="Teilen auf WhatsApp"></a>
        <a class="a2a_button_linkedin" title="Teilen auf LinkedIn"></a>
        <a class="a2a_button_reddit" title="Teilen auf Reddit"></a>
        <a class="a2a_button_email" title="Teilen per E-Mail"></a>
        <div style="clear: both;"></div>
      </div>
      <script async src="https://static.addtoany.com/menu/page.js"></script>
    `;

    if (mw.config.get("wgNamespaceNumber") === 0) {
        $(".mw-parser-output").append(shareBox);
        $(".a2a_button_mastodon").attr(
          "href",
          "https://threads.net/share?text=" +
            encodeURIComponent(document.title) +
            "&url=" +
            encodeURIComponent(window.location.href)
        );
    }
});
/* ──────────────────────────────────────────────────────────────────────────── */
/*  Dieser Block hängt bei eingeloggten Nutzer:innen die Klasse "logged-in"  */
/*  an den <body>, damit unsere CSS-Regeln (siehe Common.css) das Menü ein-   */
/*  bzw. ausblenden können.                                                   */
/* ──────────────────────────────────────────────────────────────────────────── */
$(function() {
    // mw.user.isAnon() ist false, sobald ein Konto angemeldet ist
    if (!mw.user.isAnon()) {
        document.body.classList.add('logged-in');
    }
    // Optional: Wenn jemand anonym ist, könnt ihr auch body.classList.add('anon') hinzufügen
});