Skip to main content

HTML Multi-Themes Formatter

One HTML block that supports multiple themes via CSS custom properties. Useful for light/dark mode.

Options

RuntimeOptions
Rustlanguage, themes, default_theme, pre_class, italic, include_highlights, highlight_lines, header
Elixirlanguage, themes, default_theme, css_variable_prefix, pre_class, italic, include_highlights, highlight_lines, header
JavaScriptlanguage, themes, defaultTheme, cssVariablePrefix, preClass, italic, includeHighlights, highlightLines, header
JavaNot currently supported in lumis4j
CLI--themes, --default-theme, --css-variable-prefix, --highlight-lines

Basic example

import {highlight} from '@lumis-sh/lumis'
import {htmlMultiThemes} from '@lumis-sh/lumis/formatters'
import javascript from '@lumis-sh/lumis/langs/javascript'
import githubLight from '@lumis-sh/themes/github_light'
import githubDark from '@lumis-sh/themes/github_dark'
const html = await highlight(
'const x = 1',
htmlMultiThemes({
language: javascript,
themes: {light: githubLight, dark: githubDark},
defaultTheme: 'light-dark()',
})
)

cssVariablePrefix

By default, CSS variables are prefixed with --lumis (e.g., --lumis-light, --lumis-dark-bg). Override the prefix if it conflicts with your CSS. Produces variables like --code-light, --code-dark-bg, etc.

const html = await highlight(
'const x = 1',
htmlMultiThemes({
language: javascript,
themes: {light: githubLight, dark: githubDark},
cssVariablePrefix: '--code',
})
)

defaultTheme

Controls what color values appear inline (not just as CSS variables):

ValueBehavior
omitted / nullCSS variables only, no inline colors
"light"Inline colors from the light theme, CSS variables for all themes
"light-dark()"Uses CSS light-dark() function for automatic OS-level switching

Output format

HTML Multi-Themes keeps the same HTML structure, but each token carries CSS variables for one or more themes:

<pre class="lumis" style="--lumis-light-bg: #ffffff; --lumis-dark-bg: #0d1117;">
<code class="language-javascript" translate="no" tabindex="0">
<div class="line" data-line="1">
<span style="--lumis-light: #cf222e; --lumis-dark: #ff7b72; color: light-dark(var(--lumis-light), var(--lumis-dark));">const</span>
</div>
</code>
</pre>
  • <pre class="lumis"> carries shared background and theme variables
  • <code class="language-*"> identifies the language and keeps the block focusable
  • <div class="line" data-line="N"> wraps each line
  • <span style="--lumis-..."> carries per-theme token colors and font styles

Good uses

  • light/dark mode
  • user-selectable theme switching
  • one HTML block shared across themes