import { Node } from '@tiptap/core' import { textblockTypeInputRule } from 'prosemirror-inputrules' declare module '@tiptap/core/src/Editor' { interface Editor { codeBlock(): Editor, } } export default new Node() .name('codeBlock') .schema(() => ({ content: 'text*', marks: '', group: 'block', code: true, defining: true, draggable: false, parseDOM: [ { tag: 'pre', preserveWhitespace: 'full' }, ], toDOM: () => ['pre', ['code', 0]], })) .commands(({ editor, name }) => ({ [name]: next => attrs => { editor.toggleNode(name, 'paragraph', attrs) next() }, })) .keys(({ editor }) => ({ 'Shift-Ctrl-\\': () => editor.codeBlock() })) .inputRules(({ type }) => [ textblockTypeInputRule(/^```$/, type), ]) .create()