Google Chrome、Microsoft Edge、Mozilla Firefox、Safari:按住⇧ Shift,同时单击“刷新”。
对本页面内容的变更,应通知技术团队,以免在代码部署时被误覆盖。
Copyright © The author
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
- Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- Neither the name of The author nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
This software is provided by The author and contributors "as is" and any express or implied warranties, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose are disclaimed. In no event shall The author and contributors be liable for any direct, indirect, incidental, special, exemplary, or consequential damages (including, but not limited to, procurement of substitute goods or services; loss of use, data, or profits; or business interruption) however caused and on any theory of liability, whether in contract, strict liability, or tort (including negligence or otherwise) arising in any way out of the use of this software, even if advised of the possibility of such damage.
/**
* SPDX-License-Identifier: BSD-3-Clause
* _addText: '{{Gadget Header|license=BSD}}'
*
* @base {@link https://github.com/diskdance/gadget-text-spacing}
* @source {@link https://git.qiuwen.net.cn/InterfaceAdmin/QiuwenGadgets/src/branch/master/src/TextSpacing}
* @license BSD-3-Clause {@link https://github.com/diskdance/gadget-text-spacing/blob/main/LICENSE}
*/
/**
* Copyright 2023 diskdance
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. The name of the author may not be used to
* endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR “AS IS” AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
/**
* +------------------------------------------------------------+
* | === 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";
var __getOwnPropNames = Object.getOwnPropertyNames;
var __commonJS = (cb, mod) => function __require() {
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
};
// node_modules/.pnpm/@mrhenry+core-web@1.2.2/node_modules/@mrhenry/core-web/modules/IntersectionObserver.js
var require_IntersectionObserver = __commonJS({
"node_modules/.pnpm/@mrhenry+core-web@1.2.2/node_modules/@mrhenry/core-web/modules/IntersectionObserver.js"() {
(function(undefined) {
if (!("IntersectionObserver" in window && "IntersectionObserverEntry" in window && "intersectionRatio" in window.IntersectionObserverEntry.prototype)) {
(function(window2, document2) {
"use strict";
var supportedNatively = "IntersectionObserver" in window2 && "IntersectionObserverEntry" in window2 && "intersectionRatio" in window2.IntersectionObserverEntry.prototype;
if (supportedNatively) {
return;
}
var registry = [];
function IntersectionObserverEntry(entry) {
this.time = entry.time;
this.target = entry.target;
this.rootBounds = entry.rootBounds;
this.boundingClientRect = entry.boundingClientRect;
this.intersectionRect = entry.intersectionRect || getEmptyRect();
try {
this.isIntersecting = !!entry.intersectionRect;
} catch (err) {
}
var targetRect = this.boundingClientRect;
var targetArea = targetRect.width * targetRect.height;
var intersectionRect = this.intersectionRect;
var intersectionArea = intersectionRect.width * intersectionRect.height;
if (targetArea) {
this.intersectionRatio = Number((intersectionArea / targetArea).toFixed(4));
} else {
this.intersectionRatio = this.isIntersecting ? 1 : 0;
}
}
IntersectionObserverEntry.prototype.intersectionRatio = 0;
function IntersectionObserver2(callback, opt_options) {
var options = opt_options || {};
if (typeof callback != "function") {
throw new Error("callback must be a function");
}
if (options.root && options.root.nodeType != 1) {
throw new Error("root must be an Element");
}
this._checkForIntersections = throttle(
this._checkForIntersections.bind(this),
this.THROTTLE_TIMEOUT
);
this._callback = callback;
this._observationTargets = [];
this._queuedEntries = [];
this._rootMarginValues = this._parseRootMargin(options.rootMargin);
this.thresholds = this._initThresholds(options.threshold);
this.root = options.root || null;
this.rootMargin = this._rootMarginValues.map(function(margin) {
return margin.value + margin.unit;
}).join(" ");
}
IntersectionObserver2.prototype.THROTTLE_TIMEOUT = 100;
IntersectionObserver2.prototype.POLL_INTERVAL = null;
IntersectionObserver2.prototype.USE_MUTATION_OBSERVER = true;
IntersectionObserver2.prototype.observe = function(target) {
var isTargetAlreadyObserved = this._observationTargets.some(function(item) {
return item.element == target;
});
if (isTargetAlreadyObserved) {
return;
}
if (!(target && target.nodeType == 1)) {
throw new Error("target must be an Element");
}
this._registerInstance();
this._observationTargets.push({ element: target, entry: null });
this._monitorIntersections();
this._checkForIntersections();
};
IntersectionObserver2.prototype.unobserve = function(target) {
this._observationTargets = this._observationTargets.filter(function(item) {
return item.element != target;
});
if (!this._observationTargets.length) {
this._unmonitorIntersections();
this._unregisterInstance();
}
};
IntersectionObserver2.prototype.disconnect = function() {
this._observationTargets = [];
this._unmonitorIntersections();
this._unregisterInstance();
};
IntersectionObserver2.prototype.takeRecords = function() {
var records = this._queuedEntries.slice();
this._queuedEntries = [];
return records;
};
IntersectionObserver2.prototype._initThresholds = function(opt_threshold) {
var threshold = opt_threshold || [0];
if (!Array.isArray(threshold))
threshold = [threshold];
return threshold.sort().filter(function(t, i, a) {
if (typeof t != "number" || isNaN(t) || t < 0 || t > 1) {
throw new Error("threshold must be a number between 0 and 1 inclusively");
}
return t !== a[i - 1];
});
};
IntersectionObserver2.prototype._parseRootMargin = function(opt_rootMargin) {
var marginString = opt_rootMargin || "0px";
var margins = marginString.split(/\s+/).map(function(margin) {
var parts = /^(-?\d*\.?\d+)(px|%)$/.exec(margin);
if (!parts) {
throw new Error("rootMargin must be specified in pixels or percent");
}
return { value: parseFloat(parts[1]), unit: parts[2] };
});
margins[1] = margins[1] || margins[0];
margins[2] = margins[2] || margins[0];
margins[3] = margins[3] || margins[1];
return margins;
};
IntersectionObserver2.prototype._monitorIntersections = function() {
if (!this._monitoringIntersections) {
this._monitoringIntersections = true;
if (this.POLL_INTERVAL) {
this._monitoringInterval = setInterval(
this._checkForIntersections,
this.POLL_INTERVAL
);
} else {
addEvent(window2, "resize", this._checkForIntersections, true);
addEvent(document2, "scroll", this._checkForIntersections, true);
if (this.USE_MUTATION_OBSERVER && "MutationObserver" in window2) {
this._domObserver = new MutationObserver(this._checkForIntersections);
this._domObserver.observe(document2, {
attributes: true,
childList: true,
characterData: true,
subtree: true
});
}
}
}
};
IntersectionObserver2.prototype._unmonitorIntersections = function() {
if (this._monitoringIntersections) {
this._monitoringIntersections = false;
clearInterval(this._monitoringInterval);
this._monitoringInterval = null;
removeEvent(window2, "resize", this._checkForIntersections, true);
removeEvent(document2, "scroll", this._checkForIntersections, true);
if (this._domObserver) {
this._domObserver.disconnect();
this._domObserver = null;
}
}
};
IntersectionObserver2.prototype._checkForIntersections = function() {
var rootIsInDom = this._rootIsInDom();
var rootRect = rootIsInDom ? this._getRootRect() : getEmptyRect();
this._observationTargets.forEach(function(item) {
var target = item.element;
var targetRect = getBoundingClientRect(target);
var rootContainsTarget = this._rootContainsTarget(target);
var oldEntry = item.entry;
var intersectionRect = rootIsInDom && rootContainsTarget && this._computeTargetAndRootIntersection(target, rootRect);
var newEntry = item.entry = new IntersectionObserverEntry({
time: now(),
target,
boundingClientRect: targetRect,
rootBounds: rootRect,
intersectionRect
});
if (!oldEntry) {
this._queuedEntries.push(newEntry);
} else if (rootIsInDom && rootContainsTarget) {
if (this._hasCrossedThreshold(oldEntry, newEntry)) {
this._queuedEntries.push(newEntry);
}
} else {
if (oldEntry && oldEntry.isIntersecting) {
this._queuedEntries.push(newEntry);
}
}
}, this);
if (this._queuedEntries.length) {
this._callback(this.takeRecords(), this);
}
};
IntersectionObserver2.prototype._computeTargetAndRootIntersection = function(target, rootRect) {
if (window2.getComputedStyle(target).display == "none")
return;
var targetRect = getBoundingClientRect(target);
var intersectionRect = targetRect;
var parent = getParentNode(target);
var atRoot = false;
while (!atRoot) {
var parentRect = null;
var parentComputedStyle = parent.nodeType == 1 ? window2.getComputedStyle(parent) : {};
if (parentComputedStyle.display == "none")
return;
if (parent == this.root || parent == document2) {
atRoot = true;
parentRect = rootRect;
} else {
if (parent != document2.body && parent != document2.documentElement && parentComputedStyle.overflow != "visible") {
parentRect = getBoundingClientRect(parent);
}
}
if (parentRect) {
intersectionRect = computeRectIntersection(parentRect, intersectionRect);
if (!intersectionRect)
break;
}
parent = getParentNode(parent);
}
return intersectionRect;
};
IntersectionObserver2.prototype._getRootRect = function() {
var rootRect;
if (this.root) {
rootRect = getBoundingClientRect(this.root);
} else {
var html = document2.documentElement;
var body = document2.body;
rootRect = {
x: 0,
y: 0,
top: 0,
left: 0,
right: html.clientWidth || body.clientWidth,
width: html.clientWidth || body.clientWidth,
bottom: html.clientHeight || body.clientHeight,
height: html.clientHeight || body.clientHeight
};
}
return this._expandRectByRootMargin(rootRect);
};
IntersectionObserver2.prototype._expandRectByRootMargin = function(rect) {
var margins = this._rootMarginValues.map(function(margin, i) {
return margin.unit == "px" ? margin.value : margin.value * (i % 2 ? rect.width : rect.height) / 100;
});
var newRect = {
top: rect.top - margins[0],
right: rect.right + margins[1],
bottom: rect.bottom + margins[2],
left: rect.left - margins[3]
};
newRect.width = newRect.right - newRect.left;
newRect.height = newRect.bottom - newRect.top;
newRect.x = newRect.left;
newRect.y = newRect.top;
return newRect;
};
IntersectionObserver2.prototype._hasCrossedThreshold = function(oldEntry, newEntry) {
var oldRatio = oldEntry && oldEntry.isIntersecting ? oldEntry.intersectionRatio || 0 : -1;
var newRatio = newEntry.isIntersecting ? newEntry.intersectionRatio || 0 : -1;
if (oldRatio === newRatio)
return;
for (var i = 0; i < this.thresholds.length; i++) {
var threshold = this.thresholds[i];
if (threshold == oldRatio || threshold == newRatio || threshold < oldRatio !== threshold < newRatio) {
return true;
}
}
};
IntersectionObserver2.prototype._rootIsInDom = function() {
return !this.root || containsDeep(document2, this.root);
};
IntersectionObserver2.prototype._rootContainsTarget = function(target) {
return containsDeep(this.root || document2, target);
};
IntersectionObserver2.prototype._registerInstance = function() {
if (registry.indexOf(this) < 0) {
registry.push(this);
}
};
IntersectionObserver2.prototype._unregisterInstance = function() {
var index = registry.indexOf(this);
if (index != -1)
registry.splice(index, 1);
};
function now() {
return window2.performance && performance.now && performance.now();
}
function throttle(fn, timeout) {
var timer = null;
return function() {
if (!timer) {
timer = setTimeout(function() {
fn();
timer = null;
}, timeout);
}
};
}
function addEvent(node, event, fn, opt_useCapture) {
if (typeof node.addEventListener == "function") {
node.addEventListener(event, fn, opt_useCapture || false);
} else if (typeof node.attachEvent == "function") {
node.attachEvent("on" + event, fn);
}
}
function removeEvent(node, event, fn, opt_useCapture) {
if (typeof node.removeEventListener == "function") {
node.removeEventListener(event, fn, opt_useCapture || false);
} else if (typeof node.detatchEvent == "function") {
node.detatchEvent("on" + event, fn);
}
}
function computeRectIntersection(rect1, rect2) {
var top = Math.max(rect1.top, rect2.top);
var bottom = Math.min(rect1.bottom, rect2.bottom);
var left = Math.max(rect1.left, rect2.left);
var right = Math.min(rect1.right, rect2.right);
var width = right - left;
var height = bottom - top;
return width >= 0 && height >= 0 && {
x: left,
y: top,
top,
bottom,
left,
right,
width,
height
};
}
function getBoundingClientRect(el) {
var rect;
try {
rect = el.getBoundingClientRect();
} catch (err) {
}
if (!rect)
return getEmptyRect();
if (!(rect.width && rect.height && rect.x && rect.y)) {
rect = {
x: rect.left,
y: rect.top,
top: rect.top,
right: rect.right,
bottom: rect.bottom,
left: rect.left,
width: rect.right - rect.left,
height: rect.bottom - rect.top
};
}
return rect;
}
function getEmptyRect() {
return {
x: 0,
y: 0,
top: 0,
bottom: 0,
left: 0,
right: 0,
width: 0,
height: 0
};
}
function containsDeep(parent, child) {
var node = child;
while (node) {
if (node == parent)
return true;
node = getParentNode(node);
}
return false;
}
function getParentNode(node) {
var parent = node.parentNode;
if (parent && parent.nodeType == 11 && parent.host) {
return parent.host;
}
if (parent && parent.assignedSlot) {
return parent.assignedSlot.parentNode;
}
return parent;
}
window2.IntersectionObserver = IntersectionObserver2;
window2.IntersectionObserverEntry = IntersectionObserverEntry;
})(window, document);
}
}).call("object" === typeof window && window || "object" === typeof self && self || "object" === typeof global && global || {});
}
});
// dist/TextSpacing/TextSpacing.js
require_IntersectionObserver();
function _createForOfIteratorHelper(o, allowArrayLike) {
var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
if (!it) {
if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
if (it)
o = it;
var i = 0;
var F = function() {
};
return { s: F, n: function() {
if (i >= o.length)
return { done: true };
return { done: false, value: o[i++] };
}, e: function(e) {
throw e;
}, 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 normalCompletion = true, didErr = false, err;
return { s: function() {
it = it.call(o);
}, n: function() {
var step = it.next();
normalCompletion = step.done;
return step;
}, e: function(e) {
didErr = true;
err = e;
}, f: function() {
try {
if (!normalCompletion && it.return != null)
it.return();
} finally {
if (didErr)
throw err;
}
} };
}
function _unsupportedIterableToArray(o, minLen) {
if (!o)
return;
if (typeof o === "string")
return _arrayLikeToArray(o, minLen);
var n = Object.prototype.toString.call(o).slice(8, -1);
if (n === "Object" && o.constructor)
n = o.constructor.name;
if (n === "Map" || n === "Set")
return Array.from(o);
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))
return _arrayLikeToArray(o, minLen);
}
function _arrayLikeToArray(arr, len) {
if (len == null || len > arr.length)
len = arr.length;
for (var i = 0, arr2 = new Array(len); i < len; i++)
arr2[i] = arr[i];
return arr2;
}
//! src/TextSpacing/modules/util.ts
var import_ext_gadget = require("ext.gadget.Util");
var isInlineHTMLElement = (node) => {
return node instanceof HTMLElement && window.getComputedStyle(node).display.includes("inline");
};
var isTextNode = (node) => {
return node.nodeType === Node.TEXT_NODE;
};
var isVisible = (element) => {
const style = window.getComputedStyle(element);
return style.display !== "none" && !["hidden", "collapse"].includes(style.visibility) && Number.parseFloat(style.opacity) > 0;
};
var getNodeText = (node) => {
return node instanceof HTMLElement ? node.innerText : node.data;
};
var splitAtIndexes = (str, indexes) => {
const result = [];
const normalizedIndexes = [
// Remove duplications and sort in ascending order
...(0, import_ext_gadget.uniqueArray)(
// Replace `new Set()` to avoid polyfilling core-js
indexes.sort((a, b) => {
return a - b;
}).filter((i) => {
return i >= 0 && i <= str.length;
})
),
str.length
];
for (let i = 0; i < normalizedIndexes.length; i++) {
const slice = str.slice(normalizedIndexes[i - 1], normalizedIndexes[i]);
result[result.length] = slice;
}
return result;
};
//! src/TextSpacing/modules/queue.ts
var pendingActions = /* @__PURE__ */ new WeakMap();
var onIntersection = (entries) => {
var _iterator = _createForOfIteratorHelper(entries), _step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done; ) {
const entry = _step.value;
if (!entry.isIntersecting) {
continue;
}
const element = entry.target;
observer.unobserve(element);
const callbacks = pendingActions.get(element);
if (!callbacks) {
continue;
}
while (true) {
const callback = callbacks.shift();
if (!callback) {
break;
}
callback(element);
}
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
};
var observer = new IntersectionObserver(onIntersection);
var queueDomMutation = (element, callback) => {
if (!pendingActions.has(element)) {
pendingActions.set(element, []);
}
if (pendingActions.get(element) !== void 0) {
pendingActions.get(element)[pendingActions.get(element).length] = callback;
}
observer.observe(element);
};
//! src/TextSpacing/modules/spacing.ts
var REGEX_RANGE_CHINESE = "(?:[\\u2E80-\\u2E99\\u2E9B-\\u2EF3\\u2F00-\\u2FD5\\u3005\\u3007\\u3021-\\u3029\\u3038-\\u303B\\u3400-\\u4DBF\\u4E00-\\u9FFF\\uF900-\\uFA6D\\uFA70-\\uFAD9]|\\uD81B[\\uDFE2\\uDFE3\\uDFF0\\uDFF1]|[\\uD840-\\uD868\\uD86A-\\uD86C\\uD86F-\\uD872\\uD874-\\uD879\\uD880-\\uD883][\\uDC00-\\uDFFF]|\\uD869[\\uDC00-\\uDEDF\\uDF00-\\uDFFF]|\\uD86D[\\uDC00-\\uDF38\\uDF40-\\uDFFF]|\\uD86E[\\uDC00-\\uDC1D\\uDC20-\\uDFFF]|\\uD873[\\uDC00-\\uDEA1\\uDEB0-\\uDFFF]|\\uD87A[\\uDC00-\\uDFE0]|\\uD87E[\\uDC00-\\uDE1D]|\\uD884[\\uDC00-\\uDF4A])";
var REGEX_RANGE_OTHER_LEFT = "[A-Za-z0-9@~%+=|±\\)}#$¥€£₤]";
var REGEX_RANGE_OTHER_RIGHT = "[A-Za-z0-9@~%+=|±\\({#$¥€£₤]";
var REGEX_STR_INTER_SCRIPT = "(?:(".concat(REGEX_RANGE_CHINESE, ")(?=").concat(REGEX_RANGE_OTHER_RIGHT, ")|(").concat(REGEX_RANGE_OTHER_LEFT, ")(?=").concat(REGEX_RANGE_CHINESE, "))");
var SPACE = " ";
var WRAPPER_CLASS = "gadget-text_spacing";
var SELECTOR_ALLOWED = ["a", "abbr", "article", "aside", "b", "bdi", "big", "blockquote", "button", "caption", "center", "cite", "data", "dd", "del", "details", "dfn", "div", "dt", "em", "figcaption", "footer", "h1", "h2", "h3", "h4", "h5", "header", "i", "ins", "label", "legend", "li", "main", "mark", "option", "p", "q", "ruby", "s", "section", "small", "span", "strike", "strong", "sub", "summary", "sup", "td", "th", "time", "u"];
var SELECTOR_BLOCKED = [
"code",
"kbd",
"pre",
"rp",
"rt",
"samp",
"textarea",
"var",
// Elements with this class are excluded
".gadget-nospace",
// Editable elements
'[contenteditable="true"]',
// ACE editor content
".ace_editor",
// Visual Editor (and 2017 Wikitext Editor) content & diff
".ve-ui-surface",
".ve-init-mw-diffPage-diff",
// Diff
".diff-context",
".diff-addedline",
".diff-deletedline",
// Diff (inline mode)
".mw-diff-inline-added",
".mw-diff-inline-deleted",
".mw-diff-inline-moved",
".mw-diff-inline-changed",
".mw-diff-inline-context"
];
var SELECTOR = SELECTOR_ALLOWED.map((allowed) => {
return "".concat(allowed, ":not(").concat(SELECTOR_BLOCKED.flatMap((blocked) => {
return blocked[0].match(/[a-z]/i) ? "".concat(blocked, " *") : [blocked, "".concat(blocked, " *")];
}).join(","), ")");
}).join(",");
var getLeafElements = (parent) => {
const candidates = parent.querySelectorAll(SELECTOR);
const result = [];
if (parent.matches(SELECTOR)) {
result[result.length] = parent;
}
var _iterator2 = _createForOfIteratorHelper(candidates), _step2;
try {
for (_iterator2.s(); !(_step2 = _iterator2.n()).done; ) {
const candidate = _step2.value;
var _iterator3 = _createForOfIteratorHelper(candidate.childNodes), _step3;
try {
for (_iterator3.s(); !(_step3 = _iterator3.n()).done; ) {
const childNode = _step3.value;
if (isTextNode(childNode)) {
result[result.length] = candidate;
break;
}
}
} catch (err) {
_iterator3.e(err);
} finally {
_iterator3.f();
}
}
} catch (err) {
_iterator2.e(err);
} finally {
_iterator2.f();
}
return result;
};
var getNextVisibleSibling = (node) => {
let currentNode = node;
while (true) {
const candidate = currentNode.nextSibling;
if (!candidate) {
const parent = currentNode.parentElement;
if (!parent) {
return null;
}
currentNode = parent;
continue;
}
if (!(candidate instanceof HTMLElement || candidate instanceof Text)) {
currentNode = candidate;
continue;
}
if (candidate instanceof HTMLElement) {
if (!isVisible(candidate)) {
currentNode = candidate;
continue;
}
if (!isInlineHTMLElement(candidate)) {
return null;
}
}
if (candidate instanceof Text && !candidate.data.trim()) {
currentNode = candidate;
continue;
}
return candidate;
}
};
var createSpacingWrapper = (str) => {
const span = document.createElement("span");
span.className = WRAPPER_CLASS;
span.textContent = str.slice(-1);
return [str.slice(0, -1), span];
};
var adjustSpacing = (element) => {
const childNodes = [...element.childNodes];
const textSpacingPosMap = /* @__PURE__ */ new Map();
for (var _i = 0, _childNodes = childNodes; _i < _childNodes.length; _i++) {
const child = _childNodes[_i];
if (!(child instanceof Text)) {
continue;
}
const nextSibling = getNextVisibleSibling(child);
let testString = getNodeText(child);
if (nextSibling) {
var _getNodeText$;
testString += (_getNodeText$ = getNodeText(nextSibling)[0]) !== null && _getNodeText$ !== void 0 ? _getNodeText$ : "";
}
const indexes = [];
const regexTextNodeData = new RegExp(REGEX_STR_INTER_SCRIPT, "g");
while (true) {
const match = regexTextNodeData.exec(testString);
if (!match) {
break;
}
indexes[indexes.length] = match.index + 1;
}
if (!indexes.length) {
continue;
}
textSpacingPosMap.set(child, indexes);
}
queueDomMutation(element, () => {
var _iterator4 = _createForOfIteratorHelper(textSpacingPosMap), _step4;
try {
for (_iterator4.s(); !(_step4 = _iterator4.n()).done; ) {
const [node, indexes] = _step4.value;
const text = node.data;
const fragments = splitAtIndexes(text, indexes);
const replacement = fragments.slice(0, -1).flatMap((fragment) => {
return createSpacingWrapper(fragment);
});
replacement[replacement.length] = fragments.at(-1);
requestAnimationFrame(() => {
node.replaceWith(...replacement);
});
}
} catch (err) {
_iterator4.e(err);
} finally {
_iterator4.f();
}
});
};
var addSpaceToString = (str) => {
const regex = new RegExp(REGEX_STR_INTER_SCRIPT, "g");
return str.replace(regex, "$1$2".concat(SPACE));
};
//! src/TextSpacing/TextSpacing.ts
var run = (element) => {
const leaves = getLeafElements(element);
var _iterator5 = _createForOfIteratorHelper(leaves), _step5;
try {
for (_iterator5.s(); !(_step5 = _iterator5.n()).done; ) {
const leaf = _step5.value;
adjustSpacing(leaf);
}
} catch (err) {
_iterator5.e(err);
} finally {
_iterator5.f();
}
};
var mutationObserver = new MutationObserver((records) => {
var _iterator6 = _createForOfIteratorHelper(records), _step6;
try {
for (_iterator6.s(); !(_step6 = _iterator6.n()).done; ) {
const record = _step6.value;
if (record.type !== "childList") {
continue;
}
const addedNodes = [...record.addedNodes];
if (addedNodes.some((node) => {
return node instanceof HTMLElement && node.classList.contains(WRAPPER_CLASS);
})) {
continue;
}
for (var _i2 = 0, _addedNodes = addedNodes; _i2 < _addedNodes.length; _i2++) {
const node = _addedNodes[_i2];
if (node instanceof HTMLElement) {
run(node);
} else if (node instanceof Text) {
const {
parentElement
} = node;
if (parentElement) {
run(parentElement);
}
}
}
}
} catch (err) {
_iterator6.e(err);
} finally {
_iterator6.f();
}
});
var main = () => {
document.title = addSpaceToString(document.title);
mutationObserver.observe(document.body, {
subtree: true,
childList: true
});
run(document.body);
};
$(main);
})();
/* </nowiki> */
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["node_modules/.pnpm/@mrhenry+core-web@1.2.2/node_modules/@mrhenry/core-web/modules/IntersectionObserver.js", "src/TextSpacing/modules/util.ts", "src/TextSpacing/modules/queue.ts", "src/TextSpacing/modules/spacing.ts", "src/TextSpacing/TextSpacing.ts"],
  "sourcesContent": ["(function(undefined) {\nif (!(\"IntersectionObserver\"in window&&\"IntersectionObserverEntry\"in window&&\"intersectionRatio\"in window.IntersectionObserverEntry.prototype\n)) {\n// IntersectionObserver\n/**\n * Copyright 2016 Google Inc. All Rights Reserved.\n *\n * Licensed under the W3C SOFTWARE AND DOCUMENT NOTICE AND LICENSE.\n *\n *  https://www.w3.org/Consortium/Legal/2015/copyright-software-and-document\n *\n */\n\n(function(window, document) {\n'use strict';\n\nvar supportedNatively = 'IntersectionObserver' in window &&\n'IntersectionObserverEntry' in window &&\n'intersectionRatio' in window.IntersectionObserverEntry.prototype;\n\nif (supportedNatively) {\n\treturn;\n}\n/**\n * An IntersectionObserver registry. This registry exists to hold a strong\n * reference to IntersectionObserver instances currently observing a target\n * element. Without this registry, instances without another reference may be\n * garbage collected.\n */\nvar registry = [];\n\n\n/**\n * Creates the global IntersectionObserverEntry constructor.\n * https://w3c.github.io/IntersectionObserver/#intersection-observer-entry\n * @param {Object} entry A dictionary of instance properties.\n * @constructor\n */\nfunction IntersectionObserverEntry(entry) {\n\tthis.time = entry.time;\n\tthis.target = entry.target;\n\tthis.rootBounds = entry.rootBounds;\n\tthis.boundingClientRect = entry.boundingClientRect;\n\tthis.intersectionRect = entry.intersectionRect || getEmptyRect();\n\ttry {\n\t\tthis.isIntersecting = !!entry.intersectionRect;\n\t} catch (err) {\n\t\t// This means we are using the IntersectionObserverEntry polyfill which has only defined a getter\n\t}\n\n\t// Calculates the intersection ratio.\n\tvar targetRect = this.boundingClientRect;\n\tvar targetArea = targetRect.width * targetRect.height;\n\tvar intersectionRect = this.intersectionRect;\n\tvar intersectionArea = intersectionRect.width * intersectionRect.height;\n\n\t// Sets intersection ratio.\n\tif (targetArea) {\n\t\t// Round the intersection ratio to avoid floating point math issues:\n\t\t// https://github.com/w3c/IntersectionObserver/issues/324\n\t\tthis.intersectionRatio = Number((intersectionArea / targetArea).toFixed(4));\n\t} else {\n\t\t// If area is zero and is intersecting, sets to 1, otherwise to 0\n\t\tthis.intersectionRatio = this.isIntersecting ? 1 : 0;\n\t}\n}\n\nIntersectionObserverEntry.prototype.intersectionRatio = 0;\n\n/**\n * Creates the global IntersectionObserver constructor.\n * https://w3c.github.io/IntersectionObserver/#intersection-observer-interface\n * @param {Function} callback The function to be invoked after intersection\n *     changes have queued. The function is not invoked if the queue has\n *     been emptied by calling the `takeRecords` method.\n * @param {Object=} opt_options Optional configuration options.\n * @constructor\n */\nfunction IntersectionObserver(callback, opt_options) {\n\n\tvar options = opt_options || {};\n\n\tif (typeof callback != 'function') {\n\t\tthrow new Error('callback must be a function');\n\t}\n\n\tif (options.root && options.root.nodeType != 1) {\n\t\tthrow new Error('root must be an Element');\n\t}\n\n\t// Binds and throttles `this._checkForIntersections`.\n\tthis._checkForIntersections = throttle(\n\t\t\tthis._checkForIntersections.bind(this), this.THROTTLE_TIMEOUT);\n\n\t// Private properties.\n\tthis._callback = callback;\n\tthis._observationTargets = [];\n\tthis._queuedEntries = [];\n\tthis._rootMarginValues = this._parseRootMargin(options.rootMargin);\n\n\t// Public properties.\n\tthis.thresholds = this._initThresholds(options.threshold);\n\tthis.root = options.root || null;\n\tthis.rootMargin = this._rootMarginValues.map(function(margin) {\n\t\treturn margin.value + margin.unit;\n\t}).join(' ');\n}\n\n\n/**\n * The minimum interval within which the document will be checked for\n * intersection changes.\n */\nIntersectionObserver.prototype.THROTTLE_TIMEOUT = 100;\n\n\n/**\n * The frequency in which the polyfill polls for intersection changes.\n * this can be updated on a per instance basis and must be set prior to\n * calling `observe` on the first target.\n */\nIntersectionObserver.prototype.POLL_INTERVAL = null;\n\n/**\n * Use a mutation observer on the root element\n * to detect intersection changes.\n */\nIntersectionObserver.prototype.USE_MUTATION_OBSERVER = true;\n\n\n/**\n * Starts observing a target element for intersection changes based on\n * the thresholds values.\n * @param {Element} target The DOM element to observe.\n */\nIntersectionObserver.prototype.observe = function(target) {\n\tvar isTargetAlreadyObserved = this._observationTargets.some(function(item) {\n\t\treturn item.element == target;\n\t});\n\n\tif (isTargetAlreadyObserved) {\n\t\treturn;\n\t}\n\n\tif (!(target && target.nodeType == 1)) {\n\t\tthrow new Error('target must be an Element');\n\t}\n\n\tthis._registerInstance();\n\tthis._observationTargets.push({element: target, entry: null});\n\tthis._monitorIntersections();\n\tthis._checkForIntersections();\n};\n\n\n/**\n * Stops observing a target element for intersection changes.\n * @param {Element} target The DOM element to observe.\n */\nIntersectionObserver.prototype.unobserve = function(target) {\n\tthis._observationTargets =\n\t\t\tthis._observationTargets.filter(function(item) {\n\n\t\treturn item.element != target;\n\t});\n\tif (!this._observationTargets.length) {\n\t\tthis._unmonitorIntersections();\n\t\tthis._unregisterInstance();\n\t}\n};\n\n\n/**\n * Stops observing all target elements for intersection changes.\n */\nIntersectionObserver.prototype.disconnect = function() {\n\tthis._observationTargets = [];\n\tthis._unmonitorIntersections();\n\tthis._unregisterInstance();\n};\n\n\n/**\n * Returns any queue entries that have not yet been reported to the\n * callback and clears the queue. This can be used in conjunction with the\n * callback to obtain the absolute most up-to-date intersection information.\n * @return {Array} The currently queued entries.\n */\nIntersectionObserver.prototype.takeRecords = function() {\n\tvar records = this._queuedEntries.slice();\n\tthis._queuedEntries = [];\n\treturn records;\n};\n\n\n/**\n * Accepts the threshold value from the user configuration object and\n * returns a sorted array of unique threshold values. If a value is not\n * between 0 and 1 and error is thrown.\n * @private\n * @param {Array|number=} opt_threshold An optional threshold value or\n *     a list of threshold values, defaulting to [0].\n * @return {Array} A sorted list of unique and valid threshold values.\n */\nIntersectionObserver.prototype._initThresholds = function(opt_threshold) {\n\tvar threshold = opt_threshold || [0];\n\tif (!Array.isArray(threshold)) threshold = [threshold];\n\n\treturn threshold.sort().filter(function(t, i, a) {\n\t\tif (typeof t != 'number' || isNaN(t) || t < 0 || t > 1) {\n\t\t\tthrow new Error('threshold must be a number between 0 and 1 inclusively');\n\t\t}\n\t\treturn t !== a[i - 1];\n\t});\n};\n\n\n/**\n * Accepts the rootMargin value from the user configuration object\n * and returns an array of the four margin values as an object containing\n * the value and unit properties. If any of the values are not properly\n * formatted or use a unit other than px or %, and error is thrown.\n * @private\n * @param {string=} opt_rootMargin An optional rootMargin value,\n *     defaulting to '0px'.\n * @return {Array<Object>} An array of margin objects with the keys\n *     value and unit.\n */\nIntersectionObserver.prototype._parseRootMargin = function(opt_rootMargin) {\n\tvar marginString = opt_rootMargin || '0px';\n\tvar margins = marginString.split(/\\s+/).map(function(margin) {\n\t\tvar parts = /^(-?\\d*\\.?\\d+)(px|%)$/.exec(margin);\n\t\tif (!parts) {\n\t\t\tthrow new Error('rootMargin must be specified in pixels or percent');\n\t\t}\n\t\treturn {value: parseFloat(parts[1]), unit: parts[2]};\n\t});\n\n\t// Handles shorthand.\n\tmargins[1] = margins[1] || margins[0];\n\tmargins[2] = margins[2] || margins[0];\n\tmargins[3] = margins[3] || margins[1];\n\n\treturn margins;\n};\n\n\n/**\n * Starts polling for intersection changes if the polling is not already\n * happening, and if the page's visibility state is visible.\n * @private\n */\nIntersectionObserver.prototype._monitorIntersections = function() {\n\tif (!this._monitoringIntersections) {\n\t\tthis._monitoringIntersections = true;\n\n\t\t// If a poll interval is set, use polling instead of listening to\n\t\t// resize and scroll events or DOM mutations.\n\t\tif (this.POLL_INTERVAL) {\n\t\t\tthis._monitoringInterval = setInterval(\n\t\t\t\t\tthis._checkForIntersections, this.POLL_INTERVAL);\n\t\t}\n\t\telse {\n\t\t\taddEvent(window, 'resize', this._checkForIntersections, true);\n\t\t\taddEvent(document, 'scroll', this._checkForIntersections, true);\n\n\t\t\tif (this.USE_MUTATION_OBSERVER && 'MutationObserver' in window) {\n\t\t\t\tthis._domObserver = new MutationObserver(this._checkForIntersections);\n\t\t\t\tthis._domObserver.observe(document, {\n\t\t\t\t\tattributes: true,\n\t\t\t\t\tchildList: true,\n\t\t\t\t\tcharacterData: true,\n\t\t\t\t\tsubtree: true\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n};\n\n\n/**\n * Stops polling for intersection changes.\n * @private\n */\nIntersectionObserver.prototype._unmonitorIntersections = function() {\n\tif (this._monitoringIntersections) {\n\t\tthis._monitoringIntersections = false;\n\n\t\tclearInterval(this._monitoringInterval);\n\t\tthis._monitoringInterval = null;\n\n\t\tremoveEvent(window, 'resize', this._checkForIntersections, true);\n\t\tremoveEvent(document, 'scroll', this._checkForIntersections, true);\n\n\t\tif (this._domObserver) {\n\t\t\tthis._domObserver.disconnect();\n\t\t\tthis._domObserver = null;\n\t\t}\n\t}\n};\n\n\n/**\n * Scans each observation target for intersection changes and adds them\n * to the internal entries queue. If new entries are found, it\n * schedules the callback to be invoked.\n * @private\n */\nIntersectionObserver.prototype._checkForIntersections = function() {\n\tvar rootIsInDom = this._rootIsInDom();\n\tvar rootRect = rootIsInDom ? this._getRootRect() : getEmptyRect();\n\n\tthis._observationTargets.forEach(function(item) {\n\t\tvar target = item.element;\n\t\tvar targetRect = getBoundingClientRect(target);\n\t\tvar rootContainsTarget = this._rootContainsTarget(target);\n\t\tvar oldEntry = item.entry;\n\t\tvar intersectionRect = rootIsInDom && rootContainsTarget &&\n\t\t\t\tthis._computeTargetAndRootIntersection(target, rootRect);\n\n\t\tvar newEntry = item.entry = new IntersectionObserverEntry({\n\t\t\ttime: now(),\n\t\t\ttarget: target,\n\t\t\tboundingClientRect: targetRect,\n\t\t\trootBounds: rootRect,\n\t\t\tintersectionRect: intersectionRect\n\t\t});\n\n\t\tif (!oldEntry) {\n\t\t\tthis._queuedEntries.push(newEntry);\n\t\t} else if (rootIsInDom && rootContainsTarget) {\n\t\t\t// If the new entry intersection ratio has crossed any of the\n\t\t\t// thresholds, add a new entry.\n\t\t\tif (this._hasCrossedThreshold(oldEntry, newEntry)) {\n\t\t\t\tthis._queuedEntries.push(newEntry);\n\t\t\t}\n\t\t} else {\n\t\t\t// If the root is not in the DOM or target is not contained within\n\t\t\t// root but the previous entry for this target had an intersection,\n\t\t\t// add a new record indicating removal.\n\t\t\tif (oldEntry && oldEntry.isIntersecting) {\n\t\t\t\tthis._queuedEntries.push(newEntry);\n\t\t\t}\n\t\t}\n\t}, this);\n\n\tif (this._queuedEntries.length) {\n\t\tthis._callback(this.takeRecords(), this);\n\t}\n};\n\n\n/**\n * Accepts a target and root rect computes the intersection between then\n * following the algorithm in the spec.\n * TODO(philipwalton): at this time clip-path is not considered.\n * https://w3c.github.io/IntersectionObserver/#calculate-intersection-rect-algo\n * @param {Element} target The target DOM element\n * @param {Object} rootRect The bounding rect of the root after being\n *     expanded by the rootMargin value.\n * @return {?Object} The final intersection rect object or undefined if no\n *     intersection is found.\n * @private\n */\nIntersectionObserver.prototype._computeTargetAndRootIntersection =\n\t\tfunction(target, rootRect) {\n\n\t// If the element isn't displayed, an intersection can't happen.\n\tif (window.getComputedStyle(target).display == 'none') return;\n\n\tvar targetRect = getBoundingClientRect(target);\n\tvar intersectionRect = targetRect;\n\tvar parent = getParentNode(target);\n\tvar atRoot = false;\n\n\twhile (!atRoot) {\n\t\tvar parentRect = null;\n\t\tvar parentComputedStyle = parent.nodeType == 1 ?\n\t\t\t\twindow.getComputedStyle(parent) : {};\n\n\t\t// If the parent isn't displayed, an intersection can't happen.\n\t\tif (parentComputedStyle.display == 'none') return;\n\n\t\tif (parent == this.root || parent == document) {\n\t\t\tatRoot = true;\n\t\t\tparentRect = rootRect;\n\t\t} else {\n\t\t\t// If the element has a non-visible overflow, and it's not the <body>\n\t\t\t// or <html> element, update the intersection rect.\n\t\t\t// Note: <body> and <html> cannot be clipped to a rect that's not also\n\t\t\t// the document rect, so no need to compute a new intersection.\n\t\t\tif (parent != document.body &&\n\t\t\t\t\tparent != document.documentElement &&\n\t\t\t\t\tparentComputedStyle.overflow != 'visible') {\n\t\t\t\tparentRect = getBoundingClientRect(parent);\n\t\t\t}\n\t\t}\n\n\t\t// If either of the above conditionals set a new parentRect,\n\t\t// calculate new intersection data.\n\t\tif (parentRect) {\n\t\t\tintersectionRect = computeRectIntersection(parentRect, intersectionRect);\n\n\t\t\tif (!intersectionRect) break;\n\t\t}\n\t\tparent = getParentNode(parent);\n\t}\n\treturn intersectionRect;\n};\n\n\n/**\n * Returns the root rect after being expanded by the rootMargin value.\n * @return {Object} The expanded root rect.\n * @private\n */\nIntersectionObserver.prototype._getRootRect = function() {\n\tvar rootRect;\n\tif (this.root) {\n\t\trootRect = getBoundingClientRect(this.root);\n\t} else {\n\t\t// Use <html>/<body> instead of window since scroll bars affect size.\n\t\tvar html = document.documentElement;\n\t\tvar body = document.body;\n\t\trootRect = {\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\ttop: 0,\n\t\t\tleft: 0,\n\t\t\tright: html.clientWidth || body.clientWidth,\n\t\t\twidth: html.clientWidth || body.clientWidth,\n\t\t\tbottom: html.clientHeight || body.clientHeight,\n\t\t\theight: html.clientHeight || body.clientHeight\n\t\t};\n\t}\n\treturn this._expandRectByRootMargin(rootRect);\n};\n\n\n/**\n * Accepts a rect and expands it by the rootMargin value.\n * @param {Object} rect The rect object to expand.\n * @return {Object} The expanded rect.\n * @private\n */\nIntersectionObserver.prototype._expandRectByRootMargin = function(rect) {\n\tvar margins = this._rootMarginValues.map(function(margin, i) {\n\t\treturn margin.unit == 'px' ? margin.value :\n\t\t\t\tmargin.value * (i % 2 ? rect.width : rect.height) / 100;\n\t});\n\tvar newRect = {\n\t\ttop: rect.top - margins[0],\n\t\tright: rect.right + margins[1],\n\t\tbottom: rect.bottom + margins[2],\n\t\tleft: rect.left - margins[3]\n\t};\n\tnewRect.width = newRect.right - newRect.left;\n\tnewRect.height = newRect.bottom - newRect.top;\n\tnewRect.x = newRect.left;\n\tnewRect.y = newRect.top;\n\n\treturn newRect;\n};\n\n\n/**\n * Accepts an old and new entry and returns true if at least one of the\n * threshold values has been crossed.\n * @param {?IntersectionObserverEntry} oldEntry The previous entry for a\n *    particular target element or null if no previous entry exists.\n * @param {IntersectionObserverEntry} newEntry The current entry for a\n *    particular target element.\n * @return {boolean} Returns true if a any threshold has been crossed.\n * @private\n */\nIntersectionObserver.prototype._hasCrossedThreshold =\n\t\tfunction(oldEntry, newEntry) {\n\n\t// To make comparing easier, an entry that has a ratio of 0\n\t// but does not actually intersect is given a value of -1\n\tvar oldRatio = oldEntry && oldEntry.isIntersecting ?\n\t\t\toldEntry.intersectionRatio || 0 : -1;\n\tvar newRatio = newEntry.isIntersecting ?\n\t\t\tnewEntry.intersectionRatio || 0 : -1;\n\n\t// Ignore unchanged ratios\n\tif (oldRatio === newRatio) return;\n\n\tfor (var i = 0; i < this.thresholds.length; i++) {\n\t\tvar threshold = this.thresholds[i];\n\n\t\t// Return true if an entry matches a threshold or if the new ratio\n\t\t// and the old ratio are on the opposite sides of a threshold.\n\t\tif (threshold == oldRatio || threshold == newRatio ||\n\t\t\t\tthreshold < oldRatio !== threshold < newRatio) {\n\t\t\treturn true;\n\t\t}\n\t}\n};\n\n\n/**\n * Returns whether or not the root element is an element and is in the DOM.\n * @return {boolean} True if the root element is an element and is in the DOM.\n * @private\n */\nIntersectionObserver.prototype._rootIsInDom = function() {\n\treturn !this.root || containsDeep(document, this.root);\n};\n\n\n/**\n * Returns whether or not the target element is a child of root.\n * @param {Element} target The target element to check.\n * @return {boolean} True if the target element is a child of root.\n * @private\n */\nIntersectionObserver.prototype._rootContainsTarget = function(target) {\n\treturn containsDeep(this.root || document, target);\n};\n\n\n/**\n * Adds the instance to the global IntersectionObserver registry if it isn't\n * already present.\n * @private\n */\nIntersectionObserver.prototype._registerInstance = function() {\n\tif (registry.indexOf(this) < 0) {\n\t\tregistry.push(this);\n\t}\n};\n\n\n/**\n * Removes the instance from the global IntersectionObserver registry.\n * @private\n */\nIntersectionObserver.prototype._unregisterInstance = function() {\n\tvar index = registry.indexOf(this);\n\tif (index != -1) registry.splice(index, 1);\n};\n\n\n/**\n * Returns the result of the performance.now() method or null in browsers\n * that don't support the API.\n * @return {number} The elapsed time since the page was requested.\n */\nfunction now() {\n\treturn window.performance && performance.now && performance.now();\n}\n\n\n/**\n * Throttles a function and delays its execution, so it's only called at most\n * once within a given time period.\n * @param {Function} fn The function to throttle.\n * @param {number} timeout The amount of time that must pass before the\n *     function can be called again.\n * @return {Function} The throttled function.\n */\nfunction throttle(fn, timeout) {\n\tvar timer = null;\n\treturn function () {\n\t\tif (!timer) {\n\t\t\ttimer = setTimeout(function() {\n\t\t\t\tfn();\n\t\t\t\ttimer = null;\n\t\t\t}, timeout);\n\t\t}\n\t};\n}\n\n\n/**\n * Adds an event handler to a DOM node ensuring cross-browser compatibility.\n * @param {Node} node The DOM node to add the event handler to.\n * @param {string} event The event name.\n * @param {Function} fn The event handler to add.\n * @param {boolean} opt_useCapture Optionally adds the even to the capture\n *     phase. Note: this only works in modern browsers.\n */\nfunction addEvent(node, event, fn, opt_useCapture) {\n\tif (typeof node.addEventListener == 'function') {\n\t\tnode.addEventListener(event, fn, opt_useCapture || false);\n\t}\n\telse if (typeof node.attachEvent == 'function') {\n\t\tnode.attachEvent('on' + event, fn);\n\t}\n}\n\n\n/**\n * Removes a previously added event handler from a DOM node.\n * @param {Node} node The DOM node to remove the event handler from.\n * @param {string} event The event name.\n * @param {Function} fn The event handler to remove.\n * @param {boolean} opt_useCapture If the event handler was added with this\n *     flag set to true, it should be set to true here in order to remove it.\n */\nfunction removeEvent(node, event, fn, opt_useCapture) {\n\tif (typeof node.removeEventListener == 'function') {\n\t\tnode.removeEventListener(event, fn, opt_useCapture || false);\n\t}\n\telse if (typeof node.detatchEvent == 'function') {\n\t\tnode.detatchEvent('on' + event, fn);\n\t}\n}\n\n\n/**\n * Returns the intersection between two rect objects.\n * @param {Object} rect1 The first rect.\n * @param {Object} rect2 The second rect.\n * @return {?Object} The intersection rect or undefined if no intersection\n *     is found.\n */\nfunction computeRectIntersection(rect1, rect2) {\n\tvar top = Math.max(rect1.top, rect2.top);\n\tvar bottom = Math.min(rect1.bottom, rect2.bottom);\n\tvar left = Math.max(rect1.left, rect2.left);\n\tvar right = Math.min(rect1.right, rect2.right);\n\tvar width = right - left;\n\tvar height = bottom - top;\n\n\treturn (width >= 0 && height >= 0) && {\n\t\tx: left,\n\t\ty: top,\n\t\ttop: top,\n\t\tbottom: bottom,\n\t\tleft: left,\n\t\tright: right,\n\t\twidth: width,\n\t\theight: height\n\t};\n}\n\n\n/**\n * Shims the native getBoundingClientRect for compatibility with older IE.\n * @param {Element} el The element whose bounding rect to get.\n * @return {Object} The (possibly shimmed) rect of the element.\n */\nfunction getBoundingClientRect(el) {\n\tvar rect;\n\n\ttry {\n\t\trect = el.getBoundingClientRect();\n\t} catch (err) {\n\t\t// Ignore Windows 7 IE11 \"Unspecified error\"\n\t\t// https://github.com/w3c/IntersectionObserver/pull/205\n\t}\n\n\tif (!rect) return getEmptyRect();\n\n\t// Older IE\n\tif (!(rect.width && rect.height && rect.x && rect.y)) {\n\t\trect = {\n\t\t\tx: rect.left,\n\t\t\ty: rect.top,\n\t\t\ttop: rect.top,\n\t\t\tright: rect.right,\n\t\t\tbottom: rect.bottom,\n\t\t\tleft: rect.left,\n\t\t\twidth: rect.right - rect.left,\n\t\t\theight: rect.bottom - rect.top\n\t\t};\n\t}\n\treturn rect;\n}\n\n\n/**\n * Returns an empty rect object. An empty rect is returned when an element\n * is not in the DOM.\n * @return {Object} The empty rect.\n */\nfunction getEmptyRect() {\n\treturn {\n\t\tx: 0,\n\t\ty: 0,\n\t\ttop: 0,\n\t\tbottom: 0,\n\t\tleft: 0,\n\t\tright: 0,\n\t\twidth: 0,\n\t\theight: 0\n\t};\n}\n\n/**\n * Checks to see if a parent element contains a child element (including inside\n * shadow DOM).\n * @param {Node} parent The parent element.\n * @param {Node} child The child element.\n * @return {boolean} True if the parent node contains the child node.\n */\nfunction containsDeep(parent, child) {\n\tvar node = child;\n\twhile (node) {\n\t\tif (node == parent) return true;\n\n\t\tnode = getParentNode(node);\n\t}\n\treturn false;\n}\n\n\n/**\n * Gets the parent node of an element or its host element if the parent node\n * is a shadow root.\n * @param {Node} node The node whose parent to get.\n * @return {Node|null} The parent node or null if no parent exists.\n */\nfunction getParentNode(node) {\n\tvar parent = node.parentNode;\n\n\tif (parent && parent.nodeType == 11 && parent.host) {\n\t\t// If the parent is a shadow root, return the host element.\n\t\treturn parent.host;\n\t}\n\n\tif (parent && parent.assignedSlot) {\n\t\t// If the parent is distributed in a <slot>, return the parent of a slot.\n\t\treturn parent.assignedSlot.parentNode;\n\t}\n\n\treturn parent;\n}\n\n\n// Exposes the constructors globally.\nwindow.IntersectionObserver = IntersectionObserver;\nwindow.IntersectionObserverEntry = IntersectionObserverEntry;\n\n}(window, document));\n}}).call('object' === typeof window && window || 'object' === typeof self && self || 'object' === typeof global && global || {});\n", "import {uniqueArray} from 'ext.gadget.Util';\n\nconst isInlineHTMLElement = (node: Node): node is HTMLElement => {\n\treturn node instanceof HTMLElement && window.getComputedStyle(node).display.includes('inline');\n};\n\nconst isTextNode = (node: Node): node is Text => {\n\treturn node.nodeType === Node.TEXT_NODE;\n};\n\nconst isVisible = (element: Element): boolean => {\n\tconst style: CSSStyleDeclaration = window.getComputedStyle(element);\n\n\treturn (\n\t\tstyle.display !== 'none' &&\n\t\t!['hidden', 'collapse'].includes(style.visibility) &&\n\t\tNumber.parseFloat(style.opacity) > 0\n\t);\n};\n\nconst getNodeText = (node: HTMLElement | Text): string => {\n\t// eslint-disable-next-line unicorn/prefer-dom-node-text-content\n\treturn node instanceof HTMLElement ? node.innerText : node.data;\n};\n\n/**\n * Split a string before an array of indexes.\n *\n * For example,\n * ```\n * splitAtIndexes('123456789', [3, 5, 7]);\n * ```\n * results in\n * ```\n * ['123', '45', '67', '89']\n * ```\n *\n * Note that empty string are included:\n * ```\n * splitAtIndexes('123456789', [0, 9]);\n * ```\n * results in\n * ```\n * ['', '123456789', '']\n * ```\n *\n * Indexes that are negative or greater than the length of the string are ignored.\n *\n * @param {string} str string to split\n * @param {number[]} indexes indexes\n * @return {string[]} splitted string fragments\n */\nconst splitAtIndexes = (str: string, indexes: number[]): string[] => {\n\tconst result: string[] = [];\n\n\tconst normalizedIndexes: number[] = [\n\t\t// Remove duplications and sort in ascending order\n\t\t...uniqueArray(\n\t\t\t// Replace `new Set()` to avoid polyfilling core-js\n\t\t\tindexes\n\t\t\t\t.sort((a: number, b: number): number => {\n\t\t\t\t\treturn a - b;\n\t\t\t\t})\n\t\t\t\t.filter((i: number): boolean => {\n\t\t\t\t\treturn i >= 0 && i <= str.length;\n\t\t\t\t})\n\t\t),\n\t\tstr.length,\n\t];\n\n\tfor (let i: number = 0; i < normalizedIndexes.length; i++) {\n\t\tconst slice: string = str.slice(normalizedIndexes[i - 1], normalizedIndexes[i]);\n\t\tresult[result.length] = slice; // Replace `[].push()` to avoid polyfilling core-js\n\t}\n\n\treturn result;\n};\n\nexport {isInlineHTMLElement, isTextNode, isVisible, getNodeText, splitAtIndexes};\n", "type DomMutationFunc = (element: Element) => void;\n\nconst pendingActions: WeakMap<Element, DomMutationFunc[]> = new WeakMap<Element, DomMutationFunc[]>();\n\nconst onIntersection = (entries: IntersectionObserverEntry[]): void => {\n\tfor (const entry of entries) {\n\t\tif (!entry.isIntersecting) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst element: Element = entry.target;\n\t\tobserver.unobserve(element);\n\n\t\tconst callbacks: DomMutationFunc[] | undefined = pendingActions.get(element);\n\t\tif (!callbacks) {\n\t\t\tcontinue;\n\t\t}\n\n\t\twhile (true) {\n\t\t\tconst callback: DomMutationFunc | undefined = callbacks.shift(); // FIFO\n\t\t\tif (!callback) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcallback(element);\n\t\t}\n\t}\n};\n\n// Optimization: lazily execute pending actions once an element is visible\nconst observer: IntersectionObserver = new IntersectionObserver(onIntersection);\n\nconst queueDomMutation = (element: Element, callback: DomMutationFunc): void => {\n\tif (!pendingActions.has(element)) {\n\t\tpendingActions.set(element, []);\n\t}\n\n\tif (pendingActions.get(element) !== undefined) {\n\t\t(pendingActions.get(element) as DomMutationFunc[])[(pendingActions.get(element) as DomMutationFunc[]).length] =\n\t\t\tcallback;\n\t}\n\tobserver.observe(element);\n};\n\nexport {queueDomMutation};\n", "import {getNodeText, isInlineHTMLElement, isTextNode, isVisible, splitAtIndexes} from './util';\nimport {queueDomMutation} from './queue';\n\nconst REGEX_RANGE_CHINESE: string =\n\t'(?:[\\\\u2E80-\\\\u2E99\\\\u2E9B-\\\\u2EF3\\\\u2F00-\\\\u2FD5\\\\u3005\\\\u3007\\\\u3021-\\\\u3029\\\\u3038-\\\\u303B\\\\u3400-\\\\u4DBF\\\\u4E00-\\\\u9FFF\\\\uF900-\\\\uFA6D\\\\uFA70-\\\\uFAD9]|\\\\uD81B[\\\\uDFE2\\\\uDFE3\\\\uDFF0\\\\uDFF1]|[\\\\uD840-\\\\uD868\\\\uD86A-\\\\uD86C\\\\uD86F-\\\\uD872\\\\uD874-\\\\uD879\\\\uD880-\\\\uD883][\\\\uDC00-\\\\uDFFF]|\\\\uD869[\\\\uDC00-\\\\uDEDF\\\\uDF00-\\\\uDFFF]|\\\\uD86D[\\\\uDC00-\\\\uDF38\\\\uDF40-\\\\uDFFF]|\\\\uD86E[\\\\uDC00-\\\\uDC1D\\\\uDC20-\\\\uDFFF]|\\\\uD873[\\\\uDC00-\\\\uDEA1\\\\uDEB0-\\\\uDFFF]|\\\\uD87A[\\\\uDC00-\\\\uDFE0]|\\\\uD87E[\\\\uDC00-\\\\uDE1D]|\\\\uD884[\\\\uDC00-\\\\uDF4A])';\nconst REGEX_RANGE_OTHER_LEFT: string = '[A-Za-z0-9@~%+=|±\\\\)}#$¥€£₤]';\nconst REGEX_RANGE_OTHER_RIGHT: string = '[A-Za-z0-9@~%+=|±\\\\({#$¥€£₤]';\nconst REGEX_STR_INTER_SCRIPT: string = `(?:(${REGEX_RANGE_CHINESE})(?=${REGEX_RANGE_OTHER_RIGHT})|(${REGEX_RANGE_OTHER_LEFT})(?=${REGEX_RANGE_CHINESE}))`;\n\nconst SPACE: string = '\\u200A';\n\nconst WRAPPER_CLASS: string = 'gadget-text_spacing';\n\nconst SELECTOR_ALLOWED: string[] = [\n\t'a',\n\t'abbr',\n\t'article',\n\t'aside',\n\t'b',\n\t'bdi',\n\t'big',\n\t'blockquote',\n\t'button',\n\t'caption',\n\t'center',\n\t'cite',\n\t'data',\n\t'dd',\n\t'del',\n\t'details',\n\t'dfn',\n\t'div',\n\t'dt',\n\t'em',\n\t'figcaption',\n\t'footer',\n\t'h1',\n\t'h2',\n\t'h3',\n\t'h4',\n\t'h5',\n\t'header',\n\t'i',\n\t'ins',\n\t'label',\n\t'legend',\n\t'li',\n\t'main',\n\t'mark',\n\t'option',\n\t'p',\n\t'q',\n\t'ruby',\n\t's',\n\t'section',\n\t'small',\n\t'span',\n\t'strike',\n\t'strong',\n\t'sub',\n\t'summary',\n\t'sup',\n\t'td',\n\t'th',\n\t'time',\n\t'u',\n];\nconst SELECTOR_BLOCKED: string[] = [\n\t'code',\n\t'kbd',\n\t'pre',\n\t'rp',\n\t'rt',\n\t'samp',\n\t'textarea',\n\t'var',\n\t// Elements with this class are excluded\n\t'.gadget-nospace',\n\t// Editable elements\n\t'[contenteditable=\"true\"]',\n\t// ACE editor content\n\t'.ace_editor',\n\t// Visual Editor (and 2017 Wikitext Editor) content & diff\n\t'.ve-ui-surface',\n\t'.ve-init-mw-diffPage-diff',\n\t// Diff\n\t'.diff-context',\n\t'.diff-addedline',\n\t'.diff-deletedline',\n\t// Diff (inline mode)\n\t'.mw-diff-inline-added',\n\t'.mw-diff-inline-deleted',\n\t'.mw-diff-inline-moved',\n\t'.mw-diff-inline-changed',\n\t'.mw-diff-inline-context',\n];\n\n// FIXME: Use :is() in the future once it has better browser compatibility\nconst SELECTOR: string = SELECTOR_ALLOWED.map((allowed: string): string => {\n\treturn `${allowed}:not(${SELECTOR_BLOCKED.flatMap((blocked: string): string | string[] => {\n\t\t// Not include itself if it is a tag selector\n\t\treturn (blocked[0] as string).match(/[a-z]/i) ? `${blocked} *` : [blocked, `${blocked} *`];\n\t}).join(',')})`;\n}).join(',');\n\nconst getLeafElements = (parent: HTMLElement): HTMLElement[] => {\n\tconst candidates: NodeListOf<HTMLElement> = parent.querySelectorAll(SELECTOR);\n\tconst result: HTMLElement[] = [];\n\n\tif (parent.matches(SELECTOR)) {\n\t\tresult[result.length] = parent; // Replace `result.push()` to avoid polyfilling core-js\n\t}\n\n\tfor (const candidate of candidates) {\n\t\tfor (const childNode of candidate.childNodes) {\n\t\t\tif (isTextNode(childNode)) {\n\t\t\t\tresult[result.length] = candidate; // Replace `result.push()` to avoid polyfilling core-js\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn result;\n};\n\nconst getNextVisibleSibling = (node: Node): HTMLElement | Text | null => {\n\tlet currentNode: Node = node;\n\n\t// Use loops rather than recursion for better performance\n\twhile (true) {\n\t\tconst candidate: ChildNode | null = currentNode.nextSibling;\n\n\t\tif (!candidate) {\n\t\t\tconst parent: HTMLElement | null = currentNode.parentElement;\n\t\t\tif (!parent) {\n\t\t\t\t// Parent is Document, so no visible sibling\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\t// Bubble up to its parent and get its sibling\n\t\t\tcurrentNode = parent;\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (!(candidate instanceof HTMLElement || candidate instanceof Text)) {\n\t\t\t// Comments, SVGs, etc.: get its sibling as result\n\t\t\tcurrentNode = candidate;\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (candidate instanceof HTMLElement) {\n\t\t\tif (!isVisible(candidate)) {\n\t\t\t\t// Invisible: recursively get this element's next sibling\n\t\t\t\tcurrentNode = candidate;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tif (!isInlineHTMLElement(candidate)) {\n\t\t\t\t// Next sibling is not inline (at next line), so no siblings\n\t\t\t\treturn null;\n\t\t\t}\n\t\t}\n\n\t\tif (candidate instanceof Text && !candidate.data.trim()) {\n\t\t\t// Skip empty Text nodes (e.g. line breaks)\n\t\t\tcurrentNode = candidate;\n\t\t\tcontinue;\n\t\t}\n\n\t\treturn candidate;\n\t}\n};\n\nconst createSpacingWrapper = (str: string): [string, HTMLSpanElement] => {\n\tconst span: HTMLSpanElement = document.createElement('span');\n\t// eslint-disable-next-line mediawiki/class-doc\n\tspan.className = WRAPPER_CLASS;\n\tspan.textContent = str.slice(-1);\n\n\treturn [str.slice(0, -1), span];\n};\n\nconst adjustSpacing = (element: HTMLElement): void => {\n\t// Freeze NodeList in advance\n\tconst childNodes: ChildNode[] = [...element.childNodes];\n\tconst textSpacingPosMap: Map<Text, number[]> = new Map<Text, number[]>();\n\n\tfor (const child of childNodes) {\n\t\tif (!(child instanceof Text)) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst nextSibling: HTMLElement | Text | null = getNextVisibleSibling(child);\n\n\t\tlet testString: string = getNodeText(child);\n\t\tif (nextSibling) {\n\t\t\t// Append first character to detect script intersection\n\t\t\ttestString += getNodeText(nextSibling)[0] ?? '';\n\t\t}\n\n\t\tconst indexes: number[] = [];\n\t\t// Global regexps are stateful so do initialization in each loop\n\t\tconst regexTextNodeData: RegExp = new RegExp(REGEX_STR_INTER_SCRIPT, 'g');\n\n\t\twhile (true) {\n\t\t\tconst match: RegExpExecArray | null = regexTextNodeData.exec(testString);\n\t\t\tif (!match) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tindexes[indexes.length] = match.index + 1; // Replace `indexes.push()` to avoid polyfilling core-js\n\t\t}\n\n\t\tif (!indexes.length) {\n\t\t\t// Optimization: skip further steps\n\t\t\t// Also prevent unnecessary mutation, which will be detected by MutationObserver,\n\t\t\t// resulting in infinite loops\n\t\t\tcontinue;\n\t\t}\n\n\t\ttextSpacingPosMap.set(child, indexes);\n\t}\n\n\t// Schedule DOM mutation to prevent forced reflows\n\tqueueDomMutation(element, (): void => {\n\t\tfor (const [node, indexes] of textSpacingPosMap) {\n\t\t\tconst text: string = node.data;\n\t\t\tconst fragments: string[] = splitAtIndexes(text, indexes);\n\n\t\t\tconst replacement: (string | HTMLSpanElement)[] = fragments\n\t\t\t\t.slice(0, -1)\n\t\t\t\t.flatMap((fragment: string): [string, HTMLSpanElement] => {\n\t\t\t\t\treturn createSpacingWrapper(fragment);\n\t\t\t\t});\n\t\t\treplacement[replacement.length] = fragments.at(-1) as string; // Replace `replacement.push()` to avoid polyfilling core-js\n\n\t\t\t// Optimization: prevent forced reflows\n\t\t\trequestAnimationFrame(() => {\n\t\t\t\tnode.replaceWith(...replacement);\n\t\t\t});\n\t\t}\n\t});\n};\n\nconst addSpaceToString = (str: string): string => {\n\tconst regex: RegExp = new RegExp(REGEX_STR_INTER_SCRIPT, 'g');\n\n\treturn str.replace(regex, `$1$2${SPACE}`);\n};\n\nexport {getLeafElements, adjustSpacing, addSpaceToString, WRAPPER_CLASS};\n", "import './TextSpacing.less';\nimport {WRAPPER_CLASS, addSpaceToString, adjustSpacing, getLeafElements} from './modules/spacing';\n\nconst run = (element: HTMLElement): void => {\n\tconst leaves: HTMLElement[] = getLeafElements(element);\n\tfor (const leaf of leaves) {\n\t\tadjustSpacing(leaf);\n\t}\n};\n\nconst mutationObserver: MutationObserver = new MutationObserver((records: MutationRecord[]): void => {\n\tfor (const record of records) {\n\t\tif (record.type !== 'childList') {\n\t\t\tcontinue;\n\t\t}\n\n\t\tconst addedNodes: Node[] = [...record.addedNodes];\n\n\t\t// Exclude mutations caused by adjustSpacing() to prevent infinite loops\n\t\t// Typically they will contain nodes with class WRAPPER_CLASS\n\t\tif (\n\t\t\taddedNodes.some((node: Node): boolean => {\n\t\t\t\treturn node instanceof HTMLElement && node.classList.contains(WRAPPER_CLASS);\n\t\t\t})\n\t\t) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tfor (const node of addedNodes) {\n\t\t\tif (node instanceof HTMLElement) {\n\t\t\t\trun(node);\n\t\t\t} else if (node instanceof Text) {\n\t\t\t\tconst {parentElement} = node;\n\t\t\t\tif (parentElement) {\n\t\t\t\t\trun(parentElement);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n});\n\nconst main = (): void => {\n\tdocument.title = addSpaceToString(document.title);\n\t// Watch for added nodes\n\tmutationObserver.observe(document.body, {\n\t\tsubtree: true,\n\t\tchildList: true,\n\t});\n\trun(document.body);\n};\n\n$(main);\n"],
  "mappings": "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",
  "names": ["window", "document", "IntersectionObserver", "import_ext_gadget", "require", "isInlineHTMLElement", "node", "HTMLElement", "window", "getComputedStyle", "display", "includes", "isTextNode", "nodeType", "Node", "TEXT_NODE", "isVisible", "element", "style", "visibility", "Number", "parseFloat", "opacity", "getNodeText", "innerText", "data", "splitAtIndexes", "str", "indexes", "result", "normalizedIndexes", "uniqueArray", "sort", "a", "b", "filter", "i", "length", "slice", "pendingActions", "WeakMap", "onIntersection", "entries", "_iterator", "_createForOfIteratorHelper", "_step", "s", "n", "done", "entry", "value", "isIntersecting", "target", "observer", "unobserve", "callbacks", "get", "callback", "shift", "err", "e", "f", "IntersectionObserver", "queueDomMutation", "has", "set", "observe", "REGEX_RANGE_CHINESE", "REGEX_RANGE_OTHER_LEFT", "REGEX_RANGE_OTHER_RIGHT", "REGEX_STR_INTER_SCRIPT", "concat", "SPACE", "WRAPPER_CLASS", "SELECTOR_ALLOWED", "SELECTOR_BLOCKED", "SELECTOR", "map", "allowed", "flatMap", "blocked", "match", "join", "getLeafElements", "parent", "candidates", "querySelectorAll", "matches", "_iterator2", "_step2", "candidate", "_iterator3", "childNodes", "_step3", "childNode", "getNextVisibleSibling", "currentNode", "nextSibling", "parentElement", "Text", "trim", "createSpacingWrapper", "span", "document", "createElement", "className", "textContent", "adjustSpacing", "textSpacingPosMap", "Map", "_i", "_childNodes", "child", "testString", "_getNodeText$", "regexTextNodeData", "RegExp", "exec", "index", "_iterator4", "_step4", "text", "fragments", "replacement", "fragment", "at", "requestAnimationFrame", "replaceWith", "addSpaceToString", "regex", "replace", "run", "leaves", "_iterator5", "_step5", "leaf", "mutationObserver", "MutationObserver", "records", "_iterator6", "_step6", "record", "type", "addedNodes", "some", "classList", "contains", "_i2", "_addedNodes", "main", "title", "body", "subtree", "childList", "$"]
}
