mirror of
				https://github.com/livebook-dev/livebook.git
				synced 2025-10-25 21:06:08 +08:00 
			
		
		
		
	Define light editor theme (#1755)
This commit is contained in:
		
							parent
							
								
									5fd17ca958
								
							
						
					
					
						commit
						d4a805f806
					
				
					 6 changed files with 96 additions and 64 deletions
				
			
		|  | @ -5,8 +5,8 @@ | ||||||
|     background-color: #282c34; |     background-color: #282c34; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   body[data-editor-theme="highContrast"] .bg-editor { |   body[data-editor-theme="light"] .bg-editor { | ||||||
|     background-color: #060708; |     background-color: #fafafa; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   .text-editor { |   .text-editor { | ||||||
|  |  | ||||||
|  | @ -1,7 +1,7 @@ | ||||||
| import * as monaco from "monaco-editor/esm/vs/editor/editor.api"; | import * as monaco from "monaco-editor/esm/vs/editor/editor.api"; | ||||||
| import { CommandsRegistry } from "monaco-editor/esm/vs/platform/commands/common/commands"; | import { CommandsRegistry } from "monaco-editor/esm/vs/platform/commands/common/commands"; | ||||||
| import ElixirOnTypeFormattingEditProvider from "./elixir/on_type_formatting_edit_provider"; | import ElixirOnTypeFormattingEditProvider from "./elixir/on_type_formatting_edit_provider"; | ||||||
| import { theme, highContrast } from "./theme"; | import { theme, lightTheme } from "./theme"; | ||||||
| 
 | 
 | ||||||
| import { PieceTreeTextBufferBuilder } from "monaco-editor/esm/vs/editor/common/model/pieceTreeTextBuffer/pieceTreeTextBufferBuilder"; | import { PieceTreeTextBufferBuilder } from "monaco-editor/esm/vs/editor/common/model/pieceTreeTextBuffer/pieceTreeTextBufferBuilder"; | ||||||
| 
 | 
 | ||||||
|  | @ -56,7 +56,7 @@ monaco.languages.registerOnTypeFormattingEditProvider( | ||||||
| 
 | 
 | ||||||
| // Define custom theme
 | // Define custom theme
 | ||||||
| monaco.editor.defineTheme("default", theme); | monaco.editor.defineTheme("default", theme); | ||||||
| monaco.editor.defineTheme("highContrast", highContrast); | monaco.editor.defineTheme("light", lightTheme); | ||||||
| 
 | 
 | ||||||
| // See https://github.com/microsoft/monaco-editor/issues/648#issuecomment-564978560
 | // See https://github.com/microsoft/monaco-editor/issues/648#issuecomment-564978560
 | ||||||
| // Without this selecting text with whitespace shrinks the whitespace.
 | // Without this selecting text with whitespace shrinks the whitespace.
 | ||||||
|  |  | ||||||
|  | @ -2,6 +2,7 @@ | ||||||
| // We color graded the comment so it has AA accessibility and
 | // We color graded the comment so it has AA accessibility and
 | ||||||
| // then similarly scaled the default font.
 | // then similarly scaled the default font.
 | ||||||
| const colors = { | const colors = { | ||||||
|  |   background: "#282c34", | ||||||
|   default: "#c4cad6", |   default: "#c4cad6", | ||||||
|   lightRed: "#e06c75", |   lightRed: "#e06c75", | ||||||
|   blue: "#61afef", |   blue: "#61afef", | ||||||
|  | @ -13,59 +14,72 @@ const colors = { | ||||||
|   peach: "#d19a66", |   peach: "#d19a66", | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const background = { default: "#282c34", highContrast: "#060708" }; | const lightColors = { | ||||||
|  |   background: "#fafafa", | ||||||
|  |   default: "#304254", | ||||||
|  |   lightRed: "#e45649", | ||||||
|  |   blue: "#4078F2", | ||||||
|  |   gray: "#707177", | ||||||
|  |   green: "#50a14f", | ||||||
|  |   purple: "#a726a4", | ||||||
|  |   red: "#ca1243", | ||||||
|  |   teal: "#56b6c2", | ||||||
|  |   peach: "#986801", | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | const rules = (colors) => [ | ||||||
|  |   { token: "", foreground: colors.default }, | ||||||
|  |   { token: "variable", foreground: colors.lightRed }, | ||||||
|  |   { token: "constant", foreground: colors.blue }, | ||||||
|  |   { token: "constant.character.escape", foreground: colors.blue }, | ||||||
|  |   { token: "comment", foreground: colors.gray }, | ||||||
|  |   { token: "number", foreground: colors.blue }, | ||||||
|  |   { token: "regexp", foreground: colors.lightRed }, | ||||||
|  |   { token: "type", foreground: colors.lightRed }, | ||||||
|  |   { token: "string", foreground: colors.green }, | ||||||
|  |   { token: "keyword", foreground: colors.purple }, | ||||||
|  |   { token: "operator", foreground: colors.peach }, | ||||||
|  |   { token: "delimiter.bracket.embed", foreground: colors.red }, | ||||||
|  |   { token: "sigil", foreground: colors.teal }, | ||||||
|  |   { token: "function", foreground: colors.blue }, | ||||||
|  |   { token: "function.call", foreground: colors.default }, | ||||||
|  | 
 | ||||||
|  |   // Markdown specific
 | ||||||
|  |   { token: "emphasis", fontStyle: "italic" }, | ||||||
|  |   { token: "strong", fontStyle: "bold" }, | ||||||
|  |   { token: "keyword.md", foreground: colors.lightRed }, | ||||||
|  |   { token: "keyword.table", foreground: colors.lightRed }, | ||||||
|  |   { token: "string.link.md", foreground: colors.blue }, | ||||||
|  |   { token: "variable.md", foreground: colors.teal }, | ||||||
|  |   { token: "string.md", foreground: colors.default }, | ||||||
|  |   { token: "variable.source.md", foreground: colors.default }, | ||||||
|  | 
 | ||||||
|  |   // XML specific
 | ||||||
|  |   { token: "tag", foreground: colors.lightRed }, | ||||||
|  |   { token: "metatag", foreground: colors.lightRed }, | ||||||
|  |   { token: "attribute.name", foreground: colors.peach }, | ||||||
|  |   { token: "attribute.value", foreground: colors.green }, | ||||||
|  | 
 | ||||||
|  |   // JSON specific
 | ||||||
|  |   { token: "string.key", foreground: colors.lightRed }, | ||||||
|  |   { token: "keyword.json", foreground: colors.blue }, | ||||||
|  | 
 | ||||||
|  |   // SQL specific
 | ||||||
|  |   { token: "operator.sql", foreground: colors.purple }, | ||||||
|  | ]; | ||||||
| 
 | 
 | ||||||
| const theme = { | const theme = { | ||||||
|   base: "vs-dark", |   base: "vs-dark", | ||||||
|   inherit: false, |   inherit: false, | ||||||
|   rules: [ |   rules: rules(colors), | ||||||
|     { token: "", foreground: colors.default }, |  | ||||||
|     { token: "variable", foreground: colors.lightRed }, |  | ||||||
|     { token: "constant", foreground: colors.blue }, |  | ||||||
|     { token: "constant.character.escape", foreground: colors.blue }, |  | ||||||
|     { token: "comment", foreground: colors.gray }, |  | ||||||
|     { token: "number", foreground: colors.blue }, |  | ||||||
|     { token: "regexp", foreground: colors.lightRed }, |  | ||||||
|     { token: "type", foreground: colors.lightRed }, |  | ||||||
|     { token: "string", foreground: colors.green }, |  | ||||||
|     { token: "keyword", foreground: colors.purple }, |  | ||||||
|     { token: "operator", foreground: colors.peach }, |  | ||||||
|     { token: "delimiter.bracket.embed", foreground: colors.red }, |  | ||||||
|     { token: "sigil", foreground: colors.teal }, |  | ||||||
|     { token: "function", foreground: colors.blue }, |  | ||||||
|     { token: "function.call", foreground: colors.default }, |  | ||||||
| 
 |  | ||||||
|     // Markdown specific
 |  | ||||||
|     { token: "emphasis", fontStyle: "italic" }, |  | ||||||
|     { token: "strong", fontStyle: "bold" }, |  | ||||||
|     { token: "keyword.md", foreground: colors.lightRed }, |  | ||||||
|     { token: "keyword.table", foreground: colors.lightRed }, |  | ||||||
|     { token: "string.link.md", foreground: colors.blue }, |  | ||||||
|     { token: "variable.md", foreground: colors.teal }, |  | ||||||
|     { token: "string.md", foreground: colors.default }, |  | ||||||
|     { token: "variable.source.md", foreground: colors.default }, |  | ||||||
| 
 |  | ||||||
|     // XML specific
 |  | ||||||
|     { token: "tag", foreground: colors.lightRed }, |  | ||||||
|     { token: "metatag", foreground: colors.lightRed }, |  | ||||||
|     { token: "attribute.name", foreground: colors.peach }, |  | ||||||
|     { token: "attribute.value", foreground: colors.green }, |  | ||||||
| 
 |  | ||||||
|     // JSON specific
 |  | ||||||
|     { token: "string.key", foreground: colors.lightRed }, |  | ||||||
|     { token: "keyword.json", foreground: colors.blue }, |  | ||||||
| 
 |  | ||||||
|     // SQL specific
 |  | ||||||
|     { token: "operator.sql", foreground: colors.purple }, |  | ||||||
|   ], |  | ||||||
| 
 | 
 | ||||||
|   colors: { |   colors: { | ||||||
|     "editor.background": background.default, |     "editor.background": colors.background, | ||||||
|     "editor.foreground": colors.default, |     "editor.foreground": colors.default, | ||||||
|     "editorLineNumber.foreground": "#636d83", |     "editorLineNumber.foreground": "#636d83", | ||||||
|     "editorCursor.foreground": "#636d83", |     "editorCursor.foreground": "#636d83", | ||||||
|     "editor.selectionBackground": "#3e4451", |     "editor.selectionBackground": "#3e4451", | ||||||
|     "editor.findMatchHighlightBackground": "#528bff3D", |     "editor.findMatchHighlightBackground": "#528bff3d", | ||||||
|     "editorSuggestWidget.background": "#21252b", |     "editorSuggestWidget.background": "#21252b", | ||||||
|     "editorSuggestWidget.border": "#181a1f", |     "editorSuggestWidget.border": "#181a1f", | ||||||
|     "editorSuggestWidget.selectedBackground": "#2c313a", |     "editorSuggestWidget.selectedBackground": "#2c313a", | ||||||
|  | @ -76,12 +90,29 @@ const theme = { | ||||||
|   }, |   }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const highContrast = { | const lightTheme = { | ||||||
|   ...theme, |   base: "vs", | ||||||
|  |   inherit: false, | ||||||
|  |   rules: rules(lightColors), | ||||||
|  | 
 | ||||||
|   colors: { |   colors: { | ||||||
|     ...theme.colors, |     "editor.background": lightColors.background, | ||||||
|     "editor.background": background.highContrast, |     "editor.foreground": lightColors.default, | ||||||
|  |     "editorLineNumber.foreground": "#9d9d9f", | ||||||
|  |     "editorCursor.foreground": "#526fff", | ||||||
|  |     "editor.selectionBackground": "#e5e5e6", | ||||||
|  |     "editor.findMatchHighlightBackground": "#526fff33", | ||||||
|  |     "editorSuggestWidget.highlightForeground": lightColors.default, | ||||||
|  |     "editorSuggestWidget.focusHighlightForeground": "#0431fa", | ||||||
|  |     "editorSuggestWidget.selectedForeground": lightColors.default, | ||||||
|  |     "editorSuggestWidget.background": "#eaeaeb", | ||||||
|  |     "editorSuggestWidget.border": "#dbdbdc", | ||||||
|  |     "editorSuggestWidget.selectedBackground": "#ffffff", | ||||||
|  |     "input.background": "#ffffff", | ||||||
|  |     "input.border": "#dbdbdc", | ||||||
|  |     "editorBracketMatch.border": "#fafafa", | ||||||
|  |     "editorBracketMatch.background": "#e5e5e6", | ||||||
|   }, |   }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export { theme, highContrast }; | export { theme, lightTheme }; | ||||||
|  |  | ||||||
|  | @ -20,8 +20,8 @@ const EditorSettings = { | ||||||
|     const editorFontSizeCheckbox = this.el.querySelector( |     const editorFontSizeCheckbox = this.el.querySelector( | ||||||
|       `[name="editor_font_size"][value="true"]` |       `[name="editor_font_size"][value="true"]` | ||||||
|     ); |     ); | ||||||
|     const editorHighContrastCheckbox = this.el.querySelector( |     const editorLightThemeCheckbox = this.el.querySelector( | ||||||
|       `[name="editor_high_contrast"][value="true"]` |       `[name="editor_light_theme"][value="true"]` | ||||||
|     ); |     ); | ||||||
|     const editorMarkdownWordWrapCheckbox = this.el.querySelector( |     const editorMarkdownWordWrapCheckbox = this.el.querySelector( | ||||||
|       `[name="editor_markdown_word_wrap"][value="true"]` |       `[name="editor_markdown_word_wrap"][value="true"]` | ||||||
|  | @ -31,8 +31,8 @@ const EditorSettings = { | ||||||
|     editorAutoSignatureCheckbox.checked = settings.editor_auto_signature; |     editorAutoSignatureCheckbox.checked = settings.editor_auto_signature; | ||||||
|     editorFontSizeCheckbox.checked = |     editorFontSizeCheckbox.checked = | ||||||
|       settings.editor_font_size === EDITOR_FONT_SIZE.large ? true : false; |       settings.editor_font_size === EDITOR_FONT_SIZE.large ? true : false; | ||||||
|     editorHighContrastCheckbox.checked = |     editorLightThemeCheckbox.checked = | ||||||
|       settings.editor_theme === EDITOR_THEME.highContrast ? true : false; |       settings.editor_theme === EDITOR_THEME.light ? true : false; | ||||||
|     editorMarkdownWordWrapCheckbox.checked = settings.editor_markdown_word_wrap; |     editorMarkdownWordWrapCheckbox.checked = settings.editor_markdown_word_wrap; | ||||||
| 
 | 
 | ||||||
|     editorAutoCompletionCheckbox.addEventListener("change", (event) => { |     editorAutoCompletionCheckbox.addEventListener("change", (event) => { | ||||||
|  | @ -51,10 +51,10 @@ const EditorSettings = { | ||||||
|       }); |       }); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     editorHighContrastCheckbox.addEventListener("change", (event) => { |     editorLightThemeCheckbox.addEventListener("change", (event) => { | ||||||
|       settingsStore.update({ |       settingsStore.update({ | ||||||
|         editor_theme: event.target.checked |         editor_theme: event.target.checked | ||||||
|           ? EDITOR_THEME.highContrast |           ? EDITOR_THEME.light | ||||||
|           : EDITOR_THEME.default, |           : EDITOR_THEME.default, | ||||||
|       }); |       }); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ export const EDITOR_FONT_SIZE = { | ||||||
| 
 | 
 | ||||||
| export const EDITOR_THEME = { | export const EDITOR_THEME = { | ||||||
|   default: "default", |   default: "default", | ||||||
|   highContrast: "highContrast", |   light: "light", | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| const DEFAULT_SETTINGS = { | const DEFAULT_SETTINGS = { | ||||||
|  | @ -66,6 +66,11 @@ class SettingsStore { | ||||||
|   _loadSettings() { |   _loadSettings() { | ||||||
|     const settings = load(SETTINGS_KEY); |     const settings = load(SETTINGS_KEY); | ||||||
| 
 | 
 | ||||||
|  |     // Rewrite settings for backward compatibility
 | ||||||
|  |     if (!Object.values(EDITOR_THEME).includes(settings.editor_theme)) { | ||||||
|  |       delete settings.editor_theme; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     if (settings) { |     if (settings) { | ||||||
|       this._settings = { ...this._settings, ...settings }; |       this._settings = { ...this._settings, ...settings }; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -166,11 +166,7 @@ defmodule LivebookWeb.SettingsLive do | ||||||
|                 value={false} |                 value={false} | ||||||
|               /> |               /> | ||||||
|               <.switch_field name="editor_font_size" label="Increase font size" value={false} /> |               <.switch_field name="editor_font_size" label="Increase font size" value={false} /> | ||||||
|               <.switch_field |               <.switch_field name="editor_light_theme" label="Use light theme" value={false} /> | ||||||
|                 name="editor_high_contrast" |  | ||||||
|                 label="Use high contrast theme" |  | ||||||
|                 value={false} |  | ||||||
|               /> |  | ||||||
|               <.switch_field |               <.switch_field | ||||||
|                 name="editor_markdown_word_wrap" |                 name="editor_markdown_word_wrap" | ||||||
|                 label="Wrap words in Markdown" |                 label="Wrap words in Markdown" | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue