Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Eslint upgrade to v9 #9344

Open
wants to merge 9 commits into
base: develop
Choose a base branch
from
94 changes: 0 additions & 94 deletions .eslintrc.json

This file was deleted.

145 changes: 145 additions & 0 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,145 @@
import eslint from "@eslint/js";
import tseslint from "@typescript-eslint/eslint-plugin";
import tsParser from "@typescript-eslint/parser";
import prettierConfig from "eslint-config-prettier";
amjithtitus09 marked this conversation as resolved.
Show resolved Hide resolved
import i18nextPlugin from "eslint-plugin-i18next";
import mdxPlugin from "eslint-plugin-mdx";
amjithtitus09 marked this conversation as resolved.
Show resolved Hide resolved
import prettierPlugin from "eslint-plugin-prettier";
import reactPlugin from "eslint-plugin-react";
import reactHooksPlugin from "eslint-plugin-react-hooks";
import globals from "globals";

export default [
// Base configuration
{
ignores: [
"**/dist",
"**/public",
"**/lib",
"**/build",
"**/*.bs.js",
"**/*.gen.tsx",
"**/*.res",
amjithtitus09 marked this conversation as resolved.
Show resolved Hide resolved
"**/*.css",
"**/*.csv",
"**/Dockerfile",
],
},
eslint.configs.recommended,
prettierConfig,

// Global settings for all JavaScript/TypeScript files
{
files: ["**/*.{js,jsx,ts,tsx,mjs,mts}"],
languageOptions: {
ecmaVersion: 12,
sourceType: "module",
globals: {
...globals.browser,
...globals.node,
},
parserOptions: {
ecmaFeatures: {
jsx: true,
},
},
},
settings: {
react: {
version: "detect",
},
},
linterOptions: {
reportUnusedDisableDirectives: true,
},
},

// TypeScript-specific rules
{
files: ["**/*.{ts,tsx}"],
plugins: {
"@typescript-eslint": tseslint,
},
languageOptions: {
parser: tsParser,
parserOptions: {
project: "./tsconfig.json",
},
},
rules: {
...tseslint.configs.recommended.rules,
"@typescript-eslint/no-unused-vars": [
sainak marked this conversation as resolved.
Show resolved Hide resolved
"error",
{
argsIgnorePattern: "^_",
varsIgnorePattern: "^_",
caughtErrorsIgnorePattern: "^_",
},
],
"@typescript-eslint/no-explicit-any": "warn",
},
},

// React-specific rules
{
files: ["**/*.{jsx,tsx}"],
plugins: {
react: reactPlugin,
"react-hooks": reactHooksPlugin,
},
rules: {
...reactPlugin.configs.recommended.rules,
...reactHooksPlugin.configs.recommended.rules,
sainak marked this conversation as resolved.
Show resolved Hide resolved
"react/react-in-jsx-scope": "off", // Not needed in React 17+
"react/prop-types": "off",
},
},

// i18next plugin rules
{
files: ["**/*.{js,jsx,ts,tsx}"],
plugins: {
i18next: i18nextPlugin,
},
rules: {
...i18nextPlugin.configs.recommended.rules,
"i18next/no-literal-string": [
"warn",
{
mode: "jsx-only",
"jsx-attributes": {
include: ["label", "placeholder", "error", "title"],
exclude: [".*"],
},
callees: {
exclude: [".*"],
},
},
],
},
},

// Prettier rules
{
files: ["**/*.{js,jsx,ts,tsx}"],
plugins: {
prettier: prettierPlugin,
},
rules: {
"prettier/prettier": "error",
},
},

// MDX-specific rules
{
files: ["**/*.mdx"],
plugins: {
mdx: mdxPlugin,
},
...mdxPlugin.configs.recommended,
rules: {
"react/jsx-no-target-blank": "off",
"i18next/no-literal-string": "off",
},
},
amjithtitus09 marked this conversation as resolved.
Show resolved Hide resolved
];
Loading
Loading