Zum Inhalt springen

MediaWiki:Common.js: Unterschied zwischen den Versionen

Aus ADOS Wiki
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
Zeile 1: Zeile 1:
/* Das folgende JavaScript wird für alle Benutzer geladen. */
/* Das folgende JavaScript wird für alle Benutzer geladen. */
/* Charity-Popup (v6) – angepasst für größeren weißen Bereich & höheres Herz */
/* Charity-Popup (v7) – abgestimmt auf größere Modal-Fläche & höheres Herz */
mw.loader.using(['mediawiki.util', 'jquery']).then(function () {
mw.loader.using(['mediawiki.util', 'jquery']).then(function () {
   (function ($, mw) {
   (function ($, mw) {
Zeile 7: Zeile 7:
     var CONFIG = {
     var CONFIG = {
       enabled: true,
       enabled: true,
       id: 'charity_notice_v6', // Version hochgesetzt, damit alle es neu sehen
       id: 'charity_notice_v7', // Version hochsetzen, damit alle es neu sehen
       title: 'Charity für Kinderherzen',
       title: 'Charity für Kinderherzen',
       logoUrl: 'https://www.kinderherzen.de/wp-content/uploads/2019/03/KinderherzenLogo_RGB.jpg',
      // Tipp: Logo nach Möglichkeit im Wiki hosten (CSP!)
       logoUrl: 'https://www.kinderherzen.de/wp-content/uploads/2019/03/kinderherzen.de_orange_RGB.jpg',
       html:
       html:
         '<p>Liebe Whisky, ADoS Heads,</p>' +
         '<p>Liebe Whisky, ADoS Heads,</p>' +
Zeile 17: Zeile 18:
         '<p><strong>Jede Spende zählt!</strong></p>' +
         '<p><strong>Jede Spende zählt!</strong></p>' +
         '<p><a href="https://www.thewhiskywaiter.com/charity-event" target="_blank" rel="noopener" class="mw-ui-button">Mehr erfahren</a></p>',
         '<p><a href="https://www.thewhiskywaiter.com/charity-event" target="_blank" rel="noopener" class="mw-ui-button">Mehr erfahren</a></p>',
       showOnNamespaces: 'all', // 'all' oder z.B. [0,4]
       showOnNamespaces: 'all',
       dailyLimit: 1,
       dailyLimit: 1,
       escToClose: true,
       escToClose: true,
Zeile 33: Zeile 34:
     }
     }


     // Einmal-pro-Tag
     // Einmal pro Tag
     var isAnon = mw.config.get('wgUserName') === null;
     var isAnon = mw.config.get('wgUserName') === null;
     function storageGet(k){ try { return window.localStorage.getItem(k); } catch (e) { return null; } }
     function storageGet(k){ try { return window.localStorage.getItem(k); } catch (e) { return null; } }
Zeile 43: Zeile 44:


     $(function () {
     $(function () {
       // Overlay
       // Overlay + Modal erstellen
       var $overlay = $('<div>', { 'class': 'mw-popup-overlay' });
       var $overlay = $('<div>', { 'class': 'mw-popup-overlay' });
      var $modal = $('<div>', {
        'class': 'mw-popup-modal',
        'role': 'dialog',
        'aria-modal': 'true',
        'aria-labelledby': 'mw-popup-title'
      });


       // Modal
       // Logo + Herz (Herz liegt in CSS höher / Modal hat mehr Top-Padding)
      var $modal = $('<div>', { 'class': 'mw-popup-modal', 'role': 'dialog', 'aria-modal': 'true' });
 
      // Logo + Herz
       var $logoWrap = $('<div>', { 'class': 'mw-popup-logo' })
       var $logoWrap = $('<div>', { 'class': 'mw-popup-logo' })
         .append($('<div>', { 'class': 'mw-popup-heart' }))
         .append($('<div>', { 'class': 'mw-popup-heart' }))
         .append($('<img>', { src: CONFIG.logoUrl, alt: 'Kinderherzen Logo' }));
         .append($('<img>', { src: CONFIG.logoUrl, alt: 'Kinderherzen Logo' }));


      // Titel, Inhalt, Button
       var $title = $('<h2>', { id: 'mw-popup-title' }).text(CONFIG.title);
       var $title = $('<h2>').text(CONFIG.title);
       var $content = $('<div>', { 'class': 'mw-popup-content' }).html(CONFIG.html);
       var $content = $('<div>', { 'class': 'mw-popup-content' }).html(CONFIG.html);
       var $btn = $('<button>', { 'class': 'mw-popup-close', type: 'button' }).text('OK');
       var $btn = $('<button>', { 'class': 'mw-popup-close', type: 'button' }).text('OK');


      // Zusammenbauen
       $modal.append($logoWrap, $title, $content, $btn);
       $modal.append($logoWrap, $title, $content, $btn);
       $('body').append($overlay, $modal);
       $('body').append($overlay, $modal);


       // Schließen-Funktion
       // Fokus setzen (kleine Zugänglichkeitshilfe)
      setTimeout(function(){ try { $modal.attr('tabindex','-1').focus(); } catch(e) {} }, 0);
 
       function close() {
       function close() {
         markSeen();
         markSeen();
Zeile 84: Zeile 88:
       }
       }


       // Direkt als gesehen markieren
       // Direkt als gesehen markieren (damit Reload am selben Tag nicht erneut zeigt)
       markSeen();
       markSeen();
     });
     });
   })(jQuery, mw);
   })(jQuery, mw);
}).catch(function (e) {
}).catch(function () {
   console.error('Popup init error:', e);
   // leise ignorieren, falls der Loader scheitert
});
});

