mirror of
https://github.com/danog/sass-site.git
synced 2024-12-11 17:09:52 +01:00
83 lines
1.9 KiB
TypeScript
83 lines
1.9 KiB
TypeScript
import {
|
|
autocompletion,
|
|
closeBrackets,
|
|
closeBracketsKeymap,
|
|
completionKeymap,
|
|
} from '@codemirror/autocomplete';
|
|
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';
|
|
import { highlightSelectionMatches, searchKeymap } from '@codemirror/search';
|
|
import { EditorState } from '@codemirror/state';
|
|
import {
|
|
dropCursor,
|
|
highlightActiveLine,
|
|
highlightActiveLineGutter,
|
|
highlightSpecialChars,
|
|
keymap,
|
|
lineNumbers,
|
|
} from '@codemirror/view';
|
|
|
|
import { playgroundHighlightStyle, playgroundTheme } from './theme.js';
|
|
|
|
const editorSetup = (() => [
|
|
[
|
|
lineNumbers(),
|
|
highlightActiveLineGutter(),
|
|
highlightSpecialChars(),
|
|
history(),
|
|
foldGutter(),
|
|
dropCursor(),
|
|
indentOnInput(),
|
|
syntaxHighlighting(playgroundHighlightStyle),
|
|
syntaxHighlighting(defaultHighlightStyle, { fallback: true }),
|
|
bracketMatching(),
|
|
closeBrackets(),
|
|
autocompletion(),
|
|
highlightActiveLine(),
|
|
highlightSelectionMatches(),
|
|
keymap.of([
|
|
...closeBracketsKeymap,
|
|
...defaultKeymap,
|
|
...searchKeymap,
|
|
...historyKeymap,
|
|
...foldKeymap,
|
|
...completionKeymap,
|
|
...lintKeymap,
|
|
indentWithTab,
|
|
]),
|
|
],
|
|
langSass(),
|
|
playgroundTheme,
|
|
])();
|
|
|
|
const outputSetup = (() => [
|
|
[
|
|
lineNumbers(),
|
|
highlightSpecialChars(),
|
|
foldGutter(),
|
|
syntaxHighlighting(playgroundHighlightStyle),
|
|
syntaxHighlighting(defaultHighlightStyle, { fallback: true }),
|
|
highlightActiveLine(),
|
|
EditorState.readOnly.of(true),
|
|
],
|
|
langCss(),
|
|
playgroundTheme,
|
|
])();
|
|
|
|
export { editorSetup, outputSetup };
|