Spice up your editor with tools that make conforming to styleguides fun and easy!
Check the following files in the project, along with package defaults (ie prettier has 80 char default max-len) to determine the conventions
- tslint.json
- tsconfig.json
- .eslintrc.json
- .prettierrc
- .jsbeautifyrc
- .scss-lint.yml
- setup.cfg
NOTE: several of these files are overridden by atom config, but useful for commandline calls, and should reflect atom config
prettier --write "**/*"
js-beautify -r --config .jsbeautifyrc **/*.html
scss-lint -c .scss-lint.yml **/*.scss
Note this will only output issues and not modify files.
autopep8 --in-place -a **/*.py
Note this uses level 1 aggressive so make sure to reflect that in your editor config.
npm install eslint-plugin-html eslint-config-prettier eslint-plugin-prettier tslint-config-prettier --dev
or
yarn add eslint-plugin-html eslint-config-prettier eslint-plugin-prettier tslint-config-prettier --dev
which node
should = /usr/local/bin/node
nvm deactivate
npm install -g typescript eslint tslint prettier eslint-plugin-html eslint-config-prettier eslint-plugin-prettier tslint-config-prettier js-beautify
check globally installed modules to verify the above
npm list --depth=0 -g
gem install scss_lint
apm install linter linter-eslint linter-tslint prettier-atom linter-scss-lint linter-json-lint atom-beautify
- HTML
- default beautifier: JS Beautify
- beautify_on_save: true
- end_with_newline: true
- wrap_attributes: "force-aligned"
- scss
- convert_quotes: "single"
- default_beautifier: "Prettier"
- disable when no eslint found
- lint html files
- show rule id in message
- use global eslint installation
- globalNodePath: "/usr/local"
- try to use project tslint
- use global tslint install
- eslint integration
- editor config integration
- format on save (all 3)
- only format if a prettier config file is found
- disable when no eslint found
- allow comments
- https://github.com/Microsoft/vscode-eslint
- https://github.com/prettier/prettier-vscode
- https://github.com/Microsoft/vscode-tslint
- https://github.com/HookyQR/VSCodeBeautify
"[javascriptreact]": {
"editor.rulers": [100],
"editor.formatOnSave": true
},
"[javascript]": {
"editor.rulers": [100],
"editor.formatOnSave": true
},
"[typescript]": {
"editor.rulers": [100],
"editor.formatOnSave": true
},
"[html]": {
"editor.formatOnSave": true
},
"[scss]": {
"editor.formatOnSave": true
},
"prettier.requireConfig": true, // Only run Prettier if a config exists in project
"prettier.eslintIntegration": true, // Configure Prettier with eslint config if present
"prettier.tslintIntegration": true, // Configure Prettier with tslint config if present
"beautify.ignore": ["**/*.scss"], // Use Prettier for scss instead
"python.formatting.autopep8Args": ["--aggressive"] // Use level 1 agressiveness when reformatting python
Install 2 extensions
(Ctrl+P): ext install Cardinal90.multi-cursor-case-preserve
(Ctrl+P): ext install vilicvane.sensitive-replace
Edit keybindings.json
[
{
"key": "f4",
"when": "!editorHasSelection",
"command": "actions.find"
},
{
"key": "ctrl+f",
"when": "!editorHasSelection",
"command": "actions.find"
},
{
"key": "f4",
"when": "editorHasSelection",
"command": "editor.action.selectHighlights"
},
{
"key": "ctrl+f",
"when": "editorHasSelection",
"command": "editor.action.selectHighlights"
},
{
"key": "f2",
"when": "!editorHasSelection",
"command": "editor.action.startFindReplaceAction"
},
{
"key": "ctrl+r",
"when": "!editorHasSelection",
"command": "editor.action.startFindReplaceAction"
},
{
"key": "f2",
"when": "editorHasSelection",
"command": "editor.action.replaceOne"
},
{
"key": "ctrl+r",
"when": "editorHasSelection",
"command": "editor.action.replaceOne"
},
{
"key": "f2",
"when": "editorHasMultipleSelections",
"command": "sensitive.replace"
},
{
"key": "ctrl+r",
"when": "editorHasMultipleSelections",
"command": "sensitive.replace"
},
{
"key": "ctrl+tab",
"command": "workbench.action.nextEditor"
},
{
"key": "ctrl+shift+tab",
"command": "workbench.action.previousEditor"
}
]
Tidbits for other environments (WIP)...
For sublime or IDE agnostic auto linting, install and setup the onchange package to watch for file changes like so:
https://prettier.io/docs/en/watching-files.html