From dc00ca464865feccd3760b54e0ccc58dbc1e804d Mon Sep 17 00:00:00 2001 From: Bjorn Lu Date: Wed, 9 Nov 2022 21:31:09 +0800 Subject: [PATCH] Share picture fallback image with source (#5324) --- .changeset/fifty-olives-end.md | 5 ++++ .../integrations/image/src/lib/get-picture.ts | 28 +++++++++---------- .../image/test/picture-ssg.test.js | 24 ++++++++++++++++ 3 files changed, 43 insertions(+), 14 deletions(-) create mode 100644 .changeset/fifty-olives-end.md diff --git a/.changeset/fifty-olives-end.md b/.changeset/fifty-olives-end.md new file mode 100644 index 000000000000..393418e66be1 --- /dev/null +++ b/.changeset/fifty-olives-end.md @@ -0,0 +1,5 @@ +--- +'@astrojs/image': patch +--- + +Share fallback img src with source of Picture component diff --git a/packages/integrations/image/src/lib/get-picture.ts b/packages/integrations/image/src/lib/get-picture.ts index 4149a93a2da0..d4deebb79f70 100644 --- a/packages/integrations/image/src/lib/get-picture.ts +++ b/packages/integrations/image/src/lib/get-picture.ts @@ -59,6 +59,13 @@ export async function getPicture(params: GetPictureParams): Promise { @@ -69,8 +76,13 @@ export async function getPicture(params: GetPictureParams): Promise getSource(format))); return { sources, + // @ts-expect-error image will always be defined image, }; } diff --git a/packages/integrations/image/test/picture-ssg.test.js b/packages/integrations/image/test/picture-ssg.test.js index 9f0074b17d9c..c14046220212 100644 --- a/packages/integrations/image/test/picture-ssg.test.js +++ b/packages/integrations/image/test/picture-ssg.test.js @@ -381,3 +381,27 @@ describe('SSG pictures with subpath - build', function () { }); }); }); + +describe('SSG pictures others - build', function () { + let fixture; + let $; + let html; + + before(async () => { + fixture = await loadFixture({ root: './fixtures/basic-picture/' }); + await fixture.build(); + + html = await fixture.readFile('/index.html'); + $ = cheerio.load(html); + }); + + it('fallback image should share last source', async () => { + const hero = $('#hero'); + const picture = hero.closest('picture'); + + const source = picture.children('source').last(); + const image = picture.children('img').last(); + + expect(source.attr('srcset')).to.include(image.attr('src')); + }); +});