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)