fix: resolve TypeScript errors in frontend build

This commit is contained in:
Hiro
2026-03-30 23:16:07 +00:00
parent b733306773
commit 24925e1acb
2941 changed files with 418042 additions and 49 deletions

884
node_modules/prosemirror-state/dist/index.cjs generated vendored Normal file
View File

@@ -0,0 +1,884 @@
'use strict';
function _get() { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get.bind(); } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(arguments.length < 3 ? target : receiver); } return desc.value; }; } return _get.apply(this, arguments); }
function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
var prosemirrorModel = require('prosemirror-model');
var prosemirrorTransform = require('prosemirror-transform');
var classesById = Object.create(null);
var Selection = function () {
function Selection($anchor, $head, ranges) {
_classCallCheck(this, Selection);
this.$anchor = $anchor;
this.$head = $head;
this.ranges = ranges || [new SelectionRange($anchor.min($head), $anchor.max($head))];
}
_createClass(Selection, [{
key: "anchor",
get: function get() {
return this.$anchor.pos;
}
}, {
key: "head",
get: function get() {
return this.$head.pos;
}
}, {
key: "from",
get: function get() {
return this.$from.pos;
}
}, {
key: "to",
get: function get() {
return this.$to.pos;
}
}, {
key: "$from",
get: function get() {
return this.ranges[0].$from;
}
}, {
key: "$to",
get: function get() {
return this.ranges[0].$to;
}
}, {
key: "empty",
get: function get() {
var ranges = this.ranges;
for (var i = 0; i < ranges.length; i++) if (ranges[i].$from.pos != ranges[i].$to.pos) return false;
return true;
}
}, {
key: "content",
value: function content() {
return this.$from.doc.slice(this.from, this.to, true);
}
}, {
key: "replace",
value: function replace(tr) {
var content = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : prosemirrorModel.Slice.empty;
var lastNode = content.content.lastChild,
lastParent = null;
for (var i = 0; i < content.openEnd; i++) {
lastParent = lastNode;
lastNode = lastNode.lastChild;
}
var mapFrom = tr.steps.length,
ranges = this.ranges;
for (var _i = 0; _i < ranges.length; _i++) {
var _ranges$_i = ranges[_i],
$from = _ranges$_i.$from,
$to = _ranges$_i.$to,
mapping = tr.mapping.slice(mapFrom);
tr.replaceRange(mapping.map($from.pos), mapping.map($to.pos), _i ? prosemirrorModel.Slice.empty : content);
if (_i == 0) selectionToInsertionEnd(tr, mapFrom, (lastNode ? lastNode.isInline : lastParent && lastParent.isTextblock) ? -1 : 1);
}
}
}, {
key: "replaceWith",
value: function replaceWith(tr, node) {
var mapFrom = tr.steps.length,
ranges = this.ranges;
for (var i = 0; i < ranges.length; i++) {
var _ranges$i = ranges[i],
$from = _ranges$i.$from,
$to = _ranges$i.$to,
mapping = tr.mapping.slice(mapFrom);
var from = mapping.map($from.pos),
to = mapping.map($to.pos);
if (i) {
tr.deleteRange(from, to);
} else {
tr.replaceRangeWith(from, to, node);
selectionToInsertionEnd(tr, mapFrom, node.isInline ? -1 : 1);
}
}
}
}, {
key: "getBookmark",
value: function getBookmark() {
return TextSelection.between(this.$anchor, this.$head).getBookmark();
}
}], [{
key: "findFrom",
value: function findFrom($pos, dir) {
var textOnly = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
var inner = $pos.parent.inlineContent ? new TextSelection($pos) : findSelectionIn($pos.node(0), $pos.parent, $pos.pos, $pos.index(), dir, textOnly);
if (inner) return inner;
for (var depth = $pos.depth - 1; depth >= 0; depth--) {
var found = dir < 0 ? findSelectionIn($pos.node(0), $pos.node(depth), $pos.before(depth + 1), $pos.index(depth), dir, textOnly) : findSelectionIn($pos.node(0), $pos.node(depth), $pos.after(depth + 1), $pos.index(depth) + 1, dir, textOnly);
if (found) return found;
}
return null;
}
}, {
key: "near",
value: function near($pos) {
var bias = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
return this.findFrom($pos, bias) || this.findFrom($pos, -bias) || new AllSelection($pos.node(0));
}
}, {
key: "atStart",
value: function atStart(doc) {
return findSelectionIn(doc, doc, 0, 0, 1) || new AllSelection(doc);
}
}, {
key: "atEnd",
value: function atEnd(doc) {
return findSelectionIn(doc, doc, doc.content.size, doc.childCount, -1) || new AllSelection(doc);
}
}, {
key: "fromJSON",
value: function fromJSON(doc, json) {
if (!json || !json.type) throw new RangeError("Invalid input for Selection.fromJSON");
var cls = classesById[json.type];
if (!cls) throw new RangeError("No selection type ".concat(json.type, " defined"));
return cls.fromJSON(doc, json);
}
}, {
key: "jsonID",
value: function jsonID(id, selectionClass) {
if (id in classesById) throw new RangeError("Duplicate use of selection JSON ID " + id);
classesById[id] = selectionClass;
selectionClass.prototype.jsonID = id;
return selectionClass;
}
}]);
return Selection;
}();
Selection.prototype.visible = true;
var SelectionRange = _createClass(function SelectionRange($from, $to) {
_classCallCheck(this, SelectionRange);
this.$from = $from;
this.$to = $to;
});
var warnedAboutTextSelection = false;
function checkTextSelection($pos) {
if (!warnedAboutTextSelection && !$pos.parent.inlineContent) {
warnedAboutTextSelection = true;
console["warn"]("TextSelection endpoint not pointing into a node with inline content (" + $pos.parent.type.name + ")");
}
}
var TextSelection = function (_Selection) {
_inherits(TextSelection, _Selection);
var _super = _createSuper(TextSelection);
function TextSelection($anchor) {
var $head = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : $anchor;
_classCallCheck(this, TextSelection);
checkTextSelection($anchor);
checkTextSelection($head);
return _super.call(this, $anchor, $head);
}
_createClass(TextSelection, [{
key: "$cursor",
get: function get() {
return this.$anchor.pos == this.$head.pos ? this.$head : null;
}
}, {
key: "map",
value: function map(doc, mapping) {
var $head = doc.resolve(mapping.map(this.head));
if (!$head.parent.inlineContent) return Selection.near($head);
var $anchor = doc.resolve(mapping.map(this.anchor));
return new TextSelection($anchor.parent.inlineContent ? $anchor : $head, $head);
}
}, {
key: "replace",
value: function replace(tr) {
var content = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : prosemirrorModel.Slice.empty;
_get(_getPrototypeOf(TextSelection.prototype), "replace", this).call(this, tr, content);
if (content == prosemirrorModel.Slice.empty) {
var marks = this.$from.marksAcross(this.$to);
if (marks) tr.ensureMarks(marks);
}
}
}, {
key: "eq",
value: function eq(other) {
return other instanceof TextSelection && other.anchor == this.anchor && other.head == this.head;
}
}, {
key: "getBookmark",
value: function getBookmark() {
return new TextBookmark(this.anchor, this.head);
}
}, {
key: "toJSON",
value: function toJSON() {
return {
type: "text",
anchor: this.anchor,
head: this.head
};
}
}], [{
key: "fromJSON",
value: function fromJSON(doc, json) {
if (typeof json.anchor != "number" || typeof json.head != "number") throw new RangeError("Invalid input for TextSelection.fromJSON");
return new TextSelection(doc.resolve(json.anchor), doc.resolve(json.head));
}
}, {
key: "create",
value: function create(doc, anchor) {
var head = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : anchor;
var $anchor = doc.resolve(anchor);
return new this($anchor, head == anchor ? $anchor : doc.resolve(head));
}
}, {
key: "between",
value: function between($anchor, $head, bias) {
var dPos = $anchor.pos - $head.pos;
if (!bias || dPos) bias = dPos >= 0 ? 1 : -1;
if (!$head.parent.inlineContent) {
var found = Selection.findFrom($head, bias, true) || Selection.findFrom($head, -bias, true);
if (found) $head = found.$head;else return Selection.near($head, bias);
}
if (!$anchor.parent.inlineContent) {
if (dPos == 0) {
$anchor = $head;
} else {
$anchor = (Selection.findFrom($anchor, -bias, true) || Selection.findFrom($anchor, bias, true)).$anchor;
if ($anchor.pos < $head.pos != dPos < 0) $anchor = $head;
}
}
return new TextSelection($anchor, $head);
}
}]);
return TextSelection;
}(Selection);
Selection.jsonID("text", TextSelection);
var TextBookmark = function () {
function TextBookmark(anchor, head) {
_classCallCheck(this, TextBookmark);
this.anchor = anchor;
this.head = head;
}
_createClass(TextBookmark, [{
key: "map",
value: function map(mapping) {
return new TextBookmark(mapping.map(this.anchor), mapping.map(this.head));
}
}, {
key: "resolve",
value: function resolve(doc) {
return TextSelection.between(doc.resolve(this.anchor), doc.resolve(this.head));
}
}]);
return TextBookmark;
}();
var NodeSelection = function (_Selection2) {
_inherits(NodeSelection, _Selection2);
var _super2 = _createSuper(NodeSelection);
function NodeSelection($pos) {
var _this;
_classCallCheck(this, NodeSelection);
var node = $pos.nodeAfter;
var $end = $pos.node(0).resolve($pos.pos + node.nodeSize);
_this = _super2.call(this, $pos, $end);
_this.node = node;
return _this;
}
_createClass(NodeSelection, [{
key: "map",
value: function map(doc, mapping) {
var _mapping$mapResult = mapping.mapResult(this.anchor),
deleted = _mapping$mapResult.deleted,
pos = _mapping$mapResult.pos;
var $pos = doc.resolve(pos);
if (deleted) return Selection.near($pos);
return new NodeSelection($pos);
}
}, {
key: "content",
value: function content() {
return new prosemirrorModel.Slice(prosemirrorModel.Fragment.from(this.node), 0, 0);
}
}, {
key: "eq",
value: function eq(other) {
return other instanceof NodeSelection && other.anchor == this.anchor;
}
}, {
key: "toJSON",
value: function toJSON() {
return {
type: "node",
anchor: this.anchor
};
}
}, {
key: "getBookmark",
value: function getBookmark() {
return new NodeBookmark(this.anchor);
}
}], [{
key: "fromJSON",
value: function fromJSON(doc, json) {
if (typeof json.anchor != "number") throw new RangeError("Invalid input for NodeSelection.fromJSON");
return new NodeSelection(doc.resolve(json.anchor));
}
}, {
key: "create",
value: function create(doc, from) {
return new NodeSelection(doc.resolve(from));
}
}, {
key: "isSelectable",
value: function isSelectable(node) {
return !node.isText && node.type.spec.selectable !== false;
}
}]);
return NodeSelection;
}(Selection);
NodeSelection.prototype.visible = false;
Selection.jsonID("node", NodeSelection);
var NodeBookmark = function () {
function NodeBookmark(anchor) {
_classCallCheck(this, NodeBookmark);
this.anchor = anchor;
}
_createClass(NodeBookmark, [{
key: "map",
value: function map(mapping) {
var _mapping$mapResult2 = mapping.mapResult(this.anchor),
deleted = _mapping$mapResult2.deleted,
pos = _mapping$mapResult2.pos;
return deleted ? new TextBookmark(pos, pos) : new NodeBookmark(pos);
}
}, {
key: "resolve",
value: function resolve(doc) {
var $pos = doc.resolve(this.anchor),
node = $pos.nodeAfter;
if (node && NodeSelection.isSelectable(node)) return new NodeSelection($pos);
return Selection.near($pos);
}
}]);
return NodeBookmark;
}();
var AllSelection = function (_Selection3) {
_inherits(AllSelection, _Selection3);
var _super3 = _createSuper(AllSelection);
function AllSelection(doc) {
_classCallCheck(this, AllSelection);
return _super3.call(this, doc.resolve(0), doc.resolve(doc.content.size));
}
_createClass(AllSelection, [{
key: "replace",
value: function replace(tr) {
var content = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : prosemirrorModel.Slice.empty;
if (content == prosemirrorModel.Slice.empty) {
tr["delete"](0, tr.doc.content.size);
var sel = Selection.atStart(tr.doc);
if (!sel.eq(tr.selection)) tr.setSelection(sel);
} else {
_get(_getPrototypeOf(AllSelection.prototype), "replace", this).call(this, tr, content);
}
}
}, {
key: "toJSON",
value: function toJSON() {
return {
type: "all"
};
}
}, {
key: "map",
value: function map(doc) {
return new AllSelection(doc);
}
}, {
key: "eq",
value: function eq(other) {
return other instanceof AllSelection;
}
}, {
key: "getBookmark",
value: function getBookmark() {
return AllBookmark;
}
}], [{
key: "fromJSON",
value: function fromJSON(doc) {
return new AllSelection(doc);
}
}]);
return AllSelection;
}(Selection);
Selection.jsonID("all", AllSelection);
var AllBookmark = {
map: function map() {
return this;
},
resolve: function resolve(doc) {
return new AllSelection(doc);
}
};
function findSelectionIn(doc, node, pos, index, dir) {
var text = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : false;
if (node.inlineContent) return TextSelection.create(doc, pos);
for (var i = index - (dir > 0 ? 0 : 1); dir > 0 ? i < node.childCount : i >= 0; i += dir) {
var child = node.child(i);
if (!child.isAtom) {
var inner = findSelectionIn(doc, child, pos + dir, dir < 0 ? child.childCount : 0, dir, text);
if (inner) return inner;
} else if (!text && NodeSelection.isSelectable(child)) {
return NodeSelection.create(doc, pos - (dir < 0 ? child.nodeSize : 0));
}
pos += child.nodeSize * dir;
}
return null;
}
function selectionToInsertionEnd(tr, startLen, bias) {
var last = tr.steps.length - 1;
if (last < startLen) return;
var step = tr.steps[last];
if (!(step instanceof prosemirrorTransform.ReplaceStep || step instanceof prosemirrorTransform.ReplaceAroundStep)) return;
var map = tr.mapping.maps[last],
end;
map.forEach(function (_from, _to, _newFrom, newTo) {
if (end == null) end = newTo;
});
tr.setSelection(Selection.near(tr.doc.resolve(end), bias));
}
var UPDATED_SEL = 1,
UPDATED_MARKS = 2,
UPDATED_SCROLL = 4;
var Transaction = function (_prosemirrorTransform) {
_inherits(Transaction, _prosemirrorTransform);
var _super4 = _createSuper(Transaction);
function Transaction(state) {
var _this2;
_classCallCheck(this, Transaction);
_this2 = _super4.call(this, state.doc);
_this2.curSelectionFor = 0;
_this2.updated = 0;
_this2.meta = Object.create(null);
_this2.time = Date.now();
_this2.curSelection = state.selection;
_this2.storedMarks = state.storedMarks;
return _this2;
}
_createClass(Transaction, [{
key: "selection",
get: function get() {
if (this.curSelectionFor < this.steps.length) {
this.curSelection = this.curSelection.map(this.doc, this.mapping.slice(this.curSelectionFor));
this.curSelectionFor = this.steps.length;
}
return this.curSelection;
}
}, {
key: "setSelection",
value: function setSelection(selection) {
if (selection.$from.doc != this.doc) throw new RangeError("Selection passed to setSelection must point at the current document");
this.curSelection = selection;
this.curSelectionFor = this.steps.length;
this.updated = (this.updated | UPDATED_SEL) & ~UPDATED_MARKS;
this.storedMarks = null;
return this;
}
}, {
key: "selectionSet",
get: function get() {
return (this.updated & UPDATED_SEL) > 0;
}
}, {
key: "setStoredMarks",
value: function setStoredMarks(marks) {
this.storedMarks = marks;
this.updated |= UPDATED_MARKS;
return this;
}
}, {
key: "ensureMarks",
value: function ensureMarks(marks) {
if (!prosemirrorModel.Mark.sameSet(this.storedMarks || this.selection.$from.marks(), marks)) this.setStoredMarks(marks);
return this;
}
}, {
key: "addStoredMark",
value: function addStoredMark(mark) {
return this.ensureMarks(mark.addToSet(this.storedMarks || this.selection.$head.marks()));
}
}, {
key: "removeStoredMark",
value: function removeStoredMark(mark) {
return this.ensureMarks(mark.removeFromSet(this.storedMarks || this.selection.$head.marks()));
}
}, {
key: "storedMarksSet",
get: function get() {
return (this.updated & UPDATED_MARKS) > 0;
}
}, {
key: "addStep",
value: function addStep(step, doc) {
_get(_getPrototypeOf(Transaction.prototype), "addStep", this).call(this, step, doc);
this.updated = this.updated & ~UPDATED_MARKS;
this.storedMarks = null;
}
}, {
key: "setTime",
value: function setTime(time) {
this.time = time;
return this;
}
}, {
key: "replaceSelection",
value: function replaceSelection(slice) {
this.selection.replace(this, slice);
return this;
}
}, {
key: "replaceSelectionWith",
value: function replaceSelectionWith(node) {
var inheritMarks = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
var selection = this.selection;
if (inheritMarks) node = node.mark(this.storedMarks || (selection.empty ? selection.$from.marks() : selection.$from.marksAcross(selection.$to) || prosemirrorModel.Mark.none));
selection.replaceWith(this, node);
return this;
}
}, {
key: "deleteSelection",
value: function deleteSelection() {
this.selection.replace(this);
return this;
}
}, {
key: "insertText",
value: function insertText(text, from, to) {
var schema = this.doc.type.schema;
if (from == null) {
if (!text) return this.deleteSelection();
return this.replaceSelectionWith(schema.text(text), true);
} else {
if (to == null) to = from;
if (!text) return this.deleteRange(from, to);
var marks = this.storedMarks;
if (!marks) {
var $from = this.doc.resolve(from);
marks = to == from ? $from.marks() : $from.marksAcross(this.doc.resolve(to));
}
this.replaceRangeWith(from, to, schema.text(text, marks));
if (!this.selection.empty && this.selection.to == from + text.length) this.setSelection(Selection.near(this.selection.$to));
return this;
}
}
}, {
key: "setMeta",
value: function setMeta(key, value) {
this.meta[typeof key == "string" ? key : key.key] = value;
return this;
}
}, {
key: "getMeta",
value: function getMeta(key) {
return this.meta[typeof key == "string" ? key : key.key];
}
}, {
key: "isGeneric",
get: function get() {
for (var _ in this.meta) return false;
return true;
}
}, {
key: "scrollIntoView",
value: function scrollIntoView() {
this.updated |= UPDATED_SCROLL;
return this;
}
}, {
key: "scrolledIntoView",
get: function get() {
return (this.updated & UPDATED_SCROLL) > 0;
}
}]);
return Transaction;
}(prosemirrorTransform.Transform);
function bind(f, self) {
return !self || !f ? f : f.bind(self);
}
var FieldDesc = _createClass(function FieldDesc(name, desc, self) {
_classCallCheck(this, FieldDesc);
this.name = name;
this.init = bind(desc.init, self);
this.apply = bind(desc.apply, self);
});
var baseFields = [new FieldDesc("doc", {
init: function init(config) {
return config.doc || config.schema.topNodeType.createAndFill();
},
apply: function apply(tr) {
return tr.doc;
}
}), new FieldDesc("selection", {
init: function init(config, instance) {
return config.selection || Selection.atStart(instance.doc);
},
apply: function apply(tr) {
return tr.selection;
}
}), new FieldDesc("storedMarks", {
init: function init(config) {
return config.storedMarks || null;
},
apply: function apply(tr, _marks, _old, state) {
return state.selection.$cursor ? tr.storedMarks : null;
}
}), new FieldDesc("scrollToSelection", {
init: function init() {
return 0;
},
apply: function apply(tr, prev) {
return tr.scrolledIntoView ? prev + 1 : prev;
}
})];
var Configuration = _createClass(function Configuration(schema, plugins) {
var _this3 = this;
_classCallCheck(this, Configuration);
this.schema = schema;
this.plugins = [];
this.pluginsByKey = Object.create(null);
this.fields = baseFields.slice();
if (plugins) plugins.forEach(function (plugin) {
if (_this3.pluginsByKey[plugin.key]) throw new RangeError("Adding different instances of a keyed plugin (" + plugin.key + ")");
_this3.plugins.push(plugin);
_this3.pluginsByKey[plugin.key] = plugin;
if (plugin.spec.state) _this3.fields.push(new FieldDesc(plugin.key, plugin.spec.state, plugin));
});
});
var EditorState = function () {
function EditorState(config) {
_classCallCheck(this, EditorState);
this.config = config;
}
_createClass(EditorState, [{
key: "schema",
get: function get() {
return this.config.schema;
}
}, {
key: "plugins",
get: function get() {
return this.config.plugins;
}
}, {
key: "apply",
value: function apply(tr) {
return this.applyTransaction(tr).state;
}
}, {
key: "filterTransaction",
value: function filterTransaction(tr) {
var ignore = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : -1;
for (var i = 0; i < this.config.plugins.length; i++) if (i != ignore) {
var plugin = this.config.plugins[i];
if (plugin.spec.filterTransaction && !plugin.spec.filterTransaction.call(plugin, tr, this)) return false;
}
return true;
}
}, {
key: "applyTransaction",
value: function applyTransaction(rootTr) {
if (!this.filterTransaction(rootTr)) return {
state: this,
transactions: []
};
var trs = [rootTr],
newState = this.applyInner(rootTr),
seen = null;
for (;;) {
var haveNew = false;
for (var i = 0; i < this.config.plugins.length; i++) {
var plugin = this.config.plugins[i];
if (plugin.spec.appendTransaction) {
var n = seen ? seen[i].n : 0,
oldState = seen ? seen[i].state : this;
var tr = n < trs.length && plugin.spec.appendTransaction.call(plugin, n ? trs.slice(n) : trs, oldState, newState);
if (tr && newState.filterTransaction(tr, i)) {
tr.setMeta("appendedTransaction", rootTr);
if (!seen) {
seen = [];
for (var j = 0; j < this.config.plugins.length; j++) seen.push(j < i ? {
state: newState,
n: trs.length
} : {
state: this,
n: 0
});
}
trs.push(tr);
newState = newState.applyInner(tr);
haveNew = true;
}
if (seen) seen[i] = {
state: newState,
n: trs.length
};
}
}
if (!haveNew) return {
state: newState,
transactions: trs
};
}
}
}, {
key: "applyInner",
value: function applyInner(tr) {
if (!tr.before.eq(this.doc)) throw new RangeError("Applying a mismatched transaction");
var newInstance = new EditorState(this.config),
fields = this.config.fields;
for (var i = 0; i < fields.length; i++) {
var field = fields[i];
newInstance[field.name] = field.apply(tr, this[field.name], this, newInstance);
}
return newInstance;
}
}, {
key: "tr",
get: function get() {
return new Transaction(this);
}
}, {
key: "reconfigure",
value: function reconfigure(config) {
var $config = new Configuration(this.schema, config.plugins);
var fields = $config.fields,
instance = new EditorState($config);
for (var i = 0; i < fields.length; i++) {
var name = fields[i].name;
instance[name] = this.hasOwnProperty(name) ? this[name] : fields[i].init(config, instance);
}
return instance;
}
}, {
key: "toJSON",
value: function toJSON(pluginFields) {
var result = {
doc: this.doc.toJSON(),
selection: this.selection.toJSON()
};
if (this.storedMarks) result.storedMarks = this.storedMarks.map(function (m) {
return m.toJSON();
});
if (pluginFields && _typeof(pluginFields) == 'object') for (var prop in pluginFields) {
if (prop == "doc" || prop == "selection") throw new RangeError("The JSON fields `doc` and `selection` are reserved");
var plugin = pluginFields[prop],
state = plugin.spec.state;
if (state && state.toJSON) result[prop] = state.toJSON.call(plugin, this[plugin.key]);
}
return result;
}
}], [{
key: "create",
value: function create(config) {
var $config = new Configuration(config.doc ? config.doc.type.schema : config.schema, config.plugins);
var instance = new EditorState($config);
for (var i = 0; i < $config.fields.length; i++) instance[$config.fields[i].name] = $config.fields[i].init(config, instance);
return instance;
}
}, {
key: "fromJSON",
value: function fromJSON(config, json, pluginFields) {
if (!json) throw new RangeError("Invalid input for EditorState.fromJSON");
if (!config.schema) throw new RangeError("Required config field 'schema' missing");
var $config = new Configuration(config.schema, config.plugins);
var instance = new EditorState($config);
$config.fields.forEach(function (field) {
if (field.name == "doc") {
instance.doc = prosemirrorModel.Node.fromJSON(config.schema, json.doc);
} else if (field.name == "selection") {
instance.selection = Selection.fromJSON(instance.doc, json.selection);
} else if (field.name == "storedMarks") {
if (json.storedMarks) instance.storedMarks = json.storedMarks.map(config.schema.markFromJSON);
} else {
if (pluginFields) for (var prop in pluginFields) {
var plugin = pluginFields[prop],
state = plugin.spec.state;
if (plugin.key == field.name && state && state.fromJSON && Object.prototype.hasOwnProperty.call(json, prop)) {
instance[field.name] = state.fromJSON.call(plugin, config, json[prop], instance);
return;
}
}
instance[field.name] = field.init(config, instance);
}
});
return instance;
}
}]);
return EditorState;
}();
function bindProps(obj, self, target) {
for (var prop in obj) {
var val = obj[prop];
if (val instanceof Function) val = val.bind(self);else if (prop == "handleDOMEvents") val = bindProps(val, self, {});
target[prop] = val;
}
return target;
}
var Plugin = function () {
function Plugin(spec) {
_classCallCheck(this, Plugin);
this.spec = spec;
this.props = {};
if (spec.props) bindProps(spec.props, this, this.props);
this.key = spec.key ? spec.key.key : createKey("plugin");
}
_createClass(Plugin, [{
key: "getState",
value: function getState(state) {
return state[this.key];
}
}]);
return Plugin;
}();
var keys = Object.create(null);
function createKey(name) {
if (name in keys) return name + "$" + ++keys[name];
keys[name] = 0;
return name + "$";
}
var PluginKey = function () {
function PluginKey() {
var name = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "key";
_classCallCheck(this, PluginKey);
this.key = createKey(name);
}
_createClass(PluginKey, [{
key: "get",
value: function get(state) {
return state.config.pluginsByKey[this.key];
}
}, {
key: "getState",
value: function getState(state) {
return state[this.key];
}
}]);
return PluginKey;
}();
exports.AllSelection = AllSelection;
exports.EditorState = EditorState;
exports.NodeSelection = NodeSelection;
exports.Plugin = Plugin;
exports.PluginKey = PluginKey;
exports.Selection = Selection;
exports.SelectionRange = SelectionRange;
exports.TextSelection = TextSelection;
exports.Transaction = Transaction;

