fix(assets): Fix images from public not working with the new Assets feature (#6536)
* fix(assets): Fix images from public not working with <Image> and `getImage` * test(assets): Add test for public images * refactor: simplify logic
This commit is contained in:
parent
04dddd783d
commit
035c0c4df2
6 changed files with 21 additions and 11 deletions
5
.changeset/stupid-lemons-boil.md
Normal file
5
.changeset/stupid-lemons-boil.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Fix Image component and `getImage` not handling images from public correctly
|
|
@ -1,5 +1,4 @@
|
||||||
import { AstroError, AstroErrorData } from '../../core/errors/index.js';
|
import { AstroError, AstroErrorData } from '../../core/errors/index.js';
|
||||||
import { isRemotePath } from '../../core/path.js';
|
|
||||||
import { VALID_INPUT_FORMATS } from '../consts.js';
|
import { VALID_INPUT_FORMATS } from '../consts.js';
|
||||||
import { isESMImportedImage } from '../internal.js';
|
import { isESMImportedImage } from '../internal.js';
|
||||||
import type { ImageTransform, OutputFormat } from '../types.js';
|
import type { ImageTransform, OutputFormat } from '../types.js';
|
||||||
|
@ -125,7 +124,7 @@ export const baseService: Omit<LocalImageService, 'transform'> = {
|
||||||
},
|
},
|
||||||
getURL(options: ImageTransform) {
|
getURL(options: ImageTransform) {
|
||||||
if (!isESMImportedImage(options.src)) {
|
if (!isESMImportedImage(options.src)) {
|
||||||
// For non-ESM imported images, width and height are required to avoid CLS, as we can't infer them from the file
|
// For remote images, width and height are explicitly required as we can't infer them from the file
|
||||||
let missingDimension: 'width' | 'height' | 'both' | undefined;
|
let missingDimension: 'width' | 'height' | 'both' | undefined;
|
||||||
if (!options.width && !options.height) {
|
if (!options.width && !options.height) {
|
||||||
missingDimension = 'both';
|
missingDimension = 'both';
|
||||||
|
@ -141,17 +140,12 @@ export const baseService: Omit<LocalImageService, 'transform'> = {
|
||||||
message: AstroErrorData.MissingImageDimension.message(missingDimension, options.src),
|
message: AstroErrorData.MissingImageDimension.message(missingDimension, options.src),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Both our currently available local services don't handle remote images, so for them we can just return as is
|
// Both our currently available local services don't handle remote images, so we return the path as is.
|
||||||
if (!isESMImportedImage(options.src) && isRemotePath(options.src)) {
|
|
||||||
return options.src;
|
return options.src;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (
|
if (!VALID_INPUT_FORMATS.includes(options.src.format as any)) {
|
||||||
isESMImportedImage(options.src) &&
|
|
||||||
!VALID_INPUT_FORMATS.includes(options.src.format as any)
|
|
||||||
) {
|
|
||||||
throw new AstroError({
|
throw new AstroError({
|
||||||
...AstroErrorData.UnsupportedImageFormat,
|
...AstroErrorData.UnsupportedImageFormat,
|
||||||
message: AstroErrorData.UnsupportedImageFormat.message(
|
message: AstroErrorData.UnsupportedImageFormat.message(
|
||||||
|
@ -163,7 +157,7 @@ export const baseService: Omit<LocalImageService, 'transform'> = {
|
||||||
}
|
}
|
||||||
|
|
||||||
const searchParams = new URLSearchParams();
|
const searchParams = new URLSearchParams();
|
||||||
searchParams.append('href', isESMImportedImage(options.src) ? options.src.src : options.src);
|
searchParams.append('href', options.src.src);
|
||||||
|
|
||||||
options.width && searchParams.append('w', options.width.toString());
|
options.width && searchParams.append('w', options.width.toString());
|
||||||
options.height && searchParams.append('h', options.height.toString());
|
options.height && searchParams.append('h', options.height.toString());
|
||||||
|
|
|
@ -142,6 +142,13 @@ describe('astro:image', () => {
|
||||||
expect(!!$img.attr('width')).to.equal(true);
|
expect(!!$img.attr('width')).to.equal(true);
|
||||||
expect(!!$img.attr('height')).to.equal(true);
|
expect(!!$img.attr('height')).to.equal(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('support images from public', () => {
|
||||||
|
let $img = $('#public img');
|
||||||
|
expect($img.attr('src')).to.equal('/penguin3.jpg');
|
||||||
|
expect(!!$img.attr('width')).to.equal(true);
|
||||||
|
expect(!!$img.attr('height')).to.equal(true);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
it('error if no width and height', async () => {
|
it('error if no width and height', async () => {
|
||||||
|
|
BIN
packages/astro/test/fixtures/core-image/public/penguin3.jpg
vendored
Normal file
BIN
packages/astro/test/fixtures/core-image/public/penguin3.jpg
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 13 KiB |
|
@ -11,7 +11,7 @@ export async function getStaticPaths() {
|
||||||
|
|
||||||
const { entry } = Astro.props;
|
const { entry } = Astro.props;
|
||||||
const { Content } = await entry.render();
|
const { Content } = await entry.render();
|
||||||
const myImage = await getImage(entry.data.image);
|
const myImage = await getImage({src: entry.data.image});
|
||||||
---
|
---
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
|
|
|
@ -30,5 +30,9 @@ import myImage from "../assets/penguin1.jpg";
|
||||||
<div id="data-uri">
|
<div id="data-uri">
|
||||||
<Image src="" alt="Astro logo" width="16" height="16" />
|
<Image src="" alt="Astro logo" width="16" height="16" />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div id="public">
|
||||||
|
<Image src="/penguin3.jpg" width={400} height={400} alt="..." />
|
||||||
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
Loading…
Reference in a new issue