MediaWiki:Gadget-Util.js

MediaWiki系统消息页面
/**
 * SPDX-License-Identifier: GPL-3.0-or-later
 * _addText: '{{Gadget Header|license=GPL-3.0-or-later}}'
 *
 * @source {@link https://github.com/TopRealm/YsArchives-Gadgets/tree/master/src/Util}
 * @author 安忆 <i@anyi.in>
 * @license GPL-3.0-or-later {@link https://youshou.wiki/wiki/H:GPLV3}
 */
/**
 * +------------------------------------------------------------+
 * |            === 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/Util/Util.js
function _createForOfIteratorHelper(r, e) {
  var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
  if (!t) {
    if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) {
      t && (r = t);
      var n = 0, F = function() {
      };
      return { s: F, n: function() {
        return n >= r.length ? { done: true } : { done: false, value: r[n++] };
      }, e: function(r2) {
        throw r2;
      }, f: F };
    }
    throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
  }
  var o, a = true, u = false;
  return { s: function() {
    t = t.call(r);
  }, n: function() {
    var r2 = t.next();
    return a = r2.done, r2;
  }, e: function(r2) {
    u = true, o = r2;
  }, f: function() {
    try {
      a || null == t.return || t.return();
    } finally {
      if (u) throw o;
    }
  } };
}
function _unsupportedIterableToArray(r, a) {
  if (r) {
    if ("string" == typeof r) return _arrayLikeToArray(r, a);
    var t = {}.toString.call(r).slice(8, -1);
    return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
  }
}
function _arrayLikeToArray(r, a) {
  (null == a || a > r.length) && (a = r.length);
  for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
  return n;
}
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
  for (var name in all) __defProp(target, name, {
    get: all[name],
    enumerable: true
  });
};
var __copyProps = (to, from, except, desc) => {
  if (from && typeof from === "object" || typeof from === "function") {
    var _iterator = _createForOfIteratorHelper(__getOwnPropNames(from)), _step;
    try {
      for (_iterator.s(); !(_step = _iterator.n()).done; ) {
        let key = _step.value;
        if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, {
          get: () => from[key],
          enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
        });
      }
    } catch (err) {
      _iterator.e(err);
    } finally {
      _iterator.f();
    }
  }
  return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
  // If the importer is in node compatibility mode or this is not an ESM
  // file that has been converted to a CommonJS file using a Babel-
  // compatible transform (i.e. "__esModule" has not been set), then set
  // "default" to the CommonJS "module.exports" for node compatibility.
  isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
    value: mod,
    enumerable: true
  }) : target,
  mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", {
  value: true
}), mod);
//! src/Util/Util.ts
var Util_exports = {};
__export(Util_exports, {
  addEventListenerWithRemover: () => addEventListenerWithRemover,
  changeOpacityWhenMouseEnterOrLeave: () => changeOpacityWhenMouseEnterOrLeave,
  checkA11yConfirmKey: () => checkA11yConfirmKey,
  delay: () => delay,
  generateArray: () => generateArray,
  generateSvgDataUrl: () => generateSvgDataUrl,
  getBody: () => getBody,
  getWpSummaryContent: () => getWpSummaryContent,
  getWpTextbox1Content: () => getWpTextbox1Content,
  initMwApi: () => initMwApi,
  isValidKey: () => isValidKey,
  oouiConfirmWithStyle: () => oouiConfirmWithStyle,
  scrollTop: () => scrollTop,
  setWpSummaryContent: () => setWpSummaryContent,
  setWpTextbox1Content: () => setWpTextbox1Content,
  uniqueArray: () => uniqueArray,
  userIsInGroup: () => userIsInGroup
});
module.exports = __toCommonJS(Util_exports);
//! src/Util/modules/addEventListenerWithRemover.ts
var addEventListenerWithRemover = ({
  target,
  type,
  listener,
  options = {}
}) => {
  target.addEventListener(type, listener, options);
  return {
    remove: () => {
      target.removeEventListener(type, listener, options);
    }
  };
};
//! src/Util/modules/changeOpacityWhenMouseEnterOrLeave.ts
var changeOpacityWhenMouseEnterOrLeave = (event, opacity = 0.7) => {
  event.currentTarget.style.opacity = event.type === "mouseenter" ? "1" : opacity.toString();
};
//! src/Util/modules/checkA11yConfirmKey.ts
var checkA11yConfirmKey = (event) => {
  if (["click", "keydown"].includes(event.type)) {
    if (event.type === "keydown") {
      return ["Enter", " "].includes(event.key);
    }
    return true;
  }
  return false;
};
//! src/Util/modules/delay.ts
var delay = (ms) => {
  return new Promise((resolve) => {
    setTimeout(resolve, ms);
  });
};
//! src/Util/modules/generateArray.ts
function generateArray(...args) {
  return args.flatMap((arg) => {
    if (Array.isArray(arg)) {
      return arg;
    }
    if (arg instanceof NodeList) {
      return [...arg];
    }
    return [arg];
  });
}
//! src/Util/modules/generateSvgDataUrl.ts
var generateSvgDataUrl = (svg) => {
  /*!
   * SPDX-License-Identifier: MIT
   *
   * @file svg-to-data-uri.js {@link https://github.com/heyallan/svg-to-data-uri/}
   *
   * @author Allan Moreno
   * @license MIT {@link https://github.com/heyallan/svg-to-data-uri/blob/master/LICENSE}
   *
   * 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.
   */
  svg = svg.trim();
  svg = svg.slice(svg.indexOf("<svg"));
  if (!svg.startsWith("<svg") || !svg.endsWith("svg>")) {
    return "";
  }
  if (!svg.includes("http://www.w3.org/2000/svg")) {
    svg = svg.replace(/<svg/g, "<svg xmlns='http://www.w3.org/2000/svg'");
  }
  svg = svg.replace(/<!--.{1,}-->/g, "");
  svg = svg.replace(/version=["'](.{0,}?)["'](?=[\s>])/g, "");
  svg = svg.replace(/"'(.{1,})'"/g, "'$1'");
  svg = svg.replace(/"/g, "'");
  svg = svg.replace(/>\s{1,}</g, "><");
  svg = svg.replace(/\s{2,}/g, " ");
  svg = svg.trim();
  if (!svg.startsWith("<svg") || !svg.endsWith("svg>")) {
    return "";
  }
  svg = svg.replace(/&/g, "&amp;");
  svg = svg.replace(/[%#<>?[\\\]^`{|}]/g, encodeURIComponent);
  svg = "data:image/svg+xml,".concat(svg);
  return svg;
};
//! src/Util/modules/getBody.ts
var getBody = () => {
  return $.ready.then(() => {
    const $body = $("body");
    return $body;
  });
};
//! src/Util/modules/initMwApi.ts
function initMwApi(userAgent, apiUri) {
  const apiOptions = {
    ajax: {
      headers: {
        "Api-User-Agent": userAgent ? "YsArchives/1.1 (".concat(userAgent, ")") : "YsArchives/1.1"
      }
    }
  };
  if (apiUri) {
    return new mw.ForeignApi(apiUri, apiOptions);
  }
  return new mw.Api(apiOptions);
}
//! src/Util/modules/isValidKey.ts
var isValidKey = (object, key) => {
  return key in object;
};
//! src/Util/modules/oouiConfirmWithStyle.tsx
var import_ext_gadget = __toESM(require("ext.gadget.React"), 1);
var oouiConfirmWithStyle = (message) => OO.ui.confirm($(/* @__PURE__ */ import_ext_gadget.default.createElement("div", {
  className: "oo-ui-window-foot",
  style: {
    border: ".1rem solid #0645ad",
    display: "flex",
    justifyContent: "space-evenly"
  }
}, /* @__PURE__ */ import_ext_gadget.default.createElement("span", {
  style: {
    fontSize: "1.2rem",
    fontWeight: "500",
    lineHeight: "1.8",
    padding: ".4em 0"
  }
}, message)))).then((isConfirm) => isConfirm);
//! src/Util/modules/scrollTop.ts
var scrollTop = (targetHeight, effectsOptionsOrDuration = {}) => {
  const options = typeof effectsOptionsOrDuration === "number" || typeof effectsOptionsOrDuration === "string" ? {
    duration: effectsOptionsOrDuration,
    easing: "linear"
  } : {
    duration: "slow",
    easing: "linear",
    ...effectsOptionsOrDuration
  };
  $(document).find("html, body").animate({
    scrollTop: targetHeight
  }, options);
};
//! src/Util/modules/userIsInGroup.ts
var userIsInGroup = (groups) => {
  const {
    wgUserGroups,
    wgGlobalGroups
  } = mw.config.get();
  return [...wgUserGroups || [], ...wgGlobalGroups || []].some((element) => {
    return generateArray(groups).includes(element);
  });
};
//! src/Util/modules/uniqueArray.ts
var uniqueArray = function uniqueArray2(args) {
  /**
   * @see {@link https://stackoverflow.com/questions/9229645/remove-duplicate-values-from-js-array/922982}
   * @license CC-BY-SA-4.0
   */
  const result = [];
  var _iterator2 = _createForOfIteratorHelper(args), _step2;
  try {
    for (_iterator2.s(); !(_step2 = _iterator2.n()).done; ) {
      const item = _step2.value;
      if (!result.includes(item)) {
        result[result.length] = item;
      }
    }
  } catch (err) {
    _iterator2.e(err);
  } finally {
    _iterator2.f();
  }
  return result;
};
//! src/Util/modules/wpSummaryContent.ts
var getWpSummaryContent = ({
  $editForm
}) => {
  var _$editForm$find$val, _$editForm$find;
  return (_$editForm$find$val = (_$editForm$find = $editForm.find("#wpSummary")) === null || _$editForm$find === void 0 ? void 0 : _$editForm$find.val()) !== null && _$editForm$find$val !== void 0 ? _$editForm$find$val : "";
};
var setWpSummaryContent = ({
  $editForm,
  content
}) => {
  $editForm.find("#wpSummary").val(content);
};
//! src/Util/modules/wpTextbox1Content.ts
var getWpTextbox1Content = ({
  $editForm
}) => {
  var _$editForm$find$textS;
  return (_$editForm$find$textS = $editForm.find("#wpTextbox1").textSelection("getContents")) !== null && _$editForm$find$textS !== void 0 ? _$editForm$find$textS : "";
};
var setWpTextbox1Content = ({
  $editForm,
  content
}) => {
  $editForm.find("#wpTextbox1").textSelection("setContents", content);
};

})();

/* </nowiki> */

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/Util/Util.ts", "src/Util/modules/addEventListenerWithRemover.ts", "src/Util/modules/changeOpacityWhenMouseEnterOrLeave.ts", "src/Util/modules/checkA11yConfirmKey.ts", "src/Util/modules/delay.ts", "src/Util/modules/generateArray.ts", "src/Util/modules/generateSvgDataUrl.ts", "src/Util/modules/getBody.ts", "src/Util/modules/initMwApi.ts", "src/Util/modules/isValidKey.ts", "src/Util/modules/oouiConfirmWithStyle.tsx", "src/Util/modules/scrollTop.ts", "src/Util/modules/userIsInGroup.ts", "src/Util/modules/uniqueArray.ts", "src/Util/modules/wpSummaryContent.ts", "src/Util/modules/wpTextbox1Content.ts"],
  "sourcesContent": ["export {addEventListenerWithRemover} from './modules/addEventListenerWithRemover';\nexport {changeOpacityWhenMouseEnterOrLeave} from './modules/changeOpacityWhenMouseEnterOrLeave';\nexport {checkA11yConfirmKey} from './modules/checkA11yConfirmKey';\nexport {delay} from './modules/delay';\nexport {generateArray} from './modules/generateArray';\nexport {generateSvgDataUrl} from './modules/generateSvgDataUrl';\nexport {getBody} from './modules/getBody';\nexport {initMwApi} from './modules/initMwApi';\nexport {isValidKey} from './modules/isValidKey';\nexport {oouiConfirmWithStyle} from './modules/oouiConfirmWithStyle';\nexport {scrollTop} from './modules/scrollTop';\nexport {userIsInGroup} from './modules/userIsInGroup';\nexport {uniqueArray} from './modules/uniqueArray';\nexport {getWpSummaryContent, setWpSummaryContent} from './modules/wpSummaryContent';\nexport {getWpTextbox1Content, setWpTextbox1Content} from './modules/wpTextbox1Content';\n", "type AddEventListenerWithRemover = <\n\tTarget extends Document | HTMLElement | Element | MediaQueryList | Window,\n\tType extends Target extends Document\n\t\t? keyof DocumentEventMap\n\t\t: Target extends HTMLElement\n\t\t\t? keyof HTMLElementEventMap\n\t\t\t: Target extends MediaQueryList\n\t\t\t\t? keyof MediaQueryListEventMap\n\t\t\t\t: Target extends Window\n\t\t\t\t\t? keyof WindowEventMap\n\t\t\t\t\t: keyof GlobalEventHandlersEventMap,\n\tListener extends Target extends Document\n\t\t? Type extends keyof DocumentEventMap\n\t\t\t? (this: Target, event: DocumentEventMap[Type]) => unknown\n\t\t\t: (this: Target, event: Event) => unknown\n\t\t: Target extends HTMLElement\n\t\t\t? Type extends keyof HTMLElementEventMap\n\t\t\t\t? (this: Target, event: HTMLElementEventMap[Type]) => unknown\n\t\t\t\t: (this: Target, event: Event) => unknown\n\t\t\t: Target extends Element\n\t\t\t\t? Type extends keyof ElementEventMap\n\t\t\t\t\t? (this: Target, event: ElementEventMap[Type]) => unknown\n\t\t\t\t\t: (this: Target, event: Event) => unknown\n\t\t\t\t: Target extends MediaQueryList\n\t\t\t\t\t? Type extends keyof MediaQueryListEventMap\n\t\t\t\t\t\t? (this: Target, event: MediaQueryListEventMap[Type]) => unknown\n\t\t\t\t\t\t: (this: Target, event: Event) => unknown\n\t\t\t\t\t: Target extends Window\n\t\t\t\t\t\t? Type extends keyof WindowEventMap\n\t\t\t\t\t\t\t? (this: Target, event: WindowEventMap[Type]) => unknown\n\t\t\t\t\t\t\t: (this: Target, event: Event) => unknown\n\t\t\t\t\t\t: (this: Target, event: Event) => unknown,\n>({\n\ttarget,\n\ttype,\n\tlistener,\n\toptions,\n}: {\n\ttarget: Target;\n\ttype: Type;\n\tlistener: Listener;\n\toptions?: AddEventListenerOptions;\n}) => {\n\tremove: () => void;\n};\n\nconst addEventListenerWithRemover: AddEventListenerWithRemover = ({target, type, listener, options = {}}) => {\n\ttarget.addEventListener(type, listener as EventListenerOrEventListenerObject, options);\n\treturn {\n\t\tremove: (): void => {\n\t\t\ttarget.removeEventListener(type, listener as EventListenerOrEventListenerObject, options);\n\t\t},\n\t};\n};\n\nexport {type AddEventListenerWithRemover, addEventListenerWithRemover};\n", "type ChangeOpacityWhenMouseEnterOrLeave = (event: MouseEvent | JQuery.TriggeredEvent, opacity?: number) => void;\n\nconst changeOpacityWhenMouseEnterOrLeave: ChangeOpacityWhenMouseEnterOrLeave = (event, opacity = 0.7) => {\n\t(event.currentTarget as HTMLElement).style.opacity = event.type === 'mouseenter' ? '1' : opacity.toString();\n};\n\nexport {type ChangeOpacityWhenMouseEnterOrLeave, changeOpacityWhenMouseEnterOrLeave};\n", "type CheckA11yConfirmKey = (event: KeyboardEvent | MouseEvent | JQuery.ClickEvent | JQuery.KeyDownEvent) => boolean;\n\nconst checkA11yConfirmKey: CheckA11yConfirmKey = (event): boolean => {\n\tif (['click', 'keydown'].includes(event.type)) {\n\t\tif (event.type === 'keydown') {\n\t\t\treturn ['Enter', ' '].includes((event as KeyboardEvent).key);\n\t\t}\n\t\treturn true;\n\t}\n\treturn false;\n};\n\nexport {type CheckA11yConfirmKey, checkA11yConfirmKey};\n", "type Delay = (ms: number) => Promise<void>;\n\nconst delay: Delay = (ms) => {\n\treturn new Promise((resolve: () => void): void => {\n\t\tsetTimeout(resolve, ms);\n\t});\n};\n\nexport {type Delay, delay};\n", "type GenerateArray = typeof generateArray;\n\nfunction generateArray<T extends []>(...args: (T | T[])[]): T[];\nfunction generateArray<T extends NodeList>(...args: (T | T[])[]): Node[];\nfunction generateArray<T = unknown>(...args: (T | T[])[]): T[];\n// eslint-disable-next-line func-style\nfunction generateArray<T>(...args: (T | T[])[]): T[] {\n\treturn args.flatMap((arg) => {\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (arg instanceof NodeList) {\n\t\t\treturn [...arg] as T;\n\t\t}\n\n\t\treturn [arg];\n\t});\n}\n\nexport {type GenerateArray, generateArray};\n", "type GenerateSvgDataUrl = (svg: string) => string;\n\nconst generateSvgDataUrl: GenerateSvgDataUrl = (svg) => {\n\t/*!\n\t * SPDX-License-Identifier: MIT\n\t *\n\t * @file svg-to-data-uri.js {@link https://github.com/heyallan/svg-to-data-uri/}\n\t *\n\t * @author Allan Moreno\n\t * @license MIT {@link https://github.com/heyallan/svg-to-data-uri/blob/master/LICENSE}\n\t *\n\t * Permission is hereby granted, free of charge, to any person obtaining a copy\n\t * of this software and associated documentation files (the \"Software\"), to deal\n\t * in the Software without restriction, including without limitation the rights\n\t * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\t * copies of the Software, and to permit persons to whom the Software is\n\t * furnished to do so, subject to the following conditions:\n\t *\n\t * The above copyright notice and this permission notice shall be included in all\n\t * copies or substantial portions of the Software.\n\t *\n\t * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\t * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\t * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\t * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\t * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\t * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\t * SOFTWARE.\n\t */\n\tsvg = svg.trim();\n\t// remove xml, doctype, generator...\n\tsvg = svg.slice(svg.indexOf('<svg'));\n\t// soft validate\n\tif (!svg.startsWith('<svg') || !svg.endsWith('svg>')) {\n\t\treturn '';\n\t}\n\t// add namespace if necessary\n\tif (!svg.includes('http://www.w3.org/2000/svg')) {\n\t\tsvg = svg.replace(/<svg/g, \"<svg xmlns='http://www.w3.org/2000/svg'\");\n\t}\n\t// remove comments\n\tsvg = svg.replace(/<!--.{1,}-->/g, '');\n\t// remove unnecessary attributes\n\tsvg = svg.replace(/version=[\"'](.{0,}?)[\"'](?=[\\s>])/g, '');\n\t// replace nested quotes\n\tsvg = svg.replace(/\"'(.{1,})'\"/g, \"'$1'\");\n\t// replace double quotes\n\tsvg = svg.replace(/\"/g, \"'\");\n\t// remove empty spaces between tags\n\tsvg = svg.replace(/>\\s{1,}</g, '><');\n\t// remove duplicate spaces\n\tsvg = svg.replace(/\\s{2,}/g, ' ');\n\t// trim again\n\tsvg = svg.trim();\n\t// soft validate again\n\tif (!svg.startsWith('<svg') || !svg.endsWith('svg>')) {\n\t\treturn '';\n\t}\n\t// replace ampersand\n\tsvg = svg.replace(/&/g, '&amp;');\n\t// encode only unsafe symbols\n\tsvg = svg.replace(/[%#<>?[\\\\\\]^`{|}]/g, encodeURIComponent);\n\t// build data uri\n\tsvg = `data:image/svg+xml,${svg}`;\n\t// ok, ship it!\n\treturn svg;\n};\n\nexport {type GenerateSvgDataUrl, generateSvgDataUrl};\n", "type GetBody = () => JQuery.Thenable<JQuery<HTMLBodyElement>>;\n\nconst getBody = () => {\n\treturn $.ready.then((): JQuery<HTMLBodyElement> => {\n\t\tconst $body: JQuery<HTMLBodyElement> = $('body');\n\n\t\treturn $body;\n\t});\n};\n\nexport {type GetBody, getBody};\n", "type InitMwApi = typeof initMwApi;\n\n/**\n * @requires mediawiki.api\n * @param {string} [userAgent]\n * @param {string} [apiUri]\n * @return {mw.Api|mw.ForeignApi}\n */\nfunction initMwApi(userAgent?: string): mw.Api;\nfunction initMwApi(userAgent: string, apiUri: string): mw.ForeignApi;\n// eslint-disable-next-line func-style\nfunction initMwApi(userAgent?: string, apiUri?: string): mw.Api | mw.ForeignApi {\n\tconst apiOptions = {\n\t\tajax: {\n\t\t\theaders: {\n\t\t\t\t'Api-User-Agent': userAgent ? `YsArchives/1.1 (${userAgent})` : 'YsArchives/1.1',\n\t\t\t},\n\t\t},\n\t};\n\n\tif (apiUri) {\n\t\treturn new mw.ForeignApi(apiUri, apiOptions);\n\t}\n\n\treturn new mw.Api(apiOptions);\n}\n\nexport {type InitMwApi, initMwApi};\n", "type IsValidKey = typeof isValidKey;\n\nconst isValidKey = (object: object, key: string | number | symbol): key is keyof typeof object => {\n\treturn key in object;\n};\n\nexport {type IsValidKey, isValidKey};\n", "import React from 'ext.gadget.React';\n\ntype OouiConfirmWithStyle = (message: string) => JQuery.Promise<boolean>;\n\n/**\n * @requires oojs-ui-windows\n * @param {string} [message]\n * @return {JQuery.Promise<boolean>}\n */\nconst oouiConfirmWithStyle: OouiConfirmWithStyle = (message) =>\n\tOO.ui\n\t\t.confirm(\n\t\t\t$(\n\t\t\t\t<div\n\t\t\t\t\tclassName=\"oo-ui-window-foot\"\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\tborder: '.1rem solid #0645ad',\n\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\tjustifyContent: 'space-evenly',\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<span\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tfontSize: '1.2rem',\n\t\t\t\t\t\t\tfontWeight: '500',\n\t\t\t\t\t\t\tlineHeight: '1.8',\n\t\t\t\t\t\t\tpadding: '.4em 0',\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t{message}\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t) as JQuery\n\t\t)\n\t\t.then((isConfirm: boolean): boolean => isConfirm);\n\nexport {type OouiConfirmWithStyle, oouiConfirmWithStyle};\n", "type ScrollTop = (\n\ttargetHeight: number | string,\n\teffectsOptionsOrDuration?: JQuery.EffectsOptions<HTMLElement> | number | 'fast' | 'slow'\n) => void;\n\nconst scrollTop: ScrollTop = (targetHeight, effectsOptionsOrDuration = {}) => {\n\tconst options: JQuery.EffectsOptions<HTMLElement> =\n\t\ttypeof effectsOptionsOrDuration === 'number' || typeof effectsOptionsOrDuration === 'string'\n\t\t\t? {\n\t\t\t\t\tduration: effectsOptionsOrDuration,\n\t\t\t\t\teasing: 'linear',\n\t\t\t\t}\n\t\t\t: {\n\t\t\t\t\tduration: 'slow',\n\t\t\t\t\teasing: 'linear',\n\t\t\t\t\t...effectsOptionsOrDuration,\n\t\t\t\t};\n\t$(document).find('html, body').animate(\n\t\t{\n\t\t\tscrollTop: targetHeight,\n\t\t},\n\t\toptions\n\t);\n};\n\nexport {type ScrollTop, scrollTop};\n", "import {generateArray} from './generateArray';\n\ntype UserIsInGroup = typeof userIsInGroup;\n\nconst userIsInGroup = (groups: string | string[]) => {\n\tconst {wgUserGroups, wgGlobalGroups} = mw.config.get();\n\treturn [...(wgUserGroups || []), ...((wgGlobalGroups as string[]) || [])].some((element: string): boolean => {\n\t\treturn generateArray(groups).includes(element);\n\t});\n};\n\nexport {type UserIsInGroup, userIsInGroup};\n", "type UniqueArray = typeof uniqueArray;\n\nconst uniqueArray = function uniqueArray<T>(args: T[]): T[] {\n\t/**\n\t * @see {@link https://stackoverflow.com/questions/9229645/remove-duplicate-values-from-js-array/922982}\n\t * @license CC-BY-SA-4.0\n\t */\n\tconst result: typeof args = [];\n\tfor (const item of args) {\n\t\tif (!result.includes(item)) {\n\t\t\tresult[result.length] = item; // Replace `[].push()` to avoid polyfilling core-js\n\t\t}\n\t}\n\treturn result;\n};\n\nexport {type UniqueArray, uniqueArray};\n", "type GetWpSummaryContent = typeof getWpSummaryContent;\ntype SetWpSummaryContent = typeof setWpSummaryContent;\n\nconst getWpSummaryContent = ({$editForm}: {$editForm: JQuery<HTMLElement>}): string => {\n\treturn $editForm.find<HTMLInputElement>('#wpSummary')?.val() ?? '';\n};\n\nconst setWpSummaryContent = ({$editForm, content}: {$editForm: JQuery<HTMLElement>; content: string}): void => {\n\t$editForm.find<HTMLInputElement>('#wpSummary').val(content);\n};\n\nexport {getWpSummaryContent, type GetWpSummaryContent, setWpSummaryContent, type SetWpSummaryContent};\n", "type GetWpTextbox1Content = typeof getWpTextbox1Content;\ntype SetWpTextbox1Content = typeof setWpTextbox1Content;\n\nconst getWpTextbox1Content = ({$editForm}: {$editForm: JQuery<HTMLElement>}): string => {\n\treturn $editForm.find<HTMLTextAreaElement>('#wpTextbox1').textSelection('getContents') ?? '';\n};\n\nconst setWpTextbox1Content = ({$editForm, content}: {$editForm: JQuery<HTMLElement>; content: string}): void => {\n\t$editForm.find<HTMLTextAreaElement>('#wpTextbox1').textSelection('setContents', content);\n};\n\nexport {getWpTextbox1Content, type GetWpTextbox1Content, setWpTextbox1Content, type SetWpTextbox1Content};\n"],
  "mappings": "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",
  "names": ["Util_exports", "__export", "addEventListenerWithRemover", "changeOpacityWhenMouseEnterOrLeave", "checkA11yConfirmKey", "delay", "generateArray", "generateSvgDataUrl", "getBody", "getWpSummaryContent", "getWpTextbox1Content", "initMwApi", "isValidKey", "oouiConfirmWithStyle", "scrollTop", "setWpSummaryContent", "setWpTextbox1Content", "uniqueArray", "userIsInGroup", "module", "exports", "__toCommonJS", "target", "type", "listener", "options", "addEventListener", "remove", "removeEventListener", "event", "opacity", "currentTarget", "style", "toString", "includes", "key", "ms", "Promise", "resolve", "setTimeout", "args", "flatMap", "arg", "Array", "isArray", "NodeList", "svg", "trim", "slice", "indexOf", "startsWith", "endsWith", "replace", "encodeURIComponent", "concat", "$", "ready", "then", "$body", "userAgent", "apiUri", "apiOptions", "ajax", "headers", "mw", "ForeignApi", "Api", "object", "import_ext_gadget", "__toESM", "require", "message", "OO", "ui", "confirm", "default", "createElement", "className", "border", "display", "justifyContent", "fontSize", "fontWeight", "lineHeight", "padding", "isConfirm", "targetHeight", "effectsOptionsOrDuration", "duration", "easing", "document", "find", "animate", "groups", "wgUserGroups", "wgGlobalGroups", "config", "get", "some", "element", "uniqueArray2", "result", "_iterator2", "_createForOfIteratorHelper", "_step2", "s", "n", "done", "item", "value", "length", "err", "e", "f", "$editForm", "_$editForm$find$val", "_$editForm$find", "val", "content", "_$editForm$find$textS", "textSelection"]
}
