Add the excellent CodeMirror editor to your React app with a hook.
📌 Supports multiple documents (e.g. for tabbed editors)
📌 Built with TypeScript
📌 Works with SSR
📌 Built-in lazy loading for CodeMirror itself
📌 Allows easy access to the underlying instance
yarn add use-codemirror
Create your own Editor component by calling useCodeMirror
, then passing the returned object's ref
to a <pre>
containing your initial value.
import { useCodeMirror } from 'use-codemirror'
export function Editor({ className, style, ...options }) {
let codeMirror = useCodeMirror(options)
return (
<StyledCodeMirrorEditor className={className} style={style}>
<pre ref={codeMirror.ref} className={codeMirror.config.theme}>
{options.value}
</pre>
</StyledCodeMirrorEditor>
)
}
Then use your Editor:
function App() {
let [code, setCode] = useState(initialCode)
return (
<CodeMirrorEditor
value={code}
onChange={setCode}
// Supports multiple documents with their own history,
// and automatic syntax highlighting via file extension.
docName="test.js"
// Pass config to CodeMirror itself
config={{
autoCloseBrackets: false,
}}
/>
);
}
See the example
directory for a working example.
You can pass in the following settings:
interface UseCodeMirrorOptions {
cursor?: CodeMirror.Position
doc?: CodeMirror.Doc
docName?: string
scroll?: SetScrollOptions
selection?: { ranges: Array<SetSelectionOptions>; focus?: boolean }
value: string
config?: CodeMirror.EditorConfiguration
onBlur?: () => void
onChange?: (
value: string,
docName: string | undefined,
changes: CodeMirror.EditorChange[],
doc: CodeMirror.Doc,
) => void
onCursor?: (data: CodeMirror.Position) => void
onFocus?: () => void
onGutterClick?: (lineNumber: number, gutter: string, event: Event) => void
onScroll?: (scrollInfo: CodeMirror.ScrollInfo) => void
onSelection?: (data: any) => void
onViewportChange?: (start: number, end: number) => void
// Only used on initial run
importCodeMirror?: () => Promise<any>
importCodeMirrorAddons?: () => Promise<any>
}
The returned codeMirror
object has the following shape:
interface ReactCodeMirror {
// Pass this to a `<pre>` to turn it into a CodeMirror
ref: CodeMirrorRefFunction
// The configuration, with any default settings
config: CodeMirror.EditorConfiguration
// The underlying CodeMirror instance
editor?: CodeMirror.Editor
focus(): void
}
This projects takes a lot of inspiration (and a bit of code) from react-codemirror2.
use-codemirror is MIT licensed.