import js from '@eslint/js' import globals from 'globals' import react from 'eslint-plugin-react' import reactHooks from 'eslint-plugin-react-hooks' import reactRefresh from 'eslint-plugin-react-refresh' import tseslint from 'typescript-eslint' import prettierPlugin from 'eslint-plugin-prettier' export default tseslint.config( { ignores: ['dist'] }, { extends: [ js.configs.recommended, ...tseslint.configs.recommendedTypeChecked, 'plugin:prettier/recommended', ], files: ['**/*.{ts,tsx}'], languageOptions: { ecmaVersion: 2020, globals: globals.browser, parserOptions: { project: ['./tsconfig.node.json', './tsconfig.app.json'], tsconfigRootDir: import.meta.dirname, sourceType: 'module', ecmaFeatures: { jsx: true, }, }, }, settings: { react: { version: '18.3' } }, plugins: { prettier: prettierPlugin, react, 'react-hooks': reactHooks, 'react-refresh': reactRefresh, }, rules: { 'prettier/prettier': 'error', 'react/react-in-jsx-scope': 'off', '@typescript-eslint/explicit-module-boundary-types': 'off', ...reactHooks.configs.recommended.rules, ...react.configs.recommended.rules, ...react.configs['jsx-runtime'].rules, 'react-refresh/only-export-components': [ 'warn', { allowConstantExport: true }, ], }, }, )