tiptap-editor
Original:🇺🇸 English
Translated
Tiptap editor API patterns for vmark WYSIWYG development. Use when working with editor commands, node traversal, selection handling, or format operations.
7installs
Sourcexiaolai/vmark
Added on
NPX Install
npx skill4agent add xiaolai/vmark tiptap-editorTags
Translated version includes tags in frontmatterSKILL.md Content
View Translation Comparison →Tiptap Editor API Patterns
Overview
This skill documents proper Tiptap API usage patterns for vmark development. It helps distinguish when to use Tiptap's high-level API vs direct ProseMirror access.
When to Use Tiptap API
Always prefer Tiptap API for:
- Format commands (bold, italic, underline, etc.)
- Block type changes (heading, paragraph, code block)
- List operations (bullet, ordered, toggle, indent/outdent)
- Table operations via Tiptap table extension
- Content insertion and replacement
- Editor state queries (,
isActive)getAttributes
Tiptap patterns to use:
typescript
// Direct commands
editor.commands.toggleBold()
editor.commands.setHeading({ level: 2 })
editor.commands.setContent(doc, { emitUpdate: false })
// Chained commands (for multiple operations)
editor.chain().focus().setHeading({ level: 2 }).run()
editor.chain().focus().toggleMark("underline").run()
// State queries
editor.isActive("blockquote")
editor.isActive("heading", { level: 2 })
editor.getAttributes("link")When Direct ProseMirror is Appropriate
Use ProseMirror directly for:
- Markdown conversion layer (,
proseMirrorToMdast.ts)mdastToProseMirror.ts - Multi-cursor/selection subclassing ()
MultiSelection.ts - Custom node views
- Low-level transaction manipulation
- Schema-level operations
Known Issues in vmark
1. cursorHandlers.ts Block Boundary Issue
src/hooks/mcpBridge/cursorHandlers.tsdoc.textContent$postypescript
// WRONG - loses block structure
const text = doc.textContent;
// RIGHT - respects block boundaries
const $pos = doc.resolve(from);
const currentNode = $pos.parent;
const blockStart = $pos.before($pos.depth);
const blockEnd = $pos.after($pos.depth);2. Cursor Sync Drift After WYSIWYG Edits
sourceLine3. HtmlNodeView.ts Store Issue
src/plugins/markdownArtifacts/HtmlNodeView.tsReferences
- - Detailed API patterns and $pos usage
references/patterns.md - - Real code examples from vmark codebase
references/examples.md
Workflow
- Identify operation type (format, block, selection, traversal)
- Check if Tiptap has a built-in command for it
- Use for single operations
editor.commands.xxx() - Use when focus is needed or chaining
editor.chain().focus().xxx().run() - For node traversal, use to get
doc.resolve(pos)helpers$pos - For state queries, use or
editor.isActive()editor.getAttributes()