MediaWiki:Gadget-Wikiplus-highlight.js:修订间差异

MediaWiki系统消息页面
(Git更新:([https://github.com/TopRealm/InterfaceCodes/commit/d15c45c7c00e01ff7cd2e46db820db46e53c27e5 d15c45c]) feat: add Wikiplus-highlight)
(Git commit 315405d: feat: sync upstream with Qiuwen)
 
(未显示2个用户的6个中间版本)
第1行: 第1行:
/**
/**
* SPDX-License-Identifier: GPL-3.0
* SPDX-License-Identifier: CC-BY-SA-4.0
* _addText: '{{Gadget Header|license=GPL-3.0}}'
* _addText: '{{Gadget Header|license=CC-BY-SA-4.0}}'
*
*
* @base <https://github.com/bhsd-harry/Wikiplus-highlight/blob/main/main.js>
* @source {@link https://github.com/TopRealm/YsArchives-Gadgets/tree/master/src/Wikiplus-highlight}
* @license CC-BY-SA-4.0 {@link https://youshou.wiki/wiki/H:CC-BY-SA-4.0}
* @source <https://git.qiuwen.wiki/InterfaceAdmin/Gadgets/src/branch/master/src/Gadgets/Wikiplus>
* @author Bhsd <https://github.com/bhsd-harry>
* @author 机智的小鱼君 <https://github.com/Dragon-Fish>
* @dependency mediawiki.storage, mediawiki.Title, mediawiki.util
*/
*/
/**
/**
* +--------------------------------------------------------+
* +------------------------------------------------------------+
* | === WARNING: GLOBAL GADGET FILE === |
* | === WARNING: GLOBAL GADGET FILE === |
* +--------------------------------------------------------+
* +------------------------------------------------------------+
* | All changes should be made in the repository, |
* | All changes should be made in the repository, |
* | otherwise they will be lost. |
* | otherwise they will be lost. |
* +--------------------------------------------------------+
* +------------------------------------------------------------+
* | Changes to this page may affect many users. |
* | Changes to this page may affect many users. |
* | Please discuss changes at talk page before editing. |
* | Please discuss changes by opening an issue before editing. |
* +--------------------------------------------------------+
* +------------------------------------------------------------+
*/
*/
/* <nowiki> */
/* <nowiki> */
/* Wikiplus-highlight:Wikiplus编辑器的CodeMirror语法高亮扩展 */
(async function wikiplusHighlight() {
if (mw.libs.wphl && mw.libs.wphl.version) {
return;
}
mw.libs.wphl = mw.libs.wphl || {}; // 开始加载
const version = '2.59.5';
const newAddon = 0;
/** @type {typeof mw.storage} */
const storage =
typeof mw.storage === 'object' && typeof mw.storage.getObject === 'function'
? mw.storage
: {
/** @override */
getObject(key) {
const json = localStorage.getItem(key);
if (json === false) {
return false;
}
try {
return JSON.parse(json);
} catch {
return null;
}
},
/** @override */
setObject(key, value) {
try {
return localStorage.setItem(key, JSON.stringify(value));
} catch {
return false;
}
},
};
Object.fromEntries =
Object.fromEntries ||
((entries) => {
const /** @type {Record<string, T>} */ obj = {};
for (const [key, value] of entries) {
obj[key] = value;
}
return obj;
});
/**
* 解析版本号
*
* @param {string} str 版本号
*/
const getVersion = (str = version) => str.split('.').map(Number);
/**
* 比较版本号
*
* @param {string} a 版本号1
* @param {string} b 版本号2
* @return {boolean} `a`的版本号是否小于`b`的版本号
*/
const cmpVersion = (a, b) => {
const [a0, a1] = getVersion(a);
const [b0, b1] = getVersion(b);
return a0 < b0 || (a0 === b0 && a1 < b1);
};
/**
* 获取I18N消息
*
* @param {string} key 消息键,省略`wphl-`前缀
* @param {string[]} args 替换`$1`等的参数
*/
const msg = (key, ...args) => mw.msg(`wphl-${key}`, ...args);
/**
* 生成JQuery的I18N消息
*
* @param {string[]} args 替换`$1`等的参数
*/
const htmlMsg = (...args) => $($.parseHTML(msg(...args)));
/**
* 提示消息
*
* @param {string[]} args 替换`$1`等的参数
*/
const notify =
(...args) =>
() => {
const $p = $('<p>').html(msg(...args));
mw.notify($p, {type: 'success', autoHideSeconds: 'long', tag: 'wikiplus-highlight'});
return $p;
};
// 插件和I18N依主版本号
const majorVersion = getVersion().slice(0, 2).join('.');
// 路径
const CDN = '//fastly.jsdelivr.net';
const CM_CDN = 'npm/codemirror@5.65.3';
const MW_CDN = 'gh/bhsd-harry/codemirror-mediawiki@1.1.10';
const PARSER_CDN = 'npm/wikiparser-node@0.11.0-b';
const REPO_CDN = `npm/wikiplus-highlight@${majorVersion}`;


const {
(() => {

config: {
"use strict";
values: {

wgPageName: page,
// dist/Wikiplus-highlight/Wikiplus-highlight.js
wgNamespaceNumber: ns,
function _createForOfIteratorHelper(r, e) {
wgPageContentModel: contentmodel,
var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
wgServer: server,
if (!t) {
wgScriptPath: scriptPath,
if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) {
wgUserLanguage: userLang,
t && (r = t);
skin,
var n = 0, F = function() {
},
};
},
return { s: F, n: function() {
} = mw;
return n >= r.length ? { done: true } : { done: false, value: r[n++] };
// 和本地缓存有关的常数
}, e: function(r2) {
const USING_LOCAL = mw.loader.getState('ext.CodeMirror') !== null;
throw r2;
const /** @type {Record<string, {time: number, config: mwConfig}>} */ ALL_SETTINGS_CACHE =
}, f: F };
storage.getObject('InPageEditMwConfig') || {};
}
const SITE_ID = `${server}${scriptPath}`;
throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
const /** @type {{time: number, config: mwConfig}} */ SITE_SETTINGS = ALL_SETTINGS_CACHE[SITE_ID] || {};
}
const EXPIRED = !(SITE_SETTINGS.time > Date.now() - 86400 * 1000 * 30);
var o, a = true, u = false;
const /** @type {Record<string, string>} */ CONTENTMODEL = {
return { s: function() {
css: 'css',
t = t.call(r);
'sanitized-css': 'css',
}, n: function() {
javascript: 'javascript',
var r2 = t.next();
json: 'javascript',
return a = r2.done, r2;
wikitext: 'mediawiki',
}, e: function(r2) {
};
u = true, o = r2;
const MODE_LIST = USING_LOCAL
}, f: function() {
? {
try {
lib: 'ext.CodeMirror.lib',
a || null == t.return || t.return();
css: 'ext.CodeMirror.lib.mode.css',
} finally {
javascript: 'ext.CodeMirror.lib.mode.javascript',
if (u) throw o;
lua: `${CM_CDN}/mode/lua/lua.min.js`,
}
mediawiki: EXPIRED ? 'ext.CodeMirror.data' : [],
} };
htmlmixed: 'ext.CodeMirror.lib.mode.htmlmixed',
}
xml: [],
function _unsupportedIterableToArray(r, a) {
}
if (r) {
: {
if ("string" == typeof r) return _arrayLikeToArray(r, a);
lib: `${CM_CDN}/lib/codemirror.min.js`,
var t = {}.toString.call(r).slice(8, -1);
css: `${CM_CDN}/mode/css/css.min.js`,
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;
javascript: `${CM_CDN}/mode/javascript/javascript.min.js`,
}
lua: `${CM_CDN}/mode/lua/lua.min.js`,
}
mediawiki: [],
function _arrayLikeToArray(r, a) {
htmlmixed: `${CM_CDN}/mode/htmlmixed/htmlmixed.min.js`,
(null == a || a > r.length) && (a = r.length);
xml: `${CM_CDN}/mode/xml/xml.min.js`,
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
};
return n;
const ADDON_LIST = {
}
searchcursor: `${CM_CDN}/addon/search/searchcursor.min.js`,
function asyncGeneratorStep(n, t, e, r, o, a, c) {
search: `${REPO_CDN}/search.min.js`,
try {
markSelection: `${CM_CDN}/addon/selection/mark-selection.min.js`,
var i = n[a](c), u = i.value;
activeLine: `${CM_CDN}/addon/selection/active-line.min.js`,
} catch (n2) {
trailingspace: `${CM_CDN}/addon/edit/trailingspace.min.js`,
return void e(n2);
matchBrackets: `${CM_CDN}/addon/edit/matchbrackets.min.js`,
}
closeBrackets: `${CM_CDN}/addon/edit/closebrackets.min.js`,
i.done ? t(u) : Promise.resolve(u).then(r, o);
matchTags: `${REPO_CDN}/matchtags.min.js`,
}
fold: `${REPO_CDN}/fold.min.js`,
function _asyncToGenerator(n) {
wikiEditor: 'ext.wikiEditor',
return function() {
contextmenu: 'mediawiki.Title',
var t = this, e = arguments;
lint: `${CM_CDN}/addon/lint/lint.min.js`,
return new Promise(function(r, o) {
annotateScrollbar: `${CM_CDN}/addon/scroll/annotatescrollbar.min.js`,
var a = n.apply(t, e);
parser: `${PARSER_CDN}/extensions/base.min.js`,
function _next(n2) {
lintWikitext: `${REPO_CDN}/lint.min.js`,
asyncGeneratorStep(a, r, o, _next, _throw, "next", n2);
};
}
const /** @type {addon[]} */ options = [
function _throw(n2) {
{
asyncGeneratorStep(a, r, o, _next, _throw, "throw", n2);
option: 'styleSelectedText',
}
addon: 'search',
_next(void 0);
download: 'markSelection',
});
only: true,
};
/** @implements */ complex: () => !addons.has('wikiEditor'),
}
},
var __getOwnPropNames = Object.getOwnPropertyNames;
{option: 'styleActiveLine', addon: 'activeLine'},
var __esm = (fn, res) => function __init() {
{option: 'showTrailingSpace', addon: 'trailingspace'},
return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
{
};
option: 'matchBrackets',
//! src/Wikiplus-highlight/modules/highlight.ts
/** @implements */ complex: (mode, json) =>
var highlight_exports = {};
mode === 'mediawiki' || json ? {bracketRegex: /[{}[\]]/u} : true,
var import_ext_gadget2;
},
var init_highlight = __esm({
{
"src/Wikiplus-highlight/modules/highlight.ts"() {
option: 'autoCloseBrackets',
"use strict";
addon: 'closeBrackets',
import_ext_gadget2 = require("ext.gadget.Util");
/** @implements */ complex: (mode, json) => (mode === 'mediawiki' || json ? '()[]{}""' : true),
/**
},
* @name Wikiplus-highlight Wikiplus编辑器的CodeMirror语法高亮扩展
{option: 'matchTags', addon: ['matchTags', 'fold'], modes: new Set(['mediawiki', 'widget'])},
* @author Bhsd <https://github.com/bhsd-harry>
{option: 'fold', modes: new Set(['mediawiki', 'widget'])},
* @license GPL-3.0
];
*/
const defaultAddons = ['search'];
((_window) => {
const defaultIndent = 4;
const {
const /** @type {Set<string>} */ addons = new Set(storage.getObject('Wikiplus-highlight-addons') || defaultAddons);
libs
let /** @type {number} */ indent = storage.getObject('Wikiplus-highlight-indent') || defaultIndent;
} = mw, {
/** @type {Record<string, string>} */
wphl
const entity = {'"': 'quot', "'": 'apos', '<': 'lt', '>': 'gt', '&': 'amp', ' ': 'nbsp'};
} = libs;
const /** @type {(func: (str: string) => string) => (doc: CodeMirror.Editor) => void} */
if (wphl !== null && wphl !== void 0 && wphl.version) {
convert = (func) => (doc) => {
return;
doc.replaceSelections(
}
doc.getSelections().map((selection) => selection.split('\n').map(func).join('\n')),
const version = "3.0.7";
'around'
libs["wphl"] = {
);
version,
};
cmVersion: "2.9",
const escapeHTML = convert((str) =>
...wphl
[...str]
};
.map((c) => {
const CDN = "//testingcf.jsdelivr.net", MW_CDN = "npm/@bhsd/codemirror-mediawiki@".concat(libs["wphl"].cmVersion || "latest", "/dist/mw.min.js"), REPO_CDN = "npm/wikiplus-highlight";
if (c in entity) {
(_window = window).CodeMirror6 || (_window.CodeMirror6 = new Promise((resolve) => {
return `&${entity[c]};`;
const script = document.createElement("script");
}
script.addEventListener("load", () => {
const code = c.codePointAt();
resolve(CodeMirror6);
return code < 256 ? `&#${code};` : `&#x${code.toString(16)};`;
});
})
script.type = "module";
.join('')
script.src = "".concat(CDN, "/").concat(MW_CDN);
);
document.head.append(script);
const escapeURI = convert((str) => {
}));
if (str.includes('%')) {
const {
try {
wgPageName: page,
return decodeURIComponent(str);
wgNamespaceNumber: ns,
} catch {}
wgPageContentModel: contentmodel
}
} = mw.config.get();
return encodeURIComponent(str);
const CONTENTMODELS = {
});
"sanitized-css": "css",
const escapeHash = convert((str) => {
wikitext: "mediawiki"
try {
}, EXTS = {
return decodeURIComponent(str.replace(/\.([\da-f]{2})/giu, '%$1'));
css: "css",
} catch {
js: "javascript",
return str;
json: "json"
}
}, NAMESPACES = {
});
828: "lua",
const /** @type {(cm: typeof CodeMirror) => boolean} */ isPc = ({keyMap}) => keyMap.default === keyMap.pcDefault;
274: "html"
const /** @type {(cm: typeof CodeMirror) => Record<string, (doc: CodeMirror.Editor) => void} */ extraKeys = (
};
CM
const getObject = (key) => {
) => {
return JSON.parse(String(localStorage.getItem(key)));
const ctrl = isPc(CM) ? 'Ctrl' : 'Cmd';
};
return {[`${ctrl}-/`]: escapeHTML, [`${ctrl}-\\`]: escapeURI, [`Shift-${ctrl}-\\`]: escapeHash};
const getPageMode = /* @__PURE__ */ function() {
};
var _ref = _asyncToGenerator(function* (value) {
/**
if (typeof _WikiplusPages === "object") {
* contextMenu插件
const pages = Object.values(_WikiplusPages).filter(({
*
sectionCache
* @param {CodeMirror.Editor} doc CodeMirror编辑区
}) => {
* @param {string} mode 高亮模式
return Object.values(sectionCache).includes(value);
*/
});
const handleContextMenu = (doc, mode) => {
if (pages.some(({
if ((mode !== 'mediawiki' && mode !== 'widget') || !addons.has('contextmenu')) {
title
return;
}) => {
}
return !title.endsWith("/doc");
const $wrapper = $(doc.getWrapperElement()).addClass('CodeMirror-contextmenu');
})) {
const {
yield mw.loader.using("mediawiki.Title");
functionSynonyms: [synonyms],
}
} = mw.config.get('extCodeMirrorConfig') || {
const modes = (0, import_ext_gadget2.uniqueArray)(
functionSynonyms: [{invoke: 'invoke', 调用: 'invoke', widget: 'widget', 小工具: 'widget'}],
// Replace `new Set()` to avoid polyfilling core-js
};
pages.map(({
/**
title
* 生成别名映射表
}) => {
*
var _t$getExtension;
* @param {string} str 别名
if (title.endsWith("/doc")) {
*/
return "template";
const getSysnonyms = (str) =>
}
new Set(
const t = new mw.Title(title), namespace = t.getNamespaceId();
Object.keys(synonyms)
if (namespace % 2) {
.filter((key) => synonyms[key] === str)
return "mediawiki";
.map((key) => (key.startsWith('#') ? key : `#${key}`))
}
);
const mode = EXTS[((_t$getExtension = t.getExtension()) === null || _t$getExtension === void 0 ? void 0 : _t$getExtension.toLowerCase()) || ""] || NAMESPACES[namespace];
const invoke = getSysnonyms('invoke');
if (mode) {
const widget = getSysnonyms('widget');
return mode === "javascript" && (namespace === 8 || namespace === 2300) ? "gadget" : mode;
$wrapper.on('contextmenu', ({pageX, pageY}) => {
}
const pos = doc.coordsChar({left: pageX, top: pageY});
return namespace === 10 || namespace === 2 ? "template" : "mediawiki";
const {line, ch} = pos;
})
const curType = doc.getTokenTypeAt(pos);
);
if (!/\bmw-(?:template-name|parserfunction)\b/u.test(curType)) {
if (modes.length === 1) {
return undefined;
const [mode] = modes;
}
if (mode === "gadget") {
const tokens = doc.getLineTokens(line);
return ["javascript", 8];
for (let i = tokens.length - 1; i > 0; i--) {
}
const {type, end, string} = tokens[i];
return mode === "template" ? ["mediawiki", 10] : [mode];
if (tokens[i - 1].type === type) {
} else if (modes.length === 2) {
tokens[i - 1].end = end;
if (modes.includes("javascript") && modes.includes("gadget")) {
tokens[i - 1].string += string;
return ["javascript"];
tokens.splice(i, 1);
} else if (modes.includes("mediawiki") && modes.includes("template")) {
}
return ["mediawiki"];
}
}
const index = tokens.findIndex(({start, end}) => start < ch && end >= ch);
}
const text = tokens[index].string
}
.replace(/\u200E/gu, '')
if (ns !== 274 && contentmodel !== "Scribunto" || page.endsWith("/doc")) {
.replace(/_/gu, ' ')
return [CONTENTMODELS[contentmodel] || contentmodel, contentmodel === "javascript" ? ns : void 0];
.trim();
}
if (/\bmw-template-name\b/u.test(curType)) {
yield mw.loader.using("oojs-ui-windows");
const title = new mw.Title(text);
if (yield OO.ui.confirm(mw.msg("cm-mw-contentmodel"), {
if (title.namespace !== 0 || text.startsWith(':')) {
actions: [{
open(title.getUrl(), '_blank');
label: ns === 274 ? "Widget" : "Lua"
} else {
}, {
open(mw.util.getUrl(`Template:${text}`), '_blank');
label: "Wikitext",
}
action: "accept"
return false;
}]
} else if (
})) {
index < 2 ||
return ["mediawiki"];
!/\bmw-parserfunction-delimiter\b/u.test(tokens[index - 1].type) ||
}
!/\bmw-parserfunction-name\b/u.test(tokens[index - 2].type)
return [ns === 274 ? "html" : "lua"];
) {
});
return undefined;
return function getPageMode2(_x) {
}
return _ref.apply(this, arguments);
const parserFunction = tokens[index - 2].string.trim().toLowerCase();
};
if (invoke.has(parserFunction)) {
}();
open(mw.util.getUrl(`Module:${text}`), '_blank');
const renderEditor = /* @__PURE__ */ function() {
} else if (widget.has(parserFunction)) {
var _ref2 = _asyncToGenerator(function* ($target, setting) {
open(mw.util.getUrl(`Widget:${text}`, {action: 'edit'}), '_blank');
const cm = yield (yield CodeMirror6).fromTextArea($target[0], ...setting ? ["json"] : yield getPageMode($target.val()));
} else {
if (cm.view) {
return undefined;
cm.view.dom.id = "Wikiplus-CodeMirror";
}
}
return false;
document.querySelector("#Wikiplus-Quickedit-Jump > a").href = "#Wikiplus-CodeMirror";
});
if (!setting) {
};
const settings = getObject("Wikiplus_Settings"), escToExitQuickEdit = settings && (settings["esc_to_exit_quickedit"] || settings["escToExitQuickEdit"]), submit = (
const /** @type {Record<string, string>} */ i18n = storage.getObject('Wikiplus-highlight-i18n') || {};
/** 提交编辑 @return true */
let /** @type {() => JQuery<HTMLElement>} */ welcome;
() => {
if (!i18n['wphl-version']) {
document.querySelector("#Wikiplus-Quickedit-Submit").dispatchEvent(new MouseEvent("click"));
// 首次安装
return true;
welcome = notify('welcome');
}
} else if (cmpVersion(i18n['wphl-version'], version)) {
), submitMinor = (
// 更新版本
/** 提交小编辑 */
welcome = notify(`welcome-${newAddon ? 'new-addon' : 'upgrade'}`, version, newAddon);
() => {
}
document.querySelector("#Wikiplus-Quickedit-MinorEdit").checked = true;
const /** @type {Record<string, string>} */ i18nLanguages = {
return submit();
zh: 'zh-hans',
}
'zh-hans': 'zh-hans',
), escapeEdit = (
'zh-cn': 'zh-hans',
/** 按下Esc键退出编辑 */
'zh-my': 'zh-hans',
() => {
'zh-sg': 'zh-hans',
document.querySelector("#Wikiplus-Quickedit-Back").dispatchEvent(new MouseEvent("click"));
'zh-hant': 'zh-hant',
return true;
'zh-tw': 'zh-hant',
}
'zh-hk': 'zh-hant',
);
'zh-mo': 'zh-hant',
cm.extraKeys([{
ka: 'ka',
key: "Mod-S",
};
run: submit
const i18nLang = i18nLanguages[userLang] || 'en';
}, {
const I18N_CDN = `${CDN}/${REPO_CDN}/i18n/${i18nLang}.json`;
key: "Shift-Mod-S",
const isLatest = i18n['wphl-version'] === majorVersion;
run: submitMinor
/** 加载 I18N */
}, ...escToExitQuickEdit === true || escToExitQuickEdit === "true" ? [{
const setI18N = async () => {
key: "Esc",
if (!isLatest || i18n['wphl-lang'] !== i18nLang) {
run: escapeEdit
Object.assign(
}] : []]);
i18n,
}
await $.ajax(`${I18N_CDN}`, {
const oldKey = "Wikiplus-highlight-addons", oldPrefs = getObject(oldKey), mapping = {
dataType: 'json',
activeLine: "highlightActiveLine",
cache: true,
trailingspace: "highlightTrailingWhitespace",
})
matchBrackets: "bracketMatching",
);
closeBrackets: "closeBrackets",
storage.setObject('Wikiplus-highlight-i18n', i18n);
matchTags: "tagMatching",
}
fold: "codeFolding",
mw.messages.set(i18n);
wikiEditor: "wikiEditor",
};
escape: "escape",
const i18nPromise = Promise.all([
contextmenu: "openLinks",
// 提前加载I18N
lint: "lint"
mw.loader.using('mediawiki.util'),
};
setI18N(),
localStorage.removeItem(oldKey);
]);
if (oldPrefs) {
/**
const obj = {};
* 下载MW扩展脚本
var _iterator = _createForOfIteratorHelper(oldPrefs), _step;
*
try {
* @param {string[]} exts CodeMirror扩展模块
for (_iterator.s(); !(_step = _iterator.n()).done; ) {
*/
const k = _step.value;
const getInternalScript = (exts) => (exts.length > 0 ? mw.loader.using(exts) : Promise.resolve());
if (k in mapping) {
/**
obj[mapping[k]] = true;
* 下载外部脚本
}
*
}
* @param {string[]} urls CodeMirror脚本网址
} catch (err) {
*/
_iterator.e(err);
const getExternalScript = (urls) =>
} finally {
urls.length > 0
_iterator.f();
? $.ajax(`${CDN}/${urls.length > 1 ? 'combine/' : ''}${urls.join()}`, {dataType: 'script', cache: true})
}
: Promise.resolve();
cm.prefer(obj);
/**
}
* 下载脚本
});
*
return function renderEditor2(_x2, _x3) {
* @param {string[]} urls 脚本路径
return _ref2.apply(this, arguments);
* @param {boolean|undefined} local 是否先从本地下载
};
*/
}();
const getScript = async (urls, local) => {
const internal = urls.filter((url) => !url.includes('/'));
const observer = new MutationObserver((records) => {
const $editArea = $(records.flatMap(({
const external = urls.filter((url) => url.includes('/'));
addedNodes
if (local === true) {
}) => {
await getInternalScript(internal);
return [...addedNodes];
return getExternalScript(external);
})).find("#Wikiplus-Quickedit, #Wikiplus-Setting-Input");
} else if (local === false) {
if ($editArea.length > 0) {
await getExternalScript(external);
void renderEditor($editArea, $editArea.attr("id") === "Wikiplus-Setting-Input");
return getInternalScript(internal);
}
}
});
return Promise.all([getInternalScript(internal), getExternalScript(external)]);
observer.observe(document.body, {
};
childList: true
// 以下进入CodeMirror相关内容
});
let /** @type {CodeMirror.EditorFromTextArea} */ cm;
mw.loader.load("".concat(CDN, "/").concat(REPO_CDN, "@").concat(version, "/styles.min.css"), "text/css");
/**
})();
* 生成需要的插件列表
*
}
});
* @param {typeof CodeMirror} CM CodeMirror
//! src/Wikiplus-highlight/modules/api.ts
* @param {boolean} other 是否用于Wikiplus以外的textarea
var import_ext_gadget = require("ext.gadget.Util");
*/
var api = (0, import_ext_gadget.initMwApi)("Wikiplus-highlight/2.0");
const getAddonScript = (CM, other = false) => {
//! src/Wikiplus-highlight/modules/checkDependencies.ts
const /** @type {string[]} */ addonScript = [];
var checkDependencies = /* @__PURE__ */ function() {
for (const {option, addon = option, download = Array.isArray(addon) ? option : addon, only} of options) {
var _ref3 = _asyncToGenerator(function* () {
if (!(only && other) && !(option in CM.optionHandlers) && intersect(addon, addons)) {
if (!mw.user.options.get("gadget-Wikiplus")) {
addonScript.push(ADDON_LIST[download]);
void api.postWithEditToken({
}
action: "options",
}
change: "gadget-Wikiplus=1"
return addonScript;
};
});
yield mw.loader.using("ext.gadget.Wikiplus");
/**
}
* 交集
});
*
return function checkDependencies2() {
* @param {T[]|T} arr 集合1(可重)
return _ref3.apply(this, arguments);
* @param {Set<T>} set 集合2
};
* @template T
}();
*/
//! src/Wikiplus-highlight/Wikiplus-highlight.ts
const intersect = (arr, set) => (Array.isArray(arr) ? arr.some((ele) => set.has(ele)) : set.has(arr));
(function() {
/**
var _WikiplusHighlight = _asyncToGenerator(function* () {
* 根据文本的高亮模式加载依赖项
void checkDependencies();
*
const {
* @param {string} type 高亮模式
wgAction,
*/
wgIsArticle
const initMode = (type) => {
} = mw.config.get();
let /** @type {string[]} */ scripts = [];
if (wgAction !== "view" || !wgIsArticle) {
const loaded = typeof window.CodeMirror === 'function';
return;
/**
}
* 代替`CodeMirror`的局部变量
const {
*
"visualeditor-enable": isVeEnable
* @type {typeof CodeMirror}
} = mw.user.options.get();
*/
if (isVeEnable) {
const CM = loaded
yield mw.loader.using("ext.visualEditor.core");
? window.CodeMirror
}
: {modes: {}, prototype: {}, commands: {}, optionHandlers: {}, helpers: {}};
if (!("ontouchstart" in document)) {
// lib
yield Promise.resolve().then(() => (init_highlight(), highlight_exports));
if (!loaded) {
}
scripts.push(MODE_LIST.lib);
});
if (!USING_LOCAL) {
function WikiplusHighlight() {
mw.loader.load(`${CDN}/${CM_CDN}/lib/codemirror.min.css`, 'text/css');
return _WikiplusHighlight.apply(this, arguments);
}
}
}
return WikiplusHighlight;
// modes
})()();
if (type === 'mediawiki' && SITE_SETTINGS.config && SITE_SETTINGS.config.tags.html) {
// NamespaceHTML扩展自由度过高,所以这里一律当作允许<html>标签
type = 'html';
}
if ((type === 'mediawiki' || type === 'widget') && !CM.modes.mediawiki) {
// 总是外部样式表和外部脚本
mw.loader.load(`${CDN}/${MW_CDN}/mediawiki.min.css`, 'text/css');
scripts.push(`${MW_CDN}/mediawiki.min.js`);
}
if (type === 'widget' || type === 'html') {
for (const lang of ['css', 'javascript', 'mediawiki', 'htmlmixed', 'xml']) {
if (!CM.modes[lang]) {
scripts = scripts.concat(MODE_LIST[lang]);
}
}
} else {
scripts = scripts.concat(MODE_LIST[type]);
}
// addons
if (!CM.prototype.getSearchCursor && addons.has('search') && !addons.has('wikiEditor')) {
scripts.push(ADDON_LIST.searchcursor);
}
if (!CM.prototype.annotateScrollbar && type === 'mediawiki' && addons.has('lint')) {
scripts.push(ADDON_LIST.annotateScrollbar);
}
if (!CM.commands.find && addons.has('search') && !addons.has('wikiEditor')) {
scripts.push(ADDON_LIST.search);
}
if (!window.wikiparse && type === 'mediawiki' && addons.has('lint')) {
scripts.push(ADDON_LIST.parser);
}
if (!CM.optionHandlers.lint && type === 'mediawiki' && addons.has('lint')) {
mw.loader.load(`${CDN}/${CM_CDN}/addon/lint/lint.min.css`, 'text/css');
scripts.push(ADDON_LIST.lint);
}
if (!(CM.helpers.lint && CM.helpers.lint.mediawiki) && type === 'mediawiki' && addons.has('lint')) {
scripts.push(ADDON_LIST.lintWikitext);
}
if (addons.has('wikiEditor')) {
const state = mw.loader.getState('ext.wikiEditor');
if (!state) {
addons.delete('wikiEditor');
} else if (state !== 'ready') {
scripts.push(ADDON_LIST.wikiEditor);
}
}
if (mw.loader.getState('mediawiki.Title') !== 'ready' && addons.has('contextmenu')) {
scripts.push(ADDON_LIST.contextmenu);
}
scripts.push(...getAddonScript(CM));
return getScript(scripts, loaded ? undefined : USING_LOCAL);
};
/**
* 更新缓存的设置数据
*
* @param {mwConfig} config wikitext设置
*/
const updateCachedConfig = (config) => {
ALL_SETTINGS_CACHE[SITE_ID] = {config, time: Date.now()};
storage.setObject('InPageEditMwConfig', ALL_SETTINGS_CACHE);
};
/**
* 展开别名列表
*
* @param {{aliases: string[], name: string}[]} words 原名
*/
const getAliases = (words) => words.flatMap(({aliases, name}) => aliases.map((alias) => ({alias, name})));
/**
* 将别名信息转换为CodeMirror接受的设置
*
* @param {{alias: string, name: string}[]} aliases 别名
* @return {Record<string, string>}
*/
const getConfig = (aliases) => Object.fromEntries(aliases.map(({alias, name}) => [alias.replace(/:$/u, ''), name]));
/**
* 高亮扩展标签内部
*
* @param {mwConfig} config 设置
*/
const setPlainMode = (config) => {
const tags = ['indicator', 'poem', 'ref', 'tabs', 'tab', 'poll'];
for (const tag of tags) {
if (config.tags[tag]) {
config.tagModes[tag] = 'text/mediawiki';
}
}
};
/**
* 加载CodeMirror的mediawiki模块需要的设置数据
*
* @param {string} type 高亮模式
* @param {Promise<void>} initModePromise 使用本地CodeMirror扩展时大部分数据来自ext.CodeMirror.data模块
*/
const getMwConfig = async (type, initModePromise) => {
if (type !== 'mediawiki' && type !== 'widget') {
return undefined;
}
if (USING_LOCAL && EXPIRED) {
// 只在localStorage过期时才会重新加载ext.CodeMirror.data
await initModePromise;
}
let config = mw.config.get('extCodeMirrorConfig');
if (!config && !EXPIRED && isLatest) {
({config} = SITE_SETTINGS);
setPlainMode(config);
mw.config.set('extCodeMirrorConfig', config);
}
const isIPE = config && Object.values(config.functionSynonyms[0]).includes(true);
// 情形1:config已更新,可能来自localStorage
if (config && config.redirect && config.img && config.variants && !isIPE) {
return config;
}
// 以下情形均需要发送API请求
// 情形2:localStorage未过期但不包含新设置
// 情形3:新加载的 ext.CodeMirror.data
// 情形4:`config === null`
const {
query: {
general: {variants},
magicwords,
extensiontags,
functionhooks,
variables,
},
} = await new mw.Api({
ajax: {
headers: {
'Api-User-Agent': `Qiuwen/1.1 (Wikiplus-highlight/${version}; ${mw.config.get('wgWikiID')})`,
},
},
}).get({
meta: 'siteinfo',
siprop: `general|magicwords${config && !isIPE ? '' : '|extensiontags|functionhooks|variables'}`,
formatversion: 2,
});
const otherMagicwords = new Set(['msg', 'raw', 'msgnw', 'subst', 'safesubst']);
if (config && !isIPE) {
// 情形2或3
const {
functionSynonyms: [insensitive],
} = config;
if (!insensitive.subst) {
const aliases = getAliases(magicwords.filter(({name}) => otherMagicwords.has(name)));
for (const {alias, name} of aliases) {
insensitive[alias.replace(/:$/u, '')] = name;
}
}
} else {
// 情形4:`config === null`
config = {
tagModes: {
pre: 'mw-tag-pre',
nowiki: 'mw-tag-nowiki',
ref: 'text/mediawiki',
},
tags: Object.fromEntries(extensiontags.map((tag) => [tag.slice(1, -1), true])),
urlProtocols: mw.config.get('wgUrlProtocols'),
};
const realMagicwords = new Set([...functionhooks, ...variables, ...otherMagicwords]);
const allMagicwords = magicwords.filter(
({name, aliases}) => aliases.some((alias) => /^__.+__$/u.test(alias)) || realMagicwords.has(name)
);
const sensitive = getAliases(allMagicwords.filter((word) => word['case-sensitive']));
const insensitive = getAliases(allMagicwords.filter((word) => !word['case-sensitive'])).map(
({alias, name}) => ({alias: alias.toLowerCase(), name})
);
config.doubleUnderscore = [
getConfig(insensitive.filter(({alias}) => /^__.+__$/u.test(alias))),
getConfig(sensitive.filter(({alias}) => /^__.+__$/u.test(alias))),
];
config.functionSynonyms = [
getConfig(insensitive.filter(({alias}) => !/^__.+__|^#$/u.test(alias))),
getConfig(sensitive.filter(({alias}) => !/^__.+__|^#$/u.test(alias))),
];
}
config.redirect = magicwords.find(({name}) => name === 'redirect').aliases;
config.img = getConfig(getAliases(magicwords.filter(({name}) => name.startsWith('img_'))));
config.variants = variants ? variants.map(({code}) => code) : [];
setPlainMode(config);
mw.config.set('extCodeMirrorConfig', config);
updateCachedConfig(config);
return config;
};
/** 检查页面语言类型 */
const getPageMode = async () => {
if (page.endsWith('/doc')) {
return 'mediawiki';
} else if (ns !== 274 && ns !== 828) {
return CONTENTMODEL[contentmodel];
}
const pageMode = ns === 274 ? 'Widget' : 'Lua';
await mw.loader.using(['oojs-ui-windows', 'oojs-ui.styles.icons-content']);
const bool = await OO.ui.confirm(msg('contentmodel'), {
actions: [{label: pageMode}, {label: 'Wikitext', action: 'accept'}],
});
return bool ? 'mediawiki' : pageMode.toLowerCase();
};
/**
* jQuery.textSelection overrides for CodeMirror.
* See jQuery.textSelection.js for method documentation
*/
const cmTextSelection = {
/** @override */ getContents() {
return cm.getValue();
},
/** @override */ setContents(content) {
cm.setValue(content);
return this;
},
/** @override */ getSelection() {
return cm.getSelection();
},
/** @override */ setSelection(option) {
cm.setSelection(cm.posFromIndex(option.start), 'end' in option ? cm.posFromIndex(option.end) : undefined);
cm.focus();
return this;
},
/** @override */ replaceSelection(value) {
cm.replaceSelection(value);
return this;
},
/** @override */ getCaretPosition(option) {
const caretPos = cm.indexFromPos(cm.getCursor('from'));
const endPos = cm.indexFromPos(cm.getCursor('to'));
return option.startAndEnd ? [caretPos, endPos] : caretPos;
},
/** @override */ scrollToCaretPosition() {
cm.scrollIntoView();
return this;
},
};


/**
* 渲染编辑器
*
* @param {JQuery<HTMLTextAreaElement>} $target 目标编辑框
* @param {boolean} setting 是否是Wikiplus设置(使用json语法)
*/
const renderEditor = async ($target, setting) => {
const mode = setting ? 'javascript' : await getPageMode();
const initModePromise = initMode(mode);
const [mwConfig] = await Promise.all([getMwConfig(mode, initModePromise), initModePromise]);
if (!setting && addons.has('wikiEditor')) {
try {
if (typeof mw.addWikiEditor === 'function') {
mw.addWikiEditor($target);
} else {
const {
wikiEditor: {
modules: {
dialogs: {config},
},
},
} = $;
$target.wikiEditor('addModule', {
...$.wikiEditor.modules.toolbar.config.getDefaultConfig(),
...config.getDefaultConfig(),
});
config.replaceIcons($target);
}
} catch (error) {
addons.delete('wikiEditor');
mw.notify('WikiEditor工具栏加载失败。', {type: 'error', tag: 'wikiplus-highlight'});
console.error(error);
}
}
if (mode === 'mediawiki' && mwConfig.tags.html) {
mwConfig.tagModes.html = 'htmlmixed';
await initMode('html'); // 若已经缓存过`mwConfig`,这一步什么都不会发生
} else if (mode === 'widget' && !CodeMirror.mimeModes.widget) {
// 到这里CodeMirror已确定加载完毕
CodeMirror.defineMIME('widget', {name: 'htmlmixed', tags: {noinclude: [[null, null, 'mediawiki']]}});
}
// 储存初始高度
const height = $target.height();
if (cm) {
cm.toTextArea();
}
const json = setting || contentmodel === 'json';
cm = CodeMirror.fromTextArea(
$target[0],
$.extend(
{
inputStyle: 'contenteditable',
lineNumbers: !/Android\b/u.test(navigator.userAgent),
lineWrapping: true,
mode,
mwConfig,
json,
},
Object.fromEntries(
options.map(({option, addon = option, modes, complex = (mod) => !modes || modes.has(mod)}) => {
const mainAddon = Array.isArray(addon) ? addon[0] : addon;
return [option, addons.has(mainAddon) && complex(mode, json)];
})
),
mode === 'mediawiki'
? {
extraKeys: addons.has('escape') && extraKeys(CodeMirror),
}
: {
indentUnit: addons.has('indentWithSpace') ? indent : defaultIndent,
indentWithTabs: !addons.has('indentWithSpace'),
}
)
);
cm.setSize(null, height);
cm.getWrapperElement().id = 'Wikiplus-CodeMirror';
if ($.fn.textSelection) {
$target.textSelection('register', cmTextSelection);
}
const ctrl = isPc(CodeMirror) ? 'Ctrl' : 'Cmd';
if (addons.has('wikiEditor')) {
const context = $target.data('wikiEditorContext');
cm.addKeyMap({
/** 替代CodeMirror的搜索功能 */ [`${ctrl}-F`]() {
$.wikiEditor.modules.dialogs.api.openDialog(context, 'search-and-replace');
},
});
}
handleContextMenu(cm, mode);
$('#Wikiplus-Quickedit-Jump').children('a').attr('href', '#Wikiplus-CodeMirror');
if (!setting) {
// 普通Wikiplus编辑区
const settings = storage.getObject('Wikiplus_Settings');
const escToExitQuickEdit = (settings && settings.esc_to_exit_quickedit) || settings.escToExitQuickEdit;
const submit = /** 提交编辑 */ () => {
$('#Wikiplus-Quickedit-Submit').triggerHandler('click');
};
const submitMinor = /** 提交小编辑 */ () => {
$('#Wikiplus-Quickedit-MinorEdit').trigger('click');
$('#Wikiplus-Quickedit-Submit').triggerHandler('click');
};
cm.addKeyMap(
$.extend(
{[`${ctrl}-S`]: submit, [`Shift-${ctrl}-S`]: submitMinor},
escToExitQuickEdit === true || escToExitQuickEdit === 'true'
? {
/** 按下Esc键退出编辑 */ Esc() {
$('#Wikiplus-Quickedit-Back').triggerHandler('click');
},
}
: {}
)
);
}
cm.refresh();
mw.hook('wiki-codemirror').fire(cm);
};
const {body} = document;
// 监视 Wikiplus 编辑框
const observer = new MutationObserver((records) => {
const $editArea = $(records.flatMap(({addedNodes}) => [...addedNodes])).find(
'#Wikiplus-Quickedit, #Wikiplus-Setting-Input'
);
if ($editArea.length > 0) {
renderEditor($editArea, $editArea.attr('id') === 'Wikiplus-Setting-Input');
}
});
observer.observe(body, {childList: true});
$(body).on(
'keydown.wphl',
'.ui-dialog',
/** @this {HTMLBodyElement} */
function (e) {
if (e.key === 'Escape') {
/** @type {{$textarea: JQuery<HTMLTextAreaElement>}} */
const context = $(this).children('.ui-dialog-content').data('context');
if (context && context.$textarea && context.$textarea.attr('id') === 'Wikiplus-Quickedit') {
e.stopPropagation();
}
}
}
);
/**
* 是否是Wikiplus编辑区
*
* @param {HTMLTextAreaElement} elem textarea元素
*/
const isWikiplus = (elem) => elem.id === 'Wikiplus-Quickedit' || elem.id === 'Wikiplus-Setting-Input';
$.valHooks.textarea = {
/** @override */ get(elem) {
return isWikiplus(elem) && cm ? cm.getValue() : elem.value;
},
/** @override */ set(elem, value) {
if (isWikiplus(elem) && cm) {
cm.setValue(value);
} else {
elem.value = value;
}
},
};
await i18nPromise; // 以下内容依赖I18N
// 设置对话框
let /** @type {OOUI.MessageDialog} */ dialog;
let /** @type {OOUI.CheckboxMultiselectInputWidget} */ inputWidget;
let /** @type {OOUI.CheckboxMultioptionWidget} */ searchWidget;
let /** @type {OOUI.CheckboxMultioptionWidget} */ wikiEditorWidget;
let /** @type {OOUI.NumberInputWidget} */ indentWidget;
let /** @type {OOUI.FieldLayout} */ field;
let /** @type {OOUI.FieldLayout} */ indentField;
/**
* 显示/隐藏缩进大小选项
*
* @param {string[]} value 加载的插件
*/
const toggleIndent = (value = [...addons]) => {
indentField.toggle(value.includes('indentWithSpace'));
};
const portletContainer = {
minerva: 'page-actions-overflow',
moeskin: 'ca-more-actions',
};
const $portlet = $(
mw.util.addPortletLink(portletContainer[skin] || 'p-cactions', '#', msg('portlet'), 'wphl-settings')
).on('click', async () => {
if (dialog) {
inputWidget.setValue([...addons]);
indentWidget.setValue(indent);
} else {
await mw.loader.using(['oojs-ui-windows', 'oojs-ui.styles.icons-content']);
dialog = new OO.ui.MessageDialog({id: 'Wikiplus-highlight-dialog'});
const windowManager = new OO.ui.WindowManager();
windowManager.$element.appendTo(body);
windowManager.addWindows([dialog]);
inputWidget = new OO.ui.CheckboxMultiselectInputWidget({
options: [
...options.map(({option, addon = option}) => {
const mainAddon = Array.isArray(addon) ? addon[0] : addon;
return {data: mainAddon, label: htmlMsg(`addon-${mainAddon.toLowerCase()}`)};
}),
...['wikiEditor', 'escape', 'contextmenu', 'lint', 'indentWithSpace', 'otherEditors'].map(
(addon) => ({data: addon, label: htmlMsg(`addon-${addon.toLowerCase()}`)})
),
],
value: [...addons],
}).on('change', toggleIndent);
const {checkboxMultiselectWidget} = inputWidget;
searchWidget = checkboxMultiselectWidget.findItemFromData('search');
wikiEditorWidget = checkboxMultiselectWidget.findItemFromData('wikiEditor');
indentWidget = new OO.ui.NumberInputWidget({min: 0, value: indent});
field = new OO.ui.FieldLayout(inputWidget, {
label: msg('addon-label'),
notices: [msg('addon-notice')],
align: 'top',
});
indentField = new OO.ui.FieldLayout(indentWidget, {label: msg('addon-indent')});
toggleIndent();
Object.assign(mw.libs.wphl, {widget: inputWidget, indentWidget});
}
const wikiplusLoaded = typeof window.Wikiplus === 'object' || typeof window._WikiplusPages === 'object';
searchWidget.setDisabled(!wikiplusLoaded);
wikiEditorWidget.setDisabled(!wikiplusLoaded || !mw.loader.getState('ext.wikiEditor'));
const data = await dialog.open({
title: msg('addon-title'),
message: field.$element.add(indentField.$element).add($('<p>').html(msg('feedback'))),
actions: [
{action: 'reject', label: mw.msg('ooui-dialog-message-reject')},
{action: 'accept', label: mw.msg('ooui-dialog-message-accept'), flags: 'progressive'},
],
size: i18nLang === 'en' || skin === 'minerva' ? 'medium' : 'small',
}).closing;
field.$element.detach();
indentField.$element.detach();
if (typeof data === 'object' && data.action === 'accept') {
const value = inputWidget.getValue();
addons.clear();
for (const addon of value) {
addons.add(addon);
}
indent = Number(indentWidget.getValue());
storage.setObject('Wikiplus-highlight-addons', value);
storage.setObject('Wikiplus-highlight-indent', indent);
}
});
if (skin === 'minerva') {
$portlet.find('.mw-ui-icon').addClass('mw-ui-icon-minerva-settings');
}
// 发送欢迎提示
if (typeof welcome === 'function') {
welcome()
.find('#wphl-settings-notify')
.click((e) => {
e.preventDefault();
$('#wphl-settings').triggerHandler('click');
});
}
/**
* 处理非Wikiplus编辑器
*
* @param {CodeMirror.Editor} doc CodeMirror编辑区
*/
const handleOtherEditors = async (doc) => {
if (!addons.has('otherEditors')) {
return;
}
let mode = doc.getOption('mode');
mode = mode === 'text/mediawiki' ? 'mediawiki' : mode;
const addonScript = getAddonScript(CodeMirror, true);
const json = doc.getOption('json');
const {
prototype,
optionHandlers,
helpers: {lint},
} = CodeMirror;
if (!prototype.annotateScrollbar && mode === 'mediawiki' && addons.has('lint')) {
addonScript.push(ADDON_LIST.annotateScrollbar);
}
if (!window.wikiparse && mode === 'mediawiki' && addons.has('lint')) {
addonScript.push(ADDON_LIST.parser);
}
if (!optionHandlers.lint && mode === 'mediawiki' && addons.has('lint')) {
mw.loader.load(`${CDN}/${CM_CDN}/addon/lint/lint.min.css`, 'text/css');
addonScript.push(ADDON_LIST.lint);
}
if (!(lint && lint.mediawiki) && mode === 'mediawiki' && addons.has('lint')) {
addonScript.push(ADDON_LIST.lintWikitext);
}
await getScript(addonScript);
for (const {
option,
addon = option,
modes,
complex = (/** @type {string} */ mod) => !modes || modes.has(mod),
} of options.filter(({only}) => !only)) {
const mainAddon = Array.isArray(addon) ? addon[0] : addon;
if (doc.getOption(option) === undefined && addons.has(mainAddon)) {
doc.setOption(option, complex(mode, json));
}
}
if (mode === 'mediawiki' && addons.has('escape')) {
doc.addKeyMap(extraKeys(CodeMirror), true);
} else if (mode !== 'mediawiki' && addons.has('indentWithSpace')) {
doc.setOption('indentUnit', indent);
doc.setOption('indentWithTabs', false);
}
handleContextMenu(doc, mode);
};
mw.hook('InPageEdit.quickEdit.codemirror').add(
/** @param {{cm: CodeMirror.Editor}} */ ({cm: doc}) => handleOtherEditors(doc)
);
mw.hook('inspector').add(/** @param {CodeMirror.Editor} doc */ (doc) => handleOtherEditors(doc));
mw.hook('wiki-codemirror').add(
/** @param {CodeMirror.Editor} doc */ (doc) => {
if (!doc.getTextArea || !isWikiplus(doc.getTextArea())) {
handleOtherEditors(doc);
}
}
);
mw.loader.load(`${CDN}/${REPO_CDN}/styles.min.css`, 'text/css');
Object.assign(mw.libs.wphl, {
version,
options,
addons,
i18n,
i18nLang,
storage,
$portlet,
CDN,
PARSER_CDN,
USING_LOCAL,
MODE_LIST,
ADDON_LIST,
msg,
htmlMsg,
escapeHTML,
handleContextMenu,
setI18N,
getAddonScript,
updateCachedConfig,
getMwConfig,
renderEditor,
handleOtherEditors,
isPc,
}); // 加载完毕
})();
})();


/* </nowiki> */
/* </nowiki> */

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/Wikiplus-highlight/modules/highlight.ts", "src/Wikiplus-highlight/modules/api.ts", "src/Wikiplus-highlight/modules/checkDependencies.ts", "src/Wikiplus-highlight/Wikiplus-highlight.ts"],
  "sourcesContent": ["/**\n * @name Wikiplus-highlight Wikiplus编辑器的CodeMirror语法高亮扩展\n * @author Bhsd <https://github.com/bhsd-harry>\n * @license GPL-3.0\n */\n\nimport {uniqueArray} from 'ext.gadget.Util';\n\n((): void => {\n\tconst {libs} = mw,\n\t\t{wphl} = libs;\n\tif (wphl?.version) {\n\t\treturn;\n\t}\n\tconst version = '3.0.7';\n\tlibs['wphl'] = {version, cmVersion: '2.9', ...wphl}; // 开始加载\n\n\t// 路径\n\tconst CDN = '//testingcf.jsdelivr.net',\n\t\tMW_CDN = `npm/@bhsd/codemirror-mediawiki@${libs['wphl'].cmVersion || 'latest'}/dist/mw.min.js`,\n\t\tREPO_CDN = 'npm/wikiplus-highlight';\n\n\twindow.CodeMirror6 ||= new Promise((resolve) => {\n\t\tconst script = document.createElement('script');\n\t\tscript.addEventListener('load', () => {\n\t\t\tresolve(CodeMirror6);\n\t\t});\n\t\tscript.type = 'module';\n\t\tscript.src = `${CDN}/${MW_CDN}`;\n\t\tdocument.head.append(script);\n\t});\n\n\tconst {wgPageName: page, wgNamespaceNumber: ns, wgPageContentModel: contentmodel} = mw.config.get();\n\n\tconst CONTENTMODELS: Record<string, string> = {\n\t\t\t'sanitized-css': 'css',\n\t\t\twikitext: 'mediawiki',\n\t\t},\n\t\tEXTS: Record<string, string> = {\n\t\t\tcss: 'css',\n\t\t\tjs: 'javascript',\n\t\t\tjson: 'json',\n\t\t},\n\t\tNAMESPACES: Record<number, string> = {\n\t\t\t828: 'lua',\n\t\t\t274: 'html',\n\t\t};\n\n\t// eslint-disable-next-line @typescript-eslint/no-explicit-any\n\tconst getObject = (key: string): any => {\n\t\treturn JSON.parse(String(localStorage.getItem(key)));\n\t};\n\n\t/**\n\t * 检查页面语言类型\n\t *\n\t * @param {string} value 页面内容\n\t * @return {Promise}\n\t */\n\tconst getPageMode = async (value: string): Promise<[string, (number | undefined)?]> => {\n\t\tif (typeof _WikiplusPages === 'object') {\n\t\t\tconst pages = Object.values(_WikiplusPages).filter(({sectionCache}) => {\n\t\t\t\treturn Object.values(sectionCache).includes(value);\n\t\t\t});\n\t\t\tif (\n\t\t\t\tpages.some(({title}) => {\n\t\t\t\t\treturn !title.endsWith('/doc');\n\t\t\t\t})\n\t\t\t) {\n\t\t\t\tawait mw.loader.using('mediawiki.Title');\n\t\t\t}\n\t\t\tconst modes = uniqueArray(\n\t\t\t\t// Replace `new Set()` to avoid polyfilling core-js\n\t\t\t\tpages.map(({title}) => {\n\t\t\t\t\tif (title.endsWith('/doc')) {\n\t\t\t\t\t\treturn 'template';\n\t\t\t\t\t}\n\t\t\t\t\tconst t = new mw.Title(title),\n\t\t\t\t\t\tnamespace = t.getNamespaceId();\n\t\t\t\t\tif (namespace % 2) {\n\t\t\t\t\t\treturn 'mediawiki';\n\t\t\t\t\t}\n\t\t\t\t\tconst mode = EXTS[t.getExtension()?.toLowerCase() || ''] || NAMESPACES[namespace];\n\t\t\t\t\tif (mode) {\n\t\t\t\t\t\treturn mode === 'javascript' && (namespace === 8 || namespace === 2300) ? 'gadget' : mode;\n\t\t\t\t\t}\n\t\t\t\t\treturn namespace === 10 || namespace === 2 ? 'template' : 'mediawiki';\n\t\t\t\t})\n\t\t\t);\n\t\t\tif (modes.length === 1) {\n\t\t\t\tconst [mode] = modes;\n\t\t\t\tif (mode === 'gadget') {\n\t\t\t\t\treturn ['javascript', 8];\n\t\t\t\t}\n\t\t\t\treturn mode === 'template' ? ['mediawiki', 10] : [mode!];\n\t\t\t} else if (modes.length === 2) {\n\t\t\t\tif (modes.includes('javascript') && modes.includes('gadget')) {\n\t\t\t\t\treturn ['javascript'];\n\t\t\t\t} else if (modes.includes('mediawiki') && modes.includes('template')) {\n\t\t\t\t\treturn ['mediawiki'];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif ((ns !== 274 && contentmodel !== 'Scribunto') || page.endsWith('/doc')) {\n\t\t\treturn [CONTENTMODELS[contentmodel] || contentmodel, contentmodel === 'javascript' ? ns : undefined];\n\t\t}\n\t\tawait mw.loader.using('oojs-ui-windows');\n\t\tif (\n\t\t\tawait OO.ui.confirm(mw.msg('cm-mw-contentmodel'), {\n\t\t\t\tactions: [{label: ns === 274 ? 'Widget' : 'Lua'}, {label: 'Wikitext', action: 'accept'}],\n\t\t\t})\n\t\t) {\n\t\t\treturn ['mediawiki'];\n\t\t}\n\t\treturn [ns === 274 ? 'html' : 'lua'];\n\t};\n\n\t/**\n\t * 渲染编辑器\n\t *\n\t * @param {JQuery<HTMLTextAreaElement>} $target 目标编辑框\n\t * @param {boolean} setting 是否是Wikiplus设置（使用json语法）\n\t */\n\tconst renderEditor = async ($target: JQuery<HTMLTextAreaElement>, setting: boolean): Promise<void> => {\n\t\tconst cm = await (\n\t\t\tawait CodeMirror6\n\t\t).fromTextArea($target[0]!, ...(setting ? (['json'] as [string]) : await getPageMode($target.val()!)));\n\t\tif (cm.view) {\n\t\t\tcm.view.dom.id = 'Wikiplus-CodeMirror';\n\t\t}\n\n\t\tdocument.querySelector<HTMLAnchorElement>('#Wikiplus-Quickedit-Jump > a')!.href = '#Wikiplus-CodeMirror';\n\n\t\tif (!setting) {\n\t\t\t// 普通Wikiplus编辑区\n\t\t\tconst settings: Record<string, unknown> | null = getObject('Wikiplus_Settings'),\n\t\t\t\tescToExitQuickEdit = settings && (settings['esc_to_exit_quickedit'] || settings['escToExitQuickEdit']),\n\t\t\t\tsubmit = /** 提交编辑 @return true */ (): true => {\n\t\t\t\t\tdocument.querySelector('#Wikiplus-Quickedit-Submit')!.dispatchEvent(new MouseEvent('click'));\n\t\t\t\t\treturn true;\n\t\t\t\t},\n\t\t\t\tsubmitMinor = /** 提交小编辑 */ (): true => {\n\t\t\t\t\tdocument.querySelector<HTMLInputElement>('#Wikiplus-Quickedit-MinorEdit')!.checked = true;\n\t\t\t\t\treturn submit();\n\t\t\t\t},\n\t\t\t\tescapeEdit = /** 按下Esc键退出编辑 */ (): true => {\n\t\t\t\t\tdocument.querySelector('#Wikiplus-Quickedit-Back')!.dispatchEvent(new MouseEvent('click'));\n\t\t\t\t\treturn true;\n\t\t\t\t};\n\t\t\tcm.extraKeys([\n\t\t\t\t{key: 'Mod-S', run: submit},\n\t\t\t\t{key: 'Shift-Mod-S', run: submitMinor},\n\t\t\t\t...(escToExitQuickEdit === true || escToExitQuickEdit === 'true'\n\t\t\t\t\t? [{key: 'Esc', run: escapeEdit}]\n\t\t\t\t\t: []),\n\t\t\t]);\n\t\t}\n\n\t\t/** @todo 以下过渡代码添加于2024-02-07，将于一段时间后弃用 */\n\t\tconst oldKey = 'Wikiplus-highlight-addons',\n\t\t\toldPrefs: string[] | null = getObject(oldKey),\n\t\t\tmapping: Record<string, string> = {\n\t\t\t\tactiveLine: 'highlightActiveLine',\n\t\t\t\ttrailingspace: 'highlightTrailingWhitespace',\n\t\t\t\tmatchBrackets: 'bracketMatching',\n\t\t\t\tcloseBrackets: 'closeBrackets',\n\t\t\t\tmatchTags: 'tagMatching',\n\t\t\t\tfold: 'codeFolding',\n\t\t\t\twikiEditor: 'wikiEditor',\n\t\t\t\tescape: 'escape',\n\t\t\t\tcontextmenu: 'openLinks',\n\t\t\t\tlint: 'lint',\n\t\t\t};\n\t\tlocalStorage.removeItem(oldKey);\n\t\tif (oldPrefs) {\n\t\t\tconst obj: Record<string, true> = {};\n\t\t\tfor (const k of oldPrefs) {\n\t\t\t\tif (k in mapping) {\n\t\t\t\t\tobj[mapping[k]!] = true;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tcm.prefer(obj);\n\t\t}\n\t};\n\n\t// 监视 Wikiplus 编辑框\n\tconst observer = new MutationObserver((records) => {\n\t\tconst $editArea = $(\n\t\t\trecords.flatMap(({addedNodes}) => {\n\t\t\t\treturn [...addedNodes];\n\t\t\t})\n\t\t).find<HTMLTextAreaElement>('#Wikiplus-Quickedit, #Wikiplus-Setting-Input');\n\t\tif ($editArea.length > 0) {\n\t\t\tvoid renderEditor($editArea, $editArea.attr('id') === 'Wikiplus-Setting-Input');\n\t\t}\n\t});\n\tobserver.observe(document.body, {childList: true});\n\n\tmw.loader.load(`${CDN}/${REPO_CDN}@${version}/styles.min.css`, 'text/css');\n})();\n\nexport {};\n", "import {initMwApi} from 'ext.gadget.Util';\n\nconst api: mw.Api = initMwApi('Wikiplus-highlight/2.0');\n\nexport {api};\n", "import {api} from './api';\n\nconst checkDependencies = async () => {\n\tif (!mw.user.options.get('gadget-Wikiplus')) {\n\t\tvoid api.postWithEditToken({\n\t\t\taction: 'options',\n\t\t\tchange: 'gadget-Wikiplus=1',\n\t\t} as ApiOptionsParams);\n\n\t\tawait mw.loader.using('ext.gadget.Wikiplus');\n\t}\n};\n\nexport {checkDependencies};\n", "import './Wikiplus-highlight.less';\nimport {checkDependencies} from './modules/checkDependencies';\n\n(async function WikiplusHighlight() {\n\tvoid checkDependencies();\n\tconst {wgAction, wgIsArticle} = mw.config.get();\n\tif (wgAction !== 'view' || !wgIsArticle) {\n\t\treturn;\n\t}\n\n\tconst {'visualeditor-enable': isVeEnable} = mw.user.options.get() as Record<string, unknown>;\n\n\t/* see <https://github.com/Wikiplus/Wikiplus/issues/65> */\n\tif (isVeEnable) {\n\t\tawait mw.loader.using('ext.visualEditor.core');\n\t}\n\n\tif (!('ontouchstart' in document)) {\n\t\tawait import('./modules/highlight');\n\t}\n})();\n"],
  "mappings": "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",
  "names": ["highlight_exports", "import_ext_gadget2", "init_highlight", "__esm", "require", "_window", "libs", "mw", "wphl", "version", "cmVersion", "CDN", "MW_CDN", "concat", "REPO_CDN", "window", "CodeMirror6", "Promise", "resolve", "script", "document", "createElement", "addEventListener", "type", "src", "head", "append", "wgPageName", "page", "wgNamespaceNumber", "ns", "wgPageContentModel", "contentmodel", "config", "get", "CONTENTMODELS", "wikitext", "EXTS", "css", "js", "json", "NAMESPACES", "getObject", "key", "JSON", "parse", "String", "localStorage", "getItem", "getPageMode", "_ref", "_asyncToGenerator", "value", "_WikiplusPages", "pages", "Object", "values", "filter", "sectionCache", "includes", "some", "title", "endsWith", "loader", "using", "modes", "uniqueArray", "map", "_t$getExtension", "t", "Title", "namespace", "getNamespaceId", "mode", "getExtension", "toLowerCase", "length", "OO", "ui", "confirm", "msg", "actions", "label", "action", "_x", "apply", "arguments", "renderEditor", "_ref2", "$target", "setting", "cm", "fromTextArea", "val", "view", "dom", "id", "querySelector", "href", "settings", "escToExitQuickEdit", "submit", "dispatchEvent", "MouseEvent", "submitMinor", "checked", "escapeEdit", "extraKeys", "run", "oldKey", "oldPrefs", "mapping", "activeLine", "trailingspace", "matchBrackets", "closeBrackets", "matchTags", "fold", "wikiEditor", "escape", "contextmenu", "lint", "removeItem", "obj", "_iterator", "_createForOfIteratorHelper", "_step", "s", "n", "done", "k", "err", "e", "f", "prefer", "_x2", "_x3", "observer", "MutationObserver", "records", "$editArea", "$", "flatMap", "addedNodes", "find", "attr", "observe", "body", "childList", "load", "import_ext_gadget", "api", "initMwApi", "checkDependencies", "_ref3", "user", "options", "postWithEditToken", "change", "wgAction", "wgIsArticle", "isVeEnable", "then", "WikiplusHighlight", "_WikiplusHighlight"]
}


2024年5月31日 (五) 16:02的最新版本

/**
 * SPDX-License-Identifier: CC-BY-SA-4.0
 * _addText: '{{Gadget Header|license=CC-BY-SA-4.0}}'
 *
 * @source {@link https://github.com/TopRealm/YsArchives-Gadgets/tree/master/src/Wikiplus-highlight}
 * @license CC-BY-SA-4.0 {@link https://youshou.wiki/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/Wikiplus-highlight/Wikiplus-highlight.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;
}
function asyncGeneratorStep(n, t, e, r, o, a, c) {
  try {
    var i = n[a](c), u = i.value;
  } catch (n2) {
    return void e(n2);
  }
  i.done ? t(u) : Promise.resolve(u).then(r, o);
}
function _asyncToGenerator(n) {
  return function() {
    var t = this, e = arguments;
    return new Promise(function(r, o) {
      var a = n.apply(t, e);
      function _next(n2) {
        asyncGeneratorStep(a, r, o, _next, _throw, "next", n2);
      }
      function _throw(n2) {
        asyncGeneratorStep(a, r, o, _next, _throw, "throw", n2);
      }
      _next(void 0);
    });
  };
}
var __getOwnPropNames = Object.getOwnPropertyNames;
var __esm = (fn, res) => function __init() {
  return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
};
//! src/Wikiplus-highlight/modules/highlight.ts
var highlight_exports = {};
var import_ext_gadget2;
var init_highlight = __esm({
  "src/Wikiplus-highlight/modules/highlight.ts"() {
    "use strict";
    import_ext_gadget2 = require("ext.gadget.Util");
    /**
     * @name Wikiplus-highlight Wikiplus编辑器的CodeMirror语法高亮扩展
     * @author Bhsd <https://github.com/bhsd-harry>
     * @license GPL-3.0
     */
    ((_window) => {
      const {
        libs
      } = mw, {
        wphl
      } = libs;
      if (wphl !== null && wphl !== void 0 && wphl.version) {
        return;
      }
      const version = "3.0.7";
      libs["wphl"] = {
        version,
        cmVersion: "2.9",
        ...wphl
      };
      const CDN = "//testingcf.jsdelivr.net", MW_CDN = "npm/@bhsd/codemirror-mediawiki@".concat(libs["wphl"].cmVersion || "latest", "/dist/mw.min.js"), REPO_CDN = "npm/wikiplus-highlight";
      (_window = window).CodeMirror6 || (_window.CodeMirror6 = new Promise((resolve) => {
        const script = document.createElement("script");
        script.addEventListener("load", () => {
          resolve(CodeMirror6);
        });
        script.type = "module";
        script.src = "".concat(CDN, "/").concat(MW_CDN);
        document.head.append(script);
      }));
      const {
        wgPageName: page,
        wgNamespaceNumber: ns,
        wgPageContentModel: contentmodel
      } = mw.config.get();
      const CONTENTMODELS = {
        "sanitized-css": "css",
        wikitext: "mediawiki"
      }, EXTS = {
        css: "css",
        js: "javascript",
        json: "json"
      }, NAMESPACES = {
        828: "lua",
        274: "html"
      };
      const getObject = (key) => {
        return JSON.parse(String(localStorage.getItem(key)));
      };
      const getPageMode = /* @__PURE__ */ function() {
        var _ref = _asyncToGenerator(function* (value) {
          if (typeof _WikiplusPages === "object") {
            const pages = Object.values(_WikiplusPages).filter(({
              sectionCache
            }) => {
              return Object.values(sectionCache).includes(value);
            });
            if (pages.some(({
              title
            }) => {
              return !title.endsWith("/doc");
            })) {
              yield mw.loader.using("mediawiki.Title");
            }
            const modes = (0, import_ext_gadget2.uniqueArray)(
              // Replace `new Set()` to avoid polyfilling core-js
              pages.map(({
                title
              }) => {
                var _t$getExtension;
                if (title.endsWith("/doc")) {
                  return "template";
                }
                const t = new mw.Title(title), namespace = t.getNamespaceId();
                if (namespace % 2) {
                  return "mediawiki";
                }
                const mode = EXTS[((_t$getExtension = t.getExtension()) === null || _t$getExtension === void 0 ? void 0 : _t$getExtension.toLowerCase()) || ""] || NAMESPACES[namespace];
                if (mode) {
                  return mode === "javascript" && (namespace === 8 || namespace === 2300) ? "gadget" : mode;
                }
                return namespace === 10 || namespace === 2 ? "template" : "mediawiki";
              })
            );
            if (modes.length === 1) {
              const [mode] = modes;
              if (mode === "gadget") {
                return ["javascript", 8];
              }
              return mode === "template" ? ["mediawiki", 10] : [mode];
            } else if (modes.length === 2) {
              if (modes.includes("javascript") && modes.includes("gadget")) {
                return ["javascript"];
              } else if (modes.includes("mediawiki") && modes.includes("template")) {
                return ["mediawiki"];
              }
            }
          }
          if (ns !== 274 && contentmodel !== "Scribunto" || page.endsWith("/doc")) {
            return [CONTENTMODELS[contentmodel] || contentmodel, contentmodel === "javascript" ? ns : void 0];
          }
          yield mw.loader.using("oojs-ui-windows");
          if (yield OO.ui.confirm(mw.msg("cm-mw-contentmodel"), {
            actions: [{
              label: ns === 274 ? "Widget" : "Lua"
            }, {
              label: "Wikitext",
              action: "accept"
            }]
          })) {
            return ["mediawiki"];
          }
          return [ns === 274 ? "html" : "lua"];
        });
        return function getPageMode2(_x) {
          return _ref.apply(this, arguments);
        };
      }();
      const renderEditor = /* @__PURE__ */ function() {
        var _ref2 = _asyncToGenerator(function* ($target, setting) {
          const cm = yield (yield CodeMirror6).fromTextArea($target[0], ...setting ? ["json"] : yield getPageMode($target.val()));
          if (cm.view) {
            cm.view.dom.id = "Wikiplus-CodeMirror";
          }
          document.querySelector("#Wikiplus-Quickedit-Jump > a").href = "#Wikiplus-CodeMirror";
          if (!setting) {
            const settings = getObject("Wikiplus_Settings"), escToExitQuickEdit = settings && (settings["esc_to_exit_quickedit"] || settings["escToExitQuickEdit"]), submit = (
              /** 提交编辑 @return true */
              () => {
                document.querySelector("#Wikiplus-Quickedit-Submit").dispatchEvent(new MouseEvent("click"));
                return true;
              }
            ), submitMinor = (
              /** 提交小编辑 */
              () => {
                document.querySelector("#Wikiplus-Quickedit-MinorEdit").checked = true;
                return submit();
              }
            ), escapeEdit = (
              /** 按下Esc键退出编辑 */
              () => {
                document.querySelector("#Wikiplus-Quickedit-Back").dispatchEvent(new MouseEvent("click"));
                return true;
              }
            );
            cm.extraKeys([{
              key: "Mod-S",
              run: submit
            }, {
              key: "Shift-Mod-S",
              run: submitMinor
            }, ...escToExitQuickEdit === true || escToExitQuickEdit === "true" ? [{
              key: "Esc",
              run: escapeEdit
            }] : []]);
          }
          const oldKey = "Wikiplus-highlight-addons", oldPrefs = getObject(oldKey), mapping = {
            activeLine: "highlightActiveLine",
            trailingspace: "highlightTrailingWhitespace",
            matchBrackets: "bracketMatching",
            closeBrackets: "closeBrackets",
            matchTags: "tagMatching",
            fold: "codeFolding",
            wikiEditor: "wikiEditor",
            escape: "escape",
            contextmenu: "openLinks",
            lint: "lint"
          };
          localStorage.removeItem(oldKey);
          if (oldPrefs) {
            const obj = {};
            var _iterator = _createForOfIteratorHelper(oldPrefs), _step;
            try {
              for (_iterator.s(); !(_step = _iterator.n()).done; ) {
                const k = _step.value;
                if (k in mapping) {
                  obj[mapping[k]] = true;
                }
              }
            } catch (err) {
              _iterator.e(err);
            } finally {
              _iterator.f();
            }
            cm.prefer(obj);
          }
        });
        return function renderEditor2(_x2, _x3) {
          return _ref2.apply(this, arguments);
        };
      }();
      const observer = new MutationObserver((records) => {
        const $editArea = $(records.flatMap(({
          addedNodes
        }) => {
          return [...addedNodes];
        })).find("#Wikiplus-Quickedit, #Wikiplus-Setting-Input");
        if ($editArea.length > 0) {
          void renderEditor($editArea, $editArea.attr("id") === "Wikiplus-Setting-Input");
        }
      });
      observer.observe(document.body, {
        childList: true
      });
      mw.loader.load("".concat(CDN, "/").concat(REPO_CDN, "@").concat(version, "/styles.min.css"), "text/css");
    })();
  }
});
//! src/Wikiplus-highlight/modules/api.ts
var import_ext_gadget = require("ext.gadget.Util");
var api = (0, import_ext_gadget.initMwApi)("Wikiplus-highlight/2.0");
//! src/Wikiplus-highlight/modules/checkDependencies.ts
var checkDependencies = /* @__PURE__ */ function() {
  var _ref3 = _asyncToGenerator(function* () {
    if (!mw.user.options.get("gadget-Wikiplus")) {
      void api.postWithEditToken({
        action: "options",
        change: "gadget-Wikiplus=1"
      });
      yield mw.loader.using("ext.gadget.Wikiplus");
    }
  });
  return function checkDependencies2() {
    return _ref3.apply(this, arguments);
  };
}();
//! src/Wikiplus-highlight/Wikiplus-highlight.ts
(function() {
  var _WikiplusHighlight = _asyncToGenerator(function* () {
    void checkDependencies();
    const {
      wgAction,
      wgIsArticle
    } = mw.config.get();
    if (wgAction !== "view" || !wgIsArticle) {
      return;
    }
    const {
      "visualeditor-enable": isVeEnable
    } = mw.user.options.get();
    if (isVeEnable) {
      yield mw.loader.using("ext.visualEditor.core");
    }
    if (!("ontouchstart" in document)) {
      yield Promise.resolve().then(() => (init_highlight(), highlight_exports));
    }
  });
  function WikiplusHighlight() {
    return _WikiplusHighlight.apply(this, arguments);
  }
  return WikiplusHighlight;
})()();

})();

/* </nowiki> */

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/Wikiplus-highlight/modules/highlight.ts", "src/Wikiplus-highlight/modules/api.ts", "src/Wikiplus-highlight/modules/checkDependencies.ts", "src/Wikiplus-highlight/Wikiplus-highlight.ts"],
  "sourcesContent": ["/**\n * @name Wikiplus-highlight Wikiplus编辑器的CodeMirror语法高亮扩展\n * @author Bhsd <https://github.com/bhsd-harry>\n * @license GPL-3.0\n */\n\nimport {uniqueArray} from 'ext.gadget.Util';\n\n((): void => {\n\tconst {libs} = mw,\n\t\t{wphl} = libs;\n\tif (wphl?.version) {\n\t\treturn;\n\t}\n\tconst version = '3.0.7';\n\tlibs['wphl'] = {version, cmVersion: '2.9', ...wphl}; // 开始加载\n\n\t// 路径\n\tconst CDN = '//testingcf.jsdelivr.net',\n\t\tMW_CDN = `npm/@bhsd/codemirror-mediawiki@${libs['wphl'].cmVersion || 'latest'}/dist/mw.min.js`,\n\t\tREPO_CDN = 'npm/wikiplus-highlight';\n\n\twindow.CodeMirror6 ||= new Promise((resolve) => {\n\t\tconst script = document.createElement('script');\n\t\tscript.addEventListener('load', () => {\n\t\t\tresolve(CodeMirror6);\n\t\t});\n\t\tscript.type = 'module';\n\t\tscript.src = `${CDN}/${MW_CDN}`;\n\t\tdocument.head.append(script);\n\t});\n\n\tconst {wgPageName: page, wgNamespaceNumber: ns, wgPageContentModel: contentmodel} = mw.config.get();\n\n\tconst CONTENTMODELS: Record<string, string> = {\n\t\t\t'sanitized-css': 'css',\n\t\t\twikitext: 'mediawiki',\n\t\t},\n\t\tEXTS: Record<string, string> = {\n\t\t\tcss: 'css',\n\t\t\tjs: 'javascript',\n\t\t\tjson: 'json',\n\t\t},\n\t\tNAMESPACES: Record<number, string> = {\n\t\t\t828: 'lua',\n\t\t\t274: 'html',\n\t\t};\n\n\t// eslint-disable-next-line @typescript-eslint/no-explicit-any\n\tconst getObject = (key: string): any => {\n\t\treturn JSON.parse(String(localStorage.getItem(key)));\n\t};\n\n\t/**\n\t * 检查页面语言类型\n\t *\n\t * @param {string} value 页面内容\n\t * @return {Promise}\n\t */\n\tconst getPageMode = async (value: string): Promise<[string, (number | undefined)?]> => {\n\t\tif (typeof _WikiplusPages === 'object') {\n\t\t\tconst pages = Object.values(_WikiplusPages).filter(({sectionCache}) => {\n\t\t\t\treturn Object.values(sectionCache).includes(value);\n\t\t\t});\n\t\t\tif (\n\t\t\t\tpages.some(({title}) => {\n\t\t\t\t\treturn !title.endsWith('/doc');\n\t\t\t\t})\n\t\t\t) {\n\t\t\t\tawait mw.loader.using('mediawiki.Title');\n\t\t\t}\n\t\t\tconst modes = uniqueArray(\n\t\t\t\t// Replace `new Set()` to avoid polyfilling core-js\n\t\t\t\tpages.map(({title}) => {\n\t\t\t\t\tif (title.endsWith('/doc')) {\n\t\t\t\t\t\treturn 'template';\n\t\t\t\t\t}\n\t\t\t\t\tconst t = new mw.Title(title),\n\t\t\t\t\t\tnamespace = t.getNamespaceId();\n\t\t\t\t\tif (namespace % 2) {\n\t\t\t\t\t\treturn 'mediawiki';\n\t\t\t\t\t}\n\t\t\t\t\tconst mode = EXTS[t.getExtension()?.toLowerCase() || ''] || NAMESPACES[namespace];\n\t\t\t\t\tif (mode) {\n\t\t\t\t\t\treturn mode === 'javascript' && (namespace === 8 || namespace === 2300) ? 'gadget' : mode;\n\t\t\t\t\t}\n\t\t\t\t\treturn namespace === 10 || namespace === 2 ? 'template' : 'mediawiki';\n\t\t\t\t})\n\t\t\t);\n\t\t\tif (modes.length === 1) {\n\t\t\t\tconst [mode] = modes;\n\t\t\t\tif (mode === 'gadget') {\n\t\t\t\t\treturn ['javascript', 8];\n\t\t\t\t}\n\t\t\t\treturn mode === 'template' ? ['mediawiki', 10] : [mode!];\n\t\t\t} else if (modes.length === 2) {\n\t\t\t\tif (modes.includes('javascript') && modes.includes('gadget')) {\n\t\t\t\t\treturn ['javascript'];\n\t\t\t\t} else if (modes.includes('mediawiki') && modes.includes('template')) {\n\t\t\t\t\treturn ['mediawiki'];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif ((ns !== 274 && contentmodel !== 'Scribunto') || page.endsWith('/doc')) {\n\t\t\treturn [CONTENTMODELS[contentmodel] || contentmodel, contentmodel === 'javascript' ? ns : undefined];\n\t\t}\n\t\tawait mw.loader.using('oojs-ui-windows');\n\t\tif (\n\t\t\tawait OO.ui.confirm(mw.msg('cm-mw-contentmodel'), {\n\t\t\t\tactions: [{label: ns === 274 ? 'Widget' : 'Lua'}, {label: 'Wikitext', action: 'accept'}],\n\t\t\t})\n\t\t) {\n\t\t\treturn ['mediawiki'];\n\t\t}\n\t\treturn [ns === 274 ? 'html' : 'lua'];\n\t};\n\n\t/**\n\t * 渲染编辑器\n\t *\n\t * @param {JQuery<HTMLTextAreaElement>} $target 目标编辑框\n\t * @param {boolean} setting 是否是Wikiplus设置（使用json语法）\n\t */\n\tconst renderEditor = async ($target: JQuery<HTMLTextAreaElement>, setting: boolean): Promise<void> => {\n\t\tconst cm = await (\n\t\t\tawait CodeMirror6\n\t\t).fromTextArea($target[0]!, ...(setting ? (['json'] as [string]) : await getPageMode($target.val()!)));\n\t\tif (cm.view) {\n\t\t\tcm.view.dom.id = 'Wikiplus-CodeMirror';\n\t\t}\n\n\t\tdocument.querySelector<HTMLAnchorElement>('#Wikiplus-Quickedit-Jump > a')!.href = '#Wikiplus-CodeMirror';\n\n\t\tif (!setting) {\n\t\t\t// 普通Wikiplus编辑区\n\t\t\tconst settings: Record<string, unknown> | null = getObject('Wikiplus_Settings'),\n\t\t\t\tescToExitQuickEdit = settings && (settings['esc_to_exit_quickedit'] || settings['escToExitQuickEdit']),\n\t\t\t\tsubmit = /** 提交编辑 @return true */ (): true => {\n\t\t\t\t\tdocument.querySelector('#Wikiplus-Quickedit-Submit')!.dispatchEvent(new MouseEvent('click'));\n\t\t\t\t\treturn true;\n\t\t\t\t},\n\t\t\t\tsubmitMinor = /** 提交小编辑 */ (): true => {\n\t\t\t\t\tdocument.querySelector<HTMLInputElement>('#Wikiplus-Quickedit-MinorEdit')!.checked = true;\n\t\t\t\t\treturn submit();\n\t\t\t\t},\n\t\t\t\tescapeEdit = /** 按下Esc键退出编辑 */ (): true => {\n\t\t\t\t\tdocument.querySelector('#Wikiplus-Quickedit-Back')!.dispatchEvent(new MouseEvent('click'));\n\t\t\t\t\treturn true;\n\t\t\t\t};\n\t\t\tcm.extraKeys([\n\t\t\t\t{key: 'Mod-S', run: submit},\n\t\t\t\t{key: 'Shift-Mod-S', run: submitMinor},\n\t\t\t\t...(escToExitQuickEdit === true || escToExitQuickEdit === 'true'\n\t\t\t\t\t? [{key: 'Esc', run: escapeEdit}]\n\t\t\t\t\t: []),\n\t\t\t]);\n\t\t}\n\n\t\t/** @todo 以下过渡代码添加于2024-02-07，将于一段时间后弃用 */\n\t\tconst oldKey = 'Wikiplus-highlight-addons',\n\t\t\toldPrefs: string[] | null = getObject(oldKey),\n\t\t\tmapping: Record<string, string> = {\n\t\t\t\tactiveLine: 'highlightActiveLine',\n\t\t\t\ttrailingspace: 'highlightTrailingWhitespace',\n\t\t\t\tmatchBrackets: 'bracketMatching',\n\t\t\t\tcloseBrackets: 'closeBrackets',\n\t\t\t\tmatchTags: 'tagMatching',\n\t\t\t\tfold: 'codeFolding',\n\t\t\t\twikiEditor: 'wikiEditor',\n\t\t\t\tescape: 'escape',\n\t\t\t\tcontextmenu: 'openLinks',\n\t\t\t\tlint: 'lint',\n\t\t\t};\n\t\tlocalStorage.removeItem(oldKey);\n\t\tif (oldPrefs) {\n\t\t\tconst obj: Record<string, true> = {};\n\t\t\tfor (const k of oldPrefs) {\n\t\t\t\tif (k in mapping) {\n\t\t\t\t\tobj[mapping[k]!] = true;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tcm.prefer(obj);\n\t\t}\n\t};\n\n\t// 监视 Wikiplus 编辑框\n\tconst observer = new MutationObserver((records) => {\n\t\tconst $editArea = $(\n\t\t\trecords.flatMap(({addedNodes}) => {\n\t\t\t\treturn [...addedNodes];\n\t\t\t})\n\t\t).find<HTMLTextAreaElement>('#Wikiplus-Quickedit, #Wikiplus-Setting-Input');\n\t\tif ($editArea.length > 0) {\n\t\t\tvoid renderEditor($editArea, $editArea.attr('id') === 'Wikiplus-Setting-Input');\n\t\t}\n\t});\n\tobserver.observe(document.body, {childList: true});\n\n\tmw.loader.load(`${CDN}/${REPO_CDN}@${version}/styles.min.css`, 'text/css');\n})();\n\nexport {};\n", "import {initMwApi} from 'ext.gadget.Util';\n\nconst api: mw.Api = initMwApi('Wikiplus-highlight/2.0');\n\nexport {api};\n", "import {api} from './api';\n\nconst checkDependencies = async () => {\n\tif (!mw.user.options.get('gadget-Wikiplus')) {\n\t\tvoid api.postWithEditToken({\n\t\t\taction: 'options',\n\t\t\tchange: 'gadget-Wikiplus=1',\n\t\t} as ApiOptionsParams);\n\n\t\tawait mw.loader.using('ext.gadget.Wikiplus');\n\t}\n};\n\nexport {checkDependencies};\n", "import './Wikiplus-highlight.less';\nimport {checkDependencies} from './modules/checkDependencies';\n\n(async function WikiplusHighlight() {\n\tvoid checkDependencies();\n\tconst {wgAction, wgIsArticle} = mw.config.get();\n\tif (wgAction !== 'view' || !wgIsArticle) {\n\t\treturn;\n\t}\n\n\tconst {'visualeditor-enable': isVeEnable} = mw.user.options.get() as Record<string, unknown>;\n\n\t/* see <https://github.com/Wikiplus/Wikiplus/issues/65> */\n\tif (isVeEnable) {\n\t\tawait mw.loader.using('ext.visualEditor.core');\n\t}\n\n\tif (!('ontouchstart' in document)) {\n\t\tawait import('./modules/highlight');\n\t}\n})();\n"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAAA,oBAAA,CAAA;AAAA,IAMAC;AANA,IAAAC,iBAAAC,MAAA;EAAA,gDAAA;AAAA;AAMAF,yBAA0BG,QAAA,iBAAA;IAN1B;;;;;AAQA,KAACC,aAAY;AACZ,YAAM;QAACC;MAAI,IAAIC,IACd;QAACC;MAAI,IAAIF;AACV,UAAIE,SAAA,QAAAA,SAAA,UAAAA,KAAMC,SAAS;AAClB;MACD;AACA,YAAMA,UAAU;AAChBH,WAAK,MAAM,IAAI;QAACG;QAASC,WAAW;QAAO,GAAGF;MAAI;AAGlD,YAAMG,MAAM,4BACXC,SAAA,kCAAAC,OAA2CP,KAAK,MAAM,EAAEI,aAAa,UAAQ,iBAAA,GAC7EI,WAAW;AAEZ,OAAAT,UAAAU,QAAOC,gBAAPX,QAAOW,cAAgB,IAAIC,QAASC,aAAY;AAC/C,cAAMC,SAASC,SAASC,cAAc,QAAQ;AAC9CF,eAAOG,iBAAiB,QAAQ,MAAM;AACrCJ,kBAAQF,WAAW;QACpB,CAAC;AACDG,eAAOI,OAAO;AACdJ,eAAOK,MAAA,GAAAX,OAASF,KAAG,GAAA,EAAAE,OAAID,MAAM;AAC7BQ,iBAASK,KAAKC,OAAOP,MAAM;MAC5B,CAAC;AAED,YAAM;QAACQ,YAAYC;QAAMC,mBAAmBC;QAAIC,oBAAoBC;MAAY,IAAIzB,GAAG0B,OAAOC,IAAI;AAElG,YAAMC,gBAAwC;QAC5C,iBAAiB;QACjBC,UAAU;MACX,GACAC,OAA+B;QAC9BC,KAAK;QACLC,IAAI;QACJC,MAAM;MACP,GACAC,aAAqC;QACpC,KAAK;QACL,KAAK;MACN;AAGD,YAAMC,YAAaC,SAAqB;AACvC,eAAOC,KAAKC,MAAMC,OAAOC,aAAaC,QAAQL,GAAG,CAAC,CAAC;MACpD;AAQA,YAAMM,cAAA,2BAAA;AAAA,YAAAC,OAAAC,kBAAc,WAAOC,OAA4D;AACtF,cAAI,OAAOC,mBAAmB,UAAU;AACvC,kBAAMC,QAAQC,OAAOC,OAAOH,cAAc,EAAEI,OAAO,CAAC;cAACC;YAAY,MAAM;AACtE,qBAAOH,OAAOC,OAAOE,YAAY,EAAEC,SAASP,KAAK;YAClD,CAAC;AACD,gBACCE,MAAMM,KAAK,CAAC;cAACC;YAAK,MAAM;AACvB,qBAAO,CAACA,MAAMC,SAAS,MAAM;YAC9B,CAAC,GACA;AACD,oBAAMvD,GAAGwD,OAAOC,MAAM,iBAAiB;YACxC;AACA,kBAAMC,SAAA,GAAQhE,mBAAAiE;;cAEbZ,MAAMa,IAAI,CAAC;gBAACN;cAAK,MAAM;AAAA,oBAAAO;AACtB,oBAAIP,MAAMC,SAAS,MAAM,GAAG;AAC3B,yBAAO;gBACR;AACA,sBAAMO,IAAI,IAAI9D,GAAG+D,MAAMT,KAAK,GAC3BU,YAAYF,EAAEG,eAAe;AAC9B,oBAAID,YAAY,GAAG;AAClB,yBAAO;gBACR;AACA,sBAAME,OAAOpC,OAAK+B,kBAAAC,EAAEK,aAAa,OAAA,QAAAN,oBAAA,SAAA,SAAfA,gBAAkBO,YAAY,MAAK,EAAE,KAAKlC,WAAW8B,SAAS;AAChF,oBAAIE,MAAM;AACT,yBAAOA,SAAS,iBAAiBF,cAAc,KAAKA,cAAc,QAAQ,WAAWE;gBACtF;AACA,uBAAOF,cAAc,MAAMA,cAAc,IAAI,aAAa;cAC3D,CAAC;YACF;AACA,gBAAIN,MAAMW,WAAW,GAAG;AACvB,oBAAM,CAACH,IAAI,IAAIR;AACf,kBAAIQ,SAAS,UAAU;AACtB,uBAAO,CAAC,cAAc,CAAC;cACxB;AACA,qBAAOA,SAAS,aAAa,CAAC,aAAa,EAAE,IAAI,CAACA,IAAK;YACxD,WAAWR,MAAMW,WAAW,GAAG;AAC9B,kBAAIX,MAAMN,SAAS,YAAY,KAAKM,MAAMN,SAAS,QAAQ,GAAG;AAC7D,uBAAO,CAAC,YAAY;cACrB,WAAWM,MAAMN,SAAS,WAAW,KAAKM,MAAMN,SAAS,UAAU,GAAG;AACrE,uBAAO,CAAC,WAAW;cACpB;YACD;UACD;AACA,cAAK7B,OAAO,OAAOE,iBAAiB,eAAgBJ,KAAKkC,SAAS,MAAM,GAAG;AAC1E,mBAAO,CAAC3B,cAAcH,YAAY,KAAKA,cAAcA,iBAAiB,eAAeF,KAAK,MAAS;UACpG;AACA,gBAAMvB,GAAGwD,OAAOC,MAAM,iBAAiB;AACvC,cAAA,MACOa,GAAGC,GAAGC,QAAQxE,GAAGyE,IAAI,oBAAoB,GAAG;YACjDC,SAAS,CAAC;cAACC,OAAOpD,OAAO,MAAM,WAAW;YAAK,GAAG;cAACoD,OAAO;cAAYC,QAAQ;YAAQ,CAAC;UACxF,CAAC,GACA;AACD,mBAAO,CAAC,WAAW;UACpB;AACA,iBAAO,CAACrD,OAAO,MAAM,SAAS,KAAK;QACpC,CAAA;AAAA,eAAA,SAxDMmB,aAAAmC,IAAA;AAAA,iBAAAlC,KAAAmC,MAAA,MAAAC,SAAA;QAAA;MAAA,EAAA;AAgEN,YAAMC,eAAA,2BAAA;AAAA,YAAAC,QAAArC,kBAAe,WAAOsC,SAAsCC,SAAoC;AACrG,gBAAMC,KAAA,OAAK,MACJ3E,aACL4E,aAAaH,QAAQ,CAAC,GAAI,GAAIC,UAAW,CAAC,MAAM,IAAA,MAAuBzC,YAAYwC,QAAQI,IAAI,CAAE,CAAE;AACrG,cAAIF,GAAGG,MAAM;AACZH,eAAGG,KAAKC,IAAIC,KAAK;UAClB;AAEA5E,mBAAS6E,cAAiC,8BAA8B,EAAGC,OAAO;AAElF,cAAI,CAACR,SAAS;AAEb,kBAAMS,WAA2CzD,UAAU,mBAAmB,GAC7E0D,qBAAqBD,aAAaA,SAAS,uBAAuB,KAAKA,SAAS,oBAAoB,IACpGE;;cAAkCA,MAAY;AAC7CjF,yBAAS6E,cAAc,4BAA4B,EAAGK,cAAc,IAAIC,WAAW,OAAO,CAAC;AAC3F,uBAAO;cACR;eACAC;;cAA2BA,MAAY;AACtCpF,yBAAS6E,cAAgC,+BAA+B,EAAGQ,UAAU;AACrF,uBAAOJ,OAAO;cACf;eACAK;;cAA+BA,MAAY;AAC1CtF,yBAAS6E,cAAc,0BAA0B,EAAGK,cAAc,IAAIC,WAAW,OAAO,CAAC;AACzF,uBAAO;cACR;;AACDZ,eAAGgB,UAAU,CACZ;cAAChE,KAAK;cAASiE,KAAKP;YAAM,GAC1B;cAAC1D,KAAK;cAAeiE,KAAKJ;YAAW,GACrC,GAAIJ,uBAAuB,QAAQA,uBAAuB,SACvD,CAAC;cAACzD,KAAK;cAAOiE,KAAKF;YAAU,CAAC,IAC9B,CAAA,CAAC,CACJ;UACF;AAGA,gBAAMG,SAAS,6BACdC,WAA4BpE,UAAUmE,MAAM,GAC5CE,UAAkC;YACjCC,YAAY;YACZC,eAAe;YACfC,eAAe;YACfC,eAAe;YACfC,WAAW;YACXC,MAAM;YACNC,YAAY;YACZC,QAAQ;YACRC,aAAa;YACbC,MAAM;UACP;AACD1E,uBAAa2E,WAAWb,MAAM;AAC9B,cAAIC,UAAU;AACb,kBAAMa,MAA4B,CAAC;AAAA,gBAAAC,YAAAC,2BACnBf,QAAA,GAAAgB;AAAA,gBAAA;AAAhB,mBAAAF,UAAAG,EAAA,GAAA,EAAAD,QAAAF,UAAAI,EAAA,GAAAC,QAA0B;AAAA,sBAAfC,IAAAJ,MAAA1E;AACV,oBAAI8E,KAAKnB,SAAS;AACjBY,sBAAIZ,QAAQmB,CAAC,CAAE,IAAI;gBACpB;cACD;YAAA,SAAAC,KAAA;AAAAP,wBAAAQ,EAAAD,GAAA;YAAA,UAAA;AAAAP,wBAAAS,EAAA;YAAA;AAEA1C,eAAG2C,OAAOX,GAAG;UACd;QACD,CAAA;AAAA,eAAA,SA7DMpC,cAAAgD,KAAAC,KAAA;AAAA,iBAAAhD,MAAAH,MAAA,MAAAC,SAAA;QAAA;MAAA,EAAA;AAgEN,YAAMmD,WAAW,IAAIC,iBAAkBC,aAAY;AAClD,cAAMC,YAAYC,EACjBF,QAAQG,QAAQ,CAAC;UAACC;QAAU,MAAM;AACjC,iBAAO,CAAC,GAAGA,UAAU;QACtB,CAAC,CACF,EAAEC,KAA0B,8CAA8C;AAC1E,YAAIJ,UAAUhE,SAAS,GAAG;AACzB,eAAKW,aAAaqD,WAAWA,UAAUK,KAAK,IAAI,MAAM,wBAAwB;QAC/E;MACD,CAAC;AACDR,eAASS,QAAQ9H,SAAS+H,MAAM;QAACC,WAAW;MAAI,CAAC;AAEjD7I,SAAGwD,OAAOsF,KAAA,GAAAxI,OAAQF,KAAG,GAAA,EAAAE,OAAIC,UAAQ,GAAA,EAAAD,OAAIJ,SAAO,iBAAA,GAAmB,UAAU;IAC1E,GAAG;EAAA;AAAA,CAAA;;ACxMH,IAAA6I,oBAAwBlJ,QAAA,iBAAA;AAExB,IAAMmJ,OAAA,GAAcD,kBAAAE,WAAU,wBAAwB;;ACAtD,IAAMC,oBAAA,2BAAA;AAAA,MAAAC,QAAAvG,kBAAoB,aAAY;AACrC,QAAI,CAAC5C,GAAGoJ,KAAKC,QAAQ1H,IAAI,iBAAiB,GAAG;AAC5C,WAAKqH,IAAIM,kBAAkB;QAC1B1E,QAAQ;QACR2E,QAAQ;MACT,CAAqB;AAErB,YAAMvJ,GAAGwD,OAAOC,MAAM,qBAAqB;IAC5C;EACD,CAAA;AAAA,SAAA,SATMyF,qBAAA;AAAA,WAAAC,MAAArE,MAAA,MAAAC,SAAA;EAAA;AAAA,EAAA;;;6CCCL,aAAmC;AACnC,SAAKmE,kBAAkB;AACvB,UAAM;MAACM;MAAUC;IAAW,IAAIzJ,GAAG0B,OAAOC,IAAI;AAC9C,QAAI6H,aAAa,UAAU,CAACC,aAAa;AACxC;IACD;AAEA,UAAM;MAAC,uBAAuBC;IAAU,IAAI1J,GAAGoJ,KAAKC,QAAQ1H,IAAI;AAGhE,QAAI+H,YAAY;AACf,YAAM1J,GAAGwD,OAAOC,MAAM,uBAAuB;IAC9C;AAEA,QAAI,EAAE,kBAAkB5C,WAAW;AAClC,YAAMH,QAAAC,QAAA,EAAAgJ,KAAA,OAAAhK,eAAA,GAAAF,kBAAA;IACP;EACD,CAAA;AAAA,WAjBgBmK,oBAAA;AAAA,WAAAC,mBAAA/E,MAAA,MAAAC,SAAA;EAAA;AAAA,SAAA6E;AAAA,GAAA,EAiBb;",
  "names": ["highlight_exports", "import_ext_gadget2", "init_highlight", "__esm", "require", "_window", "libs", "mw", "wphl", "version", "cmVersion", "CDN", "MW_CDN", "concat", "REPO_CDN", "window", "CodeMirror6", "Promise", "resolve", "script", "document", "createElement", "addEventListener", "type", "src", "head", "append", "wgPageName", "page", "wgNamespaceNumber", "ns", "wgPageContentModel", "contentmodel", "config", "get", "CONTENTMODELS", "wikitext", "EXTS", "css", "js", "json", "NAMESPACES", "getObject", "key", "JSON", "parse", "String", "localStorage", "getItem", "getPageMode", "_ref", "_asyncToGenerator", "value", "_WikiplusPages", "pages", "Object", "values", "filter", "sectionCache", "includes", "some", "title", "endsWith", "loader", "using", "modes", "uniqueArray", "map", "_t$getExtension", "t", "Title", "namespace", "getNamespaceId", "mode", "getExtension", "toLowerCase", "length", "OO", "ui", "confirm", "msg", "actions", "label", "action", "_x", "apply", "arguments", "renderEditor", "_ref2", "$target", "setting", "cm", "fromTextArea", "val", "view", "dom", "id", "querySelector", "href", "settings", "escToExitQuickEdit", "submit", "dispatchEvent", "MouseEvent", "submitMinor", "checked", "escapeEdit", "extraKeys", "run", "oldKey", "oldPrefs", "mapping", "activeLine", "trailingspace", "matchBrackets", "closeBrackets", "matchTags", "fold", "wikiEditor", "escape", "contextmenu", "lint", "removeItem", "obj", "_iterator", "_createForOfIteratorHelper", "_step", "s", "n", "done", "k", "err", "e", "f", "prefer", "_x2", "_x3", "observer", "MutationObserver", "records", "$editArea", "$", "flatMap", "addedNodes", "find", "attr", "observe", "body", "childList", "load", "import_ext_gadget", "api", "initMwApi", "checkDependencies", "_ref3", "user", "options", "postWithEditToken", "change", "wgAction", "wgIsArticle", "isVeEnable", "then", "WikiplusHighlight", "_WikiplusHighlight"]
}
