A tiptap extension that allows you to add inline suggestions to your editor.
Live Demo: https://sereneinserenade.github.io/tiptap-inline-suggestion/
Video Demo
tiptap-inline-suggestions-demo.mp4
npm install @sereneinserenade/tiptap-inline-suggestion
Add InlineSuggestion
extension to your list of extension for tiptap. Add a fetchAutocompletion
function to the configuration object. This function should return a string. This string will be shown as a suggestion to the user.
Add styles to show the suggestion that gets stored in the attribute data-inline-suggestion
. Below are styles I used for the demo, adjust it to your liking.
import { Editor } from "@tiptap/core";
import StarterKit from "@tiptap/starter-kit";
import InlineSuggestion from "@sereneinserenade/tiptap-inline-suggestion";
const editor = new Editor(
{
extensions: [
StarterKit,
// add InlineSuggestions to the array of tiptap extensions
InlineSuggestion.configure(
{
fetchAutocompletion: async (query) => {
// make request to your API or something else
const res = await fetch(`YOUR_API_ENDPOINT?query=${query}`)
const stringRes = res.suggestion; // or whatever your API returns
return stringRes; // return value should always be a string
}
}
),
],
}
)
[data-inline-suggestion]::after {
content: attr(data-inline-suggestion);
color: #999;
}
A ⭐️ to the repo if you 👍 / ❤️ what I'm doing would be much appreciated. If you're using this extension, it'd be very kind of you to ❤️ Sponsor me.
I've made a bunch of extensions for Tiptap 2, some of them are Resiable Images And Videos, Search and Replace, LanguageTool integration with tiptap. You can check it our here https://github.com/sereneinserenade#a-glance-of-my-projects.
MIT © Jeet Mandaliya(github: sereneinserenade)