Updated cm6 theme handling to allow extension via API

Uses our custom event system, uses methods that take callables so that
internal dependancies can be passed.
This commit is contained in:
Dan Brown 2023-04-15 15:35:41 +01:00
parent 9874a53206
commit 74b76ecdb9
No known key found for this signature in database
GPG key ID: 46D9F943C24A2EF9
4 changed files with 25 additions and 15 deletions

View file

@ -49,6 +49,7 @@ function highlightElem(elem) {
extensions: viewer(), extensions: viewer(),
}); });
setMode(ev, langName, content); setMode(ev, langName, content);
window.cm = ev;
elem.remove(); elem.remove();
@ -81,6 +82,7 @@ function addCopyIcon(editorView) {
* @returns {*|string} * @returns {*|string}
*/ */
function getTheme() { function getTheme() {
// TODO - Remove
const darkMode = document.documentElement.classList.contains('dark-mode'); const darkMode = document.documentElement.classList.contains('dark-mode');
return window.codeTheme || (darkMode ? 'darcula' : 'default'); return window.codeTheme || (darkMode ? 'darcula' : 'default');
} }

View file

@ -1,5 +1,5 @@
import {EditorView, keymap, highlightSpecialChars, drawSelection, highlightActiveLine, dropCursor, import {EditorView, keymap, drawSelection, highlightActiveLine, dropCursor,
rectangularSelection, lineNumbers, highlightActiveLineGutter} from "@codemirror/view" rectangularSelection, lineNumbers, highlightActiveLineGutter} from "@codemirror/view"
import {syntaxHighlighting, bracketMatching} from "@codemirror/language" import {syntaxHighlighting, bracketMatching} from "@codemirror/language"
import {defaultKeymap, history, historyKeymap} from "@codemirror/commands" import {defaultKeymap, history, historyKeymap} from "@codemirror/commands"
@ -11,17 +11,14 @@ export function viewer() {
return [ return [
lineNumbers(), lineNumbers(),
highlightActiveLineGutter(), highlightActiveLineGutter(),
highlightSpecialChars(),
history(),
drawSelection(), drawSelection(),
dropCursor(), dropCursor(),
syntaxHighlighting(defaultLight, {fallback: true}), // syntaxHighlighting(defaultLight, {fallback: false}),
bracketMatching(), bracketMatching(),
rectangularSelection(), rectangularSelection(),
highlightActiveLine(), highlightActiveLine(),
keymap.of([ keymap.of([
...defaultKeymap, ...defaultKeymap,
...historyKeymap,
]), ]),
EditorState.readOnly.of(true), EditorState.readOnly.of(true),
]; ];
@ -31,7 +28,6 @@ export function editor(language) {
return [ return [
lineNumbers(), lineNumbers(),
highlightActiveLineGutter(), highlightActiveLineGutter(),
highlightSpecialChars(),
history(), history(),
drawSelection(), drawSelection(),
dropCursor(), dropCursor(),

View file

@ -1,7 +1,9 @@
import {getLanguageExtension} from "./languages" import {getLanguageExtension} from "./languages"
import {HighlightStyle, syntaxHighlighting} from "@codemirror/language";
import {Compartment} from "@codemirror/state" import {Compartment} from "@codemirror/state"
import {EditorView} from "@codemirror/view" import {EditorView} from "@codemirror/view"
import {oneDark} from "@codemirror/theme-one-dark" import {oneDarkTheme, oneDarkHighlightStyle} from "@codemirror/theme-one-dark"
import {tags} from "@lezer/highlight"
const viewLangCompartments = new WeakMap(); const viewLangCompartments = new WeakMap();
@ -25,19 +27,33 @@ export function createView(config) {
/** /**
* Get the theme extension to use for editor view instance. * Get the theme extension to use for editor view instance.
* @returns {Extension} * @returns {Extension[]}
*/ */
function getTheme(viewParentEl) { function getTheme(viewParentEl) {
const darkMode = document.documentElement.classList.contains('dark-mode'); const darkMode = document.documentElement.classList.contains('dark-mode');
let viewTheme = darkMode ? oneDarkTheme : [];
let highlightStyle = darkMode ? oneDarkHighlightStyle : null;
const eventData = { const eventData = {
darkMode: darkMode, darkModeActive: darkMode,
theme: null, registerViewTheme(builder) {
const spec = builder();
if (spec) {
viewTheme = EditorView.theme(spec);
}
},
registerHighlightStyle(builder) {
const tagStyles = builder(tags) || [];
console.log('called', tagStyles);
if (tagStyles.length) {
highlightStyle = HighlightStyle.define(tagStyles);
}
}
}; };
window.$events.emitPublic(viewParentEl, 'library-cm6::configure-theme', eventData); window.$events.emitPublic(viewParentEl, 'library-cm6::configure-theme', eventData);
return eventData.theme || (darkMode ? oneDark : []); return [viewTheme, highlightStyle ? syntaxHighlighting(highlightStyle) : []];
} }
/** /**

View file

@ -412,10 +412,6 @@ span.CodeMirror-selectedtext { background: none; }
/** /**
* Custom BookStack overrides * Custom BookStack overrides
*/ */
.cm-editor {
@include lightDark(background-color, #FFF, #000);
}
// TODO - All below are old // TODO - All below are old
.CodeMirror, .CodeMirror pre { .CodeMirror, .CodeMirror pre {
font-size: 12px; font-size: 12px;