mirror of
				https://github.com/theoludwig/eslint-config-conventions.git
				synced 2025-10-21 07:35:11 +02:00 
			
		
		
		
	Compare commits
	
		
			12 Commits
		
	
	
		
			v20.1.2
			...
			e59d48f713
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| e59d48f713 | |||
| b2f5a136f9 | |||
| fa724b4f97 | |||
| 1b70b62de1 | |||
| 09493ef433 | |||
| a13aeadda8 | |||
| 5817503919 | |||
| 23bb31949d | |||
| 911fadcf02 | |||
| 2d8260472a | |||
| 929978af36 | |||
| 6f42dbcdbe | 
							
								
								
									
										4
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							| @@ -10,10 +10,10 @@ jobs: | |||||||
|   lint: |   lint: | ||||||
|     runs-on: "ubuntu-latest" |     runs-on: "ubuntu-latest" | ||||||
|     steps: |     steps: | ||||||
|       - uses: "actions/checkout@v4.2.2" |       - uses: "actions/checkout@v5.0.0" | ||||||
|  |  | ||||||
|       - name: "Setup Node.js" |       - name: "Setup Node.js" | ||||||
|         uses: "actions/setup-node@v4.2.0" |         uses: "actions/setup-node@v5.0.0" | ||||||
|         with: |         with: | ||||||
|           node-version: "lts/*" |           node-version: "lts/*" | ||||||
|           cache: "npm" |           cache: "npm" | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -13,13 +13,13 @@ jobs: | |||||||
|       pull-requests: "write" |       pull-requests: "write" | ||||||
|       id-token: "write" |       id-token: "write" | ||||||
|     steps: |     steps: | ||||||
|       - uses: "actions/checkout@v4.2.2" |       - uses: "actions/checkout@v5.0.0" | ||||||
|         with: |         with: | ||||||
|           fetch-depth: 0 |           fetch-depth: 0 | ||||||
|           persist-credentials: false |           persist-credentials: false | ||||||
|  |  | ||||||
|       - name: "Setup Node.js" |       - name: "Setup Node.js" | ||||||
|         uses: "actions/setup-node@v4.2.0" |         uses: "actions/setup-node@v5.0.0" | ||||||
|         with: |         with: | ||||||
|           node-version: "lts/*" |           node-version: "lts/*" | ||||||
|           cache: "npm" |           cache: "npm" | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -10,10 +10,10 @@ jobs: | |||||||
|   test: |   test: | ||||||
|     runs-on: "ubuntu-latest" |     runs-on: "ubuntu-latest" | ||||||
|     steps: |     steps: | ||||||
|       - uses: "actions/checkout@v4.2.2" |       - uses: "actions/checkout@v5.0.0" | ||||||
|  |  | ||||||
|       - name: "Setup Node.js" |       - name: "Setup Node.js" | ||||||
|         uses: "actions/setup-node@v4.2.0" |         uses: "actions/setup-node@v5.0.0" | ||||||
|         with: |         with: | ||||||
|           node-version: "lts/*" |           node-version: "lts/*" | ||||||
|           cache: "npm" |           cache: "npm" | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "$schema": "./node_modules/oxlint/configuration_schema.json", |   "$schema": "./node_modules/oxlint/configuration_schema.json", | ||||||
|   "plugins": ["typescript", "unicorn", "react", "oxc", "jsx-a11y", "promise"], |   "plugins": ["typescript", "unicorn", "react", "oxc", "import", "promise"], | ||||||
|   "categories": { |   "categories": { | ||||||
|     "correctness": "error", |     "correctness": "error", | ||||||
|     "perf": "error", |     "perf": "error", | ||||||
| @@ -137,6 +137,7 @@ | |||||||
|     ], |     ], | ||||||
|     "no-useless-call": "error", |     "no-useless-call": "error", | ||||||
|     "no-useless-concat": "error", |     "no-useless-concat": "error", | ||||||
|  |     "no-useless-computed-key": "error", | ||||||
|     "no-useless-constructor": "error", |     "no-useless-constructor": "error", | ||||||
|     "no-useless-escape": "error", |     "no-useless-escape": "error", | ||||||
|     "no-useless-rename": "error", |     "no-useless-rename": "error", | ||||||
| @@ -192,6 +193,9 @@ | |||||||
|     "unicorn/no-unnecessary-array-flat-depth": "error", |     "unicorn/no-unnecessary-array-flat-depth": "error", | ||||||
|     "unicorn/consistent-assert": "error", |     "unicorn/consistent-assert": "error", | ||||||
|     "unicorn/no-accessor-recursion": "error", |     "unicorn/no-accessor-recursion": "error", | ||||||
|  |     "unicorn/no-array-reverse": "off", | ||||||
|  |     "unicorn/no-array-sort": "off", | ||||||
|  |     "react/no-array-index-key": "off", | ||||||
|     "react-hooks/rules-of-hooks": "error", |     "react-hooks/rules-of-hooks": "error", | ||||||
|     "react-hooks/exhaustive-deps": "error", |     "react-hooks/exhaustive-deps": "error", | ||||||
|     "react/jsx-key": "error", |     "react/jsx-key": "error", | ||||||
| @@ -239,13 +243,24 @@ | |||||||
|     "@next/next/no-document-import-in-page": "error", |     "@next/next/no-document-import-in-page": "error", | ||||||
|     "@next/next/no-duplicate-head": "error", |     "@next/next/no-duplicate-head": "error", | ||||||
|     "@next/next/no-head-import-in-document": "error", |     "@next/next/no-head-import-in-document": "error", | ||||||
|     "@next/next/no-script-component-in-head": "error" |     "@next/next/no-script-component-in-head": "error", | ||||||
|  |     "import-x/no-absolute-path": "error", | ||||||
|  |     "import-x/no-webpack-loader-syntax": "error", | ||||||
|  |     "import-x/no-self-import": "error", | ||||||
|  |     "import-x/no-duplicates": "error", | ||||||
|  |     "import-x/no-named-default": "error", | ||||||
|  |     "import-x/no-empty-named-blocks": "error", | ||||||
|  |     "import-x/no-anonymous-default-export": "error", | ||||||
|  |     "import-x/consistent-type-specifier-style": ["error", "prefer-top-level"], | ||||||
|  |     "import-x/no-unassigned-import": "off", | ||||||
|  |     "import-x/no-named-as-default-member": "off" | ||||||
|   }, |   }, | ||||||
|   "overrides": [ |   "overrides": [ | ||||||
|     { |     { | ||||||
|       "files": ["**/*.ts", "**/*.tsx"], |       "files": ["**/*.ts", "**/*.tsx"], | ||||||
|       "rules": { |       "rules": { | ||||||
|         "@typescript-eslint/no-unnecessary-type-arguments": "off", |         "@typescript-eslint/no-unnecessary-type-arguments": "off", | ||||||
|  |         "@typescript-eslint/no-unsafe-type-assertion": "off", | ||||||
|         "no-unused-vars": [ |         "no-unused-vars": [ | ||||||
|           "error", |           "error", | ||||||
|           { |           { | ||||||
| @@ -295,7 +310,7 @@ | |||||||
|           } |           } | ||||||
|         ], |         ], | ||||||
|         "@typescript-eslint/no-base-to-string": "error", |         "@typescript-eslint/no-base-to-string": "error", | ||||||
|         "@typescript-eslint/no-dynamic-delete": "error", |         "@typescript-eslint/no-dynamic-delete": "off", | ||||||
|         "@typescript-eslint/no-extra-non-null-assertion": "error", |         "@typescript-eslint/no-extra-non-null-assertion": "error", | ||||||
|         "@typescript-eslint/no-redundant-type-constituents": "error", |         "@typescript-eslint/no-redundant-type-constituents": "error", | ||||||
|         "@typescript-eslint/no-extraneous-class": [ |         "@typescript-eslint/no-extraneous-class": [ | ||||||
|   | |||||||
| @@ -35,9 +35,9 @@ More information about **formatting rules** vs **code-quality rules** can be fou | |||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| npm install --save-dev \ | npm install --save-dev \ | ||||||
|   eslint@^9.21.0 \ |   eslint@^9.22.0 \ | ||||||
|   eslint-plugin-promise@^7.2.1 \ |   eslint-plugin-promise@^7.2.1 \ | ||||||
|   eslint-plugin-unicorn@^59.0.0 \ |   eslint-plugin-unicorn@^61.0.0 \ | ||||||
|   eslint-plugin-import-x@^4.6.1 \ |   eslint-plugin-import-x@^4.6.1 \ | ||||||
|   globals@^16.0.0 \ |   globals@^16.0.0 \ | ||||||
|   typescript@^5.8.3 \ |   typescript@^5.8.3 \ | ||||||
| @@ -62,10 +62,10 @@ Dependencies are: | |||||||
| #### `eslint.config.js` | #### `eslint.config.js` | ||||||
|  |  | ||||||
| ```js | ```js | ||||||
| import typescriptESLint from "typescript-eslint" | import { defineConfig } from "eslint/config" | ||||||
| import configConventions from "eslint-config-conventions" | import configConventions from "eslint-config-conventions" | ||||||
|  |  | ||||||
| export default typescriptESLint.config(...configConventions, { | export default defineConfig(...configConventions, { | ||||||
|   files: ["**/*.ts", "**/*.tsx"], |   files: ["**/*.ts", "**/*.tsx"], | ||||||
|   languageOptions: { |   languageOptions: { | ||||||
|     parser: typescriptESLint.parser, |     parser: typescriptESLint.parser, | ||||||
|   | |||||||
| @@ -1,16 +1,17 @@ | |||||||
|  | import importXPlugin from "eslint-plugin-import-x" | ||||||
| import promise from "eslint-plugin-promise" | import promise from "eslint-plugin-promise" | ||||||
| import unicorn from "eslint-plugin-unicorn" | import unicorn from "eslint-plugin-unicorn" | ||||||
| import importX from "eslint-plugin-import-x" | import { defineConfig } from "eslint/config" | ||||||
| import globals from "globals" | import globals from "globals" | ||||||
| import typescriptESLint from "typescript-eslint" | import typescriptESLint from "typescript-eslint" | ||||||
|  |  | ||||||
| export default typescriptESLint.config( | export default defineConfig( | ||||||
|   { |   { | ||||||
|     name: "eslint-config-conventions", |     name: "eslint-config-conventions", | ||||||
|     plugins: { |     plugins: { | ||||||
|       promise, |       promise, | ||||||
|       unicorn, |       unicorn, | ||||||
|       "import-x": importX, |       "import-x": importXPlugin, | ||||||
|     }, |     }, | ||||||
|     linterOptions: { |     linterOptions: { | ||||||
|       reportUnusedDisableDirectives: "error", |       reportUnusedDisableDirectives: "error", | ||||||
| @@ -349,8 +350,6 @@ export default typescriptESLint.config( | |||||||
|       "no-useless-constructor": "off", |       "no-useless-constructor": "off", | ||||||
|       "@typescript-eslint/no-useless-constructor": "error", |       "@typescript-eslint/no-useless-constructor": "error", | ||||||
|  |  | ||||||
|       "@typescript-eslint/no-unnecessary-type-conversion": "error", |  | ||||||
|  |  | ||||||
|       "@typescript-eslint/no-unnecessary-template-expression": "error", |       "@typescript-eslint/no-unnecessary-template-expression": "error", | ||||||
|       "@typescript-eslint/adjacent-overload-signatures": "error", |       "@typescript-eslint/adjacent-overload-signatures": "error", | ||||||
|  |  | ||||||
| @@ -386,7 +385,6 @@ export default typescriptESLint.config( | |||||||
|  |  | ||||||
|       "@typescript-eslint/no-base-to-string": "error", |       "@typescript-eslint/no-base-to-string": "error", | ||||||
|       "@typescript-eslint/no-deprecated": "error", |       "@typescript-eslint/no-deprecated": "error", | ||||||
|       "@typescript-eslint/no-dynamic-delete": "error", |  | ||||||
|       "@typescript-eslint/no-extra-non-null-assertion": "error", |       "@typescript-eslint/no-extra-non-null-assertion": "error", | ||||||
|       "@typescript-eslint/no-redundant-type-constituents": "error", |       "@typescript-eslint/no-redundant-type-constituents": "error", | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| import typescriptESLint from "typescript-eslint" | import { defineConfig } from "eslint/config" | ||||||
| import configConventions from "./eslint.config.js" | import configConventions from "./eslint.config.js" | ||||||
|  |  | ||||||
| export default typescriptESLint.config(...configConventions, { | export default defineConfig(...configConventions, { | ||||||
|   ignores: ["test/fixtures/*"], |   ignores: ["test/fixtures/*"], | ||||||
| }) | }) | ||||||
|   | |||||||
							
								
								
									
										8
									
								
								index.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								index.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -1,7 +1,5 @@ | |||||||
| import type typescriptESLint from "typescript-eslint" | import type { defineConfig } from "eslint/config" | ||||||
|  |  | ||||||
| declare const eslintConfigConventions: ReturnType< | declare const eslintConfig: ReturnType<typeof defineConfig> | ||||||
|   typeof typescriptESLint.config |  | ||||||
| > |  | ||||||
|  |  | ||||||
| export default eslintConfigConventions | export default eslintConfig | ||||||
|   | |||||||
							
								
								
									
										967
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										967
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										22
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								package.json
									
									
									
									
									
								
							| @@ -47,9 +47,9 @@ | |||||||
|     "release": "semantic-release" |     "release": "semantic-release" | ||||||
|   }, |   }, | ||||||
|   "peerDependencies": { |   "peerDependencies": { | ||||||
|     "eslint": "^9.21.0", |     "eslint": "^9.22.0", | ||||||
|     "eslint-plugin-promise": "^7.2.1", |     "eslint-plugin-promise": "^7.2.1", | ||||||
|     "eslint-plugin-unicorn": "^59.0.0 || ^60.0.0", |     "eslint-plugin-unicorn": "^61.0.0", | ||||||
|     "eslint-plugin-import-x": "^4.6.1", |     "eslint-plugin-import-x": "^4.6.1", | ||||||
|     "globals": "^16.0.0", |     "globals": "^16.0.0", | ||||||
|     "typescript-eslint": "^8.32.0" |     "typescript-eslint": "^8.32.0" | ||||||
| @@ -75,18 +75,18 @@ | |||||||
|     } |     } | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@types/node": "24.3.0", |     "@types/node": "24.7.0", | ||||||
|     "globals": "16.3.0", |     "globals": "16.4.0", | ||||||
|     "editorconfig-checker": "6.1.0", |     "editorconfig-checker": "6.1.0", | ||||||
|     "oxlint": "1.13.0", |     "oxlint": "1.20.0", | ||||||
|     "@oxlint/migrate": "1.13.0", |     "@oxlint/migrate": "1.20.0", | ||||||
|     "eslint": "9.34.0", |     "eslint": "9.37.0", | ||||||
|     "eslint-plugin-promise": "7.2.1", |     "eslint-plugin-promise": "7.2.1", | ||||||
|     "eslint-plugin-unicorn": "60.0.0", |     "eslint-plugin-unicorn": "61.0.2", | ||||||
|     "eslint-plugin-import-x": "4.16.1", |     "eslint-plugin-import-x": "4.16.1", | ||||||
|     "typescript-eslint": "8.41.0", |     "typescript-eslint": "8.46.0", | ||||||
|     "prettier": "3.6.2", |     "prettier": "3.6.2", | ||||||
|     "semantic-release": "24.2.7", |     "semantic-release": "24.2.9", | ||||||
|     "typescript": "5.9.2" |     "typescript": "5.9.3" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user