Overview ​
There are three types of extensions that you can create:
Node
- a node is a building block of the editor's content. It can be a paragraph, a heading, a list, a tableMark
- a mark is a formatting element that can be applied to a node. It can be bold, italic, underline, strikethroughExtension
- Extensions add new capabilities to Tiptap. It can be bubble menu, floating menu, etc.
Creating custom extension ​
Note
More on options that you can pass to the extension can be found here
Node ​
tsx
import { Node } from "@tiptap/core";
const CustomNode = Node.create({
name: "customNode",
// Your code goes here.
});
Mark ​
tsx
import { Mark } from "@tiptap/core";
const CustomMark = Mark.create({
name: "customMark",
// Your code goes here.
});
Extension ​
tsx
import { Extension } from "@tiptap/core";
const CustomExtension = Extension.create({
name: "customExtension",
// Your code goes here.
});