Fixed shiki import to work with "type": "module" (#2628)
* Fixed shiki import to work with "type": "module" * Changeset * Separated types import * Add "* as" to type import
This commit is contained in:
parent
ac6d2e8c64
commit
9b7e2ab251
3 changed files with 13 additions and 5 deletions
6
.changeset/great-hotels-breathe.md
Normal file
6
.changeset/great-hotels-breathe.md
Normal file
|
@ -0,0 +1,6 @@
|
|||
---
|
||||
'astro': patch
|
||||
'@astrojs/markdown-remark': patch
|
||||
---
|
||||
|
||||
Fixed shiki to work with `{ "type": "module" }`
|
|
@ -1,5 +1,6 @@
|
|||
---
|
||||
import shiki from 'shiki';
|
||||
import type * as shiki from 'shiki';
|
||||
import { getHighlighter } from 'shiki';
|
||||
|
||||
export interface Props {
|
||||
/** The code to highlight. Required. */
|
||||
|
@ -49,10 +50,10 @@ function repairShikiTheme(html: string): string {
|
|||
return html;
|
||||
}
|
||||
|
||||
const highlighter = await shiki.getHighlighter({
|
||||
const highlighter = await getHighlighter({
|
||||
theme,
|
||||
// Load custom lang if passed an object, otherwise load the default
|
||||
langs: typeof lang !== 'string' ? [lang] : undefined
|
||||
langs: typeof lang !== 'string' ? [lang] : undefined,
|
||||
});
|
||||
const _html = highlighter.codeToHtml(code, { lang: typeof lang === 'string' ? lang : lang.id });
|
||||
const html = repairShikiTheme(_html);
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import shiki from 'shiki';
|
||||
import type * as shiki from 'shiki';
|
||||
import { getHighlighter } from 'shiki';
|
||||
import { visit } from 'unist-util-visit';
|
||||
|
||||
export interface ShikiConfig {
|
||||
|
@ -30,7 +31,7 @@ export interface ShikiConfig {
|
|||
}
|
||||
|
||||
const remarkShiki = async ({ langs = [], theme = 'github-dark', wrap = false }: ShikiConfig) => {
|
||||
const highlighter = await shiki.getHighlighter({ theme });
|
||||
const highlighter = await getHighlighter({ theme });
|
||||
|
||||
for (const lang of langs) {
|
||||
await highlighter.loadLanguage(lang);
|
||||
|
|
Loading…
Reference in a new issue