remirror/remirror

View on GitHub
docs/extensions/codemirror-extension.mdx

Summary

Maintainability
Test Coverage
---
hide_title: true
title: 'CodeMirrorExtension'
---

import Basic from '../../website/extension-examples/extension-codemirror6/basic';
import WithCustomExtension from '../../website/extension-examples/extension-codemirror6/with-custom-extension';

# `CodeMirrorExtension`

## Summary

The CodeMirror extension adds fenced code blocks to your editor powered by [CodeMirror 6](https://codemirror.net/6/). A code block contains a formatted snippets of source code.

:::info

This extension differs from the `CodeExtension`, which provides code marks on inline text.

:::

:::info

Also check a simpler code block implementation at [`CodeBlockExtension`](code-block-extension).

:::

## Features

### Keyboard support

Users can create a new code block by typing <code>&grave;&grave;&grave;&nbsp;</code> (3 ticks and a space). Users can define the language of the code block by typing <code>&grave;&grave;&grave;html&nbsp;</code>.

## Usage

### Installation

This extension is NOT installed for you when you install the main `remirror` package but need to be installed separately:

```bash
npm install @remirror/extension-codemirror6
```

You will probably also want to install some basic CodeMirror packages:

```bash
npm install @codemirror/basic-setup @codemirror/language-data @codemirror/theme-one-dark
```

You can use the imports in the following way:

```ts
import { basicSetup } from '@codemirror/basic-setup';
import { languages } from '@codemirror/language-data';
import { oneDark } from '@codemirror/theme-one-dark';
import { CodeMirrorExtension } from '@remirror/extension-codemirror6';

const codeMirrorExtension = new CodeMirrorExtension({
  languages: languages,
  extensions: [basicSetup, oneDark],
});
```

### Examples

<Basic />

You can customize your CodeMirror editor by passing your custom extensions.

<WithCustomExtension />

## API

- [CodeMirrorExtension](../api/extension-codemirror6)