MediaWiki:Gadget-NavFrame.js

MediaWiki系统消息页面
/**
 * SPDX-License-Identifier: CC-BY-SA-4.0
 * _addText: '{{Gadget Header|license=CC-BY-SA-4.0}}'
 *
 * @base {@link https://zh.wikipedia.org/wiki/MediaWiki:Gadget-NavFrame.js}
 * @source {@link https://github.com/TopRealm/YsArchives-Gadgets/tree/master/src/NavFrame}
 */

/**
 * Dynamic Navigation Bars.
 *
 * Based on script from en.wikipedia.org, 2008-09-15.
 *
 * @base {@link https://www.mediawiki.org/wiki/MediaWiki:Gadget-NavFrame.js}
 * @maintainer Helder.wiki, 2012–2013
 * @maintainer Krinkle, 2013
 * @maintainer Fantasticfears, 2013-2014
 */

/**
 * Warning: NavFrame is retained for compatibility. Use .mw-collapsible instead.
 * @license CC-BY-SA-4.0 {@link https://youshou.wiki/wiki/H:CC-BY-SA-4.0}
 */
/**
 * +------------------------------------------------------------+
 * |            === WARNING: GLOBAL GADGET FILE ===             |
 * +------------------------------------------------------------+
 * |       All changes should be made in the repository,        |
 * |                otherwise they will be lost.                |
 * +------------------------------------------------------------+
 * |        Changes to this page may affect many users.         |
 * | Please discuss changes by opening an issue before editing. |
 * +------------------------------------------------------------+
 */
/* <nowiki> */

(() => {

"use strict";

// dist/NavFrame/NavFrame.js
//! src/NavFrame/modules/i18n.ts
var import_ext_gadget = require("ext.gadget.i18n");
var getI18nMessages = () => {
  return {
    Hide: (0, import_ext_gadget.localize)({
      en: "Hide",
      ja: "非表示",
      "zh-hans": "隐藏",
      "zh-hant": "隱藏"
    }),
    Show: (0, import_ext_gadget.localize)({
      en: "Show",
      ja: "表示",
      "zh-hans": "显示",
      "zh-hant": "顯示"
    })
  };
};
var i18nMessages = getI18nMessages();
var getMessage = (key) => {
  return i18nMessages[key] || key;
};
//! src/NavFrame/modules/core.ts
var collapseCaption = getMessage("Hide");
var expandCaption = getMessage("Show");
var navigationBarHide = '<span title="'.concat(collapseCaption, '" class="oo-ui-indicatorElement-indicator oo-ui-indicator-up" role="button" tabindex="0"></span>');
var navigationBarShow = '<span title="'.concat(expandCaption, '" class="oo-ui-indicatorElement-indicator oo-ui-indicator-down" role="button" tabindex="0"></span>');
var toggleNavigationBar = (indexNavigationBar) => {
  const $toggle = $("#NavToggle".concat(indexNavigationBar));
  const $frame = $("#NavFrame".concat(indexNavigationBar));
  if (!$frame || !$toggle) {
    return false;
  }
  const isFrameCollapsed = $frame.hasClass("collapsed");
  if (isFrameCollapsed) {
    $frame.find("> .NavPic, > .NavContent, > .toogleShow").each((_index, element) => {
      $(element).css("display", "block");
    });
    $frame.find("> .toggleHide").each((_index, element) => {
      $(element).css("display", "none");
    });
    $toggle.html(navigationBarHide);
    $frame.removeClass("collapsed");
  } else {
    $frame.find("> .NavPic, > .NavContent, > .toogleShow").each((_index, element) => {
      $(element).css("display", "none");
    });
    $frame.find("> .toggleHide").each((_index, element) => {
      $(element).css("display", "block");
    });
    $toggle.html(navigationBarShow);
    $frame.addClass("collapsed");
  }
};
var createNavigationBarToggleButton = ($content) => {
  $content.find("div.NavFrame").each((indexNavigationBar, frameElement) => {
    const $frame = $(frameElement).attr("id", "NavFrame".concat(indexNavigationBar));
    const $navToggle = $("<span>").addClass("NavToggle").attr("id", "NavToggle".concat(indexNavigationBar));
    $frame.find("> .NavHead").each((_index, element) => {
      $(element).on("click", toggleNavigationBar.bind(void 0, indexNavigationBar));
      return false;
    });
    if ($frame.hasClass("collapsed")) {
      $frame.find("> .NavPic, > .NavContent, > .toggleHide").each((_index, element) => {
        $(element).css("display", "none");
      });
    } else {
      $frame.find("> .toggleShow").each((_index, element) => {
        $(element).css("display", "none");
      });
    }
    let showNavigationBarHide = true;
    $frame.find("> .NavPic, > .NavContent").each((_index, element) => {
      if ($(element).css("display") === "none") {
        showNavigationBarHide = false;
        return false;
      }
    });
    $navToggle.html(showNavigationBarHide ? navigationBarHide : navigationBarShow);
    $frame.find("> .NavHead").each((_index, element) => {
      $(element).append($navToggle);
      return false;
    });
  });
};
var navFrameLoad = () => {
  mw.hook("wikipage.content").add(createNavigationBarToggleButton);
};
//! src/NavFrame/NavFrame.ts
$(navFrameLoad);

})();

