diff --git a/dist/MarkRights/MarkRights.js b/dist/MarkRights/MarkRights.js index 549d49eb..4c5d6666 100644 --- a/dist/MarkRights/MarkRights.js +++ b/dist/MarkRights/MarkRights.js @@ -278,9 +278,8 @@ var i18nMessages = getI18nMessages(); var getMessage = (key) => { return i18nMessages[key] || key; }; -//! src/MarkRights/modules/core.ts -var import_ext_gadget3 = require("ext.gadget.Util"); -var getUsername = (url) => { +//! src/MarkRights/modules/util/getUserName.ts +var getUserName = (url) => { if (!url) { return ""; } @@ -307,33 +306,30 @@ var getUsername = (url) => { } return ""; }; -var appendUserRightsMark = ($userLinks, { - userGroupMap, - globalUserGroupMap -}) => { +//! src/MarkRights/modules/util/appendUserRightsMark.ts +var import_ext_gadget3 = require("ext.gadget.Util"); +var appendUserRightsMark = ($userLinks, userGroups) => { var _iterator2 = _createForOfIteratorHelper($userLinks), _step2; try { for (_iterator2.s(); !(_step2 = _iterator2.n()).done; ) { - var _$element$attr, _userGroupMap$get, _globalUserGroupMap$g; - const element = _step2.value; - const $element = $(element); - if ($element.parents("li").find(".gadgets-markrights").length) { - continue; - } - if ($element.siblings(".gadgets-markrights").length) { - continue; - } - const username = getUsername((_$element$attr = $element.attr("href")) !== null && _$element$attr !== void 0 ? _$element$attr : ""); + var _$element$attr, _userGroups, _userGroups$username; + const $element = _step2.value; + const username = getUserName((_$element$attr = $element.attr("href")) !== null && _$element$attr !== void 0 ? _$element$attr : ""); if (!username) { continue; } - const groups = (_userGroupMap$get = userGroupMap.get(username)) !== null && _userGroupMap$get !== void 0 ? _userGroupMap$get : []; - const globalGroups = (_globalUserGroupMap$g = globalUserGroupMap.get(username)) !== null && _globalUserGroupMap$g !== void 0 ? _globalUserGroupMap$g : []; - if (!groups) { - continue; + (_userGroups = userGroups) !== null && _userGroups !== void 0 ? _userGroups : userGroups = {}; + const groups = (_userGroups$username = userGroups[username]) !== null && _userGroups$username !== void 0 ? _userGroups$username : []; + let $sups; + if ($element.parents("li").find(".gadgets-markrights").length) { + $sups = $element.siblings(".gadgets-markrights").eq(0); + } else if ($element.siblings(".gadgets-markrights").length) { + $sups = $element.parents("li").find(".gadgets-markrights").eq(0); + } else { + $sups = $("").addClass("gadgets-markrights"); + $element.after($sups); } - const $sups = $("").addClass("gadgets-markrights"); - var _iterator3 = _createForOfIteratorHelper((0, import_ext_gadget3.uniqueArray)([...groups, ...globalGroups])), _step3; + var _iterator3 = _createForOfIteratorHelper((0, import_ext_gadget3.uniqueArray)(groups)), _step3; try { for (_iterator3.s(); !(_step3 = _iterator3.n()).done; ) { const group = _step3.value; @@ -343,25 +339,8 @@ var appendUserRightsMark = ($userLinks, { } $sups.append( // The following classes are used here: - // * gadget-markrights__qiuwen - // * gadget-markrights__steward - // * gadget-markrights__checkuser - // * gadget-markrights__suppress - // * gadget-markrights__sysop - // * gadget-markrights__interface-admin - // * gadget-markrights__templateeditor - // * gadget-markrights__transwiki - // * gadget-markrights__patroller - // * gadget-markrights__autoreviewer - // * gadget-markrights__senioreditor - // * gadget-markrights__eventsponsor - // * gadget-markrights__massmessage-sender - // * gadget-markrights__confirmed - // * gadget-markrights__autoconfirmed - // * gadget-markrights__bot - // * gadget-markrights__flood - // * gadget-markrights__ipblock-exempt - // * gadget-markrights__rnrsverify-exempt + // * see ../types.d.ts + // * for more information $("").addClass(className).attr({ alt: getMessage(group), title: getMessage(group) @@ -373,7 +352,6 @@ var appendUserRightsMark = ($userLinks, { } finally { _iterator3.f(); } - $element.after($sups); } } catch (err) { _iterator2.e(err); @@ -381,97 +359,127 @@ var appendUserRightsMark = ($userLinks, { _iterator2.f(); } }; -var markUserRights = /* @__PURE__ */ function() { - var _ref3 = _asyncToGenerator(function* ($content) { - const $userLinks = $content.find("a.mw-userlink:not(.mw-anonuserlink)"); - let users = []; - const queue = []; - const userGroupMap = /* @__PURE__ */ new Map(); - const globalUserGroupMap = /* @__PURE__ */ new Map(); - var _iterator4 = _createForOfIteratorHelper($userLinks), _step4; - try { - for (_iterator4.s(); !(_step4 = _iterator4.n()).done; ) { - const element = _step4.value; - const $element = $(element); - if ($element.parents("li").find(".gadgets-markrights").length) { - continue; - } - if ($element.siblings(".gadgets-markrights").length) { - continue; - } - const { - textContent - } = element; - const userLinkText = textContent === null || textContent === void 0 ? void 0 : textContent.toString(); - if (userLinkText) { - users[users.length] = userLinkText; - } - users = (0, import_ext_gadget3.uniqueArray)(users); - if (users.length === 25) { - queue[queue.length] = users; - users = []; - } +//! src/MarkRights/modules/util/generateUserLinks.ts +var generateUserLinks = ($content) => { + const users = []; + const $userLinks = []; + const $elements = $content.find("a.mw-userlink:not(.mw-anonuserlink)"); + var _iterator4 = _createForOfIteratorHelper($elements), _step4; + try { + for (_iterator4.s(); !(_step4 = _iterator4.n()).done; ) { + const element = _step4.value; + const $element = $(element); + if ($element.parents("li").find(".gadgets-markrights").length || $element.siblings(".gadgets-markrights").length) { + continue; } - } catch (err) { - _iterator4.e(err); - } finally { - _iterator4.f(); + $userLinks[$userLinks.length] = $element; + const { + textContent + } = element; + const user = textContent === null || textContent === void 0 ? void 0 : textContent.toString(); + if (!user) { + continue; + } + users[users.length] = user; } - if (users.length > 0) { - queue[queue.length] = users; + } catch (err) { + _iterator4.e(err); + } finally { + _iterator4.f(); + } + return { + users, + $userLinks + }; +}; +//! src/MarkRights/modules/core.ts +var markUserRights = ($content) => { + const { + users, + $userLinks + } = generateUserLinks($content); + const promises = []; + for (let i = 0; i < users.length; i++) { + const ususers = users.splice(0, 25); + if (!ususers.length) { + continue; } - for (var _i = 0, _queue = queue; _i < _queue.length; _i++) { - const ususers = _queue[_i]; + promises[promises.length] = /* @__PURE__ */ _asyncToGenerator(function* () { + const userGroups = {}; try { - const queryUserResponse = yield queryUserGroups(ususers); + const response = yield queryUserGroups(ususers); const { users: queryUsers - } = queryUserResponse["query"]; + } = response["query"]; var _iterator5 = _createForOfIteratorHelper(queryUsers), _step5; try { for (_iterator5.s(); !(_step5 = _iterator5.n()).done; ) { + var _userGroups$name; const user = _step5.value; - if (!user || !user.groups) { + if (!(user !== null && user !== void 0 && user.name) || !(user !== null && user !== void 0 && user.groups)) { continue; } - userGroupMap.set(user.name, user.groups.filter((element) => { + const { + name, + groups + } = user; + (_userGroups$name = userGroups[name]) !== null && _userGroups$name !== void 0 ? _userGroups$name : userGroups[name] = []; + userGroups[name] = [...userGroups[name], ...groups.filter((element) => { return element !== "*"; - })); + })]; } } catch (err) { _iterator5.e(err); } finally { _iterator5.f(); } - var _iterator6 = _createForOfIteratorHelper(ususers), _step6; - try { - for (_iterator6.s(); !(_step6 = _iterator6.n()).done; ) { - const user = _step6.value; - const queryGlobalUserInfoResponse = yield queryGlobalUserGroups(user); - if (queryGlobalUserInfoResponse["query"] && queryGlobalUserInfoResponse["query"].globaluserinfo) { - const { - groups: globalgroups - } = queryGlobalUserInfoResponse["query"].globaluserinfo; - globalUserGroupMap.set(user, globalgroups); + } catch (error) { + console.error("[MarkRights] Ajax error:", error); + } + appendUserRightsMark($userLinks, userGroups); + }); + promises[promises.length] = /* @__PURE__ */ _asyncToGenerator(function* () { + const userGroups = {}; + var _iterator6 = _createForOfIteratorHelper(ususers), _step6; + try { + for (_iterator6.s(); !(_step6 = _iterator6.n()).done; ) { + const user = _step6.value; + try { + var _userGroups$user; + const response = yield queryGlobalUserGroups(user); + const { + globaluserinfo + } = response["query"]; + if (!(globaluserinfo !== null && globaluserinfo !== void 0 && globaluserinfo.groups)) { + continue; } + const { + groups + } = globaluserinfo; + (_userGroups$user = userGroups[user]) !== null && _userGroups$user !== void 0 ? _userGroups$user : userGroups[user] = []; + userGroups[user] = [...userGroups[user], ...groups]; + } catch (error) { + console.error("[MarkRights] Ajax error:", error); } - } catch (err) { - _iterator6.e(err); - } finally { - _iterator6.f(); } - appendUserRightsMark($userLinks, { - userGroupMap, - globalUserGroupMap - }); + } catch (err) { + _iterator6.e(err); + } finally { + _iterator6.f(); + } + appendUserRightsMark($userLinks, userGroups); + }); + } + void _asyncToGenerator(function* () { + for (var _i = 0, _promises = promises; _i < _promises.length; _i++) { + const promise = _promises[_i]; + try { + yield promise(); } catch { } } - }); - return function markUserRights2(_x3) { - return _ref3.apply(this, arguments); - }; -}(); + })(); +}; //! src/MarkRights/MarkRights.ts mw.hook("wikipage.content").add(function markRights($content) { if ($content.attr("id") === "mw-content-text" || $content.hasClass("mw-changeslist")) { @@ -483,4 +491,4 @@ mw.hook("wikipage.content").add(function markRights($content) { /* */ -//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/MarkRights/MarkRights.ts", "src/MarkRights/options.json", "src/MarkRights/modules/api.ts", "src/MarkRights/modules/query.ts", "src/MarkRights/modules/i18n.ts", "src/MarkRights/modules/core.ts"],
  "sourcesContent": ["/**\n * @description 在最近修改、监视列表、条目历史记录等位置以特殊格式显示有特殊权限的用户\n */\nimport {markUserRights} from './modules/core';\n\nmw.hook('wikipage.content').add(function markRights($content): void {\n\tif ($content.attr('id') === 'mw-content-text' || $content.hasClass('mw-changeslist')) {\n\t\tvoid markUserRights($content);\n\t}\n});\n\nexport {queryGlobalUserGroups, queryUserGroups} from './modules/query';\n", "{\n\t\"version\": 2.0\n}\n", "import * as OPTIONS from '../options.json';\nimport {initMwApi} from 'ext.gadget.Util';\n\nconst api: mw.Api = initMwApi(`MarkRights/${OPTIONS.version}`);\n\nexport {api};\n", "import {api} from './api';\n\nconst queryUserGroups = async (ususers: string | string[]) => {\n\tconst params: ApiQueryUsersParams = {\n\t\tususers,\n\t\taction: 'query',\n\t\tformat: 'json',\n\t\tformatversion: '2',\n\t\tlist: 'users',\n\t\tusprop: 'groups',\n\t\tsmaxage: 600,\n\t\tmaxage: 600,\n\t};\n\tconst response = await api.get(params);\n\n\treturn response;\n};\n\nconst queryGlobalUserGroups = async (user: string) => {\n\tconst params = {\n\t\taction: 'query',\n\t\tformat: 'json',\n\t\tformatversion: '2',\n\t\tmeta: 'globaluserinfo',\n\t\tguiuser: user,\n\t\tguiprop: 'groups',\n\t\tsmaxage: 600,\n\t\tmaxage: 600,\n\t};\n\tconst response = await api.get(params);\n\n\treturn response;\n};\n\nexport {queryUserGroups, queryGlobalUserGroups};\n", "import {localize} from 'ext.gadget.i18n';\n\nconst getI18nMessages = () => {\n\treturn {\n\t\tqiuwen: localize({\n\t\t\ten: 'Webmaster',\n\t\t\t'zh-hans': '站长',\n\t\t\t'zh-hant': '站長',\n\t\t}),\n\t\tsteward: localize({\n\t\t\ten: 'Steward',\n\t\t\t'zh-hans': '裁决委员',\n\t\t\t'zh-hant': '裁決委員',\n\t\t}),\n\t\tcheckuser: localize({\n\t\t\ten: 'CheckUser',\n\t\t\t'zh-hans': '用户查核',\n\t\t\t'zh-hant': '用戶查核',\n\t\t}),\n\t\tsuppress: localize({\n\t\t\ten: 'Oversighter',\n\t\t\t'zh-hans': '监督员',\n\t\t\t'zh-hant': '監督員',\n\t\t}),\n\t\tsysop: localize({\n\t\t\ten: 'SysOp',\n\t\t\t'zh-hans': '管理员',\n\t\t\t'zh-hant': '管理員',\n\t\t}),\n\t\t'interface-admin': localize({\n\t\t\ten: 'Interface Administrator',\n\t\t\t'zh-hans': '界面管理员',\n\t\t\t'zh-hant': '介面管理員',\n\t\t}),\n\t\ttemplateeditor: localize({\n\t\t\ten: 'Template Editor',\n\t\t\t'zh-hans': '模板编辑员',\n\t\t\t'zh-hant': '模板編輯員',\n\t\t}),\n\t\ttranswiki: localize({\n\t\t\ten: 'Importer',\n\t\t\t'zh-hans': '导入者',\n\t\t\t'zh-hant': '匯入者',\n\t\t}),\n\t\tpatroller: localize({\n\t\t\ten: 'Patroller',\n\t\t\t'zh-hans': '巡查员',\n\t\t\t'zh-hant': '巡查員',\n\t\t}),\n\t\tautoreviewer: localize({\n\t\t\ten: 'Exempted from page patrol',\n\t\t\t'zh-hans': '巡查豁免',\n\t\t\t'zh-hant': '巡查豁免',\n\t\t}),\n\t\tsenioreditor: localize({\n\t\t\ten: 'Senior Editor',\n\t\t\t'zh-hans': '资深编者',\n\t\t\t'zh-hant': '資深編者',\n\t\t}),\n\t\teventsponsor: localize({\n\t\t\ten: 'Event Sponsor',\n\t\t\t'zh-hans': '活动组织者',\n\t\t\t'zh-hant': '活動組織者',\n\t\t}),\n\t\t'massmessage-sender': localize({\n\t\t\ten: 'MassMessage sender',\n\t\t\t'zh-hans': '大量消息发送者',\n\t\t\t'zh-hant': '大量訊息傳送者',\n\t\t}),\n\t\tconfirmed: localize({\n\t\t\ten: 'Confirmed user',\n\t\t\t'zh-hans': '确认用户',\n\t\t\t'zh-hant': '確認用戶',\n\t\t}),\n\t\tautoconfirmed: localize({\n\t\t\ten: 'Auto-confirmed user',\n\t\t\t'zh-hans': '自动确认用户',\n\t\t\t'zh-hant': '自動確認用戶',\n\t\t}),\n\t\tbot: localize({\n\t\t\ten: 'Bot',\n\t\t\t'zh-hans': '机器人',\n\t\t\t'zh-hant': '機械人',\n\t\t}),\n\t\tflood: localize({\n\t\t\ten: 'Flooder',\n\t\t\t'zh-hans': '机器用户',\n\t\t\t'zh-hant': '機械用戶',\n\t\t}),\n\t\t'rnrsverify-exempt': localize({\n\t\t\ten: 'Exempted from real-name verification',\n\t\t\t'zh-hans': '实名制验证豁免',\n\t\t\t'zh-hant': '實名制驗證豁免',\n\t\t}),\n\t\t'ipblock-exempt': localize({\n\t\t\ten: 'Exempted from IP blocks',\n\t\t\t'zh-hans': 'IP封禁豁免',\n\t\t\t'zh-hant': 'IP封鎖豁免',\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 {queryGlobalUserGroups, queryUserGroups} from './query';\nimport type {UserRights} from './types';\nimport {getMessage} from './i18n';\nimport {uniqueArray} from 'ext.gadget.Util';\n\nconst getUsername = (url: string): string => {\n\tif (!url) {\n\t\treturn '';\n\t}\n\n\tconst username: string | null = mw.util.getParamValue('title', url);\n\n\tconst decode = (string: string, replace: (_string: string) => string): string => {\n\t\treturn decodeURIComponent(\n\t\t\t((): string => {\n\t\t\t\ttry {\n\t\t\t\t\treturn decodeURIComponent(replace(string));\n\t\t\t\t} catch {\n\t\t\t\t\treturn replace(string).replace(/%(?!\\d+)/g, '%25');\n\t\t\t\t}\n\t\t\t})()\n\t\t);\n\t};\n\n\tif (username) {\n\t\treturn decode(username, (string: string): string => {\n\t\t\treturn string.replace('User:', '').replace(/_/g, ' ');\n\t\t});\n\t}\n\tconst usernameMatch: RegExpMatchArray | null = url.match(/\\/wiki\\/User:(.+?)$/);\n\tif (usernameMatch?.[1]) {\n\t\treturn decode(usernameMatch[1], (string: string): string => {\n\t\t\treturn string.replace(/_/g, ' ');\n\t\t});\n\t}\n\treturn '';\n};\n\nconst appendUserRightsMark = (\n\t$userLinks: JQuery<HTMLElement>,\n\t{userGroupMap, globalUserGroupMap}: {userGroupMap: Map<string, string[]>; globalUserGroupMap: Map<string, string[]>}\n): void => {\n\tfor (const element of $userLinks) {\n\t\tconst $element: JQuery = $(element);\n\t\tif ($element.parents('li').find('.gadgets-markrights').length) {\n\t\t\tcontinue;\n\t\t}\n\t\tif ($element.siblings('.gadgets-markrights').length) {\n\t\t\tcontinue;\n\t\t}\n\t\tconst username: string = getUsername($element.attr('href') ?? '');\n\t\tif (!username) {\n\t\t\tcontinue;\n\t\t}\n\t\tconst groups = userGroupMap.get(username) ?? [];\n\t\tconst globalGroups = globalUserGroupMap.get(username) ?? [];\n\t\tif (!groups) {\n\t\t\tcontinue;\n\t\t}\n\t\tconst $sups: JQuery = $('<span>').addClass('gadgets-markrights');\n\t\tfor (const group of uniqueArray([...groups, ...globalGroups])) {\n\t\t\tconst className: string = `gadgets-markrights__${group}`;\n\t\t\tif ($sups.find('sup').hasClass(className)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\t$sups.append(\n\t\t\t\t// The following classes are used here:\n\t\t\t\t// * gadget-markrights__qiuwen\n\t\t\t\t// * gadget-markrights__steward\n\t\t\t\t// * gadget-markrights__checkuser\n\t\t\t\t// * gadget-markrights__suppress\n\t\t\t\t// * gadget-markrights__sysop\n\t\t\t\t// * gadget-markrights__interface-admin\n\t\t\t\t// * gadget-markrights__templateeditor\n\t\t\t\t// * gadget-markrights__transwiki\n\t\t\t\t// * gadget-markrights__patroller\n\t\t\t\t// * gadget-markrights__autoreviewer\n\t\t\t\t// * gadget-markrights__senioreditor\n\t\t\t\t// * gadget-markrights__eventsponsor\n\t\t\t\t// * gadget-markrights__massmessage-sender\n\t\t\t\t// * gadget-markrights__confirmed\n\t\t\t\t// * gadget-markrights__autoconfirmed\n\t\t\t\t// * gadget-markrights__bot\n\t\t\t\t// * gadget-markrights__flood\n\t\t\t\t// * gadget-markrights__ipblock-exempt\n\t\t\t\t// * gadget-markrights__rnrsverify-exempt\n\t\t\t\t$('<sup>')\n\t\t\t\t\t.addClass(className)\n\t\t\t\t\t.attr({\n\t\t\t\t\t\talt: getMessage(group as UserRights),\n\t\t\t\t\t\ttitle: getMessage(group as UserRights),\n\t\t\t\t\t})\n\t\t\t);\n\t\t}\n\t\t$element.after($sups);\n\t}\n};\n\nconst markUserRights = async ($content: JQuery): Promise<void> => {\n\tconst $userLinks: JQuery = $content.find('a.mw-userlink:not(.mw-anonuserlink)');\n\tlet users: string[] = [];\n\tconst queue: Array<typeof users> = [];\n\tconst userGroupMap: Map<string, string[]> = new Map();\n\tconst globalUserGroupMap: Map<string, string[]> = new Map();\n\n\tfor (const element of $userLinks) {\n\t\tconst $element: JQuery = $(element);\n\t\tif ($element.parents('li').find('.gadgets-markrights').length) {\n\t\t\tcontinue;\n\t\t}\n\t\tif ($element.siblings('.gadgets-markrights').length) {\n\t\t\tcontinue;\n\t\t}\n\t\tconst {textContent} = element;\n\t\tconst userLinkText: string | undefined = textContent?.toString();\n\t\tif (userLinkText) {\n\t\t\tusers[users.length] = userLinkText; // Replace `[].push()` to avoid polyfilling core-js\n\t\t}\n\n\t\t// 用户名列表去重\n\t\tusers = uniqueArray(users); // Replace `[...new Set()]` to avoid polyfilling core-js\n\n\t\tif (users.length === 25) {\n\t\t\tqueue[queue.length] = users; // Replace `[].push()` to avoid polyfilling core-js\n\t\t\tusers = [];\n\t\t}\n\t}\n\n\tif (users.length > 0) {\n\t\tqueue[queue.length] = users; // Replace `[].push()` to avoid polyfilling core-js\n\t}\n\n\tfor (const ususers of queue) {\n\t\ttry {\n\t\t\tconst queryUserResponse = await queryUserGroups(ususers);\n\t\t\tconst {users: queryUsers} = queryUserResponse['query'] as {\n\t\t\t\tusers: {groups: string[]; name: string}[];\n\t\t\t};\n\n\t\t\tfor (const user of queryUsers) {\n\t\t\t\tif (!user || !user.groups) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tuserGroupMap.set(\n\t\t\t\t\tuser.name,\n\t\t\t\t\tuser.groups.filter((element) => {\n\t\t\t\t\t\treturn element !== '*';\n\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tfor (const user of ususers) {\n\t\t\t\tconst queryGlobalUserInfoResponse = await queryGlobalUserGroups(user);\n\t\t\t\tif (queryGlobalUserInfoResponse['query'] && queryGlobalUserInfoResponse['query'].globaluserinfo) {\n\t\t\t\t\tconst {groups: globalgroups}: {groups: string[]} = queryGlobalUserInfoResponse['query']\n\t\t\t\t\t\t.globaluserinfo as {groups: string[]};\n\t\t\t\t\tglobalUserGroupMap.set(user, globalgroups);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tappendUserRightsMark($userLinks, {userGroupMap, globalUserGroupMap});\n\t\t} catch {}\n\t}\n};\n\nexport {markUserRights};\n"],
  "mappings": "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",
  "names": ["MarkRights_exports", "__export", "queryGlobalUserGroups", "queryUserGroups", "module", "exports", "__toCommonJS", "version", "import_ext_gadget", "require", "api", "initMwApi", "concat", "_ref", "_asyncToGenerator", "ususers", "params", "action", "format", "formatversion", "list", "usprop", "smaxage", "maxage", "response", "get", "_x", "apply", "arguments", "_ref2", "user", "meta", "guiuser", "guiprop", "_x2", "import_ext_gadget2", "getI18nMessages", "qiuwen", "localize", "en", "steward", "checkuser", "suppress", "sysop", "templateeditor", "transwiki", "patroller", "autoreviewer", "senioreditor", "eventsponsor", "confirmed", "autoconfirmed", "bot", "flood", "i18nMessages", "getMessage", "key", "import_ext_gadget3", "getUsername", "url", "username", "mw", "util", "getParamValue", "decode", "string", "replace", "decodeURIComponent", "usernameMatch", "match", "appendUserRightsMark", "$userLinks", "userGroupMap", "globalUserGroupMap", "_iterator2", "_createForOfIteratorHelper", "_step2", "s", "n", "done", "_$element$attr", "_userGroupMap$get", "_globalUserGroupMap$g", "element", "value", "$element", "$", "parents", "find", "length", "siblings", "attr", "groups", "globalGroups", "$sups", "addClass", "_iterator3", "uniqueArray", "_step3", "group", "className", "hasClass", "append", "alt", "title", "err", "e", "f", "after", "markUserRights", "_ref3", "$content", "users", "queue", "Map", "_iterator4", "_step4", "textContent", "userLinkText", "toString", "_i", "_queue", "queryUserResponse", "queryUsers", "_iterator5", "_step5", "set", "name", "filter", "_iterator6", "_step6", "queryGlobalUserInfoResponse", "globaluserinfo", "globalgroups", "_x3", "hook", "add", "markRights"]
}
 +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/MarkRights/MarkRights.ts", "src/MarkRights/options.json", "src/MarkRights/modules/api.ts", "src/MarkRights/modules/query.ts", "src/MarkRights/modules/i18n.ts", "src/MarkRights/modules/util/getUserName.ts", "src/MarkRights/modules/util/appendUserRightsMark.ts", "src/MarkRights/modules/util/generateUserLinks.ts", "src/MarkRights/modules/core.ts"],
  "sourcesContent": ["/**\n * @description 在最近修改、监视列表、条目历史记录等位置以特殊格式显示有特殊权限的用户\n */\nimport {markUserRights} from './modules/core';\n\nmw.hook('wikipage.content').add(function markRights($content): void {\n\tif ($content.attr('id') === 'mw-content-text' || $content.hasClass('mw-changeslist')) {\n\t\tvoid markUserRights($content);\n\t}\n});\n\nexport {queryGlobalUserGroups, queryUserGroups} from './modules/query';\n", "{\n\t\"version\": 2.0\n}\n", "import * as OPTIONS from '../options.json';\nimport {initMwApi} from 'ext.gadget.Util';\n\nconst api: mw.Api = initMwApi(`MarkRights/${OPTIONS.version}`);\n\nexport {api};\n", "import {api} from './api';\n\nconst queryUserGroups = async (ususers: string | string[]) => {\n\tconst params: ApiQueryUsersParams = {\n\t\tususers,\n\t\taction: 'query',\n\t\tformat: 'json',\n\t\tformatversion: '2',\n\t\tlist: 'users',\n\t\tusprop: 'groups',\n\t\tsmaxage: 600,\n\t\tmaxage: 600,\n\t};\n\tconst response = await api.get(params);\n\n\treturn response;\n};\n\nconst queryGlobalUserGroups = async (user: string) => {\n\tconst params = {\n\t\taction: 'query',\n\t\tformat: 'json',\n\t\tformatversion: '2',\n\t\tmeta: 'globaluserinfo',\n\t\tguiuser: user,\n\t\tguiprop: 'groups',\n\t\tsmaxage: 600,\n\t\tmaxage: 600,\n\t};\n\tconst response = await api.get(params);\n\n\treturn response;\n};\n\nexport {queryUserGroups, queryGlobalUserGroups};\n", "import {localize} from 'ext.gadget.i18n';\n\nconst getI18nMessages = () => {\n\treturn {\n\t\tqiuwen: localize({\n\t\t\ten: 'Webmaster',\n\t\t\t'zh-hans': '站长',\n\t\t\t'zh-hant': '站長',\n\t\t}),\n\t\tsteward: localize({\n\t\t\ten: 'Steward',\n\t\t\t'zh-hans': '裁决委员',\n\t\t\t'zh-hant': '裁決委員',\n\t\t}),\n\t\tcheckuser: localize({\n\t\t\ten: 'CheckUser',\n\t\t\t'zh-hans': '用户查核',\n\t\t\t'zh-hant': '用戶查核',\n\t\t}),\n\t\tsuppress: localize({\n\t\t\ten: 'Oversighter',\n\t\t\t'zh-hans': '监督员',\n\t\t\t'zh-hant': '監督員',\n\t\t}),\n\t\tsysop: localize({\n\t\t\ten: 'SysOp',\n\t\t\t'zh-hans': '管理员',\n\t\t\t'zh-hant': '管理員',\n\t\t}),\n\t\t'interface-admin': localize({\n\t\t\ten: 'Interface Administrator',\n\t\t\t'zh-hans': '界面管理员',\n\t\t\t'zh-hant': '介面管理員',\n\t\t}),\n\t\ttemplateeditor: localize({\n\t\t\ten: 'Template Editor',\n\t\t\t'zh-hans': '模板编辑员',\n\t\t\t'zh-hant': '模板編輯員',\n\t\t}),\n\t\ttranswiki: localize({\n\t\t\ten: 'Importer',\n\t\t\t'zh-hans': '导入者',\n\t\t\t'zh-hant': '匯入者',\n\t\t}),\n\t\tpatroller: localize({\n\t\t\ten: 'Patroller',\n\t\t\t'zh-hans': '巡查员',\n\t\t\t'zh-hant': '巡查員',\n\t\t}),\n\t\tautoreviewer: localize({\n\t\t\ten: 'Exempted from page patrol',\n\t\t\t'zh-hans': '巡查豁免',\n\t\t\t'zh-hant': '巡查豁免',\n\t\t}),\n\t\tsenioreditor: localize({\n\t\t\ten: 'Senior Editor',\n\t\t\t'zh-hans': '资深编者',\n\t\t\t'zh-hant': '資深編者',\n\t\t}),\n\t\teventsponsor: localize({\n\t\t\ten: 'Event Sponsor',\n\t\t\t'zh-hans': '活动组织者',\n\t\t\t'zh-hant': '活動組織者',\n\t\t}),\n\t\t'massmessage-sender': localize({\n\t\t\ten: 'MassMessage sender',\n\t\t\t'zh-hans': '大量消息发送者',\n\t\t\t'zh-hant': '大量訊息傳送者',\n\t\t}),\n\t\tconfirmed: localize({\n\t\t\ten: 'Confirmed user',\n\t\t\t'zh-hans': '确认用户',\n\t\t\t'zh-hant': '確認用戶',\n\t\t}),\n\t\tautoconfirmed: localize({\n\t\t\ten: 'Auto-confirmed user',\n\t\t\t'zh-hans': '自动确认用户',\n\t\t\t'zh-hant': '自動確認用戶',\n\t\t}),\n\t\tbot: localize({\n\t\t\ten: 'Bot',\n\t\t\t'zh-hans': '机器人',\n\t\t\t'zh-hant': '機械人',\n\t\t}),\n\t\tflood: localize({\n\t\t\ten: 'Flooder',\n\t\t\t'zh-hans': '机器用户',\n\t\t\t'zh-hant': '機械用戶',\n\t\t}),\n\t\t'rnrsverify-exempt': localize({\n\t\t\ten: 'Exempted from real-name verification',\n\t\t\t'zh-hans': '实名制验证豁免',\n\t\t\t'zh-hant': '實名制驗證豁免',\n\t\t}),\n\t\t'ipblock-exempt': localize({\n\t\t\ten: 'Exempted from IP blocks',\n\t\t\t'zh-hans': 'IP封禁豁免',\n\t\t\t'zh-hant': 'IP封鎖豁免',\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", "const getUserName = (url: string): string => {\n\tif (!url) {\n\t\treturn '';\n\t}\n\n\tconst username: string | null = mw.util.getParamValue('title', url);\n\n\tconst decode = (string: string, replace: (_string: string) => string): string => {\n\t\treturn decodeURIComponent(\n\t\t\t((): string => {\n\t\t\t\ttry {\n\t\t\t\t\treturn decodeURIComponent(replace(string));\n\t\t\t\t} catch {\n\t\t\t\t\treturn replace(string).replace(/%(?!\\d+)/g, '%25');\n\t\t\t\t}\n\t\t\t})()\n\t\t);\n\t};\n\n\tif (username) {\n\t\treturn decode(username, (string: string): string => {\n\t\t\treturn string.replace('User:', '').replace(/_/g, ' ');\n\t\t});\n\t}\n\n\tconst usernameMatch: RegExpMatchArray | null = url.match(/\\/wiki\\/User:(.+?)$/);\n\n\tif (usernameMatch?.[1]) {\n\t\treturn decode(usernameMatch[1], (string: string): string => {\n\t\t\treturn string.replace(/_/g, ' ');\n\t\t});\n\t}\n\n\treturn '';\n};\n\nexport {getUserName};\n", "import type {UserRights} from '../types';\nimport {getMessage} from '../i18n';\nimport {getUserName} from './getUserName';\nimport {uniqueArray} from 'ext.gadget.Util';\n\nconst appendUserRightsMark = ($userLinks: JQuery<HTMLAnchorElement>[], userGroups: Record<string, string[]>): void => {\n\tfor (const $element of $userLinks) {\n\t\tconst username: string = getUserName($element.attr('href') ?? '');\n\t\tif (!username) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tuserGroups ??= {};\n\t\tconst groups = userGroups[username] ?? [];\n\n\t\tlet $sups: JQuery;\n\t\tif ($element.parents('li').find('.gadgets-markrights').length) {\n\t\t\t$sups = $element.siblings('.gadgets-markrights').eq(0);\n\t\t} else if ($element.siblings('.gadgets-markrights').length) {\n\t\t\t$sups = $element.parents('li').find('.gadgets-markrights').eq(0);\n\t\t} else {\n\t\t\t$sups = $('<span>').addClass('gadgets-markrights');\n\t\t\t$element.after($sups);\n\t\t}\n\n\t\tfor (const group of uniqueArray(groups)) {\n\t\t\tconst className: string = `gadgets-markrights__${group}`;\n\t\t\tif ($sups.find('sup').hasClass(className)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t$sups.append(\n\t\t\t\t// The following classes are used here:\n\t\t\t\t// * see ../types.d.ts\n\t\t\t\t// * for more information\n\t\t\t\t$('<sup>')\n\t\t\t\t\t.addClass(className)\n\t\t\t\t\t.attr({\n\t\t\t\t\t\talt: getMessage(group as UserRights),\n\t\t\t\t\t\ttitle: getMessage(group as UserRights),\n\t\t\t\t\t})\n\t\t\t);\n\t\t}\n\t}\n};\n\nexport {appendUserRightsMark};\n", "const generateUserLinks = ($content: JQuery): {users: string[]; $userLinks: JQuery<HTMLAnchorElement>[]} => {\n\tconst users: string[] = [];\n\tconst $userLinks: JQuery<HTMLAnchorElement>[] = [];\n\tconst $elements = $content.find<HTMLAnchorElement>('a.mw-userlink:not(.mw-anonuserlink)');\n\n\tfor (const element of $elements) {\n\t\tconst $element: JQuery<HTMLAnchorElement> = $(element);\n\t\tif (\n\t\t\t$element.parents('li').find('.gadgets-markrights').length ||\n\t\t\t$element.siblings('.gadgets-markrights').length\n\t\t) {\n\t\t\tcontinue;\n\t\t}\n\n\t\t$userLinks[$userLinks.length] = $element;\n\n\t\tconst {textContent} = element;\n\t\tconst user: string | undefined = textContent?.toString();\n\n\t\tif (!user) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tusers[users.length] = user;\n\t}\n\n\treturn {users, $userLinks};\n};\n\nexport {generateUserLinks};\n", "import {queryGlobalUserGroups, queryUserGroups} from './query';\nimport {appendUserRightsMark} from './util/appendUserRightsMark';\nimport {generateUserLinks} from './util/generateUserLinks';\n\nconst markUserRights = ($content: JQuery): void => {\n\tconst {users, $userLinks} = generateUserLinks($content);\n\n\tconst promises: (() => Promise<void>)[] = [];\n\n\tfor (let i = 0; i < users.length; i++) {\n\t\tconst ususers = users.splice(0, 25);\n\t\tif (!ususers.length) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tpromises[promises.length] = async (): Promise<void> => {\n\t\t\tconst userGroups: Record<string, string[]> = {};\n\n\t\t\ttry {\n\t\t\t\tconst response = await queryUserGroups(ususers);\n\t\t\t\tconst {users: queryUsers} = response['query'] as {\n\t\t\t\t\tusers: {groups: string[]; name: string}[];\n\t\t\t\t};\n\n\t\t\t\tfor (const user of queryUsers) {\n\t\t\t\t\tif (!user?.name || !user?.groups) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst {name, groups} = user;\n\n\t\t\t\t\tuserGroups[name] ??= [];\n\n\t\t\t\t\tuserGroups[name] = [\n\t\t\t\t\t\t...userGroups[name],\n\t\t\t\t\t\t...groups.filter((element) => {\n\t\t\t\t\t\t\treturn element !== '*';\n\t\t\t\t\t\t}),\n\t\t\t\t\t];\n\t\t\t\t}\n\t\t\t} catch (error: unknown) {\n\t\t\t\tconsole.error('[MarkRights] Ajax error:', error);\n\t\t\t}\n\n\t\t\tappendUserRightsMark($userLinks, userGroups);\n\t\t};\n\n\t\tpromises[promises.length] = async (): Promise<void> => {\n\t\t\tconst userGroups: Record<string, string[]> = {};\n\n\t\t\tfor (const user of ususers) {\n\t\t\t\ttry {\n\t\t\t\t\tconst response = await queryGlobalUserGroups(user);\n\t\t\t\t\tconst {globaluserinfo} = response['query'] as {\n\t\t\t\t\t\tglobaluserinfo: {groups: string[]};\n\t\t\t\t\t};\n\n\t\t\t\t\tif (!globaluserinfo?.groups) {\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst {groups} = globaluserinfo;\n\n\t\t\t\t\tuserGroups[user] ??= [];\n\n\t\t\t\t\tuserGroups[user] = [...userGroups[user], ...groups];\n\t\t\t\t} catch (error: unknown) {\n\t\t\t\t\tconsole.error('[MarkRights] Ajax error:', error);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tappendUserRightsMark($userLinks, userGroups);\n\t\t};\n\t}\n\n\tvoid (async () => {\n\t\tfor (const promise of promises) {\n\t\t\ttry {\n\t\t\t\tawait promise();\n\t\t\t} catch {}\n\t\t}\n\t})();\n};\n\nexport {markUserRights};\n"],
  "mappings": "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",
  "names": ["MarkRights_exports", "__export", "queryGlobalUserGroups", "queryUserGroups", "module", "exports", "__toCommonJS", "version", "import_ext_gadget", "require", "api", "initMwApi", "concat", "_ref", "_asyncToGenerator", "ususers", "params", "action", "format", "formatversion", "list", "usprop", "smaxage", "maxage", "response", "get", "_x", "apply", "arguments", "_ref2", "user", "meta", "guiuser", "guiprop", "_x2", "import_ext_gadget2", "getI18nMessages", "qiuwen", "localize", "en", "steward", "checkuser", "suppress", "sysop", "templateeditor", "transwiki", "patroller", "autoreviewer", "senioreditor", "eventsponsor", "confirmed", "autoconfirmed", "bot", "flood", "i18nMessages", "getMessage", "key", "getUserName", "url", "username", "mw", "util", "getParamValue", "decode", "string", "replace", "decodeURIComponent", "usernameMatch", "match", "import_ext_gadget3", "appendUserRightsMark", "$userLinks", "userGroups", "_iterator2", "_createForOfIteratorHelper", "_step2", "s", "n", "done", "_$element$attr", "_userGroups", "_userGroups$username", "$element", "value", "attr", "groups", "$sups", "parents", "find", "length", "siblings", "eq", "$", "addClass", "after", "_iterator3", "uniqueArray", "_step3", "group", "className", "hasClass", "append", "alt", "title", "err", "e", "f", "generateUserLinks", "$content", "users", "$elements", "_iterator4", "_step4", "element", "textContent", "toString", "markUserRights", "promises", "i", "splice", "queryUsers", "_iterator5", "_step5", "_userGroups$name", "name", "filter", "error", "console", "_iterator6", "_step6", "_userGroups$user", "globaluserinfo", "_i", "_promises", "promise", "hook", "add", "markRights"]
}
 diff --git a/src/MarkRights/modules/core.ts b/src/MarkRights/modules/core.ts index 06de7928..3249b818 100644 --- a/src/MarkRights/modules/core.ts +++ b/src/MarkRights/modules/core.ts @@ -1,166 +1,85 @@ import {queryGlobalUserGroups, queryUserGroups} from './query'; -import type {UserRights} from './types'; -import {getMessage} from './i18n'; -import {uniqueArray} from 'ext.gadget.Util'; +import {appendUserRightsMark} from './util/appendUserRightsMark'; +import {generateUserLinks} from './util/generateUserLinks'; -const getUsername = (url: string): string => { - if (!url) { - return ''; - } +const markUserRights = ($content: JQuery): void => { + const {users, $userLinks} = generateUserLinks($content); - const username: string | null = mw.util.getParamValue('title', url); + const promises: (() => Promise)[] = []; - const decode = (string: string, replace: (_string: string) => string): string => { - return decodeURIComponent( - ((): string => { - try { - return decodeURIComponent(replace(string)); - } catch { - return replace(string).replace(/%(?!\d+)/g, '%25'); - } - })() - ); - }; - - if (username) { - return decode(username, (string: string): string => { - return string.replace('User:', '').replace(/_/g, ' '); - }); - } - const usernameMatch: RegExpMatchArray | null = url.match(/\/wiki\/User:(.+?)$/); - if (usernameMatch?.[1]) { - return decode(usernameMatch[1], (string: string): string => { - return string.replace(/_/g, ' '); - }); - } - return ''; -}; - -const appendUserRightsMark = ( - $userLinks: JQuery, - {userGroupMap, globalUserGroupMap}: {userGroupMap: Map; globalUserGroupMap: Map} -): void => { - for (const element of $userLinks) { - const $element: JQuery = $(element); - if ($element.parents('li').find('.gadgets-markrights').length) { - continue; - } - if ($element.siblings('.gadgets-markrights').length) { + for (let i = 0; i < users.length; i++) { + const ususers = users.splice(0, 25); + if (!ususers.length) { continue; } - const username: string = getUsername($element.attr('href') ?? ''); - if (!username) { - continue; - } - const groups = userGroupMap.get(username) ?? []; - const globalGroups = globalUserGroupMap.get(username) ?? []; - if (!groups) { - continue; - } - const $sups: JQuery = $('').addClass('gadgets-markrights'); - for (const group of uniqueArray([...groups, ...globalGroups])) { - const className: string = `gadgets-markrights__${group}`; - if ($sups.find('sup').hasClass(className)) { - continue; - } - $sups.append( - // The following classes are used here: - // * gadget-markrights__qiuwen - // * gadget-markrights__steward - // * gadget-markrights__checkuser - // * gadget-markrights__suppress - // * gadget-markrights__sysop - // * gadget-markrights__interface-admin - // * gadget-markrights__templateeditor - // * gadget-markrights__transwiki - // * gadget-markrights__patroller - // * gadget-markrights__autoreviewer - // * gadget-markrights__senioreditor - // * gadget-markrights__eventsponsor - // * gadget-markrights__massmessage-sender - // * gadget-markrights__confirmed - // * gadget-markrights__autoconfirmed - // * gadget-markrights__bot - // * gadget-markrights__flood - // * gadget-markrights__ipblock-exempt - // * gadget-markrights__rnrsverify-exempt - $('') - .addClass(className) - .attr({ - alt: getMessage(group as UserRights), - title: getMessage(group as UserRights), - }) - ); - } - $element.after($sups); - } -}; -const markUserRights = async ($content: JQuery): Promise => { - const $userLinks: JQuery = $content.find('a.mw-userlink:not(.mw-anonuserlink)'); - let users: string[] = []; - const queue: Array = []; - const userGroupMap: Map = new Map(); - const globalUserGroupMap: Map = new Map(); + promises[promises.length] = async (): Promise => { + const userGroups: Record = {}; - for (const element of $userLinks) { - const $element: JQuery = $(element); - if ($element.parents('li').find('.gadgets-markrights').length) { - continue; - } - if ($element.siblings('.gadgets-markrights').length) { - continue; - } - const {textContent} = element; - const userLinkText: string | undefined = textContent?.toString(); - if (userLinkText) { - users[users.length] = userLinkText; // Replace `[].push()` to avoid polyfilling core-js - } + try { + const response = await queryUserGroups(ususers); + const {users: queryUsers} = response['query'] as { + users: {groups: string[]; name: string}[]; + }; - // 用户名列表去重 - users = uniqueArray(users); // Replace `[...new Set()]` to avoid polyfilling core-js + for (const user of queryUsers) { + if (!user?.name || !user?.groups) { + continue; + } - if (users.length === 25) { - queue[queue.length] = users; // Replace `[].push()` to avoid polyfilling core-js - users = []; - } - } - - if (users.length > 0) { - queue[queue.length] = users; // Replace `[].push()` to avoid polyfilling core-js - } + const {name, groups} = user; - for (const ususers of queue) { - try { - const queryUserResponse = await queryUserGroups(ususers); - const {users: queryUsers} = queryUserResponse['query'] as { - users: {groups: string[]; name: string}[]; - }; + userGroups[name] ??= []; - for (const user of queryUsers) { - if (!user || !user.groups) { - continue; + userGroups[name] = [ + ...userGroups[name], + ...groups.filter((element) => { + return element !== '*'; + }), + ]; } - userGroupMap.set( - user.name, - user.groups.filter((element) => { - return element !== '*'; - }) - ); + } catch (error: unknown) { + console.error('[MarkRights] Ajax error:', error); } + appendUserRightsMark($userLinks, userGroups); + }; + + promises[promises.length] = async (): Promise => { + const userGroups: Record = {}; + for (const user of ususers) { - const queryGlobalUserInfoResponse = await queryGlobalUserGroups(user); - if (queryGlobalUserInfoResponse['query'] && queryGlobalUserInfoResponse['query'].globaluserinfo) { - const {groups: globalgroups}: {groups: string[]} = queryGlobalUserInfoResponse['query'] - .globaluserinfo as {groups: string[]}; - globalUserGroupMap.set(user, globalgroups); + try { + const response = await queryGlobalUserGroups(user); + const {globaluserinfo} = response['query'] as { + globaluserinfo: {groups: string[]}; + }; + + if (!globaluserinfo?.groups) { + continue; + } + + const {groups} = globaluserinfo; + + userGroups[user] ??= []; + + userGroups[user] = [...userGroups[user], ...groups]; + } catch (error: unknown) { + console.error('[MarkRights] Ajax error:', error); } } - appendUserRightsMark($userLinks, {userGroupMap, globalUserGroupMap}); - } catch {} + appendUserRightsMark($userLinks, userGroups); + }; } + + void (async () => { + for (const promise of promises) { + try { + await promise(); + } catch {} + } + })(); }; export {markUserRights}; diff --git a/src/MarkRights/modules/util/appendUserRightsMark.ts b/src/MarkRights/modules/util/appendUserRightsMark.ts new file mode 100644 index 00000000..ccc9e858 --- /dev/null +++ b/src/MarkRights/modules/util/appendUserRightsMark.ts @@ -0,0 +1,47 @@ +import type {UserRights} from '../types'; +import {getMessage} from '../i18n'; +import {getUserName} from './getUserName'; +import {uniqueArray} from 'ext.gadget.Util'; + +const appendUserRightsMark = ($userLinks: JQuery[], userGroups: Record): void => { + for (const $element of $userLinks) { + const username: string = getUserName($element.attr('href') ?? ''); + if (!username) { + continue; + } + + userGroups ??= {}; + const groups = userGroups[username] ?? []; + + let $sups: JQuery; + if ($element.parents('li').find('.gadgets-markrights').length) { + $sups = $element.siblings('.gadgets-markrights').eq(0); + } else if ($element.siblings('.gadgets-markrights').length) { + $sups = $element.parents('li').find('.gadgets-markrights').eq(0); + } else { + $sups = $('').addClass('gadgets-markrights'); + $element.after($sups); + } + + for (const group of uniqueArray(groups)) { + const className: string = `gadgets-markrights__${group}`; + if ($sups.find('sup').hasClass(className)) { + continue; + } + + $sups.append( + // The following classes are used here: + // * see ../types.d.ts + // * for more information + $('') + .addClass(className) + .attr({ + alt: getMessage(group as UserRights), + title: getMessage(group as UserRights), + }) + ); + } + } +}; + +export {appendUserRightsMark}; diff --git a/src/MarkRights/modules/util/generateUserLinks.ts b/src/MarkRights/modules/util/generateUserLinks.ts new file mode 100644 index 00000000..f79511cb --- /dev/null +++ b/src/MarkRights/modules/util/generateUserLinks.ts @@ -0,0 +1,30 @@ +const generateUserLinks = ($content: JQuery): {users: string[]; $userLinks: JQuery[]} => { + const users: string[] = []; + const $userLinks: JQuery[] = []; + const $elements = $content.find('a.mw-userlink:not(.mw-anonuserlink)'); + + for (const element of $elements) { + const $element: JQuery = $(element); + if ( + $element.parents('li').find('.gadgets-markrights').length || + $element.siblings('.gadgets-markrights').length + ) { + continue; + } + + $userLinks[$userLinks.length] = $element; + + const {textContent} = element; + const user: string | undefined = textContent?.toString(); + + if (!user) { + continue; + } + + users[users.length] = user; + } + + return {users, $userLinks}; +}; + +export {generateUserLinks}; diff --git a/src/MarkRights/modules/util/getUserName.ts b/src/MarkRights/modules/util/getUserName.ts new file mode 100644 index 00000000..f6f3159c --- /dev/null +++ b/src/MarkRights/modules/util/getUserName.ts @@ -0,0 +1,37 @@ +const getUserName = (url: string): string => { + if (!url) { + return ''; + } + + const username: string | null = mw.util.getParamValue('title', url); + + const decode = (string: string, replace: (_string: string) => string): string => { + return decodeURIComponent( + ((): string => { + try { + return decodeURIComponent(replace(string)); + } catch { + return replace(string).replace(/%(?!\d+)/g, '%25'); + } + })() + ); + }; + + if (username) { + return decode(username, (string: string): string => { + return string.replace('User:', '').replace(/_/g, ' '); + }); + } + + const usernameMatch: RegExpMatchArray | null = url.match(/\/wiki\/User:(.+?)$/); + + if (usernameMatch?.[1]) { + return decode(usernameMatch[1], (string: string): string => { + return string.replace(/_/g, ' '); + }); + } + + return ''; +}; + +export {getUserName};