Files
tiptap/packages/extension-history/src/history.ts
2021-07-14 23:51:53 +02:00

61 lines
1.2 KiB
TypeScript

import { Extension } from '@tiptap/core'
import { history, undo, redo } from 'prosemirror-history'
export interface HistoryOptions {
depth: number,
newGroupDelay: number,
}
declare module '@tiptap/core' {
interface Commands<ReturnType> {
history: {
/**
* Undo recent changes
*/
undo: () => ReturnType,
/**
* Reapply reverted changes
*/
redo: () => ReturnType,
}
}
}
export const History = Extension.create<HistoryOptions>({
name: 'history',
defaultOptions: {
depth: 100,
newGroupDelay: 500,
},
addCommands() {
return {
undo: () => ({ state, dispatch }) => {
return undo(state, dispatch)
},
redo: () => ({ state, dispatch }) => {
return redo(state, dispatch)
},
}
},
addProseMirrorPlugins() {
return [
history(this.options),
]
},
addKeyboardShortcuts() {
return {
'Mod-z': () => this.editor.commands.undo(),
'Mod-y': () => this.editor.commands.redo(),
'Shift-Mod-z': () => this.editor.commands.redo(),
// Russian keyboard layouts
'Mod-я': () => this.editor.commands.undo(),
'Shift-Mod-я': () => this.editor.commands.redo(),
}
},
})