mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
fix(i18n): improve error message (#11189)
* fix(i18n): improve error message * Update packages/astro/src/core/errors/errors-data.ts Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> * Update packages/astro/src/core/errors/errors-data.ts Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> --------- Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
This commit is contained in:
parent
97724da93e
commit
75a8fe7e72
3 changed files with 22 additions and 16 deletions
5
.changeset/heavy-eagles-happen.md
Normal file
5
.changeset/heavy-eagles-happen.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Improve error message when using `getLocaleByPath` on path that doesn't contain any locales.
|
|
@ -1196,6 +1196,18 @@ export const i18nNotEnabled = {
|
||||||
hint: 'See https://docs.astro.build/en/guides/internationalization for a guide on setting up i18n.',
|
hint: 'See https://docs.astro.build/en/guides/internationalization for a guide on setting up i18n.',
|
||||||
} satisfies ErrorData;
|
} satisfies ErrorData;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @docs
|
||||||
|
* @description
|
||||||
|
* An i18n utility tried to use the locale from a URL path that does not contain one. You can prevent this error by using pathHasLocale to check URLs for a `locale` first before using i18n utilities.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
export const i18nNoLocaleFoundInPath = {
|
||||||
|
name: 'i18nNoLocaleFoundInPath',
|
||||||
|
title: 'The path doesn\'t contain any locale',
|
||||||
|
message: 'You tried to use an i18n utility on a path that doesn\'t contain any locale. You can use \`pathHasLocale\` first to determine if the path has a locale.',
|
||||||
|
} satisfies ErrorData;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @docs
|
* @docs
|
||||||
* @description
|
* @description
|
||||||
|
|
|
@ -8,7 +8,7 @@ import type {
|
||||||
} from '../@types/astro.js';
|
} from '../@types/astro.js';
|
||||||
import { shouldAppendForwardSlash } from '../core/build/util.js';
|
import { shouldAppendForwardSlash } from '../core/build/util.js';
|
||||||
import { REROUTE_DIRECTIVE_HEADER } from '../core/constants.js';
|
import { REROUTE_DIRECTIVE_HEADER } from '../core/constants.js';
|
||||||
import { MissingLocale } from '../core/errors/errors-data.js';
|
import {i18nNoLocaleFoundInPath, MissingLocale} from '../core/errors/errors-data.js';
|
||||||
import { AstroError } from '../core/errors/index.js';
|
import { AstroError } from '../core/errors/index.js';
|
||||||
import { createI18nMiddleware } from './middleware.js';
|
import { createI18nMiddleware } from './middleware.js';
|
||||||
import type { RoutingStrategies } from './utils.js';
|
import type { RoutingStrategies } from './utils.js';
|
||||||
|
@ -190,11 +190,11 @@ export function getPathByLocale(locale: string, locales: Locales): string {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
throw new Unreachable();
|
throw new AstroError(i18nNoLocaleFoundInPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An utility function that retrieves the preferred locale that correspond to a path.
|
* A utility function that retrieves the preferred locale that correspond to a path.
|
||||||
*
|
*
|
||||||
* @param path
|
* @param path
|
||||||
* @param locales
|
* @param locales
|
||||||
|
@ -205,14 +205,14 @@ export function getLocaleByPath(path: string, locales: Locales): string {
|
||||||
if (locale.path === path) {
|
if (locale.path === path) {
|
||||||
// the first code is the one that user usually wants
|
// the first code is the one that user usually wants
|
||||||
const code = locale.codes.at(0);
|
const code = locale.codes.at(0);
|
||||||
if (code === undefined) throw new Unreachable();
|
if (code === undefined) throw new AstroError(i18nNoLocaleFoundInPath);
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
} else if (locale === path) {
|
} else if (locale === path) {
|
||||||
return locale;
|
return locale;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
throw new Unreachable();
|
throw new AstroError(i18nNoLocaleFoundInPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -271,17 +271,6 @@ function peekCodePathToUse(locales: Locales, locale: string): undefined | string
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
class Unreachable extends Error {
|
|
||||||
constructor() {
|
|
||||||
super(
|
|
||||||
'Astro encountered an unexpected line of code.\n' +
|
|
||||||
'In most cases, this is not your fault, but a bug in astro code.\n' +
|
|
||||||
"If there isn't one already, please create an issue.\n" +
|
|
||||||
'https://astro.build/issues'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export type MiddlewarePayload = {
|
export type MiddlewarePayload = {
|
||||||
base: string;
|
base: string;
|
||||||
locales: Locales;
|
locales: Locales;
|
||||||
|
|
Loading…
Reference in a new issue