MediaWiki:Gadget-PreviewWithVariant.js

MediaWiki系统消息页面
/**
 * SPDX-License-Identifier: MIT
 * _addText: '{{Gadget Header|license=MIT}}'
 *
 * @base {@link https://zh.wikipedia.org/wiki/Special:Permalink/67345361}
 * @source {@link https://github.com/TopRealm/YsArchives-Gadgets/tree/master/src/PreviewWithVariant}
 */
/**
 * +------------------------------------------------------------+
 * |            === 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/PreviewWithVariant/PreviewWithVariant.js
//! src/PreviewWithVariant/PreviewWithVariant.ts
mw.hook("wikipage.editform").add(($editForm) => {
  if (mw.config.get("wgPreviewWithVariantInitialized")) {
    return;
  }
  const $templateSandboxPreview = $editForm.find('input[name="wpTemplateSandboxPreview"]');
  if (mw.config.get("wgPageContentModel") !== "wikitext" && !$templateSandboxPreview.length) {
    return;
  }
  const $layout = $editForm.find(".editCheckboxes .oo-ui-horizontalLayout");
  if (!$layout.length) {
    return;
  }
  mw.config.set("wgPreviewWithVariantInitialized", true);
  const VARIANTS = [{
    data: "zh",
    label: window.wgULS("不转换", "不轉換")
  }, {
    data: "zh-hans",
    label: "简体"
  }, {
    data: "zh-hant",
    label: "繁體"
  }, {
    data: "zh-cn",
    label: "中国大陆简体"
  }, {
    data: "zh-hk",
    label: "中國香港繁體"
  }, {
    data: "zh-mo",
    label: "中國澳門繁體"
  }, {
    data: "zh-my",
    label: "马来西亚简体"
  }, {
    data: "zh-sg",
    label: "新加坡简体"
  }, {
    data: "zh-tw",
    label: "中國臺灣繁體"
  }];
  const uriVariant = mw.util.getParamValue("variant");
  const checkbox = new OO.ui.CheckboxInputWidget({
    selected: Boolean(uriVariant)
  });
  const dropdown = new OO.ui.DropdownWidget({
    $overlay: true,
    disabled: !checkbox.isSelected(),
    menu: {
      items: VARIANTS.map(({
        data,
        label
      }) => {
        return new OO.ui.MenuOptionWidget({
          data,
          label
        });
      })
    }
  });
  dropdown.getMenu().selectItemByData(mw.config.get("wgUserVariant") || uriVariant || mw.user.options.get("variant"));
  checkbox.on("change", (selected) => {
    dropdown.setDisabled(!selected);
  });
  const getSelectedVariant = () => {
    if (!checkbox.isSelected()) {
      return;
    }
    const selectedItem = dropdown.getMenu().findSelectedItem();
    return selectedItem ? selectedItem.getData() : void 0;
  };
  const manipulateActionUrl = () => {
    const selectedVariant = getSelectedVariant();
    const originalAction = $editForm.attr("action");
    if (selectedVariant && originalAction) {
      $editForm.attr("action", new mw.Uri(originalAction).extend({
        variant: selectedVariant
      }).getRelativePath());
    }
  };
  const manipulateVariantConfig = () => {
    mw.config.set("wgUserVariant", getSelectedVariant() || mw.user.options.get("variant"));
  };
  $editForm.find("input[name=wpPreview]").on("click", mw.user.options.get("uselivepreview") ? manipulateVariantConfig : manipulateActionUrl);
  $templateSandboxPreview.on("click", manipulateActionUrl);
  dropdown.getMenu().on("select", manipulateVariantConfig);
  const checkboxField = new OO.ui.FieldLayout(checkbox, {
    align: "inline",
    label: window.wgULS("预览字词转换", "預覽字詞轉換")
  });
  const dropdownField = new OO.ui.FieldLayout(dropdown, {
    align: "top",
    label: window.wgULS("使用该语言变体显示预览:", "使用該語言變體顯示預覽:"),
    invisibleLabel: true
  });
  $layout.append($("<div>").attr("id", "pwv-area").append(checkboxField.$element, dropdownField.$element));
});

})();

/* </nowiki> */

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/PreviewWithVariant/PreviewWithVariant.ts"],
  "sourcesContent": ["/**\n * @description Add a \"Preview with variant\" option to the edit form.\n */\nmw.hook('wikipage.editform').add(($editForm): void => {\n\t// Guard against double inclusions\n\tif (mw.config.get('wgPreviewWithVariantInitialized')) {\n\t\treturn;\n\t}\n\tconst $templateSandboxPreview: JQuery = $editForm.find('input[name=\"wpTemplateSandboxPreview\"]');\n\t// It is possible that a user want to preview a page with a non-wikitext module\n\t// Do not return in this case\n\tif (mw.config.get('wgPageContentModel') !== 'wikitext' && !$templateSandboxPreview.length) {\n\t\treturn;\n\t}\n\tconst $layout: JQuery = $editForm.find('.editCheckboxes .oo-ui-horizontalLayout');\n\tif (!$layout.length) {\n\t\treturn;\n\t}\n\t// Guard against double inclusions\n\tmw.config.set('wgPreviewWithVariantInitialized', true);\n\tconst VARIANTS: {\n\t\tdata: string;\n\t\tlabel: string;\n\t}[] = [\n\t\t{\n\t\t\tdata: 'zh',\n\t\t\tlabel: window.wgULS('不转换', '不轉換'),\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-hans',\n\t\t\tlabel: '简体',\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-hant',\n\t\t\tlabel: '繁體',\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-cn',\n\t\t\tlabel: '中国大陆简体',\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-hk',\n\t\t\tlabel: '中國香港繁體',\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-mo',\n\t\t\tlabel: '中國澳門繁體',\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-my',\n\t\t\tlabel: '马来西亚简体',\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-sg',\n\t\t\tlabel: '新加坡简体',\n\t\t},\n\t\t{\n\t\t\tdata: 'zh-tw',\n\t\t\tlabel: '中國臺灣繁體',\n\t\t},\n\t];\n\tconst uriVariant: string | null = mw.util.getParamValue('variant');\n\tconst checkbox: OO.ui.CheckboxInputWidget = new OO.ui.CheckboxInputWidget({\n\t\tselected: Boolean(uriVariant),\n\t});\n\tconst dropdown: OO.ui.DropdownWidget = new OO.ui.DropdownWidget({\n\t\t$overlay: true,\n\t\tdisabled: !checkbox.isSelected(),\n\t\tmenu: {\n\t\t\titems: VARIANTS.map(({data, label}): OO.ui.MenuOptionWidget => {\n\t\t\t\treturn new OO.ui.MenuOptionWidget({\n\t\t\t\t\tdata,\n\t\t\t\t\tlabel,\n\t\t\t\t});\n\t\t\t}),\n\t\t},\n\t});\n\tdropdown.getMenu().selectItemByData(mw.config.get('wgUserVariant') || uriVariant || mw.user.options.get('variant'));\n\tcheckbox.on('change', (selected: boolean | string): void => {\n\t\tdropdown.setDisabled(!selected);\n\t});\n\tconst getSelectedVariant = (): string | undefined => {\n\t\tif (!checkbox.isSelected()) {\n\t\t\treturn;\n\t\t}\n\t\tconst selectedItem: OO.ui.OptionWidget | null = dropdown\n\t\t\t.getMenu()\n\t\t\t.findSelectedItem() as OO.ui.OptionWidget | null;\n\t\treturn selectedItem ? (selectedItem.getData() as string) : undefined;\n\t};\n\tconst manipulateActionUrl = (): void => {\n\t\tconst selectedVariant: string | undefined = getSelectedVariant();\n\t\tconst originalAction: string | undefined = $editForm.attr('action');\n\t\tif (selectedVariant && originalAction) {\n\t\t\t$editForm.attr(\n\t\t\t\t'action',\n\t\t\t\tnew mw.Uri(originalAction)\n\t\t\t\t\t.extend({\n\t\t\t\t\t\tvariant: selectedVariant,\n\t\t\t\t\t})\n\t\t\t\t\t.getRelativePath()\n\t\t\t);\n\t\t}\n\t};\n\tconst manipulateVariantConfig = (): void => {\n\t\tmw.config.set('wgUserVariant', getSelectedVariant() || (mw.user.options.get('variant') as string));\n\t};\n\t$editForm\n\t\t.find('input[name=wpPreview]')\n\t\t.on('click', mw.user.options.get('uselivepreview') ? manipulateVariantConfig : manipulateActionUrl);\n\t$templateSandboxPreview.on('click', manipulateActionUrl);\n\tdropdown.getMenu().on('select', manipulateVariantConfig);\n\tconst checkboxField: OO.ui.FieldLayout<OO.ui.CheckboxInputWidget> = new OO.ui.FieldLayout(checkbox, {\n\t\talign: 'inline',\n\t\tlabel: window.wgULS('预览字词转换', '預覽字詞轉換'),\n\t});\n\tconst dropdownField: OO.ui.FieldLayout<OO.ui.DropdownWidget> = new OO.ui.FieldLayout(dropdown, {\n\t\talign: 'top',\n\t\tlabel: window.wgULS('使用该语言变体显示预览：', '使用該語言變體顯示預覽：'),\n\t\tinvisibleLabel: true,\n\t});\n\t$layout.append($('<div>').attr('id', 'pwv-area').append(checkboxField.$element, dropdownField.$element));\n});\n"],
  "mappings": "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",
  "names": ["mw", "hook", "add", "$editForm", "config", "get", "$templateSandboxPreview", "find", "length", "$layout", "set", "VARIANTS", "data", "label", "window", "wgULS", "uriVariant", "util", "getParamValue", "checkbox", "OO", "ui", "CheckboxInputWidget", "selected", "Boolean", "dropdown", "DropdownWidget", "$overlay", "disabled", "isSelected", "menu", "items", "map", "MenuOptionWidget", "getMenu", "selectItemByData", "user", "options", "on", "setDisabled", "getSelectedVariant", "selectedItem", "findSelectedItem", "getData", "manipulateActionUrl", "selectedVariant", "originalAction", "attr", "Uri", "extend", "variant", "getRelativePath", "manipulateVariantConfig", "checkboxField", "FieldLayout", "align", "dropdownField", "invisibleLabel", "append", "$", "$element"]
}
