Fixes usage of Code component in Vercel (#6198)

* Fixes usage of Code component in Vercel

* Adding a changeset
This commit is contained in:
Matthew Phillips 2023-02-09 14:22:57 -05:00 committed by GitHub
parent c75d319ee6
commit a9bdd9cc4e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 60 additions and 5 deletions

View file

@ -0,0 +1,5 @@
---
'astro': patch
---
Fixes usage of Code component in Vercel

View file

@ -15,14 +15,14 @@ function stringify(opts) {
/** /**
* @param {import('shiki').HighlighterOptions} opts * @param {import('shiki').HighlighterOptions} opts
* @returns {Promise<import('shiki').Highlighter>} * @returns {Promise<import('shiki').HighlighterOptions>}
*/ */
async function resolveHighlighter(opts) { export async function resolveHighlighterOptions(opts) {
const resolvedThemes = []; const resolvedThemes = [];
if (Object.keys(opts.theme).length) { if (opts.theme && opts.theme in themes) {
resolvedThemes.push(opts.theme);
} else if (opts.theme && opts.theme in themes) {
resolvedThemes.push(await themes[opts.theme]()); resolvedThemes.push(await themes[opts.theme]());
} else if (Object.keys(opts.theme).length) {
resolvedThemes.push(opts.theme);
} }
let resolvedLanguages; let resolvedLanguages;
@ -47,6 +47,16 @@ async function resolveHighlighter(opts) {
// Do not pass through the theme as that will attempt to load it, even if it's included in themes // Do not pass through the theme as that will attempt to load it, even if it's included in themes
delete highlighterOptions['theme']; delete highlighterOptions['theme'];
return highlighterOptions;
}
/**
* @param {import('shiki').HighlighterOptions} opts
* @returns {Promise<import('shiki').Highlighter>}
*/
async function resolveHighlighter(opts) {
const highlighterOptions = await resolveHighlighterOptions(opts);
// Start the async getHighlighter call and cache the Promise // Start the async getHighlighter call and cache the Promise
const highlighter = getShikiHighlighter(highlighterOptions).then((hl) => { const highlighter = getShikiHighlighter(highlighterOptions).then((hl) => {
hl.setColorReplacements({ hl.setColorReplacements({

View file

@ -0,0 +1,40 @@
import { expect } from 'chai';
import { createContainer } from '../../../dist/core/dev/index.js';
import { createViteLoader } from '../../../dist/core/module-loader/index.js';
const root = new URL('../../fixtures/alias/', import.meta.url);
describe('<Code />', () => {
describe('Shiki - getHighlighterOptions', () => {
let container;
let mod;
before(async () => {
container = await createContainer({ root, disableTelemetry: true });
const loader = createViteLoader(container.viteServer);
mod = await loader.import('astro/components/Shiki.js');
});
after(async () => {
await container.close();
})
it('uses the bundles themes for built-in themes', async () => {
const { resolveHighlighterOptions } = mod;
const opts = await resolveHighlighterOptions({ theme: 'css-variables' });
const themes = opts.themes;
expect(themes).to.have.a.lengthOf(1);
expect(themes[0]).to.be.an('object');
});
it('uses the string theme name for custom themes', async () => {
const { resolveHighlighterOptions } = mod;
const opts = await resolveHighlighterOptions({ theme: 'some-custom-theme' });
const themes = opts.themes;
expect(themes).to.have.a.lengthOf(1);
expect(themes[0]).to.be.an('string');
expect(themes[0]).to.equal('some-custom-theme');
})
});
});