mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
11f8905be4
GitOrigin-RevId: 610a254ea77c194969033d0791ecf1129e02c4bf
71 lines
2 KiB
TypeScript
71 lines
2 KiB
TypeScript
import { EditorView } from '@codemirror/view'
|
|
import { Compartment } from '@codemirror/state'
|
|
|
|
export type FontFamily = 'monaco' | 'lucida'
|
|
export type LineHeight = 'compact' | 'normal' | 'wide'
|
|
export type OverallTheme = '' | 'light-'
|
|
|
|
export type Options = {
|
|
fontSize: number
|
|
fontFamily: FontFamily
|
|
lineHeight: LineHeight
|
|
overallTheme: OverallTheme
|
|
}
|
|
|
|
const optionsThemeConf = new Compartment()
|
|
|
|
export const theme = (options: Options) => [
|
|
optionsThemeConf.of(createThemeFromOptions(options)),
|
|
]
|
|
|
|
export const lineHeights: Record<LineHeight, number> = {
|
|
compact: 1.33,
|
|
normal: 1.6,
|
|
wide: 2,
|
|
}
|
|
|
|
const fontFamilies: Record<FontFamily, string[]> = {
|
|
monaco: ['Monaco', 'Menlo', 'Ubuntu Mono', 'Consolas', 'monospace'],
|
|
lucida: ['Lucida Console', 'Source Code Pro', 'monospace'],
|
|
}
|
|
|
|
const createThemeFromOptions = ({
|
|
fontSize = 12,
|
|
fontFamily = 'monaco',
|
|
lineHeight = 'normal',
|
|
overallTheme = '',
|
|
}: Options) => {
|
|
// Theme styles that depend on settings
|
|
return [
|
|
EditorView.editorAttributes.of({
|
|
class: overallTheme === '' ? 'overall-theme-dark' : 'overall-theme-light',
|
|
}),
|
|
EditorView.theme({
|
|
'&.cm-editor': {
|
|
'--font-size': `${fontSize}px`,
|
|
'--source-font-family': fontFamilies[fontFamily]?.join(', '),
|
|
'--line-height': lineHeights[lineHeight],
|
|
},
|
|
'.cm-content': {
|
|
fontSize: 'var(--font-size)',
|
|
fontFamily: 'var(--source-font-family)',
|
|
lineHeight: 'var(--line-height)',
|
|
color: '#000',
|
|
},
|
|
'.cm-gutters': {
|
|
fontSize: 'var(--font-size)',
|
|
lineHeight: 'var(--line-height)',
|
|
},
|
|
'.cm-tooltip': {
|
|
// Set variables for tooltips, which are outside the editor
|
|
'--font-size': `${fontSize}px`,
|
|
'--source-font-family': fontFamilies[fontFamily]?.join(', '),
|
|
// NOTE: fontFamily is not set here, as most tooltips use the UI font
|
|
fontSize: 'var(--font-size)',
|
|
},
|
|
'.cm-lineNumbers': {
|
|
fontFamily: 'var(--source-font-family)',
|
|
},
|
|
}),
|
|
]
|
|
}
|