mirror of
https://github.com/theoludwig/eslint-config-conventions.git
synced 2025-05-18 12:02:33 +02:00
Compare commits
13 Commits
v17.0.0-be
...
v18.0.0
Author | SHA1 | Date | |
---|---|---|---|
5e63c17030
|
|||
9d91c09bea
|
|||
e05233d429
|
|||
c4c1a7f5dd
|
|||
adb164f604
|
|||
8ae05c8bee
|
|||
ee4897153d
|
|||
67ff8e18b2
|
|||
d41573f12c
|
|||
8efe22c23e
|
|||
57f419c44a
|
|||
a578bb80ba
|
|||
e32847fa3d
|
8
.github/workflows/lint.yml
vendored
8
.github/workflows/lint.yml
vendored
@ -10,12 +10,12 @@ jobs:
|
|||||||
lint:
|
lint:
|
||||||
runs-on: "ubuntu-latest"
|
runs-on: "ubuntu-latest"
|
||||||
steps:
|
steps:
|
||||||
- uses: "actions/checkout@v4.2.0"
|
- uses: "actions/checkout@v4.2.2"
|
||||||
|
|
||||||
- name: "Setup Node.js"
|
- name: "Setup Node.js"
|
||||||
uses: "actions/setup-node@v4.0.4"
|
uses: "actions/setup-node@v4.1.0"
|
||||||
with:
|
with:
|
||||||
node-version: "22.x"
|
node-version: "lts/*"
|
||||||
cache: "npm"
|
cache: "npm"
|
||||||
|
|
||||||
- name: "Install dependencies"
|
- name: "Install dependencies"
|
||||||
@ -28,6 +28,6 @@ jobs:
|
|||||||
commitlint:
|
commitlint:
|
||||||
runs-on: "ubuntu-latest"
|
runs-on: "ubuntu-latest"
|
||||||
steps:
|
steps:
|
||||||
- uses: "actions/checkout@v4.2.0"
|
- uses: "actions/checkout@v4.2.2"
|
||||||
|
|
||||||
- uses: "wagoid/commitlint-github-action@v6.1.2"
|
- uses: "wagoid/commitlint-github-action@v6.1.2"
|
||||||
|
6
.github/workflows/release.yml
vendored
6
.github/workflows/release.yml
vendored
@ -13,15 +13,15 @@ jobs:
|
|||||||
pull-requests: "write"
|
pull-requests: "write"
|
||||||
id-token: "write"
|
id-token: "write"
|
||||||
steps:
|
steps:
|
||||||
- uses: "actions/checkout@v4.2.0"
|
- uses: "actions/checkout@v4.2.2"
|
||||||
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.0.4"
|
uses: "actions/setup-node@v4.1.0"
|
||||||
with:
|
with:
|
||||||
node-version: "22.x"
|
node-version: "lts/*"
|
||||||
cache: "npm"
|
cache: "npm"
|
||||||
|
|
||||||
- name: "Install dependencies"
|
- name: "Install dependencies"
|
||||||
|
6
.github/workflows/test.yml
vendored
6
.github/workflows/test.yml
vendored
@ -10,12 +10,12 @@ jobs:
|
|||||||
test:
|
test:
|
||||||
runs-on: "ubuntu-latest"
|
runs-on: "ubuntu-latest"
|
||||||
steps:
|
steps:
|
||||||
- uses: "actions/checkout@v4.2.0"
|
- uses: "actions/checkout@v4.2.2"
|
||||||
|
|
||||||
- name: "Setup Node.js"
|
- name: "Setup Node.js"
|
||||||
uses: "actions/setup-node@v4.0.4"
|
uses: "actions/setup-node@v4.1.0"
|
||||||
with:
|
with:
|
||||||
node-version: "22.x"
|
node-version: "lts/*"
|
||||||
cache: "npm"
|
cache: "npm"
|
||||||
|
|
||||||
- name: "Install dependencies"
|
- name: "Install dependencies"
|
||||||
|
21
README.md
21
README.md
@ -29,7 +29,7 @@ More information about **formatting rules** vs **code-quality rules** can be fou
|
|||||||
|
|
||||||
### Prerequisites
|
### Prerequisites
|
||||||
|
|
||||||
[Node.js](https://nodejs.org/) >= 20.9.0
|
[Node.js](https://nodejs.org/) >= 20.11.0
|
||||||
|
|
||||||
### Installation
|
### Installation
|
||||||
|
|
||||||
@ -40,8 +40,8 @@ npm install --save-dev \
|
|||||||
eslint-plugin-unicorn@^56.0.0 \
|
eslint-plugin-unicorn@^56.0.0 \
|
||||||
eslint-plugin-import-x@^4.3.1 \
|
eslint-plugin-import-x@^4.3.1 \
|
||||||
globals@^15.10.0 \
|
globals@^15.10.0 \
|
||||||
"typescript@~5.5.4" \
|
typescript@~5.5.4 \
|
||||||
"typescript-eslint@^8.8.0" \
|
typescript-eslint@^8.8.0 \
|
||||||
eslint-config-conventions@latest
|
eslint-config-conventions@latest
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -59,13 +59,22 @@ Dependencies are:
|
|||||||
|
|
||||||
### Configuration
|
### Configuration
|
||||||
|
|
||||||
#### `eslint.config.js` (JavaScript and TypeScript)
|
#### `eslint.config.js`
|
||||||
|
|
||||||
```js
|
```js
|
||||||
import typescriptESLint from "typescript-eslint"
|
import typescriptESLint from "typescript-eslint"
|
||||||
import eslintConfigConventions from "eslint-config-conventions"
|
import configConventions from "eslint-config-conventions"
|
||||||
|
|
||||||
export default typescriptESLint.config(...eslintConfigConventions)
|
export default typescriptESLint.config(...configConventions, {
|
||||||
|
files: ["**/*.ts", "**/*.tsx"],
|
||||||
|
languageOptions: {
|
||||||
|
parser: typescriptESLint.parser,
|
||||||
|
parserOptions: {
|
||||||
|
projectService: true,
|
||||||
|
tsconfigRootDir: import.meta.dirname,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Configuration with [Prettier](https://prettier.io/) (recommended)
|
#### Configuration with [Prettier](https://prettier.io/) (recommended)
|
||||||
|
@ -79,7 +79,13 @@ export default typescriptESLint.config(
|
|||||||
"no-unused-vars": [
|
"no-unused-vars": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
|
args: "all",
|
||||||
|
argsIgnorePattern: "^_",
|
||||||
|
caughtErrors: "all",
|
||||||
|
caughtErrorsIgnorePattern: "^_",
|
||||||
|
destructuredArrayIgnorePattern: "^_",
|
||||||
varsIgnorePattern: "^_",
|
varsIgnorePattern: "^_",
|
||||||
|
ignoreRestSiblings: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
"no-use-before-define": [
|
"no-use-before-define": [
|
||||||
@ -216,7 +222,6 @@ export default typescriptESLint.config(
|
|||||||
|
|
||||||
"unicorn/better-regex": "error",
|
"unicorn/better-regex": "error",
|
||||||
"unicorn/catch-error-name": "error",
|
"unicorn/catch-error-name": "error",
|
||||||
"unicorn/consistent-destructuring": "error",
|
|
||||||
"unicorn/custom-error-definition": "error",
|
"unicorn/custom-error-definition": "error",
|
||||||
"unicorn/error-message": "error",
|
"unicorn/error-message": "error",
|
||||||
"unicorn/escape-case": "error",
|
"unicorn/escape-case": "error",
|
||||||
@ -273,19 +278,25 @@ export default typescriptESLint.config(
|
|||||||
|
|
||||||
rules: {
|
rules: {
|
||||||
"no-undef": "off",
|
"no-undef": "off",
|
||||||
|
|
||||||
"no-dupe-class-members": "off",
|
"no-dupe-class-members": "off",
|
||||||
"@typescript-eslint/no-dupe-class-members": "error",
|
"@typescript-eslint/no-dupe-class-members": "error",
|
||||||
"no-unused-vars": "off",
|
|
||||||
|
|
||||||
|
"no-unused-vars": "off",
|
||||||
"@typescript-eslint/no-unused-vars": [
|
"@typescript-eslint/no-unused-vars": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
|
args: "all",
|
||||||
|
argsIgnorePattern: "^_",
|
||||||
|
caughtErrors: "all",
|
||||||
|
caughtErrorsIgnorePattern: "^_",
|
||||||
|
destructuredArrayIgnorePattern: "^_",
|
||||||
varsIgnorePattern: "^_",
|
varsIgnorePattern: "^_",
|
||||||
|
ignoreRestSiblings: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
|
||||||
"no-use-before-define": "off",
|
"no-use-before-define": "off",
|
||||||
|
|
||||||
"@typescript-eslint/no-use-before-define": [
|
"@typescript-eslint/no-use-before-define": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
@ -299,12 +310,14 @@ export default typescriptESLint.config(
|
|||||||
|
|
||||||
"default-param-last": "off",
|
"default-param-last": "off",
|
||||||
"@typescript-eslint/default-param-last": "error",
|
"@typescript-eslint/default-param-last": "error",
|
||||||
|
|
||||||
"no-array-constructor": "off",
|
"no-array-constructor": "off",
|
||||||
"@typescript-eslint/no-array-constructor": "error",
|
"@typescript-eslint/no-array-constructor": "error",
|
||||||
|
|
||||||
"no-implied-eval": "off",
|
"no-implied-eval": "off",
|
||||||
"@typescript-eslint/no-implied-eval": "error",
|
"@typescript-eslint/no-implied-eval": "error",
|
||||||
"no-redeclare": "off",
|
|
||||||
|
|
||||||
|
"no-redeclare": "off",
|
||||||
"@typescript-eslint/no-redeclare": [
|
"@typescript-eslint/no-redeclare": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
@ -314,8 +327,8 @@ export default typescriptESLint.config(
|
|||||||
|
|
||||||
"no-throw-literal": "off",
|
"no-throw-literal": "off",
|
||||||
"@typescript-eslint/only-throw-error": "error",
|
"@typescript-eslint/only-throw-error": "error",
|
||||||
"no-unused-expressions": "off",
|
|
||||||
|
|
||||||
|
"no-unused-expressions": "off",
|
||||||
"@typescript-eslint/no-unused-expressions": [
|
"@typescript-eslint/no-unused-expressions": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
@ -327,30 +340,18 @@ 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-template-expression": "error",
|
"@typescript-eslint/no-unnecessary-template-expression": "error",
|
||||||
|
|
||||||
"@typescript-eslint/no-unnecessary-condition": [
|
|
||||||
"error",
|
|
||||||
{
|
|
||||||
allowConstantLoopConditions: true,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
"@typescript-eslint/adjacent-overload-signatures": "error",
|
"@typescript-eslint/adjacent-overload-signatures": "error",
|
||||||
|
|
||||||
"@typescript-eslint/array-type": [
|
|
||||||
"error",
|
|
||||||
{
|
|
||||||
default: "array-simple",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
"@typescript-eslint/no-unsafe-function-type": "error",
|
"@typescript-eslint/no-unsafe-function-type": "error",
|
||||||
"@typescript-eslint/no-wrapper-object-types": "error",
|
"@typescript-eslint/no-wrapper-object-types": "error",
|
||||||
"@typescript-eslint/consistent-type-definitions": ["error", "interface"],
|
"@typescript-eslint/consistent-type-definitions": ["error", "interface"],
|
||||||
|
|
||||||
"no-duplicate-imports": "off",
|
"no-duplicate-imports": "off",
|
||||||
"@typescript-eslint/consistent-type-imports": "error",
|
"@typescript-eslint/consistent-type-imports": "error",
|
||||||
|
|
||||||
|
"@typescript-eslint/explicit-member-accessibility": "error",
|
||||||
"@typescript-eslint/explicit-function-return-type": [
|
"@typescript-eslint/explicit-function-return-type": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
@ -425,6 +426,7 @@ export default typescriptESLint.config(
|
|||||||
"@typescript-eslint/prefer-reduce-type-parameter": "error",
|
"@typescript-eslint/prefer-reduce-type-parameter": "error",
|
||||||
"@typescript-eslint/prefer-return-this-type": "error",
|
"@typescript-eslint/prefer-return-this-type": "error",
|
||||||
"@typescript-eslint/promise-function-async": "error",
|
"@typescript-eslint/promise-function-async": "error",
|
||||||
|
|
||||||
"prefer-promise-reject-errors": "off",
|
"prefer-promise-reject-errors": "off",
|
||||||
"@typescript-eslint/prefer-promise-reject-errors": "error",
|
"@typescript-eslint/prefer-promise-reject-errors": "error",
|
||||||
|
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
// @ts-check
|
|
||||||
|
|
||||||
import typescriptESLint from "typescript-eslint"
|
import typescriptESLint from "typescript-eslint"
|
||||||
import eslintConfigConventions from "./eslint.config.js"
|
import configConventions from "./eslint.config.js"
|
||||||
|
|
||||||
export default typescriptESLint.config(...eslintConfigConventions, {
|
export default typescriptESLint.config(...configConventions, {
|
||||||
ignores: ["test/fixtures/*"],
|
ignores: ["test/fixtures/*"],
|
||||||
})
|
})
|
||||||
|
1773
package-lock.json
generated
1773
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
22
package.json
22
package.json
@ -34,7 +34,7 @@
|
|||||||
"provenance": true
|
"provenance": true
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=20.9.0"
|
"node": ">=20.11.0"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint:editorconfig": "editorconfig-checker",
|
"lint:editorconfig": "editorconfig-checker",
|
||||||
@ -54,16 +54,16 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/eslint__js": "8.42.3",
|
"@types/eslint__js": "8.42.3",
|
||||||
"@types/node": "22.7.4",
|
"@types/node": "22.10.2",
|
||||||
"globals": "15.10.0",
|
"globals": "15.13.0",
|
||||||
"editorconfig-checker": "6.0.0",
|
"editorconfig-checker": "6.0.0",
|
||||||
"eslint": "9.12.0",
|
"eslint": "9.17.0",
|
||||||
"eslint-plugin-promise": "7.1.0",
|
"eslint-plugin-promise": "7.2.1",
|
||||||
"eslint-plugin-unicorn": "56.0.0",
|
"eslint-plugin-unicorn": "56.0.1",
|
||||||
"eslint-plugin-import-x": "4.3.1",
|
"eslint-plugin-import-x": "4.5.0",
|
||||||
"typescript-eslint": "8.8.0",
|
"typescript-eslint": "8.18.0",
|
||||||
"prettier": "3.3.3",
|
"prettier": "3.4.2",
|
||||||
"semantic-release": "23.1.1",
|
"semantic-release": "24.2.0",
|
||||||
"typescript": "5.5.4"
|
"typescript": "5.7.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user