0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2025-01-13 22:11:20 -05:00

fix(errors): Add more information to some error messages (#9818)

* fix(errors): Add more information to some error messages

* chore: changeset

* Apply suggestions from code review

Co-authored-by: Nate Moore <natemoo-re@users.noreply.github.com>
Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>

---------

Co-authored-by: Nate Moore <natemoo-re@users.noreply.github.com>
Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
This commit is contained in:
Erika 2024-01-25 10:45:53 -05:00 committed by GitHub
parent 05f808c1da
commit d688954c5a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 40 additions and 11 deletions

View file

@ -0,0 +1,5 @@
---
"astro": patch
---
Improves the wording of a few confusing error messages

View file

@ -851,7 +851,7 @@ export const LocalImageUsedWrongly = {
title: 'Local images must be imported.', title: 'Local images must be imported.',
message: (imageFilePath: string) => message: (imageFilePath: string) =>
`\`Image\`'s and \`getImage\`'s \`src\` parameter must be an imported image or an URL, it cannot be a string filepath. Received \`${imageFilePath}\`.`, `\`Image\`'s and \`getImage\`'s \`src\` parameter must be an imported image or an URL, it cannot be a string filepath. Received \`${imageFilePath}\`.`,
hint: 'If you want to use an image from your `src` folder, you need to either import it or if the image is coming from a content collection, use the [image() schema helper](https://docs.astro.build/en/guides/images/#images-in-content-collections) See https://docs.astro.build/en/guides/images/#src-required for more information on the `src` property.', hint: 'If you want to use an image from your `src` folder, you need to either import it or if the image is coming from a content collection, use the [image() schema helper](https://docs.astro.build/en/guides/images/#images-in-content-collections). See https://docs.astro.build/en/guides/images/#src-required for more information on the `src` property.',
} satisfies ErrorData; } satisfies ErrorData;
/** /**
@ -879,8 +879,8 @@ export const AstroGlobUsedOutside = {
export const AstroGlobNoMatch = { export const AstroGlobNoMatch = {
name: 'AstroGlobNoMatch', name: 'AstroGlobNoMatch',
title: 'Astro.glob() did not match any files.', title: 'Astro.glob() did not match any files.',
message: (globStr: string) => message: (globStr: string) => `\`Astro.glob(${globStr})\` did not return any matching files.`,
`\`Astro.glob(${globStr})\` did not return any matching files. Check the pattern for typos.`, hint: 'Check the pattern for typos.',
} satisfies ErrorData; } satisfies ErrorData;
/** /**
* @docs * @docs
@ -1001,11 +1001,20 @@ export const MissingLocale = {
`The locale/path \`${locale}\` does not exist in the configured \`i18n.locales\`.`, `The locale/path \`${locale}\` does not exist in the configured \`i18n.locales\`.`,
} satisfies ErrorData; } satisfies ErrorData;
/**
* @docs
* @description
* Astro could not find the index URL of your website. An index page is required so that Astro can create a redirect from the main index page to the localized index page of the default locale when using [`i18n.routing.prefixDefaultLocale`](https://docs.astro.build/en/reference/configuration-reference/#i18nroutingprefixdefaultlocale).
* @see
* - [Internationalization](https://docs.astro.build/en/guides/internationalization/#routing)
* - [`i18n.routing` Configuration Reference](https://docs.astro.build/en/reference/configuration-reference/#i18nrouting)
*/
export const MissingIndexForInternationalization = { export const MissingIndexForInternationalization = {
name: 'MissingIndexForInternationalizationError', name: 'MissingIndexForInternationalizationError',
title: 'Index page not found.', title: 'Index page not found.',
message: (src: string) => message: (defaultLocale: string) =>
`Astro couldn't find the index URL. This index page is required to create a redirect from the index URL to the index URL of the default locale. \nCreate an index page in \`${src}\``, `Could not find index page. A root index page is required in order to create a redirect to the index URL of the default locale. (\`/${defaultLocale}\`)`,
hint: (src: string) => `Create an index page (\`index.astro, index.md, etc.\`) in \`${src}\`.`,
} satisfies ErrorData; } satisfies ErrorData;
/** /**
@ -1037,7 +1046,21 @@ export const UnhandledRejection = {
/** /**
* @docs * @docs
* @description * @description
* Astro could not find any code to handle a rejected `Promise`. Make sure all your promises have an `await` or `.catch()` handler. * The `astro:i18n` module can not be used without enabling i18n in your Astro config. To enable i18n, add a default locale and a list of supported locales to your Astro config:
* ```js
* import { defineConfig } from 'astro'
* export default defineConfig({
* i18n: {
* defaultLocale: 'en',
* locales: ['en', 'fr'],
* },
* })
* ```
*
* For more information on internationalization support in Astro, see our [Internationalization guide](https://docs.astro.build/en/guides/internationalization/).
* @see
* - [Internationalization](https://docs.astro.build/en/guides/internationalization/)
* - [`i18n` Configuration Reference](https://docs.astro.build/en/reference/configuration-reference/#i18n)
*/ */
export const i18nNotEnabled = { export const i18nNotEnabled = {
name: 'i18nNotEnabled', name: 'i18nNotEnabled',
@ -1385,6 +1408,6 @@ export const UnknownError = { name: 'UnknownError', title: 'Unknown Error.' } sa
* - If your message is fully dynamic (ex: lots of conditional logic), make `message` a proper function, like such: `message(parameters) { logic }`. * - If your message is fully dynamic (ex: lots of conditional logic), make `message` a proper function, like such: `message(parameters) { logic }`.
* Make sure to add a `@message` tag with a static example of the error message, the docs won't be able to parse it otherwise. * Make sure to add a `@message` tag with a static example of the error message, the docs won't be able to parse it otherwise.
* - If your message is static, you can just use a string, `message: "my message"`. * - If your message is static, you can just use a string, `message: "my message"`.
* 5. Make sure to add a JSdoc comment with the `@docs` tag so that it shows up in the docs * 5. Make sure to add a JSdoc comment with the `@docs` tag so that it shows up in the docs, otherwise the error overlay will point to a 404!
* For more information, see the README in this folder! * For more information, see the README in this folder!
*/ */

View file

@ -1,10 +1,10 @@
import type { import type {
AstroConfig, AstroConfig,
AstroSettings, AstroSettings,
RoutePriorityOverride,
ManifestData, ManifestData,
RouteData, RouteData,
RoutePart, RoutePart,
RoutePriorityOverride,
} from '../../../@types/astro.js'; } from '../../../@types/astro.js';
import type { Logger } from '../../logger/core.js'; import type { Logger } from '../../logger/core.js';
@ -15,11 +15,11 @@ import path from 'node:path';
import { fileURLToPath } from 'node:url'; import { fileURLToPath } from 'node:url';
import { getPrerenderDefault } from '../../../prerender/utils.js'; import { getPrerenderDefault } from '../../../prerender/utils.js';
import { SUPPORTED_MARKDOWN_FILE_EXTENSIONS } from '../../constants.js'; import { SUPPORTED_MARKDOWN_FILE_EXTENSIONS } from '../../constants.js';
import { MissingIndexForInternationalization } from '../../errors/errors-data.js';
import { AstroError } from '../../errors/index.js';
import { removeLeadingForwardSlash, slash } from '../../path.js'; import { removeLeadingForwardSlash, slash } from '../../path.js';
import { resolvePages } from '../../util.js'; import { resolvePages } from '../../util.js';
import { getRouteGenerator } from './generator.js'; import { getRouteGenerator } from './generator.js';
import { AstroError } from '../../errors/index.js';
import { MissingIndexForInternationalization } from '../../errors/errors-data.js';
const require = createRequire(import.meta.url); const require = createRequire(import.meta.url);
interface Item { interface Item {
@ -719,7 +719,8 @@ export function createRouteManifest(
); );
throw new AstroError({ throw new AstroError({
...MissingIndexForInternationalization, ...MissingIndexForInternationalization,
message: MissingIndexForInternationalization.message(relativePath), message: MissingIndexForInternationalization.message(i18n.defaultLocale),
hint: MissingIndexForInternationalization.hint(relativePath),
}); });
} }
} }