0.2.0 • Published 8 months ago
plain-shiki v0.2.0
Plain Shiki
Highlight your plaintext in any container via Shiki.
By using the CSS Custom Highlight API, code can be highlighted on plain text nodes without rich text. It will help you get the lightest code editor.
Installation
pnpm i plain-shikiUsage
Firstly, create any element that can contain text nodes, e.g.
<div class="plain-shiki"></div>Add the
contenteditableattribute to this element. If you don't mind the compatibility of the target browser, you can specify its value asplaintext-onlyWrite the following code:
import { createPlainShiki } from "plain-shiki";
import { createHighlighterCore } from "shiki/core";
import { createJavaScriptRegexEngine } from "shiki/engine-javascript.mjs";
import grammarTs from "shiki/langs/typescript.mjs";
import vitesseDark from "shiki/themes/vitesse-dark.mjs";
import vitesseLight from "shiki/themes/vitesse-light.mjs";
const shiki = await createHighlighterCore({
  langs: [grammarTs],
  themes: [vitesseLight, vitesseDark],
  engine: createJavaScriptRegexEngine()
});
const el = document.querySelector(".plain-shiki") as HTMLElement;
createPlainShiki(shiki).mount(el, {
  lang: "ts",
  themes: {
    light: "vitesse-light",
    dark: "vitesse-dark"
  }
});