709
node_modules/prosemirror-state/dist/index.d.cts generated vendored Normal file
View File

@@ -0,0 +1,709 @@
import { Schema, Node, Mark, MarkType, Slice, ResolvedPos } from 'prosemirror-model';
import { Transform, Mappable } from 'prosemirror-transform';
import { EditorProps, EditorView } from 'prosemirror-view';
/**
The type of object passed to
[`EditorState.create`](https://prosemirror.net/docs/ref/#state.EditorState^create).
*/
interface EditorStateConfig {
/**
The schema to use (only relevant if no `doc` is specified).
*/
schema?: Schema;
/**
The starting document. Either this or `schema` _must_ be
provided.
*/
doc?: Node;
/**
A valid selection in the document.
*/
selection?: Selection;
/**
The initial set of [stored marks](https://prosemirror.net/docs/ref/#state.EditorState.storedMarks).
*/
storedMarks?: readonly Mark[] | null;
/**
The plugins that should be active in this state.
*/
plugins?: readonly Plugin[];
}
/**
The state of a ProseMirror editor is represented by an object of
this type. A state is a persistent data structure—it isn't
updated, but rather a new state value is computed from an old one
using the [`apply`](https://prosemirror.net/docs/ref/#state.EditorState.apply) method.
A state holds a number of built-in fields, and plugins can
[define](https://prosemirror.net/docs/ref/#state.PluginSpec.state) additional fields.
*/
declare class EditorState {
/**
The current document.
*/
doc: Node;
/**
The selection.
*/
selection: Selection;
/**
A set of marks to apply to the next input. Will be null when
no explicit marks have been set.
*/
storedMarks: readonly Mark[] | null;
/**
The schema of the state's document.
*/
get schema(): Schema;
/**
The plugins that are active in this state.
*/
get plugins(): readonly Plugin[];
/**
Apply the given transaction to produce a new state.
*/
apply(tr: Transaction): EditorState;
/**
Verbose variant of [`apply`](https://prosemirror.net/docs/ref/#state.EditorState.apply) that
returns the precise transactions that were applied (which might
be influenced by the [transaction
hooks](https://prosemirror.net/docs/ref/#state.PluginSpec.filterTransaction) of
plugins) along with the new state.
*/
applyTransaction(rootTr: Transaction): {
state: EditorState;
transactions: readonly Transaction[];
};
/**
Accessor that constructs and returns a new [transaction](https://prosemirror.net/docs/ref/#state.Transaction) from this state.
*/
get tr(): Transaction;
/**
Create a new state.
*/
static create(config: EditorStateConfig): EditorState;
/**
Create a new state based on this one, but with an adjusted set
of active plugins. State fields that exist in both sets of
plugins are kept unchanged. Those that no longer exist are
dropped, and those that are new are initialized using their
[`init`](https://prosemirror.net/docs/ref/#state.StateField.init) method, passing in the new
configuration object..
*/
reconfigure(config: {
/**
New set of active plugins.
*/
plugins?: readonly Plugin[];
}): EditorState;
/**
Serialize this state to JSON. If you want to serialize the state
of plugins, pass an object mapping property names to use in the
resulting JSON object to plugin objects. The argument may also be
a string or number, in which case it is ignored, to support the
way `JSON.stringify` calls `toString` methods.
*/
toJSON(pluginFields?: {
[propName: string]: Plugin;
}): any;
/**
Deserialize a JSON representation of a state. `config` should
have at least a `schema` field, and should contain array of
plugins to initialize the state with. `pluginFields` can be used
to deserialize the state of plugins, by associating plugin
instances with the property names they use in the JSON object.
*/
static fromJSON(config: {
/**
The schema to use.
*/
schema: Schema;
/**
The set of active plugins.
*/
plugins?: readonly Plugin[];
}, json: any, pluginFields?: {
[propName: string]: Plugin;
}): EditorState;
}
/**
This is the type passed to the [`Plugin`](https://prosemirror.net/docs/ref/#state.Plugin)
constructor. It provides a definition for a plugin.
*/
interface PluginSpec<PluginState> {
/**
The [view props](https://prosemirror.net/docs/ref/#view.EditorProps) added by this plugin. Props
that are functions will be bound to have the plugin instance as
their `this` binding.
*/
props?: EditorProps<Plugin<PluginState>>;
/**
Allows a plugin to define a [state field](https://prosemirror.net/docs/ref/#state.StateField), an
extra slot in the state object in which it can keep its own data.
*/
state?: StateField<PluginState>;
/**
Can be used to make this a keyed plugin. You can have only one
plugin with a given key in a given state, but it is possible to
access the plugin's configuration and state through the key,
without having access to the plugin instance object.
*/
key?: PluginKey;
/**
When the plugin needs to interact with the editor view, or
set something up in the DOM, use this field. The function
will be called when the plugin's state is associated with an
editor view.
*/
view?: (view: EditorView) => PluginView;
/**
When present, this will be called before a transaction is
applied by the state, allowing the plugin to cancel it (by
returning false).
*/
filterTransaction?: (tr: Transaction, state: EditorState) => boolean;
/**
Allows the plugin to append another transaction to be applied
after the given array of transactions. When another plugin
appends a transaction after this was called, it is called again
with the new state and new transactions—but only the new
transactions, i.e. it won't be passed transactions that it
already saw.
*/
appendTransaction?: (transactions: readonly Transaction[], oldState: EditorState, newState: EditorState) => Transaction | null | undefined;
/**
Additional properties are allowed on plugin specs, which can be
read via [`Plugin.spec`](https://prosemirror.net/docs/ref/#state.Plugin.spec).
*/
[key: string]: any;
}
/**
A stateful object that can be installed in an editor by a
[plugin](https://prosemirror.net/docs/ref/#state.PluginSpec.view).
*/
type PluginView = {
/**
Called whenever the view's state is updated.
*/
update?: (view: EditorView, prevState: EditorState) => void;
/**
Called when the view is destroyed or receives a state
with different plugins.
*/
destroy?: () => void;
};
/**
Plugins bundle functionality that can be added to an editor.
They are part of the [editor state](https://prosemirror.net/docs/ref/#state.EditorState) and
may influence that state and the view that contains it.
*/
declare class Plugin<PluginState = any> {
/**
The plugin's [spec object](https://prosemirror.net/docs/ref/#state.PluginSpec).
*/
readonly spec: PluginSpec<PluginState>;
/**
Create a plugin.
*/
constructor(
/**
The plugin's [spec object](https://prosemirror.net/docs/ref/#state.PluginSpec).
*/
spec: PluginSpec<PluginState>);
/**
The [props](https://prosemirror.net/docs/ref/#view.EditorProps) exported by this plugin.
*/
readonly props: EditorProps<Plugin<PluginState>>;
/**
Extract the plugin's state field from an editor state.
*/
getState(state: EditorState): PluginState | undefined;
}
/**
A plugin spec may provide a state field (under its
[`state`](https://prosemirror.net/docs/ref/#state.PluginSpec.state) property) of this type, which
describes the state it wants to keep. Functions provided here are
always called with the plugin instance as their `this` binding.
*/
interface StateField<T> {
/**
Initialize the value of the field. `config` will be the object
passed to [`EditorState.create`](https://prosemirror.net/docs/ref/#state.EditorState^create). Note
that `instance` is a half-initialized state instance, and will
not have values for plugin fields initialized after this one.
*/
init: (config: EditorStateConfig, instance: EditorState) => T;
/**
Apply the given transaction to this state field, producing a new
field value. Note that the `newState` argument is again a partially
constructed state does not yet contain the state from plugins
coming after this one.
*/
apply: (tr: Transaction, value: T, oldState: EditorState, newState: EditorState) => T;
/**
Convert this field to JSON. Optional, can be left off to disable
JSON serialization for the field.
*/
toJSON?: (value: T) => any;
/**
Deserialize the JSON representation of this field. Note that the
`state` argument is again a half-initialized state.
*/
fromJSON?: (config: EditorStateConfig, value: any, state: EditorState) => T;
}
/**
A key is used to [tag](https://prosemirror.net/docs/ref/#state.PluginSpec.key) plugins in a way
that makes it possible to find them, given an editor state.
Assigning a key does mean only one plugin of that type can be
active in a state.
*/
declare class PluginKey<PluginState = any> {
/**
Create a plugin key.
*/
constructor(name?: string);
/**
Get the active plugin with this key, if any, from an editor
state.
*/
get(state: EditorState): Plugin<PluginState> | undefined;
/**
Get the plugin's state from an editor state.
*/
getState(state: EditorState): PluginState | undefined;
}
/**
Commands are functions that take a state and a an optional
transaction dispatch function and...
- determine whether they apply to this state
- if not, return false
- if `dispatch` was passed, perform their effect, possibly by
passing a transaction to `dispatch`
- return true
In some cases, the editor view is passed as a third argument.
*/
type Command = (state: EditorState, dispatch?: (tr: Transaction) => void, view?: EditorView) => boolean;
/**
An editor state transaction, which can be applied to a state to
create an updated state. Use
[`EditorState.tr`](https://prosemirror.net/docs/ref/#state.EditorState.tr) to create an instance.
Transactions track changes to the document (they are a subclass of
[`Transform`](https://prosemirror.net/docs/ref/#transform.Transform)), but also other state changes,
like selection updates and adjustments of the set of [stored
marks](https://prosemirror.net/docs/ref/#state.EditorState.storedMarks). In addition, you can store
metadata properties in a transaction, which are extra pieces of
information that client code or plugins can use to describe what a
transaction represents, so that they can update their [own
state](https://prosemirror.net/docs/ref/#state.StateField) accordingly.
The [editor view](https://prosemirror.net/docs/ref/#view.EditorView) uses a few metadata
properties: it will attach a property `"pointer"` with the value
`true` to selection transactions directly caused by mouse or touch
input, a `"composition"` property holding an ID identifying the
composition that caused it to transactions caused by composed DOM
input, and a `"uiEvent"` property of that may be `"paste"`,
`"cut"`, or `"drop"`.
*/
declare class Transaction extends Transform {
/**
The timestamp associated with this transaction, in the same
format as `Date.now()`.
*/
time: number;
private curSelection;
private curSelectionFor;
private updated;
private meta;
/**
The stored marks set by this transaction, if any.
*/
storedMarks: readonly Mark[] | null;
/**
The transaction's current selection. This defaults to the editor
selection [mapped](https://prosemirror.net/docs/ref/#state.Selection.map) through the steps in the
transaction, but can be overwritten with
[`setSelection`](https://prosemirror.net/docs/ref/#state.Transaction.setSelection).
*/
get selection(): Selection;
/**
Update the transaction's current selection. Will determine the
selection that the editor gets when the transaction is applied.
*/
setSelection(selection: Selection): this;
/**
Whether the selection was explicitly updated by this transaction.
*/
get selectionSet(): boolean;
/**
Set the current stored marks.
*/
setStoredMarks(marks: readonly Mark[] | null): this;
/**
Make sure the current stored marks or, if that is null, the marks
at the selection, match the given set of marks. Does nothing if
this is already the case.
*/
ensureMarks(marks: readonly Mark[]): this;
/**
Add a mark to the set of stored marks.
*/
addStoredMark(mark: Mark): this;
/**
Remove a mark or mark type from the set of stored marks.
*/
removeStoredMark(mark: Mark | MarkType): this;
/**
Whether the stored marks were explicitly set for this transaction.
*/
get storedMarksSet(): boolean;
/**
Update the timestamp for the transaction.
*/
setTime(time: number): this;
/**
Replace the current selection with the given slice.
*/
replaceSelection(slice: Slice): this;
/**
Replace the selection with the given node. When `inheritMarks` is
true and the content is inline, it inherits the marks from the
place where it is inserted.
*/
replaceSelectionWith(node: Node, inheritMarks?: boolean): this;
/**
Delete the selection.
*/
deleteSelection(): this;
/**
Replace the given range, or the selection if no range is given,
with a text node containing the given string.
*/
insertText(text: string, from?: number, to?: number): this;
/**
Store a metadata property in this transaction, keyed either by
name or by plugin.
*/
setMeta(key: string | Plugin | PluginKey, value: any): this;
/**
Retrieve a metadata property for a given name or plugin.
*/
getMeta(key: string | Plugin | PluginKey): any;
/**
Returns true if this transaction doesn't contain any metadata,
and can thus safely be extended.
*/
get isGeneric(): boolean;
/**
Indicate that the editor should scroll the selection into view
when updated to the state produced by this transaction.
*/
scrollIntoView(): this;
/**
True when this transaction has had `scrollIntoView` called on it.
*/
get scrolledIntoView(): boolean;
}
/**
Superclass for editor selections. Every selection type should
extend this. Should not be instantiated directly.
*/
declare abstract class Selection {
/**
The resolved anchor of the selection (the side that stays in
place when the selection is modified).
*/
readonly $anchor: ResolvedPos;
/**
The resolved head of the selection (the side that moves when
the selection is modified).
*/
readonly $head: ResolvedPos;
/**
Initialize a selection with the head and anchor and ranges. If no
ranges are given, constructs a single range across `$anchor` and
`$head`.
*/
constructor(
/**
The resolved anchor of the selection (the side that stays in
place when the selection is modified).
*/
$anchor: ResolvedPos,
/**
The resolved head of the selection (the side that moves when
the selection is modified).
*/
$head: ResolvedPos, ranges?: readonly SelectionRange[]);
/**
The ranges covered by the selection.
*/
ranges: readonly SelectionRange[];
/**
The selection's anchor, as an unresolved position.
*/
get anchor(): number;
/**
The selection's head.
*/
get head(): number;
/**
The lower bound of the selection's main range.
*/
get from(): number;
/**
The upper bound of the selection's main range.
*/
get to(): number;
/**
The resolved lower bound of the selection's main range.
*/
get $from(): ResolvedPos;
/**
The resolved upper bound of the selection's main range.
*/
get $to(): ResolvedPos;
/**
Indicates whether the selection contains any content.
*/
get empty(): boolean;
/**
Test whether the selection is the same as another selection.
*/
abstract eq(selection: Selection): boolean;
/**
Map this selection through a [mappable](https://prosemirror.net/docs/ref/#transform.Mappable)
thing. `doc` should be the new document to which we are mapping.
*/
abstract map(doc: Node, mapping: Mappable): Selection;
/**
Get the content of this selection as a slice.
*/
content(): Slice;
/**
Replace the selection with a slice or, if no slice is given,
delete the selection. Will append to the given transaction.
*/
replace(tr: Transaction, content?: Slice): void;
/**
Replace the selection with the given node, appending the changes
to the given transaction.
*/
replaceWith(tr: Transaction, node: Node): void;
/**
Convert the selection to a JSON representation. When implementing
this for a custom selection class, make sure to give the object a
`type` property whose value matches the ID under which you
[registered](https://prosemirror.net/docs/ref/#state.Selection^jsonID) your class.
*/
abstract toJSON(): any;
/**
Find a valid cursor or leaf node selection starting at the given
position and searching back if `dir` is negative, and forward if
positive. When `textOnly` is true, only consider cursor
selections. Will return null when no valid selection position is
found.
*/
static findFrom($pos: ResolvedPos, dir: number, textOnly?: boolean): Selection | null;
/**
Find a valid cursor or leaf node selection near the given
position. Searches forward first by default, but if `bias` is
negative, it will search backwards first.
*/
static near($pos: ResolvedPos, bias?: number): Selection;
/**
Find the cursor or leaf node selection closest to the start of
the given document. Will return an
[`AllSelection`](https://prosemirror.net/docs/ref/#state.AllSelection) if no valid position
exists.
*/
static atStart(doc: Node): Selection;
/**
Find the cursor or leaf node selection closest to the end of the
given document.
*/
static atEnd(doc: Node): Selection;
/**
Deserialize the JSON representation of a selection. Must be
implemented for custom classes (as a static class method).
*/
static fromJSON(doc: Node, json: any): Selection;
/**
To be able to deserialize selections from JSON, custom selection
classes must register themselves with an ID string, so that they
can be disambiguated. Try to pick something that's unlikely to
clash with classes from other modules.
*/
static jsonID(id: string, selectionClass: {
fromJSON: (doc: Node, json: any) => Selection;
}): {
fromJSON: (doc: Node, json: any) => Selection;
};
/**
Get a [bookmark](https://prosemirror.net/docs/ref/#state.SelectionBookmark) for this selection,
which is a value that can be mapped without having access to a
current document, and later resolved to a real selection for a
given document again. (This is used mostly by the history to
track and restore old selections.) The default implementation of
this method just converts the selection to a text selection and
returns the bookmark for that.
*/
getBookmark(): SelectionBookmark;
/**
Controls whether, when a selection of this type is active in the
browser, the selected range should be visible to the user.
Defaults to `true`.
*/
visible: boolean;
}
/**
A lightweight, document-independent representation of a selection.
You can define a custom bookmark type for a custom selection class
to make the history handle it well.
*/
interface SelectionBookmark {
/**
Map the bookmark through a set of changes.
*/
map: (mapping: Mappable) => SelectionBookmark;
/**
Resolve the bookmark to a real selection again. This may need to
do some error checking and may fall back to a default (usually
[`TextSelection.between`](https://prosemirror.net/docs/ref/#state.TextSelection^between)) if
mapping made the bookmark invalid.
*/
resolve: (doc: Node) => Selection;
}
/**
Represents a selected range in a document.
*/
declare class SelectionRange {
/**
The lower bound of the range.
*/
readonly $from: ResolvedPos;
/**
The upper bound of the range.
*/
readonly $to: ResolvedPos;
/**
Create a range.
*/
constructor(
/**
The lower bound of the range.
*/
$from: ResolvedPos,
/**
The upper bound of the range.
*/
$to: ResolvedPos);
}
/**
A text selection represents a classical editor selection, with a
head (the moving side) and anchor (immobile side), both of which
point into textblock nodes. It can be empty (a regular cursor
position).
*/
declare class TextSelection extends Selection {
/**
Construct a text selection between the given points.
*/
constructor($anchor: ResolvedPos, $head?: ResolvedPos);
/**
Returns a resolved position if this is a cursor selection (an
empty text selection), and null otherwise.
*/
get $cursor(): ResolvedPos | null;
map(doc: Node, mapping: Mappable): Selection;
replace(tr: Transaction, content?: Slice): void;
eq(other: Selection): boolean;
getBookmark(): TextBookmark;
toJSON(): any;
/**
Create a text selection from non-resolved positions.
*/
static create(doc: Node, anchor: number, head?: number): TextSelection;
/**
Return a text selection that spans the given positions or, if
they aren't text positions, find a text selection near them.
`bias` determines whether the method searches forward (default)
or backwards (negative number) first. Will fall back to calling
[`Selection.near`](https://prosemirror.net/docs/ref/#state.Selection^near) when the document
doesn't contain a valid text position.
*/
static between($anchor: ResolvedPos, $head: ResolvedPos, bias?: number): Selection;
}
declare class TextBookmark {
readonly anchor: number;
readonly head: number;
constructor(anchor: number, head: number);
map(mapping: Mappable): TextBookmark;
resolve(doc: Node): Selection;
}
/**
A node selection is a selection that points at a single node. All
nodes marked [selectable](https://prosemirror.net/docs/ref/#model.NodeSpec.selectable) can be the
target of a node selection. In such a selection, `from` and `to`
point directly before and after the selected node, `anchor` equals
`from`, and `head` equals `to`..
*/
declare class NodeSelection extends Selection {
/**
Create a node selection. Does not verify the validity of its
argument.
*/
constructor($pos: ResolvedPos);
/**
The selected node.
*/
node: Node;
map(doc: Node, mapping: Mappable): Selection;
content(): Slice;
eq(other: Selection): boolean;
toJSON(): any;
getBookmark(): NodeBookmark;
/**
Create a node selection from non-resolved positions.
*/
static create(doc: Node, from: number): NodeSelection;
/**
Determines whether the given node may be selected as a node
selection.
*/
static isSelectable(node: Node): boolean;
}
declare class NodeBookmark {
readonly anchor: number;
constructor(anchor: number);
map(mapping: Mappable): TextBookmark | NodeBookmark;
resolve(doc: Node): Selection | NodeSelection;
}
/**
A selection type that represents selecting the whole document
(which can not necessarily be expressed with a text selection, when
there are for example leaf block nodes at the start or end of the
document).
*/
declare class AllSelection extends Selection {
/**
Create an all-selection over the given document.
*/
constructor(doc: Node);
replace(tr: Transaction, content?: Slice): void;
toJSON(): any;
map(doc: Node): AllSelection;
eq(other: Selection): boolean;
getBookmark(): {
map(): any;
resolve(doc: Node): AllSelection;
};
}
export { AllSelection, type Command, EditorState, type EditorStateConfig, NodeSelection, Plugin, PluginKey, type PluginSpec, type PluginView, Selection, type SelectionBookmark, SelectionRange, type StateField, TextSelection, Transaction };

