import js from '@eslint/js'; import tseslint from 'typescript-eslint'; import react from 'eslint-plugin-react'; import reactHooks from 'eslint-plugin-react-hooks'; import reactRefresh from 'eslint-plugin-react-refresh'; export default tseslint.config( // Global ignores { ignores: [ '**/node_modules', '**/dist', '**/build', '**/coverage', '**/public', '**/*.js', '**/vite.config.ts', '**/eslint.config.js', ], }, // Base configuration js.configs.recommended, ...tseslint.configs.recommended, ...tseslint.configs.recommendedTypeChecked, { files: ['**/*.{ts,tsx}'], plugins: { react, 'react-hooks': reactHooks, 'react-refresh': reactRefresh, }, languageOptions: { ecmaVersion: 2022, sourceType: 'module', parserOptions: { ecmaFeatures: { jsx: true, }, project: './tsconfig.json', tsconfigRootDir: import.meta.dirname, }, }, settings: { react: { version: 'detect', }, }, rules: { // General rules 'no-console': [ 'warn', { allow: ['warn', 'error', 'debug'], }, ], 'no-duplicate-imports': 'error', 'no-unused-vars': 'off', // React rules 'react/prop-types': 'off', 'react/react-in-jsx-scope': 'off', 'react/jsx-uses-react': 'off', // React Hooks rules 'react-hooks/rules-of-hooks': 'error', 'react-hooks/exhaustive-deps': 'warn', // React Refresh rules 'react-refresh/only-export-components': [ 'warn', { allowConstantExport: true }, ], // TypeScript rules '@typescript-eslint/explicit-module-boundary-types': 'off', '@typescript-eslint/no-explicit-any': 'warn', '@typescript-eslint/no-unused-vars': [ 'warn', { argsIgnorePattern: '^_', varsIgnorePattern: '^_', caughtErrorsIgnorePattern: '^_', }, ], '@typescript-eslint/consistent-type-imports': [ 'warn', { prefer: 'type-imports', }, ], '@typescript-eslint/no-misused-promises': 'warn', '@typescript-eslint/no-floating-promises': 'warn', '@typescript-eslint/unbound-method': 'off', '@typescript-eslint/no-non-null-assertion': 'warn', }, }, // Override configuration for test files { files: ['**/*.test.ts', '**/*.test.tsx', '**/test/**/*.ts', '**/test/**/*.tsx'], rules: { '@typescript-eslint/no-non-null-assertion': 'off', '@typescript-eslint/no-explicit-any': 'off', }, } );