mirror of
https://github.com/eliasstepanik/strudel-docker.git
synced 2026-01-24 20:18:34 +00:00
vanilla-repl-cm6: add keybindings
This commit is contained in:
parent
1494cc38fc
commit
f069f53fae
@ -7,7 +7,7 @@ import { StateField, StateEffect } from '@codemirror/state';
|
|||||||
import './style.css';
|
import './style.css';
|
||||||
|
|
||||||
// https://codemirror.net/docs/guide/
|
// https://codemirror.net/docs/guide/
|
||||||
export function initEditor(initialCode, onUpdate) {
|
export function initEditor({ initialCode, onChange, onEvaluate, onStop }) {
|
||||||
let state = EditorState.create({
|
let state = EditorState.create({
|
||||||
doc: initialCode,
|
doc: initialCode,
|
||||||
extensions: [
|
extensions: [
|
||||||
@ -22,9 +22,17 @@ export function initEditor(initialCode, onUpdate) {
|
|||||||
syntaxHighlighting(defaultHighlightStyle),
|
syntaxHighlighting(defaultHighlightStyle),
|
||||||
keymap.of(defaultKeymap),
|
keymap.of(defaultKeymap),
|
||||||
//flashField,
|
//flashField,
|
||||||
EditorView.updateListener.of((v) => {
|
EditorView.updateListener.of((v) => onChange(v)),
|
||||||
onUpdate(v);
|
keymap.of([
|
||||||
}),
|
{
|
||||||
|
key: 'Ctrl-Enter',
|
||||||
|
run: () => onEvaluate(),
|
||||||
|
},
|
||||||
|
{
|
||||||
|
key: 'Ctrl-.',
|
||||||
|
run: () => onStop(),
|
||||||
|
},
|
||||||
|
]),
|
||||||
],
|
],
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@ -5,28 +5,36 @@ import { initStrudel } from './strudel';
|
|||||||
import { Highlighter } from './highlighter';
|
import { Highlighter } from './highlighter';
|
||||||
import { bumpStreet } from './tunes';
|
import { bumpStreet } from './tunes';
|
||||||
let code = bumpStreet;
|
let code = bumpStreet;
|
||||||
|
|
||||||
const view = initEditor(code, (v) => {
|
|
||||||
code = v.state.doc.toString();
|
|
||||||
});
|
|
||||||
const repl = initStrudel();
|
const repl = initStrudel();
|
||||||
|
|
||||||
let highlighter = new Highlighter((haps) => highlightHaps(view, haps));
|
async function onEvaluate() {
|
||||||
|
|
||||||
document.getElementById('play').addEventListener('click', async () => {
|
|
||||||
const { evaluate, scheduler } = await repl;
|
const { evaluate, scheduler } = await repl;
|
||||||
if (!scheduler.started) {
|
if (!scheduler.started) {
|
||||||
scheduler.stop();
|
scheduler.stop();
|
||||||
scheduler.lastEnd = 0;
|
|
||||||
await evaluate(code);
|
await evaluate(code);
|
||||||
highlighter.start(scheduler);
|
highlighter.start(scheduler);
|
||||||
} else {
|
} else {
|
||||||
await evaluate(code);
|
await evaluate(code);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function onStop() {
|
||||||
|
const { scheduler } = await repl;
|
||||||
|
scheduler.stop();
|
||||||
|
highlighter.stop();
|
||||||
|
}
|
||||||
|
|
||||||
|
const view = initEditor({
|
||||||
|
initialCode: code,
|
||||||
|
onChange: (v) => {
|
||||||
|
code = v.state.doc.toString();
|
||||||
|
},
|
||||||
|
onEvaluate,
|
||||||
|
onStop,
|
||||||
});
|
});
|
||||||
|
|
||||||
document.getElementById('stop').addEventListener('click', async () => {
|
let highlighter = new Highlighter((haps) => highlightHaps(view, haps));
|
||||||
const { stop } = await repl;
|
|
||||||
stop();
|
document.getElementById('play').addEventListener('click', () => onEvaluate());
|
||||||
highlighter.stop();
|
|
||||||
});
|
document.getElementById('stop').addEventListener('click', async () => onStop());
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user