MediaWiki:Gadget-PartialLoadTool.js

/** * PartialLoadTool * * Implements click-and-load for page content that uses the "partialLoad-settings" class. * @author MonkeysHK  * @license BSD-3 clause  */

(function {    if (window.partialLoadTool && window.partialLoadTool.Loaded)        return;    window.partialLoadTool = window.partialLoadTool || {};    window.partialLoadTool.Loaded = true;

$.when(       mw.loader.using(["mediawiki.util", "mediawiki.api"]),        $.Deferred(function (def) { if (mw.libs.QDmodal) { def.resolve(mw.libs.QDmodal); } else { $.ajax({                   cache: true,                    dataType: "script",                    url: "https://dev.fandom.com/load.php?mode=articles&only=scripts&articles=MediaWiki:QDmodal.js"                }).done(function  {                    def.resolve(mw.libs.QDmodal);                }); }       })    ).then(function  {        var that;        var private_cache = {}; // data security: do not add this to window.partialLoadTool        var partialLoadTool = window.partialLoadTool = Object.assign(this, { api: new mw.Api, getSpinner: function { return $(" ", {                   style: "justify-content: center; display: flex; margin: 3em 0;",                    html: mw.libs.QDmodal.getSpinner,                }); },           parsePage: function (pagename) { return that.api.post({                   action: "parse",                    contentmodel: "wikitext",                    page: pagename,                    formatversion: 2,                }); },           buttonclick: function (event) { event.preventDefault; var $this = $(this); var button = $this.parent; $this.text("Loading..."); that.parsePage($this.attr("data-page")) .done(function (d) {                       var out = $(" ", { class: "partialLoaded", html: d.parse.text, });                       button.after(out);                        button.remove;                    }) .catch(console.warn); },           tabclick: function (event) { event.preventDefault; var $this = $(this), $parent = $this.parents(".partialLoad-tabber").eq(0), $parenttab = $this.parents(".partialLoad-tabs__tab").eq(0), $frame = $parent.find(".partialLoad-frame"), $actionLinks = $parent.find(".partialLoad-actionLinks"), requested_page = $this.attr("data-page"), cache_enabled = ($this.attr("data-cache") === "true"), pageActions = [ "edit", "view", "purge", ].map(function (act) {                       var pref = /^\//.test(requested_page) && mw.config.get("wgPageName") || "";                        return "[" + $("", { href: new mw.Title(pref + requested_page).getUrl({                               action: act,                            }), title: pref + requested_page + "?action=" + act, text: act + " page", }).prop("outerHTML") + "]";                   }).join(" • "); $parent.find(".selected").removeClass("selected"); $parenttab.addClass("selected"); $actionLinks.html(pageActions); if (cache_enabled && (requested_page in private_cache)) { $frame.html(private_cache[requested_page]); } else { $frame.empty.append(that.getSpinner); that.parsePage(requested_page) .done(function (d) {                           var requested_content = $(d.parse.text);                            mw.hook("wikipage.content").fire(requested_content);                            $frame.empty.append(requested_content);                            private_cache[requested_page] = requested_content;                        }) .catch(console.warn); }           },            makeButton: function (pagename) { var button = $(" ", {                   class: "page-header__actions",                    style: "text-align: center; width: 100%; clear: both; display: block;",                    html: $("", { href: "#", html: "Load This Part Of Content", "data-page": pagename, click: that.buttonclick, class: "wds-button wds-is-text page-header__action-button has-label", }),               });                return button; },           main: function  { $(".partialLoad-settings").each(function {                    var el = $(this);                    var data = JSON.parse(el.attr("data-tabs"));                    if (!data.tabs.length) return;                    if (data.tabs.length == 1) {                        el.after(that.makeButton(data.tabs[0].pagename));                        el.remove;                    } else {                        var tabLabels = $(" ", { class: "partialLoad-tabs__wrapper", html: $("", {                               class: "partialLoad-tabs",                                html: data.tabs.map(function (tab) { return $("", {                                       class: "partialLoad-tabs__tab",                                        html: $(" ", { html: $("", {                                               href: "#",                                                text: tab.caption,                                                "data-page": tab.pagename,                                                "data-cache": tab.cache,                                                click: that.tabclick,                                            }), class: "partialLoad-tabs__label", }),                                   });                                }),                            }),                        });                        var tabLinks = $(" ", { class: "partialLoad-actionLinks noselect", });                       var tabSep = $(" ", { class: "partialLoad-separator" });                       var tabFrame = $(" ", { class: "partialLoad-frame", });                       el.after($(" ", {                            class: "partialLoad-tabber",                            html: [                                tabLabels,                                tabLinks,                                tabSep,                                tabFrame,                            ],                        }));                        el.remove;                        var activeTabIndex = parseInt(data.activeTabIndex);                        if (isNaN(activeTabIndex) || activeTabIndex > data.tabs.length || activeTabIndex < 1) {                            console.warn("[PartialLoad/Tabview] One or more tabbers have invalid active tab index. It will be changed to first tab.");                            activeTabIndex = 0;                        } else                            activeTabIndex--;                        tabLabels.find(".partialLoad-tabs__tab").eq(activeTabIndex).find("a").eq(0).trigger("click"); }               });            },            init: function  {                // This hook forces it to apply script even in TabViews                mw.hook("wikipage.content").add(function{ that.main; // prevents adding more TOC icons $("#toc .toctitle .wds-icon").slice(1).remove; });               $(" ", {                    rel: "stylesheet", href: new mw.Title("Gadget-PartialLoadTool.css", 8).getUrl({                       action: "raw",                        ctype: "text/css"                    }) }).appendTo("head");               that.main;            },        });

that = partialLoadTool; this.init; }); });