From abd6c61fcb08b179bf3c96eabc9a20bcc1a20160 Mon Sep 17 00:00:00 2001 From: tmhglnd Date: Tue, 30 Jan 2024 23:04:59 +0100 Subject: [PATCH 1/2] initial idea for toggle linenumbers and linewrap --- packages/web/src/components/editor.tsx | 28 ++++++++++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) diff --git a/packages/web/src/components/editor.tsx b/packages/web/src/components/editor.tsx index 40e5a50e..11444257 100644 --- a/packages/web/src/components/editor.tsx +++ b/packages/web/src/components/editor.tsx @@ -7,8 +7,8 @@ import { } from "@/settings.json"; import { javascript } from "@codemirror/lang-javascript"; import { python } from "@codemirror/lang-python"; -import { EditorState, Prec } from "@codemirror/state"; -import { EditorView, keymap } from "@codemirror/view"; +import { EditorState, Prec, Compartment } from "@codemirror/state"; +import { EditorView, keymap, lineNumbers } from "@codemirror/view"; import { evalKeymap, flashField, remoteEvalFlash } from "@flok-editor/cm-eval"; import { tidal } from "@flok-editor/lang-tidal"; import type { Document } from "@flok-editor/session"; @@ -124,6 +124,26 @@ export interface EditorProps extends ReactCodeMirrorProps { document?: Document; } +// Code example from: +// https://codemirror.net/examples/config/#dynamic-configuration +// Allows toggling of extensions based on string shortkey +// +const toggleWith = (key: string, extension: Extension) => { + let comp = new Compartment; + + function toggle(view: EditorView) { + let on = comp.get(view.state) == extension; + view.dispatch({ + effects: comp.reconfigure(on ? [] : extension) + }) + return true; + } + return [ + comp.of([]), + keymap.of([{key, run: toggle}]) + ] +} + export const Editor = React.forwardRef( ( { document, ...props }: EditorProps, @@ -153,6 +173,10 @@ export const Editor = React.forwardRef( flokSetup(document, { readOnly }), languageExtension(), readOnly ? EditorState.readOnly.of(true) : [], + // toggle linenumbers on/off + toggleWith('shift-ctrl-l', lineNumbers()), + // toggle linewrapping on/off + toggleWith('shift-ctrl-w', EditorView.lineWrapping) ]; // If it's read-only, put a div in front of the editor so that the user From a49dc3954b8ff0204c56548e6826338998109ed1 Mon Sep 17 00:00:00 2001 From: tmhglnd Date: Tue, 30 Jan 2024 23:13:28 +0100 Subject: [PATCH 2/2] import Extension --- packages/web/src/components/editor.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/web/src/components/editor.tsx b/packages/web/src/components/editor.tsx index 11444257..3f1d2d00 100644 --- a/packages/web/src/components/editor.tsx +++ b/packages/web/src/components/editor.tsx @@ -7,7 +7,7 @@ import { } from "@/settings.json"; import { javascript } from "@codemirror/lang-javascript"; import { python } from "@codemirror/lang-python"; -import { EditorState, Prec, Compartment } from "@codemirror/state"; +import { EditorState, Prec, Compartment, Extension } from "@codemirror/state"; import { EditorView, keymap, lineNumbers } from "@codemirror/view"; import { evalKeymap, flashField, remoteEvalFlash } from "@flok-editor/cm-eval"; import { tidal } from "@flok-editor/lang-tidal";