709
node_modules/prosemirror-state/dist/index.d.ts generated vendored Normal file
View File

@@ -0,0 +1,709 @@
import { Schema, Node, Mark, MarkType, Slice, ResolvedPos } from 'prosemirror-model';
import { Transform, Mappable } from 'prosemirror-transform';
import { EditorProps, EditorView } from 'prosemirror-view';
/**
The type of object passed to
[`EditorState.create`](https://prosemirror.net/docs/ref/#state.EditorState^create).
*/
interface EditorStateConfig {
/**
The schema to use (only relevant if no `doc` is specified).
*/
schema?: Schema;
/**
The starting document. Either this or `schema` _must_ be
provided.
*/
doc?: Node;
/**
A valid selection in the document.
*/
selection?: Selection;
/**
The initial set of [stored marks](https://prosemirror.net/docs/ref/#state.EditorState.storedMarks).
*/
storedMarks?: readonly Mark[] | null;
/**
The plugins that should be active in this state.
*/
plugins?: readonly Plugin[];
}
/**
The state of a ProseMirror editor is represented by an object of
this type. A state is a persistent data structure—it isn't
updated, but rather a new state value is computed from an old one
using the [`apply`](https://prosemirror.net/docs/ref/#state.EditorState.apply) method.
A state holds a number of built-in fields, and plugins can
[define](https://prosemirror.net/docs/ref/#state.PluginSpec.state) additional fields.
*/
declare class EditorState {
/**
The current document.
*/
doc: Node;
/**
The selection.
*/
selection: Selection;
/**
A set of marks to apply to the next input. Will be null when
no explicit marks have been set.
*/
storedMarks: readonly Mark[] | null;
/**
The schema of the state's document.
*/
get schema(): Schema;
/**
The plugins that are active in this state.
*/
get plugins(): readonly Plugin[];
/**
Apply the given transaction to produce a new state.
*/
apply(tr: Transaction): EditorState;
/**
Verbose variant of [`apply`](https://prosemirror.net/docs/ref/#state.EditorState.apply) that
returns the precise transactions that were applied (which might
be influenced by the [transaction
hooks](https://prosemirror.net/docs/ref/#state.PluginSpec.filterTransaction) of
plugins) along with the new state.
*/
applyTransaction(rootTr: Transaction): {
state: EditorState;
transactions: readonly Transaction[];
};
/**
Accessor that constructs and returns a new [transaction](https://prosemirror.net/docs/ref/#state.Transaction) from this state.
*/
get tr(): Transaction;
/**
Create a new state.
*/
static create(config: EditorStateConfig): EditorState;
/**
Create a new state based on this one, but with an adjusted set
of active plugins. State fields that exist in both sets of
plugins are kept unchanged. Those that no longer exist are
dropped, and those that are new are initialized using their
[`init`](https://prosemirror.net/docs/ref/#state.StateField.init) method, passing in the new
configuration object..
*/
reconfigure(config: {
/**
New set of active plugins.
*/
plugins?: readonly Plugin[];
}): EditorState;
/**
Serialize this state to JSON. If you want to serialize the state
of plugins, pass an object mapping property names to use in the
resulting JSON object to plugin objects. The argument may also be
a string or number, in which case it is ignored, to support the
way `JSON.stringify` calls `toString` methods.
*/
toJSON(pluginFields?: {
[propName: string]: Plugin;
}): any;
/**
Deserialize a JSON representation of a state. `config` should
have at least a `schema` field, and should contain array of
plugins to initialize the state with. `pluginFields` can be used
to deserialize the state of plugins, by associating plugin
instances with the property names they use in the JSON object.
*/
static fromJSON(config: {
/**
The schema to use.
*/
schema: Schema;
/**
The set of active plugins.
*/
plugins?: readonly Plugin[];
}, json: any, pluginFields?: {
[propName: string]: Plugin;
}): EditorState;
}
/**
This is the type passed to the [`Plugin`](https://prosemirror.net/docs/ref/#state.Plugin)
constructor. It provides a definition for a plugin.
*/
interface PluginSpec<PluginState> {
/**
The [view props](https://prosemirror.net/docs/ref/#view.EditorProps) added by this plugin. Props
that are functions will be bound to have the plugin instance as
their `this` binding.
*/
props?: EditorProps<Plugin<PluginState>>;
/**
Allows a plugin to define a [state field](https://prosemirror.net/docs/ref/#state.StateField), an
extra slot in the state object in which it can keep its own data.
*/
state?: StateField<PluginState>;
/**
Can be used to make this a keyed plugin. You can have only one
plugin with a given key in a given state, but it is possible to
access the plugin's configuration and state through the key,
without having access to the plugin instance object.
*/
key?: PluginKey;
/**
When the plugin needs to interact with the editor view, or
set something up in the DOM, use this field. The function
will be called when the plugin's state is associated with an
editor view.
*/
view?: (view: EditorView) => PluginView;
/**
When present, this will be called before a transaction is
applied by the state, allowing the plugin to cancel it (by
returning false).
*/
filterTransaction?: (tr: Transaction, state: EditorState) => boolean;
/**
Allows the plugin to append another transaction to be applied
after the given array of transactions. When another plugin
appends a transaction after this was called, it is called again
with the new state and new transactions—but only the new
transactions, i.e. it won't be passed transactions that it
already saw.
*/
appendTransaction?: (transactions: readonly Transaction[], oldState: EditorState, newState: EditorState) => Transaction | null | undefined;
/**
Additional properties are allowed on plugin specs, which can be
read via [`Plugin.spec`](https://prosemirror.net/docs/ref/#state.Plugin.spec).
*/
[key: string]: any;
}
/**
A stateful object that can be installed in an editor by a
[plugin](https://prosemirror.net/docs/ref/#state.PluginSpec.view).
*/
type PluginView = {
/**
Called whenever the view's state is updated.
*/
update?: (view: EditorView, prevState: EditorState) => void;
/**
Called when the view is destroyed or receives a state
with different plugins.
*/
destroy?: () => void;
};
/**
Plugins bundle functionality that can be added to an editor.
They are part of the [editor state](https://prosemirror.net/docs/ref/#state.EditorState) and
may influence that state and the view that contains it.
*/
declare class Plugin<PluginState = any> {
/**
The plugin's [spec object](https://prosemirror.net/docs/ref/#state.PluginSpec).
*/
readonly spec: PluginSpec<PluginState>;
/**
Create a plugin.
*/
constructor(
/**
The plugin's [spec object](https://prosemirror.net/docs/ref/#state.PluginSpec).
*/
spec: PluginSpec<PluginState>);
/**
The [props](https://prosemirror.net/docs/ref/#view.EditorProps) exported by this plugin.
*/
readonly props: EditorProps<Plugin<PluginState>>;
/**
Extract the plugin's state field from an editor state.
*/
getState(state: EditorState): PluginState | undefined;
}
/**
A plugin spec may provide a state field (under its
[`state`](https://prosemirror.net/docs/ref/#state.PluginSpec.state) property) of this type, which
describes the state it wants to keep. Functions provided here are
always called with the plugin instance as their `this` binding.
*/
interface StateField<T> {
/**
Initialize the value of the field. `config` will be the object
passed to [`EditorState.create`](https://prosemirror.net/docs/ref/#state.EditorState^create). Note
that `instance` is a half-initialized state instance, and will
not have values for plugin fields initialized after this one.
*/
init: (config: EditorStateConfig, instance: EditorState) => T;
/**
Apply the given transaction to this state field, producing a new
field value. Note that the `newState` argument is again a partially
constructed state does not yet contain the state from plugins
coming after this one.
*/
apply: (tr: Transaction, value: T, oldState: EditorState, newState: EditorState) => T;
/**
Convert this field to JSON. Optional, can be left off to disable
JSON serialization for the field.
*/
toJSON?: (value: T) => any;
/**
Deserialize the JSON representation of this field. Note that the
`state` argument is again a half-initialized state.
*/
fromJSON?: (config: EditorStateConfig, value: any, state: EditorState) => T;
}
/**
A key is used to [tag](https://prosemirror.net/docs/ref/#state.PluginSpec.key) plugins in a way
that makes it possible to find them, given an editor state.
Assigning a key does mean only one plugin of that type can be
active in a state.
*/
declare class PluginKey<PluginState = any> {
/**
Create a plugin key.
*/
constructor(name?: string);
/**
Get the active plugin with this key, if any, from an editor
state.
*/
get(state: EditorState): Plugin<PluginState> | undefined;
/**
Get the plugin's state from an editor state.
*/
getState(state: EditorState): PluginState | undefined;
}
/**
Commands are functions that take a state and a an optional
transaction dispatch function and...
- determine whether they apply to this state
- if not, return false
- if `dispatch` was passed, perform their effect, possibly by
passing a transaction to `dispatch`
- return true
In some cases, the editor view is passed as a third argument.
*/
type Command = (state: EditorState, dispatch?: (tr: Transaction) => void, view?: EditorView) => boolean;
/**
An editor state transaction, which can be applied to a state to
create an updated state. Use
[`EditorState.tr`](https://prosemirror.net/docs/ref/#state.EditorState.tr) to create an instance.
Transactions track changes to the document (they are a subclass of
[`Transform`](https://prosemirror.net/docs/ref/#transform.Transform)), but also other state changes,
like selection updates and adjustments of the set of [stored
marks](https://prosemirror.net/docs/ref/#state.EditorState.storedMarks). In addition, you can store
metadata properties in a transaction, which are extra pieces of
information that client code or plugins can use to describe what a
transaction represents, so that they can update their [own
state](https://prosemirror.net/docs/ref/#state.StateField) accordingly.
The [editor view](https://prosemirror.net/docs/ref/#view.EditorView) uses a few metadata
properties: it will attach a property `"pointer"` with the value
`true` to selection transactions directly caused by mouse or touch
input, a `"composition"` property holding an ID identifying the
composition that caused it to transactions caused by composed DOM
input, and a `"uiEvent"` property of that may be `"paste"`,
`"cut"`, or `"drop"`.
*/
declare class Transaction extends Transform {
/**
The timestamp associated with this transaction, in the same
format as `Date.now()`.
*/
time: number;
private curSelection;
private curSelectionFor;
private updated;
private meta;
/**
The stored marks set by this transaction, if any.
*/
storedMarks: readonly Mark[] | null;
/**
The transaction's current selection. This defaults to the editor
selection [mapped](https://prosemirror.net/docs/ref/#state.Selection.map) through the steps in the
transaction, but can be overwritten with
[`setSelection`](https://prosemirror.net/docs/ref/#state.Transaction.setSelection).
*/
get selection(): Selection;
/**
Update the transaction's current selection. Will determine the
selection that the editor gets when the transaction is applied.
*/
setSelection(selection: Selection): this;
/**
Whether the selection was explicitly updated by this transaction.
*/
get selectionSet(): boolean;
/**
Set the current stored marks.
*/
setStoredMarks(marks: readonly Mark[] | null): this;
/**
Make sure the current stored marks or, if that is null, the marks
at the selection, match the given set of marks. Does nothing if
this is already the case.
*/
ensureMarks(marks: readonly Mark[]): this;
/**
Add a mark to the set of stored marks.
*/
addStoredMark(mark: Mark): this;
/**
Remove a mark or mark type from the set of stored marks.
*/
removeStoredMark(mark: Mark | MarkType): this;
/**
Whether the stored marks were explicitly set for this transaction.
*/
get storedMarksSet(): boolean;
/**
Update the timestamp for the transaction.
*/
setTime(time: number): this;
/**
Replace the current selection with the given slice.
*/
replaceSelection(slice: Slice): this;
/**
Replace the selection with the given node. When `inheritMarks` is
true and the content is inline, it inherits the marks from the
place where it is inserted.
*/
replaceSelectionWith(node: Node, inheritMarks?: boolean): this;
/**
Delete the selection.
*/
deleteSelection(): this;
/**
Replace the given range, or the selection if no range is given,
with a text node containing the given string.
*/
insertText(text: string, from?: number, to?: number): this;
/**
Store a metadata property in this transaction, keyed either by
name or by plugin.
*/
setMeta(key: string | Plugin | PluginKey, value: any): this;
/**
Retrieve a metadata property for a given name or plugin.
*/
getMeta(key: string | Plugin | PluginKey): any;
/**
Returns true if this transaction doesn't contain any metadata,
and can thus safely be extended.
*/
get isGeneric(): boolean;
/**
Indicate that the editor should scroll the selection into view
when updated to the state produced by this transaction.
*/
scrollIntoView(): this;
/**
True when this transaction has had `scrollIntoView` called on it.
*/
get scrolledIntoView(): boolean;
}
/**
Superclass for editor selections. Every selection type should
extend this. Should not be instantiated directly.
*/
declare abstract class Selection {
/**
The resolved anchor of the selection (the side that stays in
place when the selection is modified).
*/
readonly $anchor: ResolvedPos;
/**
The resolved head of the selection (the side that moves when
the selection is modified).
*/
readonly $head: ResolvedPos;
/**
Initialize a selection with the head and anchor and ranges. If no
ranges are given, constructs a single range across `$anchor` and
`$head`.
*/
constructor(
/**
The resolved anchor of the selection (the side that stays in
place when the selection is modified).
*/
$anchor: ResolvedPos,
/**
The resolved head of the selection (the side that moves when
the selection is modified).
*/
$head: ResolvedPos, ranges?: readonly SelectionRange[]);
/**
The ranges covered by the selection.
*/
ranges: readonly SelectionRange[];
/**
The selection's anchor, as an unresolved position.
*/
get anchor(): number;
/**
The selection's head.
*/
get head(): number;
/**
The lower bound of the selection's main range.
*/
get from(): number;
/**
The upper bound of the selection's main range.
*/
get to(): number;
/**
The resolved lower bound of the selection's main range.
*/
get $from(): ResolvedPos;
/**
The resolved upper bound of the selection's main range.
*/
get $to(): ResolvedPos;
/**
Indicates whether the selection contains any content.
*/
get empty(): boolean;
/**
Test whether the selection is the same as another selection.
*/
abstract eq(selection: Selection): boolean;
/**
Map this selection through a [mappable](https://prosemirror.net/docs/ref/#transform.Mappable)
thing. `doc` should be the new document to which we are mapping.
*/
abstract map(doc: Node, mapping: Mappable): Selection;
/**
Get the content of this selection as a slice.
*/
content(): Slice;
/**
Replace the selection with a slice or, if no slice is given,
delete the selection. Will append to the given transaction.
*/
replace(tr: Transaction, content?: Slice): void;
/**
Replace the selection with the given node, appending the changes
to the given transaction.
*/
replaceWith(tr: Transaction, node: Node): void;
/**
Convert the selection to a JSON representation. When implementing
this for a custom selection class, make sure to give the object a
`type` property whose value matches the ID under which you
[registered](https://prosemirror.net/docs/ref/#state.Selection^jsonID) your class.
*/
abstract toJSON(): any;
/**
Find a valid cursor or leaf node selection starting at the given
position and searching back if `dir` is negative, and forward if
positive. When `textOnly` is true, only consider cursor
selections. Will return null when no valid selection position is
found.
*/
static findFrom($pos: ResolvedPos, dir: number, textOnly?: boolean): Selection | null;
/**
Find a valid cursor or leaf node selection near the given
position. Searches forward first by default, but if `bias` is
negative, it will search backwards first.
*/
static near($pos: ResolvedPos, bias?: number): Selection;
/**
Find the cursor or leaf node selection closest to the start of
the given document. Will return an
[`AllSelection`](https://prosemirror.net/docs/ref/#state.AllSelection) if no valid position
exists.
*/
static atStart(doc: Node): Selection;
/**
Find the cursor or leaf node selection closest to the end of the
given document.
*/
static atEnd(doc: Node): Selection;
/**
Deserialize the JSON representation of a selection. Must be
implemented for custom classes (as a static class method).
*/
static fromJSON(doc: Node, json: any): Selection;
/**
To be able to deserialize selections from JSON, custom selection
classes must register themselves with an ID string, so that they
can be disambiguated. Try to pick something that's unlikely to
clash with classes from other modules.
*/
static jsonID(id: string, selectionClass: {
fromJSON: (doc: Node, json: any) => Selection;
}): {
fromJSON: (doc: Node, json: any) => Selection;
};
/**
Get a [bookmark](https://prosemirror.net/docs/ref/#state.SelectionBookmark) for this selection,
which is a value that can be mapped without having access to a
current document, and later resolved to a real selection for a
given document again. (This is used mostly by the history to
track and restore old selections.) The default implementation of
this method just converts the selection to a text selection and
returns the bookmark for that.
*/
getBookmark(): SelectionBookmark;
/**
Controls whether, when a selection of this type is active in the
browser, the selected range should be visible to the user.
Defaults to `true`.
*/
visible: boolean;
}
/**
A lightweight, document-independent representation of a selection.
You can define a custom bookmark type for a custom selection class
to make the history handle it well.
*/
interface SelectionBookmark {
/**
Map the bookmark through a set of changes.
*/
map: (mapping: Mappable) => SelectionBookmark;
/**
Resolve the bookmark to a real selection again. This may need to
do some error checking and may fall back to a default (usually
[`TextSelection.between`](https://prosemirror.net/docs/ref/#state.TextSelection^between)) if
mapping made the bookmark invalid.
*/
resolve: (doc: Node) => Selection;
}
/**
Represents a selected range in a document.
*/
declare class SelectionRange {
/**
The lower bound of the range.
*/
readonly $from: ResolvedPos;
/**
The upper bound of the range.
*/
readonly $to: ResolvedPos;
/**
Create a range.
*/
constructor(
/**
The lower bound of the range.
*/
$from: ResolvedPos,
/**
The upper bound of the range.
*/
$to: ResolvedPos);
}
/**
A text selection represents a classical editor selection, with a
head (the moving side) and anchor (immobile side), both of which
point into textblock nodes. It can be empty (a regular cursor
position).
*/
declare class TextSelection extends Selection {
/**
Construct a text selection between the given points.
*/
constructor($anchor: ResolvedPos, $head?: ResolvedPos);
/**
Returns a resolved position if this is a cursor selection (an
empty text selection), and null otherwise.
*/
get $cursor(): ResolvedPos | null;
map(doc: Node, mapping: Mappable): Selection;
replace(tr: Transaction, content?: Slice): void;
eq(other: Selection): boolean;
getBookmark(): TextBookmark;
toJSON(): any;
/**
Create a text selection from non-resolved positions.
*/
static create(doc: Node, anchor: number, head?: number): TextSelection;
/**
Return a text selection that spans the given positions or, if
they aren't text positions, find a text selection near them.
`bias` determines whether the method searches forward (default)
or backwards (negative number) first. Will fall back to calling
[`Selection.near`](https://prosemirror.net/docs/ref/#state.Selection^near) when the document
doesn't contain a valid text position.
*/
static between($anchor: ResolvedPos, $head: ResolvedPos, bias?: number): Selection;
}
declare class TextBookmark {
readonly anchor: number;
readonly head: number;
constructor(anchor: number, head: number);
map(mapping: Mappable): TextBookmark;
resolve(doc: Node): Selection;
}
/**
A node selection is a selection that points at a single node. All
nodes marked [selectable](https://prosemirror.net/docs/ref/#model.NodeSpec.selectable) can be the
target of a node selection. In such a selection, `from` and `to`
point directly before and after the selected node, `anchor` equals
`from`, and `head` equals `to`..
*/
declare class NodeSelection extends Selection {
/**
Create a node selection. Does not verify the validity of its
argument.
*/
constructor($pos: ResolvedPos);
/**
The selected node.
*/
node: Node;
map(doc: Node, mapping: Mappable): Selection;
content(): Slice;
eq(other: Selection): boolean;
toJSON(): any;
getBookmark(): NodeBookmark;
/**
Create a node selection from non-resolved positions.
*/
static create(doc: Node, from: number): NodeSelection;
/**
Determines whether the given node may be selected as a node
selection.
*/
static isSelectable(node: Node): boolean;
}
declare class NodeBookmark {
readonly anchor: number;
constructor(anchor: number);
map(mapping: Mappable): TextBookmark | NodeBookmark;
resolve(doc: Node): Selection | NodeSelection;
}
/**
A selection type that represents selecting the whole document
(which can not necessarily be expressed with a text selection, when
there are for example leaf block nodes at the start or end of the
document).
*/
declare class AllSelection extends Selection {
/**
Create an all-selection over the given document.
*/
constructor(doc: Node);
replace(tr: Transaction, content?: Slice): void;
toJSON(): any;
map(doc: Node): AllSelection;
eq(other: Selection): boolean;
getBookmark(): {
map(): any;
resolve(doc: Node): AllSelection;
};
}
export { AllSelection, type Command, EditorState, type EditorStateConfig, NodeSelection, Plugin, PluginKey, type PluginSpec, type PluginView, Selection, type SelectionBookmark, SelectionRange, type StateField, TextSelection, Transaction };

1002
node_modules/prosemirror-state/dist/index.js generated vendored Normal file

File diff suppressed because it is too large Load Diff