2023-06-22 15:44:26 -04:00
|
|
|
/* eslint-disable node/no-extraneous-import */
|
2023-06-02 09:24:32 -04:00
|
|
|
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';
|
2023-06-02 09:24:32 -04:00
|
|
|
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';
|
2023-06-02 09:24:32 -04:00
|
|
|
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-05 16:02:44 +00:00
|
|
|
|
2023-06-02 10:53:32 -04:00
|
|
|
const editorSetup = (() => [
|
2023-06-05 16:02:44 +00:00
|
|
|
[
|
|
|
|
lineNumbers(),
|
|
|
|
highlightActiveLineGutter(),
|
|
|
|
highlightSpecialChars(),
|
|
|
|
history(),
|
2023-06-07 09:55:41 -04:00
|
|
|
foldGutter(),
|
2023-06-05 16:02:44 +00:00
|
|
|
dropCursor(),
|
|
|
|
indentOnInput(),
|
|
|
|
syntaxHighlighting(playgroundHighlightStyle),
|
2023-06-22 15:44:26 -04:00
|
|
|
syntaxHighlighting(defaultHighlightStyle, {fallback: true}),
|
2023-06-05 16:02:44 +00:00
|
|
|
bracketMatching(),
|
|
|
|
closeBrackets(),
|
|
|
|
autocompletion(),
|
|
|
|
highlightActiveLine(),
|
|
|
|
keymap.of([
|
|
|
|
...closeBracketsKeymap,
|
|
|
|
...defaultKeymap,
|
|
|
|
...historyKeymap,
|
|
|
|
...foldKeymap,
|
|
|
|
...completionKeymap,
|
|
|
|
...lintKeymap,
|
2023-06-06 11:49:43 -04:00
|
|
|
indentWithTab,
|
2023-06-05 16:02:44 +00:00
|
|
|
]),
|
|
|
|
],
|
|
|
|
langSass(),
|
2023-06-02 09:24:32 -04:00
|
|
|
])();
|
2023-06-02 10:53:32 -04:00
|
|
|
|
|
|
|
const outputSetup = (() => [
|
2023-06-05 16:02:44 +00:00
|
|
|
[
|
|
|
|
lineNumbers(),
|
|
|
|
highlightSpecialChars(),
|
2023-06-07 09:55:41 -04:00
|
|
|
foldGutter(),
|
2023-06-05 16:02:44 +00:00
|
|
|
syntaxHighlighting(playgroundHighlightStyle),
|
2023-06-22 15:44:26 -04:00
|
|
|
syntaxHighlighting(defaultHighlightStyle, {fallback: true}),
|
2023-06-05 16:02:44 +00:00
|
|
|
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};
|