Merge branch 'main' into bare-standalone-paths
This commit is contained in:
commit
5b124f3b81
3 changed files with 14 additions and 5 deletions
5
.changeset/stale-dragons-invite.md
Normal file
5
.changeset/stale-dragons-invite.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Improve the logging of assets for adapters that do not support image optimization
|
|
@ -131,7 +131,7 @@ function validateAssetsFeature(
|
||||||
isSquooshCompatible = false,
|
isSquooshCompatible = false,
|
||||||
} = assets;
|
} = assets;
|
||||||
if (config?.image?.service?.entrypoint === SHARP_SERVICE && !isSharpCompatible) {
|
if (config?.image?.service?.entrypoint === SHARP_SERVICE && !isSharpCompatible) {
|
||||||
logger.error(
|
logger.warn(
|
||||||
'astro',
|
'astro',
|
||||||
`The currently selected adapter \`${adapterName}\` is not compatible with the image service "Sharp".`
|
`The currently selected adapter \`${adapterName}\` is not compatible with the image service "Sharp".`
|
||||||
);
|
);
|
||||||
|
@ -139,7 +139,7 @@ function validateAssetsFeature(
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config?.image?.service?.entrypoint === SQUOOSH_SERVICE && !isSquooshCompatible) {
|
if (config?.image?.service?.entrypoint === SQUOOSH_SERVICE && !isSquooshCompatible) {
|
||||||
logger.error(
|
logger.warn(
|
||||||
'astro',
|
'astro',
|
||||||
`The currently selected adapter \`${adapterName}\` is not compatible with the image service "Squoosh".`
|
`The currently selected adapter \`${adapterName}\` is not compatible with the image service "Squoosh".`
|
||||||
);
|
);
|
||||||
|
|
|
@ -221,7 +221,11 @@ export async function runHookConfigDone({
|
||||||
logger
|
logger
|
||||||
);
|
);
|
||||||
for (const [featureName, supported] of Object.entries(validationResult)) {
|
for (const [featureName, supported] of Object.entries(validationResult)) {
|
||||||
if (!supported) {
|
// If `supported` / `validationResult[featureName]` only allows boolean,
|
||||||
|
// in theory 'assets' false, doesn't mean that the feature is not supported, but rather that the chosen image service is unsupported
|
||||||
|
// in this case we should not show an error, that the featrue is not supported
|
||||||
|
// if we would refactor the validation to support more than boolean, we could still be able to differentiate between the two cases
|
||||||
|
if (!supported && featureName !== 'assets') {
|
||||||
logger.error(
|
logger.error(
|
||||||
'astro',
|
'astro',
|
||||||
`The adapter ${adapter.name} doesn't support the feature ${featureName}. Your project won't be built. You should not use it.`
|
`The adapter ${adapter.name} doesn't support the feature ${featureName}. Your project won't be built. You should not use it.`
|
||||||
|
@ -229,9 +233,9 @@ export async function runHookConfigDone({
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!validationResult.assets) {
|
if (!validationResult.assets) {
|
||||||
logger.info(
|
logger.warn(
|
||||||
'astro',
|
'astro',
|
||||||
`The selected adapter ${adapter.name} does not support Sharp or Squoosh for image processing. To ensure your project is still able to build, image processing has been disabled.`
|
`The selected adapter ${adapter.name} does not support image optimization. To allow your project to build with the original, unoptimized images, the image service has been automatically switched to the 'noop' option. See https://docs.astro.build/en/reference/configuration-reference/#imageservice`
|
||||||
);
|
);
|
||||||
settings.config.image.service = {
|
settings.config.image.service = {
|
||||||
entrypoint: 'astro/assets/services/noop',
|
entrypoint: 'astro/assets/services/noop',
|
||||||
|
|
Loading…
Reference in a new issue