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

79 lines
1.7 KiB
TypeScript
Raw Normal View History

2023-06-22 15:44:26 -04:00
/* eslint-disable node/no-extraneous-import */
import {
autocompletion,
closeBrackets,
closeBracketsKeymap,
completionKeymap,
} from '@codemirror/autocomplete';
2023-06-06 11:49:43 -04:00
import {
defaultKeymap,
history,
historyKeymap,
indentWithTab,
} from '@codemirror/commands';
2023-06-22 15:44:26 -04:00
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';
2023-06-22 15:44:26 -04:00
import {lintKeymap} from '@codemirror/lint';
import {EditorState} from '@codemirror/state';
import {
dropCursor,
highlightActiveLine,
highlightActiveLineGutter,
highlightSpecialChars,
keymap,
lineNumbers,
} from '@codemirror/view';
2023-06-22 15:44:26 -04:00
import {playgroundHighlightStyle} from './theme.js';
2023-06-02 10:53:32 -04:00
const editorSetup = (() => [
[
lineNumbers(),
highlightActiveLineGutter(),
highlightSpecialChars(),
history(),
foldGutter(),
dropCursor(),
indentOnInput(),
syntaxHighlighting(playgroundHighlightStyle),
2023-06-22 15:44:26 -04:00
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(),
])();
2023-06-02 10:53:32 -04:00
const outputSetup = (() => [
[
lineNumbers(),
highlightSpecialChars(),
foldGutter(),
syntaxHighlighting(playgroundHighlightStyle),
2023-06-22 15:44:26 -04:00
syntaxHighlighting(defaultHighlightStyle, {fallback: true}),
highlightActiveLine(),
EditorState.readOnly.of(true),
],
langCss(),
2023-06-02 10:53:32 -04:00
])();
2023-06-22 15:44:26 -04:00
export {editorSetup, outputSetup};