mirror of
https://github.com/eliasstepanik/strudel.git
synced 2026-01-11 13:48:40 +00:00
fix: redundant style injections for multiple repls
This commit is contained in:
parent
20e8a30583
commit
48e06bd213
14
packages/codemirror/themes.mjs
vendored
14
packages/codemirror/themes.mjs
vendored
@ -484,11 +484,16 @@ export function injectStyle(rule) {
|
||||
return () => styleSheet.deleteRule(ruleIndex);
|
||||
}
|
||||
|
||||
let currentTheme, resetThemeStyle, themeStyle;
|
||||
let currentTheme,
|
||||
resetThemeStyle,
|
||||
themeStyle,
|
||||
styleID = 'strudel-theme-vars';
|
||||
export function initTheme(theme) {
|
||||
themeStyle = document.createElement('style');
|
||||
themeStyle.id = 'strudel-theme';
|
||||
document.head.append(themeStyle);
|
||||
if (!document.getElementById(styleID)) {
|
||||
themeStyle = document.createElement('style');
|
||||
themeStyle.id = styleID;
|
||||
document.head.append(themeStyle);
|
||||
}
|
||||
activateTheme(theme);
|
||||
}
|
||||
|
||||
@ -496,6 +501,7 @@ export function activateTheme(name) {
|
||||
if (currentTheme === name) {
|
||||
return;
|
||||
}
|
||||
currentTheme = name;
|
||||
if (!settings[name]) {
|
||||
console.warn('theme', name, 'has no settings.. defaulting to strudelTheme settings');
|
||||
}
|
||||
|
||||
@ -54,6 +54,7 @@ export function MicroRepl({ code, hideHeader = false }) {
|
||||
<div className="overflow-auto relative">
|
||||
<strudel-editor
|
||||
is-line-numbers-displayed="0"
|
||||
is-active-line-highlighted="0"
|
||||
code={code}
|
||||
ref={(el) => {
|
||||
if (wc.current) {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user