feat: codemirror editor options are reactive
This commit is contained in:
committed by
liyasthomas
parent
33951482d5
commit
61da0733c2
@@ -26,7 +26,7 @@ import { LinterDefinition } from "./linting/linter"
|
|||||||
const DEFAULT_THEME = "juejin"
|
const DEFAULT_THEME = "juejin"
|
||||||
|
|
||||||
type CodeMirrorOptions = {
|
type CodeMirrorOptions = {
|
||||||
extendedEditorConfig: CodeMirror.EditorConfiguration
|
extendedEditorConfig: Omit<CodeMirror.EditorConfiguration, "value">
|
||||||
linter: LinterDefinition | null
|
linter: LinterDefinition | null
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -55,17 +55,34 @@ export function useCodemirror(
|
|||||||
) {
|
) {
|
||||||
const cm = ref<CodeMirror.Editor | null>(null)
|
const cm = ref<CodeMirror.Editor | null>(null)
|
||||||
|
|
||||||
|
const updateEditorConfig = () => {
|
||||||
|
Object.keys(options.extendedEditorConfig).forEach((key) => {
|
||||||
|
// Only update options which need updating
|
||||||
|
if (
|
||||||
|
cm.value &&
|
||||||
|
cm.value?.getOption(key as any) !==
|
||||||
|
(options.extendedEditorConfig as any)[key]
|
||||||
|
) {
|
||||||
|
cm.value?.setOption(
|
||||||
|
key as any,
|
||||||
|
(options.extendedEditorConfig as any)[key]
|
||||||
|
)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
const updateLinterConfig = () => {
|
||||||
|
if (options.linter) {
|
||||||
|
cm.value?.setOption("lint", options.linter)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Boot-up CodeMirror, set the value and listeners
|
// Boot-up CodeMirror, set the value and listeners
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
cm.value = CodeMirror(el.value!, {
|
cm.value = CodeMirror(el.value!, DEFAULT_EDITOR_CONFIG)
|
||||||
...DEFAULT_EDITOR_CONFIG,
|
|
||||||
...options.extendedEditorConfig,
|
|
||||||
})
|
|
||||||
cm.value.setValue(value.value)
|
|
||||||
|
|
||||||
if (options.linter) {
|
updateEditorConfig()
|
||||||
cm.value.setOption("lint", options.linter)
|
updateLinterConfig()
|
||||||
}
|
|
||||||
|
|
||||||
cm.value.on("change", (instance) => {
|
cm.value.on("change", (instance) => {
|
||||||
// External update propagation (via watchers) should be ignored
|
// External update propagation (via watchers) should be ignored
|
||||||
@@ -75,6 +92,13 @@ export function useCodemirror(
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// If the editor properties are reactive, watch for updates
|
||||||
|
watch(() => options.extendedEditorConfig, updateEditorConfig, {
|
||||||
|
immediate: true,
|
||||||
|
deep: true,
|
||||||
|
})
|
||||||
|
watch(() => options.linter, updateLinterConfig, { immediate: true })
|
||||||
|
|
||||||
// Watch value updates
|
// Watch value updates
|
||||||
watch(value, (newVal) => {
|
watch(value, (newVal) => {
|
||||||
// Check if we are mounted
|
// Check if we are mounted
|
||||||
|
|||||||
Reference in New Issue
Block a user