https://github.com/replit/codemirror-vscode-keymap
VSCode keyboard shortcuts for CodeMirror 6
https://github.com/replit/codemirror-vscode-keymap
codemirror editor vscode
Last synced: 9 months ago
JSON representation
VSCode keyboard shortcuts for CodeMirror 6
- Host: GitHub
- URL: https://github.com/replit/codemirror-vscode-keymap
- Owner: replit
- Created: 2022-01-05T17:50:57.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2023-10-07T11:34:07.000Z (about 2 years ago)
- Last Synced: 2025-03-20T13:17:58.333Z (9 months ago)
- Topics: codemirror, editor, vscode
- Language: TypeScript
- Homepage: https://replit.com/@util/CodeMirror-VSCode-Keymap
- Size: 195 KB
- Stars: 39
- Watchers: 39
- Forks: 7
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# CodeMirror VSCode Keymap
Ports VSCode's keyboard shortcuts to CodeMirror 6.
This keymap includes shortcuts for all the official extension and replaces codemirror default keymaps:
- autocomplete (make sure to set `defaultKeymap: false` when enabling this plugin)
- closebrackets
- commands
- comment
- fold
- history
- lint
- search
The keymap is based on the following:
- [Windows](https://code.visualstudio.com/shortcuts/keyboard-shortcuts-windows.pdf)
- [Mac](https://code.visualstudio.com/shortcuts/keyboard-shortcuts-macos.pdf)
- [Linux](https://code.visualstudio.com/shortcuts/keyboard-shortcuts-linux.pdf)
### Usage
```ts
import { EditorView, keymap } from '@codemirror/view';
import { EditorState } from '@codemirror/state';
import { javascript } from '@codemirror/lang-javascript';
import { vscodeKeymap } from "@replit/codemirror-vscode-keymap";
const doc = `
function wow() {
function hello() {
console.log({
lol: 1
})
}
}
`
new EditorView({
state: EditorState.create({
doc,
extensions: [keymap.of(vscodeKeymap), javascript()],
}),
parent: document.querySelector('#editor'),
});
```
### Missing features
- Scroll Line Down Ctrl+Down
- Scroll Line Up Ctrl+Up
- Scroll Page Down Alt+PageDown
- Scroll Page Up Alt+PageUp