overleaf/services/web/frontend/js/features/source-editor/extensions/symbol-palette.ts
Alf Eaton e025088065 Merge pull request #13241 from overleaf/ae-extensions-documentation
Add documentation for CodeMirror extensions

GitOrigin-RevId: e5f07084173f201919272f9d46dcdaef4b817874
2023-07-17 10:28:53 +00:00

42 lines
1 KiB
TypeScript

import { ViewPlugin } from '@codemirror/view'
import { EditorSelection } from '@codemirror/state'
/**
* A custom extension that listens for an `editor:insert-symbol` event and inserts the given content into the document.
*/
export const symbolPalette = () => {
return ViewPlugin.define(view => {
const listener = (event: Event) => {
const symbol = (event as CustomEvent<{ command: string }>).detail
view.focus()
const spec = view.state.changeByRange(range => {
const changeSet = view.state.changes([
{
from: range.from,
to: range.to,
insert: symbol.command,
},
])
return {
range: EditorSelection.cursor(changeSet.mapPos(range.to, 1)),
changes: changeSet,
}
})
view.dispatch(spec, {
scrollIntoView: true,
})
}
window.addEventListener('editor:insert-symbol', listener)
return {
destroy() {
window.removeEventListener('editor:insert-symbol', listener)
},
}
})
}