-
-
Notifications
You must be signed in to change notification settings - Fork 126
/
Copy pathindex.js
74 lines (67 loc) · 1.29 KB
/
index.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
import Vue from 'vue'
import MonacoEditor from '../src'
import './style.css'
const code = `
function foo() {
return 'foo'
}
`.trim()
const markdownCode = `
<template>
<div id="app">hello</div>
</template>
<script>
export default {
data() {
return {
foo: 'foo'
}
}
}
</script>
`
new Vue({
el: '#app',
data: {
code,
language: 'javascript',
theme: 'vs',
options: {
lineNumbers: true
}
},
methods: {
updateCode() {
this.language = 'html'
this.code = markdownCode
this.options.tabSize = 8
this.options.lineNumbers = false
this.theme = 'vs-dark'
}
},
render() {
return (
<div id="app">
<button onClick={this.updateCode}>update</button>
<MonacoEditor
class="editor"
value={this.code}
language={this.language}
theme={this.theme}
options={this.options}
onChange={newValue => (this.code = newValue)}
/>
<MonacoEditor
class="editor"
diffEditor={true}
original={`original value`}
value={this.code}
language={this.language}
theme={this.theme}
options={this.options}
onChange={newValue => (this.code = newValue)}
/>
</div>
)
}
})