跳转到内容
主菜单
主菜单
移至侧栏
隐藏
导航
首页
最近更改
随机页面
MediaWiki帮助
中医百科
搜索
搜索
登录
个人工具
登录
深色模式
查看“MediaWiki:Gadget-GadgetsDefinition.js”的源代码
系统消息
讨论
English
阅读
查看源代码
查看历史
工具
工具
移至侧栏
隐藏
操作
阅读
查看源代码
查看历史
清除缓存
常规
链入页面
相关更改
特殊页面
页面信息
页面值
←
MediaWiki:Gadget-GadgetsDefinition.js
因为以下原因,您没有权限编辑该页面:
您请求的操作仅限属于该用户组的用户执行:
用户
此页面为本wiki上的软件提供界面文本,并受到保护以防止滥用。 如欲修改所有wiki的翻译,请访问
translatewiki.net
上的MediaWiki本地化项目。
您无权编辑此JavaScript页面,因为编辑此页面可能会影响所有访问者。
您必须确认您的电子邮件地址才能编辑页面。请通过
参数设置
设置并确认您的电子邮件地址。
您可以查看和复制此页面的源代码。
/** * SPDX-License-Identifier: CC-BY-SA-4.0 * _addText: '{{Gadget Header|license=CC-BY-SA-4.0}}' * * @base {@link https://en.wiktionary.org/wiki/User:Erutuon/scripts/gadgets-definition.js} * @source {@link https://git.qiuwen.net.cn/InterfaceAdmin/QiuwenGadgets/src/branch/master/src/GadgetsDefinition} * @license CC-BY-SA-4.0 {@link https://www.qiuwenbaike.cn/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/GadgetsDefinition/GadgetsDefinition.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; } //! src/GadgetsDefinition/modules/util/generateGadgetId.ts var generateGadgetId = (gadgetName) => { return "Gadget-".concat(gadgetName); }; //! src/GadgetsDefinition/GadgetsDefinition.ts var import_ext_gadget = require("ext.gadget.Util"); //! src/GadgetsDefinition/modules/constant.ts var REXEX_GADGET_NAME = /^(\s*)([\w_-]+)\s*/; //! src/GadgetsDefinition/modules/util/matchGadgetName.ts var matchGadgetName = (innerHTML) => { var _ref; const regExpExecArray = REXEX_GADGET_NAME.exec(innerHTML); return (_ref = regExpExecArray ? regExpExecArray[2] : null) !== null && _ref !== void 0 ? _ref : ""; }; //! src/GadgetsDefinition/modules/util/makeLink.ts var makeLink = (href, text) => { const link = document.createElement("a"); link.href = href; link.textContent = text; return link.outerHTML; }; var makeWikilink = (page, text) => { return makeLink(mw.util.getUrl(page), text || page); }; //! src/GadgetsDefinition/modules/processGadgetDefinition.ts var linkGadgetSource = (sourcePage) => { return makeWikilink("MediaWiki:Gadget-".concat(sourcePage), sourcePage); }; var linkGadgetAnchor = (gadgetName, text) => { return makeLink("#".concat(generateGadgetId(gadgetName)), text || gadgetName); }; var processGadgetDefinition = (innerHTML) => { return innerHTML.replace(REXEX_GADGET_NAME, (_wholeMatch, whitespace, gadgetName) => { return "".concat(whitespace + linkGadgetSource(gadgetName), " "); }).replace(/([\w_\-.]+\.(?:css|js(?:on)?))/g, linkGadgetSource).replace(/\s*\|\s*/g, " | ").replace(/([a-z]+)\s*=\s*(.+?)(?=\s*[|\]])/g, (_wholeMatch, key, value) => { let splitValue = value.split(/\s*,\s*/g); switch (key) { case "dependencies": splitValue = splitValue.map((dependency) => { const gadgetName = /^ext\.gadget\.(.+)$/.exec(dependency); if (gadgetName) { var _gadgetName$; const _gadgetName = (_gadgetName$ = gadgetName[1]) !== null && _gadgetName$ !== void 0 ? _gadgetName$ : ""; return linkGadgetAnchor(_gadgetName, dependency); } return makeWikilink("Special:GoToInterwiki/mw:ResourceLoader/Core_modules#".concat(dependency), dependency); }); break; case "rights": key = makeWikilink("Special:GoToInterwiki/mw:Manual:User_rights#List_of_permissions", key); break; case "peers": splitValue = splitValue.map((gadgetName) => { return linkGadgetAnchor(gadgetName); }); } return "".concat(key, " = ").concat(splitValue.join(", ")); }); }; //! src/GadgetsDefinition/GadgetsDefinition.ts void (0, import_ext_gadget.getBody)().then(function gadgetsDefinition($body) { const { wgCanonicalNamespace, wgTitle } = mw.config.get(); const isDefinitionPage = wgCanonicalNamespace === "MediaWiki" && wgTitle === "Gadgets-definition"; const $parserOutput = $body.find(".mw-parser-output"); if (!isDefinitionPage || !$parserOutput.length) { return; } var _iterator = _createForOfIteratorHelper($parserOutput.find("li")), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done; ) { const element = _step.value; const gadgetName = matchGadgetName(element.innerHTML); if (gadgetName) { element.id = generateGadgetId(gadgetName); } element.innerHTML = processGadgetDefinition(element.innerHTML); } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } var _iterator2 = _createForOfIteratorHelper($parserOutput.find("pre")), _step2; try { for (_iterator2.s(); !(_step2 = _iterator2.n()).done; ) { const element = _step2.value; element.innerHTML = element.innerHTML.replace(/[^\n]+/g, processGadgetDefinition); } } catch (err) { _iterator2.e(err); } finally { _iterator2.f(); } }); })();
该页面使用的模板:
Template:Gadget Header
(
查看源代码
)
返回
MediaWiki:Gadget-GadgetsDefinition.js
。
开关有限宽度模式