-
Notifications
You must be signed in to change notification settings - Fork 132
Expand file tree
/
Copy pathmain.js
More file actions
100 lines (87 loc) · 2.29 KB
/
main.js
File metadata and controls
100 lines (87 loc) · 2.29 KB
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
// Imports
import { SuperDoc } from '@harbour-enterprises/superdoc';
import '@harbour-enterprises/superdoc/style.css';
import './style.css';
// Init
let editor = null;
//Init SuperDoc from DOCX file
function initSuperDocFromFile(file = null) {
if (editor) {
editor = null;
}
editor = new SuperDoc({
selector: '#superdoc',
toolbar: '#superdoc-toolbar',
document: file, // DOCX URL, File object, or document config
documentMode: 'editing',
mode: 'docx',
pagination: true,
rulers: true,
onReady: (event) => {
const docJSON = event.superdoc.activeEditor.getJSON();
console.log('SuperDoc ready - JSON', docJSON);
},
onEditorUpdate: (event) => {
const docJSON = event.editor.getJSON();
console.log('SuperDoc updated - JSON', docJSON);
},
});
}
//Init SuperDoc from JSON
function initSuperDocFromJSON() {
if (editor) {
editor = null;
}
//Hardcoded demo JSON
const demoJSON = {
type: 'doc',
content: [
{
type: 'paragraph',
content: [
{
type: 'text',
text: 'Hello, SuperDoc~!!',
},
],
},
],
};
editor = new SuperDoc({
selector: '#superdoc',
toolbar: '#superdoc-toolbar',
documentMode: 'editing',
/* LOADING JSON */
//https://docs.superdoc.dev/core/supereditor/configuration#param-options-content
mode: 'docx',
jsonOverride: demoJSON,
pagination: true,
rulers: true,
onReady: (event) => {
const docJSON = event.superdoc.activeEditor.getJSON();
console.log('SuperDoc ready - JSON', docJSON);
},
onEditorUpdate: (event) => {
const docJSON = event.editor.getJSON();
console.log('SuperDoc updated - JSON', docJSON);
},
});
}
// Setup file input handling
const fileInput = document.getElementById('fileInput');
const loadButton = document.getElementById('loadButton');
const loadJSON = document.getElementById('loadJSON');
loadButton.addEventListener('click', () => {
fileInput.click();
});
loadJSON.addEventListener('click', () => {
initSuperDocFromJSON();
});
fileInput.addEventListener('change', (event) => {
const file = event.target.files?.[0];
if (file) {
initSuperDocFromFile(file);
}
});
// Initialize empty editor on page load
initSuperDocFromFile(null);