Angular 10 EsLintrc
This is part of Githooks Project Automation.
Before writting this, be sure to have installed @angular-eslint/schematics and prettier.
Follow the guide here
Run this whole script in the terminal to generate an .estlintrc that is configured for Angular.
cat > .eslintrc.js <<EOL
module.exports = {
/**
* See packages/eslint-plugin/src/configs/README.md
* for what this recommended config contains.
*/
env: {
es6: true,
browser: true,
node: true,
},
extends: ['plugin:@angular-eslint/recommended'],
rules: {
// ORIGINAL tslint.json -> "directive-selector": [true, "attribute", "app", "camelCase"],
'@angular-eslint/directive-selector': [
'error',
{ type: 'attribute', prefix: 'app', style: 'camelCase' },
],
// ORIGINAL tslint.json -> "component-selector": [true, "element", "app", "kebab-case"],
'@angular-eslint/component-selector': [
'error',
{ type: 'element', prefix: 'app', style: 'kebab-case' },
],
},
overrides: [
{
files: ['*.html'],
rules: {
'max-len': 'off'
}
},
/**
* This extra piece of configuration is only necessary if you make use of inline
* templates within Component metadata, e.g.:
*/
{
files: ['*.component.ts'],
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaVersion: 2020,
sourceType: 'module',
},
plugins: ['@angular-eslint/template'],
processor: '@angular-eslint/template/extract-inline-html',
},
// Custom rules for TypeScript
{
files: ['*.ts'],
extends: [
'airbnb-typescript/base',
'prettier/@typescript-eslint',
'plugin:prettier/recommended',
],
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaVersion: 2020,
sourceType: 'module',
},
rules: {
'import/no-unresolved': 'off',
'import/prefer-default-export': 'off',
'class-methods-use-this': 'off',
'lines-between-class-members': 'off',
'@typescript-eslint/unbound-method': [
'error',
{
ignoreStatic: true,
},
],
},
},
// Configuration for unit and e2e spec files
{
files: ['*.spec.ts'],
rules: {
'@typescript-eslint/no-unused-vars': 'off',
},
},
{
files: ['src/**/*.spec.ts', 'src/**/*.d.ts'],
parserOptions: {
project: './tsconfig.spec.json',
},
extends: ['plugin:jasmine/recommended'],
plugins: ['jasmine'],
env: { jasmine: true },
},
{
files: ['e2e/**/*.e2e-spec.ts', 'e2e/**/*.po.ts'],
parserOptions: {
project: './e2e/tsconfig.json',
},
extends: ['plugin:protractor/recommended'],
plugins: ['protractor'],
rules: {
'import/no-extraneous-dependencies': ['error', { devDependencies: true }],
},
},
],
};
EOL