configuration-eslint/rules/astro.ts
2026-03-15 10:44:38 +01:00

116 lines
5.4 KiB
TypeScript

/* eslint-disable unicorn/no-null -- Le null est nécessaire ici. */
/* eslint-disable functional/no-throw-statements -- L'exécution d'ESLint doit pouvoir s'arrêter en cas d'échec critique. */
import type { ESLint, Linter } from "eslint";
import * as astroEsLintParser from "astro-eslint-parser";
import astro from "eslint-plugin-astro";
import globals from "globals";
import typeScriptEsLint from "typescript-eslint";
const getAstroPlugin = (): ESLint.Plugin => {
const firstBaseConfig = astro.configs.base.at(0);
if (firstBaseConfig === undefined) {
throw new Error("Impossible de récupérer la configuration de base du plugin Astro.");
}
const astroPlugin = firstBaseConfig.plugins?.["astro"];
if (astroPlugin === undefined) {
throw new Error("Impossible de récupérer le plugin Astro.");
}
return astroPlugin;
};
export const astroRules: ReadonlyArray<Linter.Config> = [
{
files: ["**/*.astro"],
languageOptions: {
globals: {
...globals.astro,
},
parser: astroEsLintParser,
parserOptions: {
extraFileExtensions: [".astro"],
parser: typeScriptEsLint.parser,
/// Ces lignes sont nécessaires pour surcharger la configuration pour les fichiers TS.
project: true,
projectService: null,
tsconfigRootDir: null,
},
sourceType: "module",
},
name: "Astro",
plugins: {
astro: getAstroPlugin(),
},
processor: "astro/client-side-ts",
rules: {
//
// Enforce that all elements that require alternative text have meaningful information to relay back to the end user.
"astro/jsx-a11y/alt-text": "error",
// Enforces <a> values are not exact matches for the phrases “click here”, “here”, “link”, “a link”, or “learn more”.
"astro/jsx-a11y/anchor-ambiguous-text": "error",
// Enforce that anchors have content and that the content is accessible to screen readers. Accessible means that it is not hidden using the aria-hidden prop.
"astro/jsx-a11y/anchor-has-content": "error",
// Ennforces that <a> elements avec valid hyperlinks (and not buttons).
"astro/jsx-a11y/anchor-is-valid": "error",
// Enforces good aria-activedescendant handling.
"astro/jsx-a11y/aria-activedescendant-has-tabindex": "error",
// Elements cannot use an invalid ARIA attribute. This will fail if it finds an aria-* property that is not listed in WAI-ARIA States and Properties spec.
"astro/jsx-a11y/aria-props": "error",
// ARIA state and property values must be valid.
"astro/jsx-a11y/aria-proptypes": "error",
// Elements with ARIA roles must use a valid, non-abstract ARIA role. A reference to role definitions can be found at
"astro/jsx-a11y/aria-role": "error",
// This rule reports not setting a value for the client:only directive.
"astro/missing-client-only-directive-value": "error",
// This rule reports conflicting set:text, set:html, and child content.
"astro/no-conflict-set-directives": "error",
// This rule reports use of deprecated Astro.canonicalURL.
"astro/no-deprecated-astro-canonicalurl": "error",
// This rule reports use of deprecated Astro.fetchContent().
"astro/no-deprecated-astro-fetchcontent": "error",
// This rule reports use of deprecated Astro.resolve().
"astro/no-deprecated-astro-resolve": "error",
// This rule reports use of deprecated getEntryBySlug().
"astro/no-deprecated-getentrybyslug": "error",
// This rule reports value exports from Astro components. The use of typed exports are still allowed.
"astro/no-exports-from-components": "error",
// This rule reports all uses of set:html in order to reduce the risk of injecting potentially unsafe / unescaped html into the browser leading to Cross-Site Scripting (XSS) attacks.
"astro/no-set-html-directive": "error",
// This rule reports all uses of set:text directive.
"astro/no-set-text-directive": "error",
// This rule aims to remove unused CSS selectors.
"astro/no-unused-css-selector": "error",
// This rule is aimed at eliminating unused defined variables in define:vars={...} in style tag.
"astro/no-unused-define-vars-in-style": "error",
// This rule aims to replace the class attribute with expression with the class:list directive.
"astro/prefer-class-list-directive": "error",
// This rule aims to replace the class attribute with expression with the class:list directive.
"astro/prefer-object-class-list": "error",
// This rule aims to use split array elements than string concatenation in class:list.
"astro/prefer-split-class-list": ["error", { splitLiteral: false }],
// This rule ensures that attributes are sorted, making the structure of your elements more predictable and easier to manage.
"astro/sort-attributes": ["error", { ignoreCase: false, order: "asc", type: "alphabetical" }],
// This rule uses @astrojs/compiler to check the source code.
"astro/valid-compile": "error",
// TODO: Finir.
},
},
{
/// Cette configuration permet de vérfier les blocs TS dans les fichiers Astro.
files: ["**/*.astro/*.ts"],
languageOptions: {
globals: { ...globals.browser },
parser: typeScriptEsLint.parser,
parserOptions: {
project: null,
},
sourceType: "module",
},
name: "Astro/TypeScript",
},
];