MediaWiki:Common.js: Difference between revisions

From Fatesend Wiki
Jump to navigation Jump to search
No edit summary
No edit summary
 
Line 33: Line 33:
   }
   }


  // POPUP viewer (button)
   function openPopupFromLink(a) {
   function openPopupFromLink(a) {
     var sprite = a.getAttribute('data-sprite') || a.getAttribute('data-accessory') || '';
     var sprite = a.getAttribute('data-sprite') || a.getAttribute('data-accessory') || '';
Line 59: Line 58:
   }
   }


  // EMBED viewer (div)
  function initEmbed(el) {
    if (el.getAttribute('data-ro-init') === '1') return;
    el.setAttribute('data-ro-init', '1');
    var accessory = el.getAttribute('data-accessory') || '';
    if (!accessory) return;
    var ro = new window.ROBrowser({
      type: window.ROBrowser.TYPE.FRAME,
      target: el,
      application: window.ROBrowser.APP.MODELVIEWER,
      development: true,
      remoteClient: 'https://grf.robrowser.com/',
      skipIntro: true,
      skipServerList: true,
      accessory: accessory
    });
    ro.start();
  }
  // Click handler for popup buttons
   document.addEventListener('click', function (e) {
   document.addEventListener('click', function (e) {
     var a = e.target.closest && e.target.closest('a.dp-modelviewer');
     var a = e.target.closest && e.target.closest('a.dp-modelviewer');
     if (!a) return;
     if (!a) return;


    // IMPORTANT: prevents navigation / recursion
     e.preventDefault();
     e.preventDefault();
     e.stopPropagation();
     e.stopPropagation();
Line 94: Line 69:
       .catch(function (err) { console.error('ModelViewer popup error:', err); });
       .catch(function (err) { console.error('ModelViewer popup error:', err); });
   });
   });
  // Auto-init embedded viewers on page load / ajax loads
  function bootEmbeds(root) {
    var nodes = (root || document).querySelectorAll('.ro-modelviewer');
    if (!nodes.length) return;
    ensureROBrowser()
      .then(function () { nodes.forEach(initEmbed); })
      .catch(function (err) { console.error('ModelViewer embed error:', err); });
  }
  if (window.mw && mw.hook) {
    mw.hook('wikipage.content').add(function ($content) {
      bootEmbeds($content[0]);
    });
  } else {
    document.addEventListener('DOMContentLoaded', function () { bootEmbeds(document); });
  }
})();
})();

Latest revision as of 15:32, 27 January 2026

/* Any JavaScript here will be loaded for all users on every page load. */
(function () {
  // If there are no DP links on the page, don't load anything.
  if (!document.querySelector('a[href*="divine-pride.net/database/item/"]')) return;

  var s = document.createElement('script');
  s.src = 'https://www.divine-pride.net/scripts/tooltip.js';
  s.async = true;
  document.head.appendChild(s);
})();


(function () {
  function loadScriptOnce(src, id) {
    return new Promise(function (resolve, reject) {
      if (document.getElementById(id)) return resolve();
      var s = document.createElement('script');
      s.id = id;
      s.src = src;
      s.async = true;
      s.onload = resolve;
      s.onerror = reject;
      document.head.appendChild(s);
    });
  }

  var RO_API_JS = '/robrowser/api.js';

  function ensureROBrowser() {
    return loadScriptOnce(RO_API_JS, 'robrowser-api').then(function () {
      if (!window.ROBrowser) throw new Error('ROBrowser not available after loading api.js');
    });
  }

  function openPopupFromLink(a) {
    var sprite = a.getAttribute('data-sprite') || a.getAttribute('data-accessory') || '';
    var jobId = parseInt(a.getAttribute('data-jobid') || '0', 10) || 0;
    var job = a.getAttribute('data-job') || '';
    var robe = a.getAttribute('data-robe') || '';
    if (!sprite) return;

    var ro = new window.ROBrowser({
      application: window.ROBrowser.APP.MODELVIEWER,
      type: window.ROBrowser.TYPE.POPUP,
      width: 820,
      height: 520,
      development: true,
      remoteClient: 'https://grf.robrowser.com/',
      skipIntro: true,
      skipServerList: true,
      accessory: sprite,
      jobId: jobId,
      job: job,
      robe: robe
    });

    ro.start();
  }

  document.addEventListener('click', function (e) {
    var a = e.target.closest && e.target.closest('a.dp-modelviewer');
    if (!a) return;

    e.preventDefault();
    e.stopPropagation();

    ensureROBrowser()
      .then(function () { openPopupFromLink(a); })
      .catch(function (err) { console.error('ModelViewer popup error:', err); });
  });
})();