sass-site/source/assets/js/playground/editor-setup.ts

80 lines
1.8 KiB
TypeScript
Raw Normal View History

import {
autocompletion,
closeBrackets,
closeBracketsKeymap,
completionKeymap,
} from '@codemirror/autocomplete';
2023-06-06 11:49:43 -04:00
import {
defaultKeymap,
history,
historyKeymap,
indentWithTab,
} from '@codemirror/commands';
import { css as langCss } from '@codemirror/lang-css';
import { sass as langSass } from '@codemirror/lang-sass';
import {
bracketMatching,
defaultHighlightStyle,
foldGutter,
foldKeymap,
indentOnInput,
syntaxHighlighting,
} from '@codemirror/language';
import { lintKeymap } from '@codemirror/lint';
2023-06-02 10:53:32 -04:00
import { EditorState } from '@codemirror/state';
import {
dropCursor,
highlightActiveLine,
highlightActiveLineGutter,
highlightSpecialChars,
keymap,
lineNumbers,
} from '@codemirror/view';
import { playgroundHighlightStyle, playgroundTheme } from './theme.js';
2023-06-02 10:53:32 -04:00
const editorSetup = (() => [
[
lineNumbers(),
highlightActiveLineGutter(),
highlightSpecialChars(),
history(),
foldGutter(),
dropCursor(),
indentOnInput(),
syntaxHighlighting(playgroundHighlightStyle),
syntaxHighlighting(defaultHighlightStyle, { fallback: true }),
bracketMatching(),
closeBrackets(),
autocompletion(),
highlightActiveLine(),
keymap.of([
...closeBracketsKeymap,
...defaultKeymap,
...historyKeymap,
...foldKeymap,
...completionKeymap,
...lintKeymap,
2023-06-06 11:49:43 -04:00
indentWithTab,
]),
],
langSass(),
playgroundTheme,
])();
2023-06-02 10:53:32 -04:00
const outputSetup = (() => [
[
lineNumbers(),
highlightSpecialChars(),
foldGutter(),
syntaxHighlighting(playgroundHighlightStyle),
syntaxHighlighting(defaultHighlightStyle, { fallback: true }),
highlightActiveLine(),
EditorState.readOnly.of(true),
],
langCss(),
playgroundTheme,
2023-06-02 10:53:32 -04:00
])();
export { editorSetup, outputSetup };