diff --git a/packages/next/src/shared/lib/get-img-props.ts b/packages/next/src/shared/lib/get-img-props.ts index 157dfa16e54c7..4df01b8911577 100644 --- a/packages/next/src/shared/lib/get-img-props.ts +++ b/packages/next/src/shared/lib/get-img-props.ts @@ -69,7 +69,7 @@ export type ImageProps = Omit< lazyRoot?: string } -export type ImgProps = Omit & { +export type ImgProps = Omit & { loading: LoadingValue width: number | undefined height: number | undefined diff --git a/test/unit/next-image-get-img-props.test.ts b/test/unit/next-image-get-img-props.test.ts index 19a2e4125ba82..6ae0eb35f773b 100644 --- a/test/unit/next-image-get-img-props.test.ts +++ b/test/unit/next-image-get-img-props.test.ts @@ -37,6 +37,30 @@ describe('getImageProps()', () => { ['src', '/_next/image?url=%2Ftest.png&w=256&q=75'], ]) }) + + it('should have correct type for props', async () => { + const { props } = getImageProps({ + alt: 'a nice desc', + id: 'my-image', + src: '/test.png', + width: 100, + height: 200, + }) + + expect(props.alt).toBeString() + expect(props.id).toBeString() + expect(props.loading).toBeString() + + expect(props.width).toBeNumber() + expect(props.height).toBeNumber() + + expect(props.decoding).toBeString() + expect(props.style).toBeObject() + expect(props.style.color).toBeString() + expect(props.src).toBeString() + expect(props.srcSet).toBeString() + }) + it('should handle priority', async () => { const { props } = getImageProps({ alt: 'a nice desc',