forked from we-miks/collaborative-editor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
editor.js
106 lines (79 loc) · 3.05 KB
/
editor.js
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
import Quill from "quill";
import 'quill/dist/quill.bubble.css';
import 'quill/dist/quill.core.css';
import Authorship from "./authorship";
import ImageHandlers from "./image-handlers";
import Composition from "./composition";
import shareDB from "sharedb/lib/client";
import richText from "rich-text";
import lodashObject from "lodash/fp/object";
import QuillImageDropAndPaste from "quill-image-drop-and-paste";
import ImagePlaceholder from "./blot/image-placeholder";
import Synchronizer from "./synchronizer";
import History from "./modules/history";
import MiksClipboard from "./modules/miks-clipboard";
shareDB.types.register(richText.type);
Quill.register('modules/imageDropAndPaste', QuillImageDropAndPaste);
Quill.register(ImagePlaceholder);
Quill.register("modules/history", History);
Quill.register("modules/clipboard", MiksClipboard);
class Editor {
constructor(container, editorOptions, quillOptions) {
this.options = editorOptions;
this.eventHandlers = {};
this.imageHandlers = new ImageHandlers(this);
let options = this.mergeQuillOptions(quillOptions);
this.quill = new Quill(container, options);
this.composition = new Composition(this);
this.synchronizer = new Synchronizer(this, this.composition);
this.composition.setSynchronizer(this.synchronizer);
this.authorship = new Authorship(this, this.composition, editorOptions.authorship || {});
// Add image upload toolbar button handler
this.quill.getModule("toolbar").addHandler('image', this.imageHandlers.imageUploadButtonHandler);
// Initialize clipboard module
this.quill.getModule("clipboard").setEditor(this);
}
mergeQuillOptions(options) {
let self = this;
return lodashObject.merge(options, {
modules: {
imageDropAndPaste: {
handler: self.imageHandlers.imageDropAndPasteHandler
}
}
});
}
syncThroughWebsocket(endpoint, collection, docId) {
this.composition.clear();
return this.synchronizer.syncThroughWebsocket(endpoint, collection, docId);
}
getEditorContents() {
return this.composition.getEditorContents();
}
on(event, handler) {
let handlerId = Math.ceil(Math.random() * 10000);
if(!this.eventHandlers[event]) {
this.eventHandlers[event] = {};
}
this.eventHandlers[event][handlerId] = handler;
return handlerId;
}
off(event, handlerId) {
if(this.eventHandlers[event] && this.eventHandlers[event][handlerId]) {
delete this.eventHandlers[event][handlerId];
}
}
dispatchEvent(event, payload) {
if(this.eventHandlers[event]) {
Object.keys(this.eventHandlers[event]).forEach((handlerId) => {
let handler = this.eventHandlers[event][handlerId];
handler(payload);
});
}
}
close() {
this.eventHandlers = {};
this.synchronizer.close();
}
}
export default Editor;