mirror of
				https://github.com/pgadmin-org/pgadmin4.git
				synced 2025-02-25 18:55:31 -06:00 
			
		
		
		
	- Set the browser target to ES6 and reduce the JS bundle size considerably
- Upgrade ESLint to v9.x and migrate the .eslintrc.js file to make it work
This commit is contained in:
		
							
								
								
									
										198
									
								
								web/.eslintrc.js
									
									
									
									
									
								
							
							
						
						
									
										198
									
								
								web/.eslintrc.js
									
									
									
									
									
								
							| @@ -6,98 +6,122 @@ | ||||
| // This software is released under the PostgreSQL Licence | ||||
| // | ||||
| ////////////////////////////////////////////////////////////// | ||||
| const globals = require('globals'); | ||||
| const js = require('@eslint/js'); | ||||
| const reactjs = require('eslint-plugin-react'); | ||||
| const jest = require('eslint-plugin-jest'); | ||||
| const babel = require('@babel/eslint-plugin'); | ||||
| const babelParser = require('@babel/eslint-parser'); | ||||
| const ts = require('typescript-eslint'); | ||||
|  | ||||
| module.exports = { | ||||
|   'env': { | ||||
|     'browser': true, | ||||
|     'es6': true, | ||||
|     'amd': true, | ||||
|  | ||||
| module.exports = [ | ||||
|   { | ||||
|     ignores: [ | ||||
|       '**/generated', | ||||
|       '**/node_modules', | ||||
|       '**/vendor', | ||||
|       '**/templates/', | ||||
|       '**/templates\\', | ||||
|       '**/ycache', | ||||
|       '**/regression/htmlcov', | ||||
|     ], | ||||
|   }, | ||||
|   'extends': [ | ||||
|     'eslint:recommended', | ||||
|     'plugin:react/recommended', | ||||
|     /* Uncomment the below line to use linter error for React Hooks. | ||||
|        By Default commented so that builds are generated successfully. | ||||
|        Once all the errors will be resolved will uncomment it and commit it. | ||||
|     */ | ||||
|     // "plugin:react-hooks/recommended", | ||||
|   ], | ||||
|   'parser': '@babel/eslint-parser', | ||||
|   'parserOptions': { | ||||
|     'requireConfigFile': false, | ||||
|     'ecmaVersion': 2018, | ||||
|     'ecmaFeatures': { | ||||
|       'jsx': true, | ||||
|   js.configs.recommended, | ||||
|   { | ||||
|     files: ['**/*.{js,jsx,mjs,cjs,ts,tsx}'], | ||||
|     languageOptions: { | ||||
|       'parser': babelParser, | ||||
|       ecmaVersion: 2018, | ||||
|       parserOptions: { | ||||
|         'ecmaFeatures': { | ||||
|           'jsx': true, | ||||
|         }, | ||||
|         'requireConfigFile': false, | ||||
|         'babelOptions': { | ||||
|           'plugins': [ | ||||
|             '@babel/plugin-syntax-jsx', | ||||
|             '@babel/plugin-proposal-class-properties', | ||||
|           ], | ||||
|         }, | ||||
|       }, | ||||
|       'sourceType': 'module', | ||||
|       globals: { | ||||
|         ...globals.browser, | ||||
|         ...globals.es2017, | ||||
|         ...globals.amd, | ||||
|         '_': 'readonly', | ||||
|         'module': 'readonly', | ||||
|         '__dirname': 'readonly', | ||||
|         'global': 'readonly', | ||||
|         'jest': 'readonly', | ||||
|         'process': 'readonly', | ||||
|       }, | ||||
|     }, | ||||
|     'sourceType': 'module', | ||||
|     'babelOptions': { | ||||
|       'plugins': [ | ||||
|         '@babel/plugin-syntax-jsx', | ||||
|         '@babel/plugin-proposal-class-properties', | ||||
|     'plugins': { | ||||
|       'react': reactjs, | ||||
|       '@babel': babel, | ||||
|     }, | ||||
|     'rules': { | ||||
|       'indent': [ | ||||
|         'error', | ||||
|         2, | ||||
|       ], | ||||
|     }, | ||||
|   }, | ||||
|   'plugins': [ | ||||
|     'react', | ||||
|     '@babel', | ||||
|     'jest' | ||||
|   ], | ||||
|   'overrides': [ | ||||
|     { | ||||
|       'files': ['**/*.{ts,tsx}'], | ||||
|       'plugins': [ | ||||
|         '@typescript-eslint', | ||||
|       'linebreak-style': 0, | ||||
|       'quotes': [ | ||||
|         'error', | ||||
|         'single', | ||||
|       ], | ||||
|       'extends': ['eslint:recommended', 'plugin:@typescript-eslint/recommended', 'plugin:@typescript-eslint/eslint-recommended'], | ||||
|       'parser': '@typescript-eslint/parser', | ||||
|       'rules': { | ||||
|         '@typescript-eslint/no-explicit-any': ['off'], | ||||
|         '@typescript-eslint/no-this-alias': ['off'], | ||||
|       } | ||||
|       'semi': [ | ||||
|         'error', | ||||
|         'always', | ||||
|       ], | ||||
|       'comma-dangle': [ | ||||
|         'error', | ||||
|         'only-multiline', | ||||
|       ], | ||||
|       'no-console': ['error', { allow: ['warn', 'error'] }], | ||||
|       // We need to exclude below for RegEx case | ||||
|       'no-useless-escape': 'off', | ||||
|       'no-prototype-builtins': 'off', | ||||
|       'no-global-assign': 'off', | ||||
|       'no-import-assign': 'off', | ||||
|       'react/jsx-uses-vars': 'error', | ||||
|       'react/jsx-uses-react': 'error' | ||||
|     }, | ||||
|     { | ||||
|       'files': ['**/*{spec,test}.{js,jsx}', './regression/javascript/**/*.{js}'], | ||||
|       'extends': ['eslint:recommended'], | ||||
|       'env': { | ||||
|         'jest': true | ||||
|       } | ||||
|     }, | ||||
|   ], | ||||
|   'globals': { | ||||
|     '_': true, | ||||
|     'module': true, | ||||
|     '__dirname': true, | ||||
|     'global': true, | ||||
|     'jest': true | ||||
|   }, | ||||
|   'rules': { | ||||
|     'indent': [ | ||||
|       'error', | ||||
|       2, | ||||
|     ], | ||||
|     'linebreak-style': 0, | ||||
|     'quotes': [ | ||||
|       'error', | ||||
|       'single', | ||||
|     ], | ||||
|     'semi': [ | ||||
|       'error', | ||||
|       'always', | ||||
|     ], | ||||
|     'comma-dangle': [ | ||||
|       'error', | ||||
|       'only-multiline', | ||||
|     ], | ||||
|     'no-console': ['error', { allow: ['warn', 'error'] }], | ||||
|     // We need to exclude below for RegEx case | ||||
|     'no-useless-escape': 0, | ||||
|     'no-prototype-builtins': 0, | ||||
|     'no-global-assign': 0, | ||||
|     'no-import-assign': 0, | ||||
|   }, | ||||
|   'settings': { | ||||
|     'react': { | ||||
|       'version': 'detect', | ||||
|     'settings': { | ||||
|       'react': { | ||||
|         'version': 'detect', | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
|   { | ||||
|     'files': ['**/*.{ts,tsx}'], | ||||
|     languageOptions: { | ||||
|       'parser': ts.parser, | ||||
|     }, | ||||
|     'plugins': { | ||||
|       '@typescript-eslint': ts.plugin, | ||||
|     }, | ||||
|     'rules': { | ||||
|       'no-unused-vars': 'off', | ||||
|       'no-undef': 'off', | ||||
|       '@typescript-eslint/no-unused-vars': ['error'], | ||||
|       '@typescript-eslint/no-explicit-any': ['off'], | ||||
|       '@typescript-eslint/no-this-alias': ['off'], | ||||
|     } | ||||
|   }, | ||||
|   { | ||||
|     'files': ['**/*{spec,test}.{js,jsx}', './regression/javascript/**/*.{js}'], | ||||
|     ...jest.configs['flat/recommended'], | ||||
|     rules: { | ||||
|       ...jest.configs['flat/recommended'].rules, | ||||
|       'jest/prefer-expect-assertions': 'off', | ||||
|       'jest/expect-expect': 'off', | ||||
|       'jest/no-identical-title': 'off', | ||||
|       'jest/no-done-callback': 'off', | ||||
|       'jest/no-conditional-expect': 'off', | ||||
|       'jest/valid-title': 'off', | ||||
|     }, | ||||
|   } | ||||
| ]; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user