/* </nowiki> */

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/NavFrame/modules/i18n.ts", "src/NavFrame/modules/core.ts", "src/NavFrame/NavFrame.ts"],
  "sourcesContent": ["import {localize} from 'ext.gadget.i18n';\n\nconst getI18nMessages = () => {\n\treturn {\n\t\tHide: localize({\n\t\t\ten: 'Hide',\n\t\t\tja: '非表示',\n\t\t\t'zh-hans': '隐藏',\n\t\t\t'zh-hant': '隱藏',\n\t\t}),\n\t\tShow: localize({\n\t\t\ten: 'Show',\n\t\t\tja: '表示',\n\t\t\t'zh-hans': '显示',\n\t\t\t'zh-hant': '顯示',\n\t\t}),\n\t};\n};\n\nconst i18nMessages = getI18nMessages();\n\nconst getMessage: GetMessages<typeof i18nMessages> = (key) => {\n\treturn i18nMessages[key] || key;\n};\n\nexport {getMessage};\n", "import {getMessage} from './i18n';\n\nconst collapseCaption: string = getMessage('Hide');\nconst expandCaption: string = getMessage('Show');\nconst navigationBarHide: string = `<span title=\"${collapseCaption}\" class=\"oo-ui-indicatorElement-indicator oo-ui-indicator-up\" role=\"button\" tabindex=\"0\"></span>`;\nconst navigationBarShow: string = `<span title=\"${expandCaption}\" class=\"oo-ui-indicatorElement-indicator oo-ui-indicator-down\" role=\"button\" tabindex=\"0\"></span>`;\n\n/**\n * Shows and hides content and picture (if available) of navigation bars.\n *\n * @param {number} indexNavigationBar The index of navigation bar to be toggled\n * @return {false | void}\n */\nconst toggleNavigationBar = (indexNavigationBar: number): false | void => {\n\tconst $toggle: JQuery = $(`#NavToggle${indexNavigationBar}`);\n\tconst $frame: JQuery = $(`#NavFrame${indexNavigationBar}`);\n\tif (!$frame || !$toggle) {\n\t\treturn false;\n\t}\n\tconst isFrameCollapsed: boolean = $frame.hasClass('collapsed');\n\tif (isFrameCollapsed) {\n\t\t$frame.find('> .NavPic, > .NavContent, > .toogleShow').each((_index: number, element: HTMLElement): void => {\n\t\t\t$(element).css('display', 'block');\n\t\t});\n\t\t$frame.find('> .toggleHide').each((_index: number, element: HTMLElement): void => {\n\t\t\t$(element).css('display', 'none');\n\t\t});\n\t\t$toggle.html(navigationBarHide);\n\t\t$frame.removeClass('collapsed');\n\t} else {\n\t\t$frame.find('> .NavPic, > .NavContent, > .toogleShow').each((_index: number, element: HTMLElement): void => {\n\t\t\t$(element).css('display', 'none');\n\t\t});\n\t\t$frame.find('> .toggleHide').each((_index: number, element: HTMLElement): void => {\n\t\t\t$(element).css('display', 'block');\n\t\t});\n\t\t$toggle.html(navigationBarShow);\n\t\t$frame.addClass('collapsed');\n\t}\n};\n\n/**\n * Adds show/hide-button to navigation bars.\n *\n * @param {JQuery} $content\n */\nconst createNavigationBarToggleButton = ($content: JQuery): void => {\n\t// Iterate over all (new) nav frames\n\t$content.find('div.NavFrame').each((indexNavigationBar: number, frameElement: HTMLElement): void => {\n\t\tconst $frame: JQuery = $(frameElement).attr('id', `NavFrame${indexNavigationBar}`);\n\t\t// If found a navigation bar\n\t\tconst $navToggle: JQuery = $('<span>').addClass('NavToggle').attr('id', `NavToggle${indexNavigationBar}`);\n\t\t$frame.find('> .NavHead').each((_index: number, element: HTMLElement): false => {\n\t\t\t$(element).on('click', toggleNavigationBar.bind(undefined, indexNavigationBar));\n\t\t\treturn false;\n\t\t});\n\t\tif ($frame.hasClass('collapsed')) {\n\t\t\t$frame\n\t\t\t\t.find('> .NavPic, > .NavContent, > .toggleHide')\n\t\t\t\t.each((_index: number, element: HTMLElement): void => {\n\t\t\t\t\t$(element).css('display', 'none');\n\t\t\t\t});\n\t\t} else {\n\t\t\t$frame.find('> .toggleShow').each((_index: number, element: HTMLElement): void => {\n\t\t\t\t$(element).css('display', 'none');\n\t\t\t});\n\t\t}\n\t\tlet showNavigationBarHide: boolean = true;\n\t\t$frame.find('> .NavPic, > .NavContent').each((_index: number, element: HTMLElement): false | void => {\n\t\t\tif ($(element).css('display') === 'none') {\n\t\t\t\tshowNavigationBarHide = false;\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t\t$navToggle.html(showNavigationBarHide ? navigationBarHide : navigationBarShow);\n\t\t$frame.find('> .NavHead').each((_index: number, element: HTMLElement): false => {\n\t\t\t$(element).append($navToggle);\n\t\t\treturn false;\n\t\t});\n\t});\n};\n\nexport const navFrameLoad = (): void => {\n\tmw.hook('wikipage.content').add(createNavigationBarToggleButton);\n};\n", "import {navFrameLoad} from './modules/core';\n\n$(navFrameLoad);\n"],
  "mappings": "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",
  "names": ["import_ext_gadget", "require", "getI18nMessages", "Hide", "localize", "en", "ja", "Show", "i18nMessages", "getMessage", "key", "collapseCaption", "expandCaption", "navigationBarHide", "concat", "navigationBarShow", "toggleNavigationBar", "indexNavigationBar", "$toggle", "$", "$frame", "isFrameCollapsed", "hasClass", "find", "each", "_index", "element", "css", "html", "removeClass", "addClass", "createNavigationBarToggleButton", "$content", "frameElement", "attr", "$navToggle", "on", "bind", "showNavigationBarHide", "append", "navFrameLoad", "mw", "hook", "add"]
}
