@tiptap/extension-placeholder 3.0.0 → 3.0.2-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +21 -0
- package/README.md +5 -1
- package/dist/index.cjs +32 -70
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +9 -67
- package/dist/index.js.map +1 -1
- package/package.json +12 -12
- package/src/index.ts +3 -2
- package/dist/index.umd.js +0 -74
- package/dist/index.umd.js.map +0 -1
- package/dist/packages/core/src/CommandManager.d.ts +0 -20
- package/dist/packages/core/src/Editor.d.ts +0 -161
- package/dist/packages/core/src/EventEmitter.d.ts +0 -11
- package/dist/packages/core/src/Extension.d.ts +0 -343
- package/dist/packages/core/src/ExtensionManager.d.ts +0 -55
- package/dist/packages/core/src/InputRule.d.ts +0 -42
- package/dist/packages/core/src/Mark.d.ts +0 -451
- package/dist/packages/core/src/Node.d.ts +0 -611
- package/dist/packages/core/src/NodePos.d.ts +0 -44
- package/dist/packages/core/src/NodeView.d.ts +0 -31
- package/dist/packages/core/src/PasteRule.d.ts +0 -50
- package/dist/packages/core/src/Tracker.d.ts +0 -11
- package/dist/packages/core/src/commands/blur.d.ts +0 -13
- package/dist/packages/core/src/commands/clearContent.d.ts +0 -14
- package/dist/packages/core/src/commands/clearNodes.d.ts +0 -13
- package/dist/packages/core/src/commands/command.d.ts +0 -18
- package/dist/packages/core/src/commands/createParagraphNear.d.ts +0 -13
- package/dist/packages/core/src/commands/cut.d.ts +0 -20
- package/dist/packages/core/src/commands/deleteCurrentNode.d.ts +0 -13
- package/dist/packages/core/src/commands/deleteNode.d.ts +0 -15
- package/dist/packages/core/src/commands/deleteRange.d.ts +0 -14
- package/dist/packages/core/src/commands/deleteSelection.d.ts +0 -13
- package/dist/packages/core/src/commands/enter.d.ts +0 -13
- package/dist/packages/core/src/commands/exitCode.d.ts +0 -13
- package/dist/packages/core/src/commands/extendMarkRange.d.ts +0 -25
- package/dist/packages/core/src/commands/first.d.ts +0 -14
- package/dist/packages/core/src/commands/focus.d.ts +0 -27
- package/dist/packages/core/src/commands/forEach.d.ts +0 -14
- package/dist/packages/core/src/commands/index.d.ts +0 -55
- package/dist/packages/core/src/commands/insertContent.d.ts +0 -34
- package/dist/packages/core/src/commands/insertContentAt.d.ts +0 -47
- package/dist/packages/core/src/commands/join.d.ts +0 -41
- package/dist/packages/core/src/commands/joinItemBackward.d.ts +0 -13
- package/dist/packages/core/src/commands/joinItemForward.d.ts +0 -13
- package/dist/packages/core/src/commands/joinTextblockBackward.d.ts +0 -12
- package/dist/packages/core/src/commands/joinTextblockForward.d.ts +0 -12
- package/dist/packages/core/src/commands/keyboardShortcut.d.ts +0 -14
- package/dist/packages/core/src/commands/lift.d.ts +0 -17
- package/dist/packages/core/src/commands/liftEmptyBlock.d.ts +0 -13
- package/dist/packages/core/src/commands/liftListItem.d.ts +0 -15
- package/dist/packages/core/src/commands/newlineInCode.d.ts +0 -13
- package/dist/packages/core/src/commands/resetAttributes.d.ts +0 -16
- package/dist/packages/core/src/commands/scrollIntoView.d.ts +0 -13
- package/dist/packages/core/src/commands/selectAll.d.ts +0 -13
- package/dist/packages/core/src/commands/selectNodeBackward.d.ts +0 -13
- package/dist/packages/core/src/commands/selectNodeForward.d.ts +0 -13
- package/dist/packages/core/src/commands/selectParentNode.d.ts +0 -13
- package/dist/packages/core/src/commands/selectTextblockEnd.d.ts +0 -13
- package/dist/packages/core/src/commands/selectTextblockStart.d.ts +0 -13
- package/dist/packages/core/src/commands/setContent.d.ts +0 -40
- package/dist/packages/core/src/commands/setMark.d.ts +0 -15
- package/dist/packages/core/src/commands/setMeta.d.ts +0 -15
- package/dist/packages/core/src/commands/setNode.d.ts +0 -16
- package/dist/packages/core/src/commands/setNodeSelection.d.ts +0 -14
- package/dist/packages/core/src/commands/setTextSelection.d.ts +0 -14
- package/dist/packages/core/src/commands/sinkListItem.d.ts +0 -15
- package/dist/packages/core/src/commands/splitBlock.d.ts +0 -17
- package/dist/packages/core/src/commands/splitListItem.d.ts +0 -15
- package/dist/packages/core/src/commands/toggleList.d.ts +0 -18
- package/dist/packages/core/src/commands/toggleMark.d.ts +0 -30
- package/dist/packages/core/src/commands/toggleNode.d.ts +0 -17
- package/dist/packages/core/src/commands/toggleWrap.d.ts +0 -16
- package/dist/packages/core/src/commands/undoInputRule.d.ts +0 -13
- package/dist/packages/core/src/commands/unsetAllMarks.d.ts +0 -13
- package/dist/packages/core/src/commands/unsetMark.d.ts +0 -25
- package/dist/packages/core/src/commands/updateAttributes.d.ts +0 -24
- package/dist/packages/core/src/commands/wrapIn.d.ts +0 -16
- package/dist/packages/core/src/commands/wrapInList.d.ts +0 -16
- package/dist/packages/core/src/extensions/clipboardTextSerializer.d.ts +0 -5
- package/dist/packages/core/src/extensions/commands.d.ts +0 -3
- package/dist/packages/core/src/extensions/editable.d.ts +0 -2
- package/dist/packages/core/src/extensions/focusEvents.d.ts +0 -2
- package/dist/packages/core/src/extensions/index.d.ts +0 -6
- package/dist/packages/core/src/extensions/keymap.d.ts +0 -2
- package/dist/packages/core/src/extensions/tabindex.d.ts +0 -2
- package/dist/packages/core/src/helpers/combineTransactionSteps.d.ts +0 -10
- package/dist/packages/core/src/helpers/createChainableState.d.ts +0 -10
- package/dist/packages/core/src/helpers/createDocument.d.ts +0 -12
- package/dist/packages/core/src/helpers/createNodeFromContent.d.ts +0 -15
- package/dist/packages/core/src/helpers/defaultBlockAt.d.ts +0 -7
- package/dist/packages/core/src/helpers/findChildren.d.ts +0 -9
- package/dist/packages/core/src/helpers/findChildrenInRange.d.ts +0 -10
- package/dist/packages/core/src/helpers/findParentNode.d.ts +0 -16
- package/dist/packages/core/src/helpers/findParentNodeClosestToPos.d.ts +0 -17
- package/dist/packages/core/src/helpers/generateHTML.d.ts +0 -8
- package/dist/packages/core/src/helpers/generateJSON.d.ts +0 -8
- package/dist/packages/core/src/helpers/generateText.d.ts +0 -12
- package/dist/packages/core/src/helpers/getAttributes.d.ts +0 -9
- package/dist/packages/core/src/helpers/getAttributesFromExtensions.d.ts +0 -6
- package/dist/packages/core/src/helpers/getChangedRanges.d.ts +0 -11
- package/dist/packages/core/src/helpers/getDebugJSON.d.ts +0 -8
- package/dist/packages/core/src/helpers/getExtensionField.d.ts +0 -9
- package/dist/packages/core/src/helpers/getHTMLFromFragment.d.ts +0 -2
- package/dist/packages/core/src/helpers/getMarkAttributes.d.ts +0 -3
- package/dist/packages/core/src/helpers/getMarkRange.d.ts +0 -3
- package/dist/packages/core/src/helpers/getMarkType.d.ts +0 -2
- package/dist/packages/core/src/helpers/getMarksBetween.d.ts +0 -3
- package/dist/packages/core/src/helpers/getNodeAtPosition.d.ts +0 -11
- package/dist/packages/core/src/helpers/getNodeAttributes.d.ts +0 -3
- package/dist/packages/core/src/helpers/getNodeType.d.ts +0 -2
- package/dist/packages/core/src/helpers/getRenderedAttributes.d.ts +0 -3
- package/dist/packages/core/src/helpers/getSchema.d.ts +0 -4
- package/dist/packages/core/src/helpers/getSchemaByResolvedExtensions.d.ts +0 -10
- package/dist/packages/core/src/helpers/getSchemaTypeByName.d.ts +0 -8
- package/dist/packages/core/src/helpers/getSchemaTypeNameByName.d.ts +0 -8
- package/dist/packages/core/src/helpers/getSplittedAttributes.d.ts +0 -9
- package/dist/packages/core/src/helpers/getText.d.ts +0 -15
- package/dist/packages/core/src/helpers/getTextBetween.d.ts +0 -14
- package/dist/packages/core/src/helpers/getTextContentFromNodes.d.ts +0 -8
- package/dist/packages/core/src/helpers/getTextSerializersFromSchema.d.ts +0 -8
- package/dist/packages/core/src/helpers/index.d.ts +0 -50
- package/dist/packages/core/src/helpers/injectExtensionAttributesToParseRule.d.ts +0 -9
- package/dist/packages/core/src/helpers/isActive.d.ts +0 -2
- package/dist/packages/core/src/helpers/isAtEndOfNode.d.ts +0 -2
- package/dist/packages/core/src/helpers/isAtStartOfNode.d.ts +0 -2
- package/dist/packages/core/src/helpers/isExtensionRulesEnabled.d.ts +0 -2
- package/dist/packages/core/src/helpers/isList.d.ts +0 -2
- package/dist/packages/core/src/helpers/isMarkActive.d.ts +0 -3
- package/dist/packages/core/src/helpers/isNodeActive.d.ts +0 -3
- package/dist/packages/core/src/helpers/isNodeEmpty.d.ts +0 -2
- package/dist/packages/core/src/helpers/isNodeSelection.d.ts +0 -2
- package/dist/packages/core/src/helpers/isTextSelection.d.ts +0 -2
- package/dist/packages/core/src/helpers/posToDOMRect.d.ts +0 -2
- package/dist/packages/core/src/helpers/resolveFocusPosition.d.ts +0 -4
- package/dist/packages/core/src/helpers/selectionToInsertionEnd.d.ts +0 -2
- package/dist/packages/core/src/helpers/splitExtensions.d.ts +0 -9
- package/dist/packages/core/src/index.d.ts +0 -24
- package/dist/packages/core/src/inputRules/index.d.ts +0 -5
- package/dist/packages/core/src/inputRules/markInputRule.d.ts +0 -13
- package/dist/packages/core/src/inputRules/nodeInputRule.d.ts +0 -23
- package/dist/packages/core/src/inputRules/textInputRule.d.ts +0 -10
- package/dist/packages/core/src/inputRules/textblockTypeInputRule.d.ts +0 -15
- package/dist/packages/core/src/inputRules/wrappingInputRule.d.ts +0 -28
- package/dist/packages/core/src/pasteRules/index.d.ts +0 -3
- package/dist/packages/core/src/pasteRules/markPasteRule.d.ts +0 -13
- package/dist/packages/core/src/pasteRules/nodePasteRule.d.ts +0 -13
- package/dist/packages/core/src/pasteRules/textPasteRule.d.ts +0 -10
- package/dist/packages/core/src/style.d.ts +0 -1
- package/dist/packages/core/src/types.d.ts +0 -255
- package/dist/packages/core/src/utilities/callOrReturn.d.ts +0 -9
- package/dist/packages/core/src/utilities/createStyleTag.d.ts +0 -1
- package/dist/packages/core/src/utilities/deleteProps.d.ts +0 -6
- package/dist/packages/core/src/utilities/elementFromString.d.ts +0 -1
- package/dist/packages/core/src/utilities/escapeForRegEx.d.ts +0 -1
- package/dist/packages/core/src/utilities/findDuplicates.d.ts +0 -1
- package/dist/packages/core/src/utilities/fromString.d.ts +0 -1
- package/dist/packages/core/src/utilities/index.d.ts +0 -20
- package/dist/packages/core/src/utilities/isAndroid.d.ts +0 -1
- package/dist/packages/core/src/utilities/isEmptyObject.d.ts +0 -1
- package/dist/packages/core/src/utilities/isFunction.d.ts +0 -1
- package/dist/packages/core/src/utilities/isMacOS.d.ts +0 -1
- package/dist/packages/core/src/utilities/isNumber.d.ts +0 -1
- package/dist/packages/core/src/utilities/isPlainObject.d.ts +0 -1
- package/dist/packages/core/src/utilities/isRegExp.d.ts +0 -1
- package/dist/packages/core/src/utilities/isString.d.ts +0 -1
- package/dist/packages/core/src/utilities/isiOS.d.ts +0 -1
- package/dist/packages/core/src/utilities/mergeAttributes.d.ts +0 -1
- package/dist/packages/core/src/utilities/mergeDeep.d.ts +0 -1
- package/dist/packages/core/src/utilities/minMax.d.ts +0 -1
- package/dist/packages/core/src/utilities/objectIncludes.d.ts +0 -8
- package/dist/packages/core/src/utilities/removeDuplicates.d.ts +0 -8
- package/dist/packages/extension-placeholder/src/index.d.ts +0 -3
- package/dist/packages/extension-placeholder/src/placeholder.d.ts +0 -56
- package/src/placeholder.ts +0 -133
package/LICENSE.md
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2025, Tiptap GmbH
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
CHANGED
|
@@ -1,14 +1,18 @@
|
|
|
1
1
|
# @tiptap/extension-placeholder
|
|
2
|
+
|
|
2
3
|
[](https://www.npmjs.com/package/@tiptap/extension-placeholder)
|
|
3
4
|
[](https://npmcharts.com/compare/tiptap?minimal=true)
|
|
4
5
|
[](https://www.npmjs.com/package/@tiptap/extension-placeholder)
|
|
5
6
|
[](https://github.com/sponsors/ueberdosis)
|
|
6
7
|
|
|
7
8
|
## Introduction
|
|
8
|
-
|
|
9
|
+
|
|
10
|
+
Tiptap is a headless wrapper around [ProseMirror](https://ProseMirror.net) – a toolkit for building rich text WYSIWYG editors, which is already in use at many well-known companies such as _New York Times_, _The Guardian_ or _Atlassian_.
|
|
9
11
|
|
|
10
12
|
## Official Documentation
|
|
13
|
+
|
|
11
14
|
Documentation can be found on the [Tiptap website](https://tiptap.dev).
|
|
12
15
|
|
|
13
16
|
## License
|
|
17
|
+
|
|
14
18
|
Tiptap is open sourced software licensed under the [MIT license](https://github.com/ueberdosis/tiptap/blob/main/LICENSE.md).
|
package/dist/index.cjs
CHANGED
|
@@ -1,72 +1,34 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
2
19
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* This extension allows you to add a placeholder to your editor.
|
|
11
|
-
* A placeholder is a text that appears when the editor or a node is empty.
|
|
12
|
-
* @see https://www.tiptap.dev/api/extensions/placeholder
|
|
13
|
-
*/
|
|
14
|
-
const Placeholder = core.Extension.create({
|
|
15
|
-
name: 'placeholder',
|
|
16
|
-
addOptions() {
|
|
17
|
-
return {
|
|
18
|
-
emptyEditorClass: 'is-editor-empty',
|
|
19
|
-
emptyNodeClass: 'is-empty',
|
|
20
|
-
placeholder: 'Write something …',
|
|
21
|
-
showOnlyWhenEditable: true,
|
|
22
|
-
showOnlyCurrent: true,
|
|
23
|
-
includeChildren: false,
|
|
24
|
-
};
|
|
25
|
-
},
|
|
26
|
-
addProseMirrorPlugins() {
|
|
27
|
-
return [
|
|
28
|
-
new state.Plugin({
|
|
29
|
-
key: new state.PluginKey('placeholder'),
|
|
30
|
-
props: {
|
|
31
|
-
decorations: ({ doc, selection }) => {
|
|
32
|
-
const active = this.editor.isEditable || !this.options.showOnlyWhenEditable;
|
|
33
|
-
const { anchor } = selection;
|
|
34
|
-
const decorations = [];
|
|
35
|
-
if (!active) {
|
|
36
|
-
return null;
|
|
37
|
-
}
|
|
38
|
-
const isEmptyDoc = this.editor.isEmpty;
|
|
39
|
-
doc.descendants((node, pos) => {
|
|
40
|
-
const hasAnchor = anchor >= pos && anchor <= pos + node.nodeSize;
|
|
41
|
-
const isEmpty = !node.isLeaf && core.isNodeEmpty(node);
|
|
42
|
-
if ((hasAnchor || !this.options.showOnlyCurrent) && isEmpty) {
|
|
43
|
-
const classes = [this.options.emptyNodeClass];
|
|
44
|
-
if (isEmptyDoc) {
|
|
45
|
-
classes.push(this.options.emptyEditorClass);
|
|
46
|
-
}
|
|
47
|
-
const decoration = view.Decoration.node(pos, pos + node.nodeSize, {
|
|
48
|
-
class: classes.join(' '),
|
|
49
|
-
'data-placeholder': typeof this.options.placeholder === 'function'
|
|
50
|
-
? this.options.placeholder({
|
|
51
|
-
editor: this.editor,
|
|
52
|
-
node,
|
|
53
|
-
pos,
|
|
54
|
-
hasAnchor,
|
|
55
|
-
})
|
|
56
|
-
: this.options.placeholder,
|
|
57
|
-
});
|
|
58
|
-
decorations.push(decoration);
|
|
59
|
-
}
|
|
60
|
-
return this.options.includeChildren;
|
|
61
|
-
});
|
|
62
|
-
return view.DecorationSet.create(doc, decorations);
|
|
63
|
-
},
|
|
64
|
-
},
|
|
65
|
-
}),
|
|
66
|
-
];
|
|
67
|
-
},
|
|
20
|
+
// src/index.ts
|
|
21
|
+
var index_exports = {};
|
|
22
|
+
__export(index_exports, {
|
|
23
|
+
Placeholder: () => import_extensions2.Placeholder,
|
|
24
|
+
default: () => index_default
|
|
68
25
|
});
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
26
|
+
module.exports = __toCommonJS(index_exports);
|
|
27
|
+
var import_extensions = require("@tiptap/extensions");
|
|
28
|
+
var import_extensions2 = require("@tiptap/extensions");
|
|
29
|
+
var index_default = import_extensions.Placeholder;
|
|
30
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
31
|
+
0 && (module.exports = {
|
|
32
|
+
Placeholder
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=index.cjs.map
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { Placeholder } from '@tiptap/extensions'\n\nexport type { PlaceholderOptions } from '@tiptap/extensions'\nexport { Placeholder } from '@tiptap/extensions'\n\nexport default Placeholder\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBAA4B;AAG5B,IAAAA,qBAA4B;AAE5B,IAAO,gBAAQ;","names":["import_extensions"]}
|
package/dist/index.d.cts
ADDED
package/dist/index.d.ts
ADDED
package/dist/index.js
CHANGED
|
@@ -1,67 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const Placeholder = Extension.create({
|
|
11
|
-
name: 'placeholder',
|
|
12
|
-
addOptions() {
|
|
13
|
-
return {
|
|
14
|
-
emptyEditorClass: 'is-editor-empty',
|
|
15
|
-
emptyNodeClass: 'is-empty',
|
|
16
|
-
placeholder: 'Write something …',
|
|
17
|
-
showOnlyWhenEditable: true,
|
|
18
|
-
showOnlyCurrent: true,
|
|
19
|
-
includeChildren: false,
|
|
20
|
-
};
|
|
21
|
-
},
|
|
22
|
-
addProseMirrorPlugins() {
|
|
23
|
-
return [
|
|
24
|
-
new Plugin({
|
|
25
|
-
key: new PluginKey('placeholder'),
|
|
26
|
-
props: {
|
|
27
|
-
decorations: ({ doc, selection }) => {
|
|
28
|
-
const active = this.editor.isEditable || !this.options.showOnlyWhenEditable;
|
|
29
|
-
const { anchor } = selection;
|
|
30
|
-
const decorations = [];
|
|
31
|
-
if (!active) {
|
|
32
|
-
return null;
|
|
33
|
-
}
|
|
34
|
-
const isEmptyDoc = this.editor.isEmpty;
|
|
35
|
-
doc.descendants((node, pos) => {
|
|
36
|
-
const hasAnchor = anchor >= pos && anchor <= pos + node.nodeSize;
|
|
37
|
-
const isEmpty = !node.isLeaf && isNodeEmpty(node);
|
|
38
|
-
if ((hasAnchor || !this.options.showOnlyCurrent) && isEmpty) {
|
|
39
|
-
const classes = [this.options.emptyNodeClass];
|
|
40
|
-
if (isEmptyDoc) {
|
|
41
|
-
classes.push(this.options.emptyEditorClass);
|
|
42
|
-
}
|
|
43
|
-
const decoration = Decoration.node(pos, pos + node.nodeSize, {
|
|
44
|
-
class: classes.join(' '),
|
|
45
|
-
'data-placeholder': typeof this.options.placeholder === 'function'
|
|
46
|
-
? this.options.placeholder({
|
|
47
|
-
editor: this.editor,
|
|
48
|
-
node,
|
|
49
|
-
pos,
|
|
50
|
-
hasAnchor,
|
|
51
|
-
})
|
|
52
|
-
: this.options.placeholder,
|
|
53
|
-
});
|
|
54
|
-
decorations.push(decoration);
|
|
55
|
-
}
|
|
56
|
-
return this.options.includeChildren;
|
|
57
|
-
});
|
|
58
|
-
return DecorationSet.create(doc, decorations);
|
|
59
|
-
},
|
|
60
|
-
},
|
|
61
|
-
}),
|
|
62
|
-
];
|
|
63
|
-
},
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
export { Placeholder, Placeholder as default };
|
|
67
|
-
//# sourceMappingURL=index.js.map
|
|
1
|
+
// src/index.ts
|
|
2
|
+
import { Placeholder } from "@tiptap/extensions";
|
|
3
|
+
import { Placeholder as Placeholder2 } from "@tiptap/extensions";
|
|
4
|
+
var index_default = Placeholder;
|
|
5
|
+
export {
|
|
6
|
+
Placeholder2 as Placeholder,
|
|
7
|
+
index_default as default
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { Placeholder } from '@tiptap/extensions'\n\nexport type { PlaceholderOptions } from '@tiptap/extensions'\nexport { Placeholder } from '@tiptap/extensions'\n\nexport default Placeholder\n"],"mappings":";AAAA,SAAS,mBAAmB;AAG5B,SAAS,eAAAA,oBAAmB;AAE5B,IAAO,gBAAQ;","names":["Placeholder"]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tiptap/extension-placeholder",
|
|
3
3
|
"description": "placeholder extension for tiptap",
|
|
4
|
-
"version": "3.0.0",
|
|
4
|
+
"version": "3.0.2-beta.0",
|
|
5
5
|
"homepage": "https://tiptap.dev",
|
|
6
6
|
"keywords": [
|
|
7
7
|
"tiptap",
|
|
@@ -15,34 +15,34 @@
|
|
|
15
15
|
"type": "module",
|
|
16
16
|
"exports": {
|
|
17
17
|
".": {
|
|
18
|
-
"types":
|
|
18
|
+
"types": {
|
|
19
|
+
"import": "./dist/index.d.ts",
|
|
20
|
+
"require": "./dist/index.d.cts"
|
|
21
|
+
},
|
|
19
22
|
"import": "./dist/index.js",
|
|
20
23
|
"require": "./dist/index.cjs"
|
|
21
24
|
}
|
|
22
25
|
},
|
|
23
26
|
"main": "dist/index.cjs",
|
|
24
27
|
"module": "dist/index.js",
|
|
25
|
-
"
|
|
26
|
-
"types": "dist/packages/extension-placeholder/src/index.d.ts",
|
|
28
|
+
"types": "dist/index.d.ts",
|
|
27
29
|
"files": [
|
|
28
30
|
"src",
|
|
29
31
|
"dist"
|
|
30
32
|
],
|
|
31
33
|
"devDependencies": {
|
|
32
|
-
"@tiptap/
|
|
33
|
-
"@tiptap/pm": "^3.0.0"
|
|
34
|
+
"@tiptap/extensions": "^3.0.2-beta.0"
|
|
34
35
|
},
|
|
35
36
|
"peerDependencies": {
|
|
36
|
-
"@tiptap/
|
|
37
|
-
"@tiptap/pm": "^3.0.0"
|
|
37
|
+
"@tiptap/extensions": "^3.0.2-beta.0"
|
|
38
38
|
},
|
|
39
39
|
"repository": {
|
|
40
40
|
"type": "git",
|
|
41
41
|
"url": "https://github.com/ueberdosis/tiptap",
|
|
42
|
-
"directory": "packages/extension-placeholder"
|
|
42
|
+
"directory": "packages-deprecated/extension-placeholder"
|
|
43
43
|
},
|
|
44
44
|
"scripts": {
|
|
45
|
-
"
|
|
46
|
-
"
|
|
45
|
+
"build": "tsup",
|
|
46
|
+
"lint": "prettier ./src/ --check && eslint --cache --quiet --no-error-on-unmatched-pattern ./src/"
|
|
47
47
|
}
|
|
48
|
-
}
|
|
48
|
+
}
|
package/src/index.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { Placeholder } from '
|
|
1
|
+
import { Placeholder } from '@tiptap/extensions'
|
|
2
2
|
|
|
3
|
-
export
|
|
3
|
+
export type { PlaceholderOptions } from '@tiptap/extensions'
|
|
4
|
+
export { Placeholder } from '@tiptap/extensions'
|
|
4
5
|
|
|
5
6
|
export default Placeholder
|
package/dist/index.umd.js
DELETED
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
(function (global, factory) {
|
|
2
|
-
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@tiptap/core'), require('@tiptap/pm/state'), require('@tiptap/pm/view')) :
|
|
3
|
-
typeof define === 'function' && define.amd ? define(['exports', '@tiptap/core', '@tiptap/pm/state', '@tiptap/pm/view'], factory) :
|
|
4
|
-
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["@tiptap/extension-placeholder"] = {}, global.core, global.state, global.view));
|
|
5
|
-
})(this, (function (exports, core, state, view) { 'use strict';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* This extension allows you to add a placeholder to your editor.
|
|
9
|
-
* A placeholder is a text that appears when the editor or a node is empty.
|
|
10
|
-
* @see https://www.tiptap.dev/api/extensions/placeholder
|
|
11
|
-
*/
|
|
12
|
-
const Placeholder = core.Extension.create({
|
|
13
|
-
name: 'placeholder',
|
|
14
|
-
addOptions() {
|
|
15
|
-
return {
|
|
16
|
-
emptyEditorClass: 'is-editor-empty',
|
|
17
|
-
emptyNodeClass: 'is-empty',
|
|
18
|
-
placeholder: 'Write something …',
|
|
19
|
-
showOnlyWhenEditable: true,
|
|
20
|
-
showOnlyCurrent: true,
|
|
21
|
-
includeChildren: false,
|
|
22
|
-
};
|
|
23
|
-
},
|
|
24
|
-
addProseMirrorPlugins() {
|
|
25
|
-
return [
|
|
26
|
-
new state.Plugin({
|
|
27
|
-
key: new state.PluginKey('placeholder'),
|
|
28
|
-
props: {
|
|
29
|
-
decorations: ({ doc, selection }) => {
|
|
30
|
-
const active = this.editor.isEditable || !this.options.showOnlyWhenEditable;
|
|
31
|
-
const { anchor } = selection;
|
|
32
|
-
const decorations = [];
|
|
33
|
-
if (!active) {
|
|
34
|
-
return null;
|
|
35
|
-
}
|
|
36
|
-
const isEmptyDoc = this.editor.isEmpty;
|
|
37
|
-
doc.descendants((node, pos) => {
|
|
38
|
-
const hasAnchor = anchor >= pos && anchor <= pos + node.nodeSize;
|
|
39
|
-
const isEmpty = !node.isLeaf && core.isNodeEmpty(node);
|
|
40
|
-
if ((hasAnchor || !this.options.showOnlyCurrent) && isEmpty) {
|
|
41
|
-
const classes = [this.options.emptyNodeClass];
|
|
42
|
-
if (isEmptyDoc) {
|
|
43
|
-
classes.push(this.options.emptyEditorClass);
|
|
44
|
-
}
|
|
45
|
-
const decoration = view.Decoration.node(pos, pos + node.nodeSize, {
|
|
46
|
-
class: classes.join(' '),
|
|
47
|
-
'data-placeholder': typeof this.options.placeholder === 'function'
|
|
48
|
-
? this.options.placeholder({
|
|
49
|
-
editor: this.editor,
|
|
50
|
-
node,
|
|
51
|
-
pos,
|
|
52
|
-
hasAnchor,
|
|
53
|
-
})
|
|
54
|
-
: this.options.placeholder,
|
|
55
|
-
});
|
|
56
|
-
decorations.push(decoration);
|
|
57
|
-
}
|
|
58
|
-
return this.options.includeChildren;
|
|
59
|
-
});
|
|
60
|
-
return view.DecorationSet.create(doc, decorations);
|
|
61
|
-
},
|
|
62
|
-
},
|
|
63
|
-
}),
|
|
64
|
-
];
|
|
65
|
-
},
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
exports.Placeholder = Placeholder;
|
|
69
|
-
exports.default = Placeholder;
|
|
70
|
-
|
|
71
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
72
|
-
|
|
73
|
-
}));
|
|
74
|
-
//# sourceMappingURL=index.umd.js.map
|
package/dist/index.umd.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.umd.js","sources":["../src/placeholder.ts"],"sourcesContent":["import { Editor, Extension, isNodeEmpty } from '@tiptap/core'\nimport { Node as ProsemirrorNode } from '@tiptap/pm/model'\nimport { Plugin, PluginKey } from '@tiptap/pm/state'\nimport { Decoration, DecorationSet } from '@tiptap/pm/view'\n\nexport interface PlaceholderOptions {\n /**\n * **The class name for the empty editor**\n * @default 'is-editor-empty'\n */\n emptyEditorClass: string\n\n /**\n * **The class name for empty nodes**\n * @default 'is-empty'\n */\n emptyNodeClass: string\n\n /**\n * **The placeholder content**\n *\n * You can use a function to return a dynamic placeholder or a string.\n * @default 'Write something …'\n */\n placeholder:\n | ((PlaceholderProps: {\n editor: Editor\n node: ProsemirrorNode\n pos: number\n hasAnchor: boolean\n }) => string)\n | string\n\n /**\n * **Checks if the placeholder should be only shown when the editor is editable.**\n *\n * If true, the placeholder will only be shown when the editor is editable.\n * If false, the placeholder will always be shown.\n * @default true\n */\n showOnlyWhenEditable: boolean\n\n /**\n * **Checks if the placeholder should be only shown when the current node is empty.**\n *\n * If true, the placeholder will only be shown when the current node is empty.\n * If false, the placeholder will be shown when any node is empty.\n * @default true\n */\n showOnlyCurrent: boolean\n\n /**\n * **Controls if the placeholder should be shown for all descendents.**\n *\n * If true, the placeholder will be shown for all descendents.\n * If false, the placeholder will only be shown for the current node.\n * @default false\n */\n includeChildren: boolean\n}\n\n/**\n * This extension allows you to add a placeholder to your editor.\n * A placeholder is a text that appears when the editor or a node is empty.\n * @see https://www.tiptap.dev/api/extensions/placeholder\n */\nexport const Placeholder = Extension.create<PlaceholderOptions>({\n name: 'placeholder',\n\n addOptions() {\n return {\n emptyEditorClass: 'is-editor-empty',\n emptyNodeClass: 'is-empty',\n placeholder: 'Write something …',\n showOnlyWhenEditable: true,\n showOnlyCurrent: true,\n includeChildren: false,\n }\n },\n\n addProseMirrorPlugins() {\n return [\n new Plugin({\n key: new PluginKey('placeholder'),\n props: {\n decorations: ({ doc, selection }) => {\n const active = this.editor.isEditable || !this.options.showOnlyWhenEditable\n const { anchor } = selection\n const decorations: Decoration[] = []\n\n if (!active) {\n return null\n }\n\n const isEmptyDoc = this.editor.isEmpty\n\n doc.descendants((node, pos) => {\n const hasAnchor = anchor >= pos && anchor <= pos + node.nodeSize\n const isEmpty = !node.isLeaf && isNodeEmpty(node)\n\n if ((hasAnchor || !this.options.showOnlyCurrent) && isEmpty) {\n const classes = [this.options.emptyNodeClass]\n\n if (isEmptyDoc) {\n classes.push(this.options.emptyEditorClass)\n }\n\n const decoration = Decoration.node(pos, pos + node.nodeSize, {\n class: classes.join(' '),\n 'data-placeholder':\n typeof this.options.placeholder === 'function'\n ? this.options.placeholder({\n editor: this.editor,\n node,\n pos,\n hasAnchor,\n })\n : this.options.placeholder,\n })\n\n decorations.push(decoration)\n }\n\n return this.options.includeChildren\n })\n\n return DecorationSet.create(doc, decorations)\n },\n },\n }),\n ]\n },\n})\n"],"names":["Extension","Plugin","PluginKey","isNodeEmpty","Decoration","DecorationSet"],"mappings":";;;;;;EA6DA;;;;EAIG;AACU,QAAA,WAAW,GAAGA,cAAS,CAAC,MAAM,CAAqB;EAC9D,IAAA,IAAI,EAAE,aAAa;MAEnB,UAAU,GAAA;UACR,OAAO;EACL,YAAA,gBAAgB,EAAE,iBAAiB;EACnC,YAAA,cAAc,EAAE,UAAU;EAC1B,YAAA,WAAW,EAAE,mBAAmB;EAChC,YAAA,oBAAoB,EAAE,IAAI;EAC1B,YAAA,eAAe,EAAE,IAAI;EACrB,YAAA,eAAe,EAAE,KAAK;WACvB,CAAA;OACF;MAED,qBAAqB,GAAA;UACnB,OAAO;EACL,YAAA,IAAIC,YAAM,CAAC;EACT,gBAAA,GAAG,EAAE,IAAIC,eAAS,CAAC,aAAa,CAAC;EACjC,gBAAA,KAAK,EAAE;sBACL,WAAW,EAAE,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,KAAI;EAClC,wBAAA,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAA;EAC3E,wBAAA,MAAM,EAAE,MAAM,EAAE,GAAG,SAAS,CAAA;0BAC5B,MAAM,WAAW,GAAiB,EAAE,CAAA;0BAEpC,IAAI,CAAC,MAAM,EAAE;EACX,4BAAA,OAAO,IAAI,CAAA;2BACZ;EAED,wBAAA,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAA;0BAEtC,GAAG,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,GAAG,KAAI;EAC5B,4BAAA,MAAM,SAAS,GAAG,MAAM,IAAI,GAAG,IAAI,MAAM,IAAI,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAA;8BAChE,MAAM,OAAO,GAAG,CAAC,IAAI,CAAC,MAAM,IAAIC,gBAAW,CAAC,IAAI,CAAC,CAAA;EAEjD,4BAAA,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,KAAK,OAAO,EAAE;kCAC3D,MAAM,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAA;kCAE7C,IAAI,UAAU,EAAE;sCACd,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAA;mCAC5C;EAED,gCAAA,MAAM,UAAU,GAAGC,eAAU,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE;EAC3D,oCAAA,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;sCACxB,kBAAkB,EAChB,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,KAAK,UAAU;EAC5C,0CAAE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;8CACzB,MAAM,EAAE,IAAI,CAAC,MAAM;8CACnB,IAAI;8CACJ,GAAG;8CACH,SAAS;2CACV,CAAC;EACF,0CAAE,IAAI,CAAC,OAAO,CAAC,WAAW;EAC/B,iCAAA,CAAC,CAAA;EAEF,gCAAA,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;+BAC7B;EAED,4BAAA,OAAO,IAAI,CAAC,OAAO,CAAC,eAAe,CAAA;EACrC,yBAAC,CAAC,CAAA;0BAEF,OAAOC,kBAAa,CAAC,MAAM,CAAC,GAAG,EAAE,WAAW,CAAC,CAAA;uBAC9C;EACF,iBAAA;eACF,CAAC;WACH,CAAA;OACF;EACF,CAAA;;;;;;;;;;;"}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { EditorState, Transaction } from '@tiptap/pm/state';
|
|
2
|
-
import { Editor } from './Editor.js';
|
|
3
|
-
import { AnyCommands, CanCommands, ChainedCommands, CommandProps, SingleCommands } from './types.js';
|
|
4
|
-
export declare class CommandManager {
|
|
5
|
-
editor: Editor;
|
|
6
|
-
rawCommands: AnyCommands;
|
|
7
|
-
customState?: EditorState;
|
|
8
|
-
constructor(props: {
|
|
9
|
-
editor: Editor;
|
|
10
|
-
state?: EditorState;
|
|
11
|
-
});
|
|
12
|
-
get hasCustomState(): boolean;
|
|
13
|
-
get state(): EditorState;
|
|
14
|
-
get commands(): SingleCommands;
|
|
15
|
-
get chain(): () => ChainedCommands;
|
|
16
|
-
get can(): () => CanCommands;
|
|
17
|
-
createChain(startTr?: Transaction, shouldDispatch?: boolean): ChainedCommands;
|
|
18
|
-
createCan(startTr?: Transaction): CanCommands;
|
|
19
|
-
buildProps(tr: Transaction, shouldDispatch?: boolean): CommandProps;
|
|
20
|
-
}
|
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
import { MarkType, NodeType, Schema } from '@tiptap/pm/model';
|
|
2
|
-
import { EditorState, Plugin, PluginKey, Transaction } from '@tiptap/pm/state';
|
|
3
|
-
import { EditorView } from '@tiptap/pm/view';
|
|
4
|
-
import { EventEmitter } from './EventEmitter.js';
|
|
5
|
-
import { ExtensionManager } from './ExtensionManager.js';
|
|
6
|
-
import { NodePos } from './NodePos.js';
|
|
7
|
-
import { CanCommands, ChainedCommands, EditorEvents, EditorOptions, JSONContent, SingleCommands, TextSerializer } from './types.js';
|
|
8
|
-
export * as extensions from './extensions/index.js';
|
|
9
|
-
declare global {
|
|
10
|
-
interface HTMLElement {
|
|
11
|
-
editor?: Editor;
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
export declare class Editor extends EventEmitter<EditorEvents> {
|
|
15
|
-
private commandManager;
|
|
16
|
-
extensionManager: ExtensionManager;
|
|
17
|
-
private css;
|
|
18
|
-
schema: Schema;
|
|
19
|
-
view: EditorView;
|
|
20
|
-
isFocused: boolean;
|
|
21
|
-
extensionStorage: Record<string, any>;
|
|
22
|
-
options: EditorOptions;
|
|
23
|
-
constructor(options?: Partial<EditorOptions>);
|
|
24
|
-
/**
|
|
25
|
-
* Returns the editor storage.
|
|
26
|
-
*/
|
|
27
|
-
get storage(): Record<string, any>;
|
|
28
|
-
/**
|
|
29
|
-
* An object of all registered commands.
|
|
30
|
-
*/
|
|
31
|
-
get commands(): SingleCommands;
|
|
32
|
-
/**
|
|
33
|
-
* Create a command chain to call multiple commands at once.
|
|
34
|
-
*/
|
|
35
|
-
chain(): ChainedCommands;
|
|
36
|
-
/**
|
|
37
|
-
* Check if a command or a command chain can be executed. Without executing it.
|
|
38
|
-
*/
|
|
39
|
-
can(): CanCommands;
|
|
40
|
-
/**
|
|
41
|
-
* Inject CSS styles.
|
|
42
|
-
*/
|
|
43
|
-
private injectCSS;
|
|
44
|
-
/**
|
|
45
|
-
* Update editor options.
|
|
46
|
-
*
|
|
47
|
-
* @param options A list of options
|
|
48
|
-
*/
|
|
49
|
-
setOptions(options?: Partial<EditorOptions>): void;
|
|
50
|
-
/**
|
|
51
|
-
* Update editable state of the editor.
|
|
52
|
-
*/
|
|
53
|
-
setEditable(editable: boolean, emitUpdate?: boolean): void;
|
|
54
|
-
/**
|
|
55
|
-
* Returns whether the editor is editable.
|
|
56
|
-
*/
|
|
57
|
-
get isEditable(): boolean;
|
|
58
|
-
/**
|
|
59
|
-
* Returns the editor state.
|
|
60
|
-
*/
|
|
61
|
-
get state(): EditorState;
|
|
62
|
-
/**
|
|
63
|
-
* Register a ProseMirror plugin.
|
|
64
|
-
*
|
|
65
|
-
* @param plugin A ProseMirror plugin
|
|
66
|
-
* @param handlePlugins Control how to merge the plugin into the existing plugins.
|
|
67
|
-
*/
|
|
68
|
-
registerPlugin(plugin: Plugin, handlePlugins?: (newPlugin: Plugin, plugins: Plugin[]) => Plugin[]): void;
|
|
69
|
-
/**
|
|
70
|
-
* Unregister a ProseMirror plugin.
|
|
71
|
-
*
|
|
72
|
-
* @param nameOrPluginKey The plugins name
|
|
73
|
-
*/
|
|
74
|
-
unregisterPlugin(nameOrPluginKey: string | PluginKey): void;
|
|
75
|
-
/**
|
|
76
|
-
* Creates an extension manager.
|
|
77
|
-
*/
|
|
78
|
-
private createExtensionManager;
|
|
79
|
-
/**
|
|
80
|
-
* Creates an command manager.
|
|
81
|
-
*/
|
|
82
|
-
private createCommandManager;
|
|
83
|
-
/**
|
|
84
|
-
* Creates a ProseMirror schema.
|
|
85
|
-
*/
|
|
86
|
-
private createSchema;
|
|
87
|
-
/**
|
|
88
|
-
* Creates a ProseMirror view.
|
|
89
|
-
*/
|
|
90
|
-
private createView;
|
|
91
|
-
/**
|
|
92
|
-
* Creates all node views.
|
|
93
|
-
*/
|
|
94
|
-
createNodeViews(): void;
|
|
95
|
-
/**
|
|
96
|
-
* Prepend class name to element.
|
|
97
|
-
*/
|
|
98
|
-
prependClass(): void;
|
|
99
|
-
isCapturingTransaction: boolean;
|
|
100
|
-
private capturedTransaction;
|
|
101
|
-
captureTransaction(fn: Function): Transaction | null;
|
|
102
|
-
/**
|
|
103
|
-
* The callback over which to send transactions (state updates) produced by the view.
|
|
104
|
-
*
|
|
105
|
-
* @param transaction An editor state transaction
|
|
106
|
-
*/
|
|
107
|
-
private dispatchTransaction;
|
|
108
|
-
/**
|
|
109
|
-
* Get attributes of the currently selected node or mark.
|
|
110
|
-
*/
|
|
111
|
-
getAttributes(nameOrType: string | NodeType | MarkType): Record<string, any>;
|
|
112
|
-
/**
|
|
113
|
-
* Returns if the currently selected node or mark is active.
|
|
114
|
-
*
|
|
115
|
-
* @param name Name of the node or mark
|
|
116
|
-
* @param attributes Attributes of the node or mark
|
|
117
|
-
*/
|
|
118
|
-
isActive(name: string, attributes?: {}): boolean;
|
|
119
|
-
isActive(attributes: {}): boolean;
|
|
120
|
-
/**
|
|
121
|
-
* Get the document as JSON.
|
|
122
|
-
*/
|
|
123
|
-
getJSON(): JSONContent;
|
|
124
|
-
/**
|
|
125
|
-
* Get the document as HTML.
|
|
126
|
-
*/
|
|
127
|
-
getHTML(): string;
|
|
128
|
-
/**
|
|
129
|
-
* Get the document as text.
|
|
130
|
-
*/
|
|
131
|
-
getText(options?: {
|
|
132
|
-
blockSeparator?: string;
|
|
133
|
-
textSerializers?: Record<string, TextSerializer>;
|
|
134
|
-
}): string;
|
|
135
|
-
/**
|
|
136
|
-
* Check if there is no content.
|
|
137
|
-
*/
|
|
138
|
-
get isEmpty(): boolean;
|
|
139
|
-
/**
|
|
140
|
-
* Get the number of characters for the current document.
|
|
141
|
-
*
|
|
142
|
-
* @deprecated
|
|
143
|
-
*/
|
|
144
|
-
getCharacterCount(): number;
|
|
145
|
-
/**
|
|
146
|
-
* Destroy the editor.
|
|
147
|
-
*/
|
|
148
|
-
destroy(): void;
|
|
149
|
-
/**
|
|
150
|
-
* Check if the editor is already destroyed.
|
|
151
|
-
*/
|
|
152
|
-
get isDestroyed(): boolean;
|
|
153
|
-
$node(selector: string, attributes?: {
|
|
154
|
-
[key: string]: any;
|
|
155
|
-
}): NodePos | null;
|
|
156
|
-
$nodes(selector: string, attributes?: {
|
|
157
|
-
[key: string]: any;
|
|
158
|
-
}): NodePos[] | null;
|
|
159
|
-
$pos(pos: number): NodePos;
|
|
160
|
-
get $doc(): NodePos;
|
|
161
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
type StringKeyOf<T> = Extract<keyof T, string>;
|
|
2
|
-
type CallbackType<T extends Record<string, any>, EventName extends StringKeyOf<T>> = T[EventName] extends any[] ? T[EventName] : [T[EventName]];
|
|
3
|
-
type CallbackFunction<T extends Record<string, any>, EventName extends StringKeyOf<T>> = (...props: CallbackType<T, EventName>) => any;
|
|
4
|
-
export declare class EventEmitter<T extends Record<string, any>> {
|
|
5
|
-
private callbacks;
|
|
6
|
-
on<EventName extends StringKeyOf<T>>(event: EventName, fn: CallbackFunction<T, EventName>): this;
|
|
7
|
-
emit<EventName extends StringKeyOf<T>>(event: EventName, ...args: CallbackType<T, EventName>): this;
|
|
8
|
-
off<EventName extends StringKeyOf<T>>(event: EventName, fn?: CallbackFunction<T, EventName>): this;
|
|
9
|
-
removeAllListeners(): void;
|
|
10
|
-
}
|
|
11
|
-
export {};
|