Version vom 1. September 2025, 22:36 Uhr

/* Das folgende JavaScript wird für alle Benutzer geladen. */
/* Charity-Popup (v7) – abgestimmt auf größere Modal-Fläche & höheres Herz */
mw.loader.using(['mediawiki.util', 'jquery']).then(function () {
  (function ($, mw) {
    'use strict';

    var CONFIG = {
      enabled: true,
      id: 'charity_notice_v7', // Version hochsetzen, damit alle es neu sehen
      title: 'Charity für Kinderherzen',
      // Tipp: Logo nach Möglichkeit im Wiki hosten (CSP!)
      logoUrl: 'https://www.kinderherzen.de/wp-content/uploads/2019/03/kinderherzen.de_orange_RGB.jpg',
      html:
        '<p>Liebe Whisky, ADoS Heads,</p>' +
        '<p>wir wurden jetzt schon gefragt, ob ihr dieses Wiki-Projekt unterstützen könnt.</p>' +
        '<p>Wir freuen uns sehr, dass dieses Projekt so gut angenommen wurde.</p>' +
        '<p>Wir würden uns daher sehr freuen, wenn ihr anstatt uns lieber das Projekt vom Whiskywaiter unterstützen würdet.</p>' +
        '<p><strong>Jede Spende zählt!</strong></p>' +
        '<p><a href="https://www.thewhiskywaiter.com/charity-event" target="_blank" rel="noopener" class="mw-ui-button">Mehr erfahren</a></p>',
      showOnNamespaces: 'all',
      dailyLimit: 1,
      escToClose: true,
      clickBackdropToClose: true
    };

    if (!CONFIG.enabled) return;

    // Namespace-Filter
    var ns = mw.config.get('wgNamespaceNumber');
    if (CONFIG.showOnNamespaces !== 'all' &&
        $.isArray(CONFIG.showOnNamespaces) &&
        $.inArray(ns, CONFIG.showOnNamespaces) === -1) {
      return;
    }

    // Einmal pro Tag
    var isAnon = mw.config.get('wgUserName') === null;
    function storageGet(k){ try { return window.localStorage.getItem(k); } catch (e) { return null; } }
    function storageSet(k,v){ try { window.localStorage.setItem(k, v); } catch (e) {} }
    var key = 'popup_' + CONFIG.id + (isAnon ? ':anon' : ':user');
    var today = (function(d){ return d.getFullYear() + '-' + ('0'+(d.getMonth()+1)).slice(-2) + '-' + ('0'+d.getDate()).slice(-2); })(new Date());
    if (storageGet(key) === today) return;
    function markSeen(){ storageSet(key, today); }

    $(function () {
      // Overlay + Modal erstellen
      var $overlay = $('<div>', { 'class': 'mw-popup-overlay' });
      var $modal = $('<div>', {
        'class': 'mw-popup-modal',
        'role': 'dialog',
        'aria-modal': 'true',
        'aria-labelledby': 'mw-popup-title'
      });

      // Logo + Herz (Herz liegt in CSS höher / Modal hat mehr Top-Padding)
      var $logoWrap = $('<div>', { 'class': 'mw-popup-logo' })
        .append($('<div>', { 'class': 'mw-popup-heart' }))
        .append($('<img>', { src: CONFIG.logoUrl, alt: 'Kinderherzen Logo' }));

      var $title = $('<h2>', { id: 'mw-popup-title' }).text(CONFIG.title);
      var $content = $('<div>', { 'class': 'mw-popup-content' }).html(CONFIG.html);
      var $btn = $('<button>', { 'class': 'mw-popup-close', type: 'button' }).text('OK');

      $modal.append($logoWrap, $title, $content, $btn);
      $('body').append($overlay, $modal);

      // Fokus setzen (kleine Zugänglichkeitshilfe)
      setTimeout(function(){ try { $modal.attr('tabindex','-1').focus(); } catch(e) {} }, 0);

      function close() {
        markSeen();
        $overlay.remove();
        $modal.remove();
        $(document).off('keydown.mwpopup');
      }

      // Events
      $btn.on('click', close);
      if (CONFIG.clickBackdropToClose) $overlay.on('click', close);
      if (CONFIG.escToClose) {
        $(document).on('keydown.mwpopup', function (e) {
          var key = e.key || e.keyCode;
          if (key === 'Escape' || key === 'Esc' || key === 27) {
            e.preventDefault();
            close();
          }
        });
      }

      // Direkt als gesehen markieren (damit Reload am selben Tag nicht erneut zeigt)
      markSeen();
    });
  })(jQuery, mw);
}).catch(function () {
  // leise ignorieren, falls der Loader scheitert
});