eslint-config/README.md
RingOfStorms (Joshua Bell) af0c093759 update to latests
2023-01-10 00:37:47 -06:00

102 lines
1.9 KiB
Markdown

# Eslint Config
# Notable linting rules
- No default exports
- No relative imports from other modules, imports must be exported in an index file
- Index files only contain imports/exports, no other code
# Usage
## base
Base is used for node/typescript and excludes react specific settings.
```
npm i @ringofstorms/eslint-config \
@typescript-eslint/eslint-plugin \
@typescript-eslint/parser \
eslint \
eslint-config-prettier \
eslint-import-resolver-typescript \
eslint-plugin-eslint-comments \
eslint-plugin-filenames \
eslint-plugin-import \
eslint-plugin-new-with-error \
eslint-plugin-prettier \
prettier \
--save-dev
```
In your .eslintrc
```
{
extends: ["@ringofstorms/eslint-config/base"],
}
```
## react
React is for react/typescript and is base + react specific settings.
```
npm i @ringofstorms/eslint-config \
@typescript-eslint/eslint-plugin \
@typescript-eslint/parser \
eslint \
eslint-config-prettier \
eslint-config-react \
eslint-import-resolver-typescript \
eslint-plugin-css-modules \
eslint-plugin-eslint-comments \
eslint-plugin-filenames \
eslint-plugin-import \
eslint-plugin-new-with-error \
eslint-plugin-prettier \
eslint-plugin-react \
eslint-plugin-react-hooks \
prettier \
--save-dev
```
In your .eslintrc
```
{
extends: ["@ringofstorms/eslint-config/react"],
}
```
## prettier settings
Create `prettier.config.js` file in root of project with this content:
```
module.exports = require('@ringofstorms/eslint-config').prettierConfig;
```
# Common rule overrides
```
{
rules: {
// This will differ for every project and may not even need any settings
"import/no-internal-modules": ["error", {
allow: ["rxjs/**", "uuid/**", "@nestjs/**"]
}],
},
}
```
# Contributing
## Packing
`npm pack`
## publishing
if not already done `npm login`
`npm publish --access public`