MediaWiki:Common.js

From LINKS Community Center
Revision as of 14:05, 15 February 2022 by Eschmidt (talk | contribs)
Jump to: navigation, search

Note: After publishing, you may have to bypass your browser's cache to see the changes.

  • Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
  • Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
  • Internet Explorer / Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5
  • Opera: Press Ctrl-F5.
/* Any JavaScript here will be loaded for all users on every page load. */

/* Matomo */
var _paq = window._paq = window._paq || [];
/* Tracker methods like 'setCustomDimension' should be called before 'trackPageView'. */
_paq.push(['trackPageView']);
_paq.push(['enableLinkTracking']);
(function () {
    var u = '//analytics.safetyinnovation.center/';
    _paq.push(['setTrackerUrl', u + 'matomo.php']);
    _paq.push(['setSiteId', '11']);
    var d = document, g = d.createElement('script'), s = d.getElementsByTagName('script')[0];
    g.async = true; g.src = u + 'matomo.js'; s.parentNode.insertBefore(g, s);
})();
/* End Matomo Code */

/* Recent Changes Start */
var changesWrapper = document.getElementById('recentChanges');
if (changesWrapper) {
    var url = 'https://links.communitycenter.eu/api.php';
    var params = {
        action: 'query',
        list: 'recentchanges',
        rcprop: 'title|user|timestamp',
        rclimit: '5',
        format: 'json'
    };
    var xxx = new URLSearchParams(params);
    console.log(xxx);

    url = url + '?origin=*';
    Object.keys(params).forEach(function (key) { url += '&' + key + '=' + params[key]; });

    fetch(url)
        .then(function (response) { return response.json(); })
        .then(function (response) {
            var domStr = response.query.recentchanges.reduce(function (output, change) {
                return output
                    + '<div class="recentChange">'
                    + '<span>' + change.title + '</span>'
                    + '<span>' + change.user + '</span>'
                    + '<span>' + change.timestamp + '</span>'
                    + '</div>'
            }, '');
            changesWrapper.innerHTML = domStr;
        })
        .catch(function (error) { console.log('Error in Recent Changes Widget', error); });
}
/* Recent Changes End */