slate-edit-code
Version:
A Slate plugin to handle code blocks editing.
141 lines (92 loc) • 4.32 kB
Markdown
[](http://badge.fury.io/js/slate-edit-code)
[](https://travis-ci.org/GitbookIO/slate-edit-code)
A Slate plugin to handle code block editing.
```js
npm install slate-edit-code
```
- Pressing <kbd>Enter</kbd> insert a new line starting with the right indentation
- Pressing <kbd>Tab</kbd> insert the right indentation if selection is collapsed or indent all lines in selection
- Pressing <kbd>Delete</kbd> remove the indentation before cursor if possible
- Pressing <kbd>Mod+Enter</kbd> exits the code block
- Pressing <kbd>Mod+A</kbd> selects all the text in the block
> <kbd>Mod</kbd> means <kbd>Ctrl</kbd> on Windows/Linux and <kbd>Command</kbd> on Mac.
This plugin uses the following structure for code blocks:
``` yaml
nodes:
- object: block
type: code_block
nodes:
- object: block
type: code_line
nodes:
- text: "A code block is made of..."
- object: block
type: code_line
nodes:
- text: "...several code lines"
```
The plugin automatically converts multiline texts in `code_blocks` into the appropriate number of `code_lines`.
```js
import EditCode from 'slate-edit-code'
const plugins = [
EditCode()
]
```
- `containerType = 'code_block' : string` — The type of the code containers
- `lineType = 'code_line' : string` — The type of the code lines
- `exitBlockType = 'paragraph' : null | string` — <kbd>Mod+Enter</kbd> will exit the code container, into the given block type. Backspace at start of an empty code container will convert it to the given block type. Pass `null` to disable this behavior.
- `onExit: (Change) => void | Change` — Change to do when the user hits <kbd>Mod+Enter</kbd>. Defaults to exiting the code block, into a new `exitBlockType` block.
- `selectAll = true : boolean` — True to select all code inside a code container on <kbd>Mod+A</kbd>
- `allowMarks = false : boolean` — False disallow marks in code blocks by normalizing them away.
- `getIndent: (Value) => string` — Returns the indent unit as a string. The current value is passed as context.
Some behavior implemented by this plugins have no corresponding option. While there is an option `selectAll` to disable the behavior on `Mod+A`, If you would like to fine tune these behavior, you can always redefine the exported `onKeyDown` function.
The following example disable all indent behavior
```js
import EditCode from 'slate-edit-code'
const options = { ... };
const basePlugin = EditCode(options);
const customPlugin = {
...basePlugin,
onKeyDown(event, change, editor) {
if (event.key === 'Tab') {
// Bypass the original plugin behavior on `Tab`
return;
} else {
return basePlugin.onKeyDown(event, change, editor);
}
}
}
// Use customPlugin later on
```
`slate-edit-code` exports utilities, accessible like so:
``` js
const plugin = EditCode()
// Access exported utilities there
plugin.utils
```
`plugin.utils.deserializeCode(text: String) => Block`
Split a text string into lines, and deserialize them to a `code_container` `Block`, with one children `code_line` `Block` per line.
`plugin.changes.toggleCodeBlock(change: Change, type: String) => Change`
Toggle a block into a code block or a normal block (defined by `type`).
#### `changes.wrapCodeBlockByKey`
`plugin.changes.wrapCodeBlockByKey(change: Change, key: String) => Change`
Convert a block (paragraph, etc) into a code block.
#### `changes.wrapCodeBlock`
`plugin.changes.wrapCodeBlock(change: Change) => Change`
Convert current block (paragraph, etc) into a code block.
#### `changes.unwrapCodeBlockByKey`
`plugin.changes.unwrapCodeBlockByKey(change: Change, key: String, type: String) => Change`
Convert a code block into a normal block (paragraph, etc).
#### `changes.unwrapCodeBlock`
`plugin.changes.unwrapCodeBlock(change: Change, type: String) => Change`
Convert current code block into a normal block (paragraph, etc).