MediaWiki: Common.js: Difference between revisions

From LINKS Community Center
Jump to: navigation, search
Eschmidt (talk | contribs)
No edit summary
Eschmidt (talk | contribs)
No edit summary
Line 18: Line 18:
const changeWrapper = document.getElementById('recentChanges');
const changeWrapper = document.getElementById('recentChanges');
if (changeWrapper) {
if (changeWrapper) {
     var url = 'https://links.communitycenter.eu/api.php';
     let url = 'https://links.communitycenter.eu/api.php';
     var params = {
     var params = {
         action: 'query',
         action: 'query',

Revision as of 12:57, 15 February 2022

/* 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 */
const changeWrapper = document.getElementById('recentChanges');
if (changeWrapper) {
    let url = 'https://links.communitycenter.eu/api.php';
    var params = {
        action: 'query',
        list: 'recentchanges',
        rcprop: 'title|user|timestamp',
        rclimit: '5',
        format: 'json'
    };

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

    fetch(url)
        .then(function (response) { return response.json(); })
        .then(function (response) {
            const recentchanges = response.query.recentchanges;
            console.log(recentchanges);

            for (var rc in recentchanges) {
                changeWrapper.innerHTML += '<div>' + recentchanges[rc].title + ' ' + recentchanges[rc].user + ' ' + recentchanges[rc].timestamp + '</div>';

                console.log(recentchanges[rc].title);
            }
        })
        .catch(function (error) { console.log(error); });
}
/* Recent Changes End */