Security News
tea.xyz Spam Plagues npm and RubyGems Package Registries
Tea.xyz, a crypto project aimed at rewarding open source contributions, is once again facing backlash due to an influx of spam packages flooding public package registries.
eslint-plugin-maintainable
Advanced tools
Readme
This plugin focused on keeping the code clean, maintainable, and readable for humans. Because coders read existing code most of the times, cumbersome code will slow you down and lead to bugs.
This is achieved via rules like complexity
, sonarjs/cognitive-complexity
, max-params
, max-nested-callbacks
etc.
Also, line length is limited to 80 characters, so it's convinient to split and edit code side by side.
Also includes setup to format code with prettier
via eslint, so no hassle to set up those two.
Feel free to ask questions or propose improvements to "issues"
:star: if you like the the project :)
Need eslint 8+ and prettier 3+
npm i -D eslint@latest eslint-plugin-maintainable@latest prettier@latest
maintainable
to the plugins section of your .eslintrc
configuration file. You can omit the eslint-plugin-
prefix
{
"extends": [
"plugin:maintainable/recommended",
"plugin:maintainable/react",
"...your others configs"
],
"plugins": [
"maintainable"
"...your others plugins"
]
}
By default plugin intended to be used with Typescript, but can tune it for pure JS, just change parser to default "espree" or "@babel/eslint-parser".
"parser": "espree",
.editorconfig
, IDEs and prettier will format code according to itroot = true
[*]
end_of_line = lf
charset = utf-8
trim_trailing_whitespace = true
insert_final_newline = true
indent_style = space
indent_size = 2
quote_type = single
max_line_length = 80
package.json
eslint-plugin-compat
will tell you if you use api that not supported by browsers
"browserslist": [
"last 5 Chrome versions",
"last 5 ChromeAndroid versions",
"last 5 Firefox versions",
"last 5 FirefoxAndroid versions",
"Firefox ESR",
"last 3 Safari major versions",
"last 2 iOS major versions"
],
husky
and lint-staged
Install deps
npm i -D husky lint-staged
npx husky install
More details at lint-staged repo
Edit(or create) file pre-commit
in .husky
directory with this content:
#!/usr/bin/env sh
. "$(dirname -- "$0")/_/husky.sh"
npx lint-staged
And update package.json
"lint-staged": {
"*.{js,jsx,ts,tsx}": [
"eslint --fix",
],
"*.{html,css,less,ejs,json}": [
"prettier --write",
]
},
Name | Description | |
---|---|---|
✅ | base | Basic rules and prettier formatter |
✅ | recommended | Basic + more rules for Node and Browser |
✅ | react | Basic + React specific rules |
You can take a look at configs definitions
FAQs
Eslint config to keep code clean and in maintainable state
The npm package eslint-plugin-maintainable receives a total of 6 weekly downloads. As such, eslint-plugin-maintainable popularity was classified as not popular.
We found that eslint-plugin-maintainable demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Tea.xyz, a crypto project aimed at rewarding open source contributions, is once again facing backlash due to an influx of spam packages flooding public package registries.
Security News
As cyber threats become more autonomous, AI-powered defenses are crucial for businesses to stay ahead of attackers who can exploit software vulnerabilities at scale.
Security News
UnitedHealth Group disclosed that the ransomware attack on Change Healthcare compromised protected health information for millions in the U.S., with estimated costs to the company expected to reach $1 billion.