From a695e44aed6e2f5d32cb950d4237be6e5657ba98 Mon Sep 17 00:00:00 2001
From: Erika <3019731+Princesseuh@users.noreply.github.com>
Date: Tue, 2 May 2023 14:23:37 +0200
Subject: [PATCH] fix(types): Fix getImage type requesting for a second
parameter (#6961)
---
.changeset/nice-jars-breathe.md | 5 +++++
packages/astro/client-base.d.ts | 21 ++++++++++++++++++++-
packages/astro/src/assets/internal.ts | 16 ----------------
3 files changed, 25 insertions(+), 17 deletions(-)
create mode 100644 .changeset/nice-jars-breathe.md
diff --git a/.changeset/nice-jars-breathe.md b/.changeset/nice-jars-breathe.md
new file mode 100644
index 000000000000..1a47e9bc3c33
--- /dev/null
+++ b/.changeset/nice-jars-breathe.md
@@ -0,0 +1,5 @@
+---
+'astro': patch
+---
+
+Fix getImage type
diff --git a/packages/astro/client-base.d.ts b/packages/astro/client-base.d.ts
index 52bd5870fc77..15c1fb905420 100644
--- a/packages/astro/client-base.d.ts
+++ b/packages/astro/client-base.d.ts
@@ -3,7 +3,26 @@
declare module 'astro:assets' {
// Exporting things one by one is a bit cumbersome, not sure if there's a better way - erika, 2023-02-03
type AstroAssets = {
- getImage: typeof import('./dist/assets/index.js').getImage;
+ // getImage's type here is different from the internal function since the Vite module implicitly pass the service config
+ /**
+ * Get an optimized image and the necessary attributes to render it.
+ *
+ * **Example**
+ * ```astro
+ * ---
+ * import { getImage } from 'astro:assets';
+ * import originalImage from '../assets/image.png';
+ *
+ * const optimizedImage = await getImage({src: originalImage, width: 1280 });
+ * ---
+ *
+ * ```
+ *
+ * This is functionally equivalent to using the `` component, as the component calls this function internally.
+ */
+ getImage: (
+ options: import('./dist/assets/types.js').ImageTransform
+ ) => Promise;
getConfiguredImageService: typeof import('./dist/assets/index.js').getConfiguredImageService;
Image: typeof import('./components/Image.astro').default;
};
diff --git a/packages/astro/src/assets/internal.ts b/packages/astro/src/assets/internal.ts
index 945b5a3e862d..c4b8ca751eb9 100644
--- a/packages/astro/src/assets/internal.ts
+++ b/packages/astro/src/assets/internal.ts
@@ -29,22 +29,6 @@ export async function getConfiguredImageService(): Promise {
return globalThis.astroAsset.imageService;
}
-/**
- * Get an optimized image and the necessary attributes to render it.
- *
- * **Example**
- * ```astro
- * ---
- * import { getImage } from 'astro:assets';
- * import originalImage from '../assets/image.png';
- *
- * const optimizedImage = await getImage({src: originalImage, width: 1280 });
- * ---
- *
- * ```
- *
- * This is functionally equivalent to using the `` component, as the component calls this function internally.
- */
export async function getImage(
options: ImageTransform,
serviceConfig: Record