UNPKG

@tiptap/extension-image

Version:

image extension for tiptap

130 lines (113 loc) 2.51 kB
import { mergeAttributes, Node, nodeInputRule, } from '@tiptap/core' export interface ImageOptions { /** * Controls if the image node should be inline or not. * @default false * @example true */ inline: boolean, /** * Controls if base64 images are allowed. Enable this if you want to allow * base64 image urls in the `src` attribute. * @default false * @example true */ allowBase64: boolean, /** * HTML attributes to add to the image element. * @default {} * @example { class: 'foo' } */ HTMLAttributes: Record<string, any>, } declare module '@tiptap/core' { interface Commands<ReturnType> { image: { /** * Add an image * @param options The image attributes * @example * editor * .commands * .setImage({ src: 'https://tiptap.dev/logo.png', alt: 'tiptap', title: 'tiptap logo' }) */ setImage: (options: { src: string, alt?: string, title?: string }) => ReturnType, } } } /** * Matches an image to a ![image](src "title") on input. */ export const inputRegex = /(?:^|\s)(!\[(.+|:?)]\((\S+)(?:(?:\s+)["'](\S+)["'])?\))$/ /** * This extension allows you to insert images. * @see https://www.tiptap.dev/api/nodes/image */ export const Image = Node.create<ImageOptions>({ name: 'image', addOptions() { return { inline: false, allowBase64: false, HTMLAttributes: {}, } }, inline() { return this.options.inline }, group() { return this.options.inline ? 'inline' : 'block' }, draggable: true, addAttributes() { return { src: { default: null, }, alt: { default: null, }, title: { default: null, }, } }, parseHTML() { return [ { tag: this.options.allowBase64 ? 'img[src]' : 'img[src]:not([src^="data:"])', }, ] }, renderHTML({ HTMLAttributes }) { return ['img', mergeAttributes(this.options.HTMLAttributes, HTMLAttributes)] }, addCommands() { return { setImage: options => ({ commands }) => { return commands.insertContent({ type: this.name, attrs: options, }) }, } }, addInputRules() { return [ nodeInputRule({ find: inputRegex, type: this.type, getAttributes: match => { const [,, alt, src, title] = match return { src, alt, title } }, }), ] }, })