Toggle menu
209
925
189
6.3K
Dovedale Railway Wiki
Toggle preferences menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

MediaWiki:Citizen.js

MediaWiki interface page

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)
  • Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5.
/* All JavaScript here will be loaded for users of the Citizen skin */
/* Current version of MediaWiki does not support ES6 */

mw.loader.using(["mediawiki.util"]).done(function () {
    /* Trigger search box when click on the fake search button on main page */
    var searchTrigger = document.getElementById("skin-citizen-search-trigger");
    if (searchTrigger) {
        searchTrigger.addEventListener("click", function () {
            var search = document.getElementById("citizen-search-details");
            // HACK: Force sticky header to be visible
            var isSearchHidden =
                document.body.classList.contains("citizen-scroll--down") &&
                window.matchMedia("(max-width: 1119px)");
            if (isSearchHidden) {
                document.body.classList.remove("citizen-scroll--down");
                document.body.classList.add("citizen-scroll--up");
            }
            var prefill = searchTrigger.dataset.prefill;
            if (prefill) {
                var prefillText = mw.html.escape(searchTrigger.dataset.prefill);
                document.getElementById("searchInput").value = prefillText;
            }
            // Citizen does not have a visible search bar, you need to expand the search card first
            // And Citizen will focus the input automatically
            search.open = true;
        });
    }
});

/**
 * Name:        DiscordIntegrator
 * Author:      KockaAdmiralac <[email protected]>
 * Description: Allows intergration with Discord [https://discord.com]
 */
