Tiptap 3 editor for Vue3 with Vuetify toolbar implementation
Alpha
Not production ready (yet) - may contain bugs and internal logic may change
- Vue 3.x
- Vuetify.js 3.x
- Vuetify components
- Markdown support
- TypeScript support
- i18n
- Bubble Menu
- Floating Menu
- Slash Command
- Dark theme
Install package
# npm
npm i tiptapify
# or pnpm
pnpm i tiptapify
Register plugin in your main.js (main.ts)
import TiptapifyPlugin from 'tiptapify';
import 'tiptapify/style.css';
app.use(TiptapifyPlugin, { locale: 'en' });
Should be something like this
import { createApp } from "vue";
import App from "./App.vue";
import { aliases, mdi as mdiSvg } from 'vuetify/iconsets/mdi-svg'
import 'vuetify/styles'
import { createVuetify } from 'vuetify'
import { aliases, mdi } from 'vuetify/iconsets/mdi-svg'
import * as components from 'vuetify/components'
import * as directives from 'vuetify/directives'
const app = createApp(App)
const vuetify = createVuetify({
components,
directives,
icons: { defaultSet: 'mdi', aliases, sets: { mdiSvg } },
})
app.use(vuetify);
// add these lines
import TiptapifyPlugin from 'tiptapify';
import 'tiptapify/style.css';
app.use(TiptapifyPlugin, { locale: 'en' });
// Mount vue app
app.mount('#app')
<script setup lang="ts">
const handleEditorReady = (options: { editor: any, getHTML: Function, getJSON: Function, echo: Function }) => {
console.log('The editor is ready', options.editor);
console.log('editor html', options.getHTML());
console.log('editor json', options.getJSON());
};
</script>
<template>
<Tiptapify
:content="content"
:bubble-menu="true"
:floating-menu="false"
:slash-commands="true"
@editor-ready="handleEditorReady"
/>
</template>
You can choose which toolbar items to display by providing array/object to items prop
<script setup lang="ts">
// show items in predefined sections
const items = ['fontFamily', 'fontSize', 'lineHeight', 'textColor', 'highlightColor', 'code', 'codeBlock', 'pagebreak']
// show items in custom sections
const items = { section1: ['textColor', 'fontFamily', 'fontSize', 'lineHeight', 'code', 'codeBlock'], section2: ['pagebreak'] }
</script>
<template>
<Tiptapify
...
:items="items"
/>
</template>
Also you can choose which toolbar items to ignore by providing prop items-exclude alongside items prop.
<script setup lang="ts">
const items = ['fontFamily', 'fontSize', 'lineHeight', 'textColor', 'highlightColor', 'code', 'codeBlock', 'pagebreak']
</script>
<template>
<Tiptapify
...
:items="items"
:items-exclude="true"
/>
</template>
Found a wrong translation or want to add a new language? Feel free to send your translation made from the template.
Found a bug or have ideas on improvement? Feel free to create a ticket.
- menu items list customizable
- extend a built-in font list
- raw html mode
- fullscreen mode
- tables extension
- preview extension
- image extension
- text styling (background & font color)
- dark theme
- emoji extension
- video extensions
- filter option in emoji extension
- option to provide custom extension
- iframe extension
- charmap extension
- extended video extensions
- print hotkey in a tooltip
- demo
- documentation
- AI features