MediaWiki:Gadget-PreviewWithVariant.js

MediaWiki系统消息页面
/**
 * SPDX-License-Identifier: MIT + CC-BY-SA-4.0
 * _addText: '{{Gadget Header|license=CC-BY-SA-4.0}}'
 * _addText: '{{Gadget Header|license=MIT|attribution=Diskdance, Lt2818}}'
 *
 * @base {@link https://zh.wikipedia.org/wiki/MediaWiki:Gadget-PreviewWithVariant.js}
 * @source {@link https://git.qiuwen.net.cn/InterfaceAdmin/QiuwenGadgets/src/branch/master/src/PreviewWithVariant}
 * @license MIT {@link https://zh.wikipedia.org/wiki/MediaWiki:Gadget-PreviewWithVariant.js}
 * @license CC-BY-SA-4.0 {@link https://www.qiuwenbaike.cn/wiki/H:CC-BY-SA-4.0}
 */

/**
 * Copyright Diskdance, Lt2818
 *
 * Permission is hereby granted, free of charge, to any person obtaining
 * a copy of this software and associated documentation files (the
 * "Software"), to deal in the Software without restriction, including
 * without limitation the rights to use, copy, modify, merge, publish,
 * distribute, sublicense, and/or sell copies of the Software, and to
 * permit persons to whom the Software is furnished to do so, subject to
 * the following conditions:
 *
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */
/**
 * +------------------------------------------------------------+
 * |            === 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/options.json
var configKey = "gadget-PreviewWithVariant__Initialized";
//! src/PreviewWithVariant/modules/constant.ts
var 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: "中國臺灣繁體"
}];
//! src/PreviewWithVariant/modules/processWikiEditor.ts
var processWikiEditor = ($editForm) => {
  if (mw.config.get(configKey)) {
    return;
  }
  const {
    wgPageContentModel,
    wgUserVariant
  } = mw.config.get();
  const $templateSandboxPreview = $editForm.find('input[name="wpTemplateSandboxPreview"]');
  if (wgPageContentModel !== "wikitext" && !$templateSandboxPreview.length) {
    return;
  }
  const $layout = $editForm.find(".editCheckboxes .oo-ui-horizontalLayout");
  if (!$layout.length) {
    return;
  }
  mw.config.set(configKey, true);
  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(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));
};
//! src/PreviewWithVariant/PreviewWithVariant.ts
(function previewWithVariants() {
  mw.hook("wikipage.editform").add(($editForm) => {
    processWikiEditor($editForm);
  });
})();

})();

/* </nowiki> */

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/PreviewWithVariant/options.json", "src/PreviewWithVariant/modules/constant.ts", "src/PreviewWithVariant/modules/processWikiEditor.ts", "src/PreviewWithVariant/PreviewWithVariant.ts"],
  "sourcesContent": ["{\n\t\"configKey\": \"gadget-PreviewWithVariant__Initialized\"\n}\n", "const VARIANTS: {\n\tdata: string;\n\tlabel: string;\n}[] = [\n\t{\n\t\tdata: 'zh',\n\t\tlabel: window.wgULS('不转换', '不轉換'),\n\t},\n\t{\n\t\tdata: 'zh-hans',\n\t\tlabel: '简体',\n\t},\n\t{\n\t\tdata: 'zh-hant',\n\t\tlabel: '繁體',\n\t},\n\t{\n\t\tdata: 'zh-cn',\n\t\tlabel: '中国大陆简体',\n\t},\n\t{\n\t\tdata: 'zh-hk',\n\t\tlabel: '中國香港繁體',\n\t},\n\t{\n\t\tdata: 'zh-mo',\n\t\tlabel: '中國澳門繁體',\n\t},\n\t{\n\t\tdata: 'zh-my',\n\t\tlabel: '马来西亚简体',\n\t},\n\t{\n\t\tdata: 'zh-sg',\n\t\tlabel: '新加坡简体',\n\t},\n\t{\n\t\tdata: 'zh-tw',\n\t\tlabel: '中國臺灣繁體',\n\t},\n];\n\nexport {VARIANTS};\n", "import './processWikiEditor.less';\nimport * as OPTIONS from '../options.json';\nimport {VARIANTS} from './constant';\n/**\n * @description Add a \"Preview with variant\" option to the edit form.\n *\n * @param {JQuery} $editForm\n */\nconst processWikiEditor = ($editForm: JQuery<HTMLElement>): void => {\n\t// Guard against double inclusions\n\tif (mw.config.get(OPTIONS.configKey)) {\n\t\treturn;\n\t}\n\tconst {wgPageContentModel, wgUserVariant} = mw.config.get();\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 (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(OPTIONS.configKey, true);\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(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\nexport {processWikiEditor};\n", "import {processWikiEditor} from './modules/processWikiEditor';\n\n(function previewWithVariants(): void {\n\tmw.hook('wikipage.editform').add(($editForm): void => {\n\t\tprocessWikiEditor($editForm);\n\t});\n})();\n"],
  "mappings": "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",
  "names": ["configKey", "VARIANTS", "data", "label", "window", "wgULS", "processWikiEditor", "$editForm", "mw", "config", "get", "wgPageContentModel", "wgUserVariant", "$templateSandboxPreview", "find", "length", "$layout", "set", "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", "previewWithVariants", "hook", "add"]
}
