Last active
October 9, 2024 03:43
-
-
Save 1natsu172/a65a4b45faed2bd3fa74b24163e4256e to your computer and use it in GitHub Desktop.
My airbnb based ESLint config for "typescript-eslint" with React & prettier
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{ | |
"parser": "@typescript-eslint/parser", | |
"parserOptions": { | |
"project": "./tsconfig.json", | |
"tsconfigRootDir": "." | |
}, | |
"env": { | |
"browser": true, | |
"jest/globals": true | |
}, | |
"plugins": ["@typescript-eslint", "react-hooks", "jest", "prettier"], | |
"extends": [ | |
"airbnb", | |
"plugin:@typescript-eslint/recommended", | |
"plugin:import/typescript", | |
"plugin:prettier/recommended", | |
"prettier/@typescript-eslint" | |
], | |
"rules": { | |
/** | |
* @description rules of eslint official | |
*/ | |
/** | |
* @bug https://github.com/benmosher/eslint-plugin-import/issues/1282 | |
* "import/named" temporary disable. | |
*/ | |
"import/named": "off", | |
/** | |
* @bug? | |
* "import/export" temporary disable. | |
*/ | |
"import/export": "off", | |
"import/prefer-default-export": "off", // Allow single Named-export | |
"no-unused-expressions": ["warn", { | |
"allowShortCircuit": true, | |
"allowTernary": true | |
}], // https://eslint.org/docs/rules/no-unused-expressions | |
/** | |
* @description rules of @typescript-eslint | |
*/ | |
"@typescript-eslint/prefer-interface": "off", // also want to use "type" | |
"@typescript-eslint/explicit-function-return-type": "off", // annoying to force return type | |
/** | |
* @description rules of eslint-plugin-react | |
*/ | |
"react/jsx-filename-extension": ["warn", { | |
"extensions": [".jsx", ".tsx"] | |
}], // also want to use with ".tsx" | |
"react/prop-types": "off", // Is this incompatible with TS props type? | |
/** | |
* @description rules of eslint-plugin-react-hooks | |
*/ | |
"react-hooks/rules-of-hooks": "error", | |
/** | |
* @description rules of eslint-plugin-prettier | |
*/ | |
"prettier/prettier": [ | |
"error", { | |
"singleQuote": true, | |
"semi": false | |
} | |
] | |
} | |
} |
WRT react/prop-types
, they recommend that you use both TS types and prop-types: jsx-eslint/eslint-plugin-react#2275
I am trying to use a react like custom library. How can make changes for that?
remove eslint-plugin-{react,react-hooks}
and related react rules.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Thanks for sharing!