mw.loader.using(["mediawiki.api", "mediawiki.util"]).then(function() {
    "use strict";
    var mconfig = mw.config.get([
        "wgContentLanguage",
        "wgUserLanguage",
        "wgUserName"
    ]);
    if (window.DiscordIntegratorLoaded) {
        return;
    }
    window.DiscordIntegratorLoaded = true;
    /**
     * Main object
     * @static
     */
    var DiscordIntegrator = {
        /**
         * Configuration for the plugin
         * @property config
         * @type {Object}
         */
        config: (window.DiscordIntegratorConfig || {}).siderail || {},
        /**
         * Preload resources
         */
        preload: function() {
            mw.hook("wikipage.content").add(this.insertToContent.bind(this));
            mw.hook("ext.themes.themeChanged").add(this.determineTheme.bind(this));

            this.api = new mw.Api();
            this.api.get({
                action: "query",
                meta: "allmessages",
                ammessages: [
                    "id",
                    "title",
                    "moduleHeight",
                    "theme",
                    "width",
                    "height",
                    "text",
                    "logged-in",
                    "footer",
                    "username"
                ].map(function(el) {
                    return "Custom-DiscordIntegrator-config-" + el;
                }).join("|"),
                amlang: mconfig.wgUserLanguage === "qqx" ?
                    mconfig.wgContentLanguage :
                    mconfig.wgUserLanguage,
                uselang: "content", // T97096
                smaxage: 300,
                maxage: 300
            }).done((function(d) {
                if (!d.error) {
                    d.query.allmessages.forEach(function(el) {
                        if(el["*"]) {
                            this.config[el.name.substring(32)] = el["*"];
                        }
                    }, this);
                    this._loading = 0;
                    ["text", "title", "footer"].forEach(this.parse, this);
                    if (this._loading === 0) {
                        this.init();
                    }
                }
            }).bind(this));
        },
        /**
         * Parse the configuration that needs to be parsed
         */
        parse: function(msg) {
            if (this.config[msg]) {
                ++this._loading;
                this.api.get({
                    action: "parse",
                    text: this.config[msg],
                    // Also cache the individual parser outputs of messages for anonymous users.
                    // This can be a bit more aggressive as the cache varies on the
                    // actual message text, which often contains no wikitext at all.
                    smaxage: 86400,
                    maxage: 86400
                }).done((function(d) {
                    if (!d.error) {
                        this.config[msg] = d.parse.text["*"];
                        if (--this._loading === 0) {
                            this.init();
                        }
                    }
                }).bind(this));
            }
        },
        /**
         * Initializing
         */
        init: function() {
            if (this.config.id && $("#WikiaRail").length > 0) {
                var clas = $("#WikiaRail").attr("class");
                if (clas) {
                    var classSplit = clas.split(/\s+/);
                    if (classSplit.indexOf("loaded") === -1 && classSplit.indexOf("is-ready") === -1) {
                        $("#WikiaRail").on("afterLoad.rail", this.insertToSiderail.bind(this));
                    } else {
                        this.insertToSiderail();
                    }
                } else {
                    this.insertToSiderail();
                }
            }
        },
        /**
         * Inserting the widget to siderail
         */
        insertToSiderail: function() {
            var filter = $("#top-right-boxad-wrapper, #top-boxad-wrapper, #NATIVE_TABOOLA_RAIL, .content-review-module").last();
            // TODO: Insert some user configuration here
            var el = $("<div>", { class: "DiscordIntegratorModule rail-module" });
            if (this.config.title) {
                el.append(
                    $("<h2>", {
                        "class": "activity-heading",
                        html: this.config.title.trim()
                    })
                );
            }
            if (this.config.text) {
                el.append(
                    $("<p>", {
                        id: "DiscordIntegratorModuleText",
                        html: this.config.text
                    })
                );
            }
            el.append(this.generateContent(this.config));
            if (this.config.footer) {
                el.append(
                    $("<p>", {
                        id: "DiscordIntegratorModuleFooter",
                        html: this.config.footer
                    })
                );
            }
            if (filter.length > 0) {
                el.insertAfter(filter);
            } else {
                $("#WikiaRail").prepend(el);
            }
            if (this.config.moduleHeight) {
                mw.util.addCSS(".DiscordIntegratorModule { height: " + Number(this.config.moduleHeight) + "px; }");
            }
            mw.hook("DiscordIntegrator.added").fire(el);
        },
        /**
         * Finding the designated places in content
         * in which to place the widget and placing it
         */
        insertToContent: function($content) {
            $content.find(".DiscordIntegrator:not(.loaded)").each((function(cabbage, el) {
                el = $(el);
                el.html(this.generateContent(el.data()))
                  .addClass("loaded");
            }).bind(this));
        },
        /**
         * Determines the theme of the widget.
         * @param {string} config Configured theme
         * @return {string} "light" or "dark" depending on the wiki theme and configuration
         */
        determineTheme: function(config) {
            // If explicitly configured to light or dark.
            // If not configured, and the current theme is set.
            //if (MwSkinTheme.getCurrent() === "dark") {
            //    return "dark";
            //}
            //if (MwSkinTheme.getCurrent() === "light") {
            //    return "light";
            //}
            if (config === "dark") {
                return "dark";
            }
            if (config === "light") {
                return "light";
            }
            // Otherwise, default to dark.
            return "light";
        },
        /**
         * Generating widget content from an object
         * @return {string} Content of the widget
         */
        generateContent: function(config) {
            if (!config.id || !String(config.id).match(/\d{17,19}/)) {
                return "Error: ID of the widget is malformed or not supplied, please see step 2 of <a href=\"https://dev.fandom.com/wiki/DiscordIntegrator/instructions\" title=\"the instructions\">the instructions</a> for how to find your server's ID. Please make sure you are not inserting <strong>the DiscordIntegrator template</strong> when asked for <strong>your widget ID</strong>.";
            }
            if (
                (
                    config.loggedIn === true ||
                    Boolean(config["logged-in"]) === true &&
                    config["logged-in"] !== "false" &&
                    config["logged-in"] !== "{{{loggedIn}}}"
                ) && !mconfig.wgUserName
            ) {
                return "Please <a href=\"/wiki/Special:UserLogin\" title=\"log in\">log in</a> to see this widget.";
            }
            var username = config.username === "@disabled" ?
                 "" :
                 config.username === "@function" &&
                 typeof window.DiscordIntegratorGetUsername === "function" ?
                     window.DiscordIntegratorGetUsername() :
                     config.username || mconfig.wgUserName;
            return mw.html.element("iframe", {
                src: "https://discord.com/widget?id=" + config.id +
                     "&theme=" + this.determineTheme(config.theme) +
                     "&username=" + encodeURIComponent(username),
                width: config.width || "100%",
                height: config.height || "400px",
                allowtransparency: "true",
                frameborder: "0",
                title: "Discord server widget"
            });
        }
    };
    DiscordIntegrator.preload();
})();

/* Discord Icon */
$(document).ready( function () {
    $(".citizen-drawer").after($("<div class=\"citizen-discord citizen-header__item\"><a href=\"https://discord.com/invite/hmqCYg4P23\"><img src=\"//dovedale.wiki/wiki/File:Discord-icon.svg\" width=\"40\" height=\"40\"></a></div>"));
});
🍪 Yum Yum Yum! Cookies help us better deliver our services. By using our site, you agree to our use of cookies.