Fix astro-entry
error on build with multiple JSX frameworks (#6967)
This commit is contained in:
parent
8dd43db93f
commit
a8a319aef7
3 changed files with 10 additions and 2 deletions
5
.changeset/loud-bears-glow.md
Normal file
5
.changeset/loud-bears-glow.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Fix `astro-entry` error on build with multiple JSX frameworks
|
|
@ -2,7 +2,7 @@ import type { Plugin as VitePlugin } from 'vite';
|
||||||
import type { BuildInternals } from '../internal.js';
|
import type { BuildInternals } from '../internal.js';
|
||||||
import type { AstroBuildPlugin } from '../plugin.js';
|
import type { AstroBuildPlugin } from '../plugin.js';
|
||||||
|
|
||||||
const astroEntryPrefix = '\0astro-entry:';
|
export const astroEntryPrefix = '\0astro-entry:';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* When adding hydrated or client:only components as Rollup inputs, sometimes we're not using all
|
* When adding hydrated or client:only components as Rollup inputs, sometimes we're not using all
|
||||||
|
|
|
@ -13,6 +13,7 @@ import babel from '@babel/core';
|
||||||
import * as colors from 'kleur/colors';
|
import * as colors from 'kleur/colors';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
import { CONTENT_FLAG, PROPAGATED_ASSET_FLAG } from '../content/index.js';
|
import { CONTENT_FLAG, PROPAGATED_ASSET_FLAG } from '../content/index.js';
|
||||||
|
import { astroEntryPrefix } from '../core/build/plugins/plugin-component-entry.js';
|
||||||
import { error } from '../core/logger/core.js';
|
import { error } from '../core/logger/core.js';
|
||||||
import { removeQueryString } from '../core/path.js';
|
import { removeQueryString } from '../core/path.js';
|
||||||
import { detectImportSource } from './import-source.js';
|
import { detectImportSource } from './import-source.js';
|
||||||
|
@ -139,7 +140,9 @@ export default function jsx({ settings, logging }: AstroPluginJSXOptions): Plugi
|
||||||
},
|
},
|
||||||
async transform(code, id, opts) {
|
async transform(code, id, opts) {
|
||||||
const ssr = Boolean(opts?.ssr);
|
const ssr = Boolean(opts?.ssr);
|
||||||
if (SPECIAL_QUERY_REGEX.test(id)) {
|
// Skip special queries and astro entries. We skip astro entries here as we know it doesn't contain
|
||||||
|
// JSX code, and also because we can't detect the import source to apply JSX transforms.
|
||||||
|
if (SPECIAL_QUERY_REGEX.test(id) || id.startsWith(astroEntryPrefix)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
id = removeQueryString(id);
|
id = removeQueryString(id);
|
||||||
|
|
Loading…
Reference in a new issue