forked from motla/vue-document-editor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuseDocument.ts
47 lines (40 loc) · 926 Bytes
/
useDocument.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import {ref, onBeforeUnmount} from 'vue';
import {useRefHistory} from '@vueuse/core'
export default () => {
const content = ref([]);
const {
canRedo,
canUndo,
undo,
redo,
pause: pauseStackTracking
} = useRefHistory(
content,
{
capacity: 1000,
deep: true
},
)
const redoUndoListener = (e: KeyboardEvent) => {
if (e.ctrlKey && e.key === 'z') {
e.preventDefault();
undo();
}
if (e.ctrlKey && e.key === 'y') {
e.preventDefault();
redo();
}
};
document.addEventListener('keydown', redoUndoListener)
onBeforeUnmount(() => {
document.removeEventListener("keydown", redoUndoListener);
})
return {
content,
undo,
redo,
canRedo,
canUndo,
pauseStackTracking,
}
}