UNPKG

eslint-config-zillow-typescript

Version:

Zillow's ESLint config for TypeScript, following our code conventions

364 lines (303 loc) 15.9 kB
/** * Exhaustive list (duplicates removed) * @see https://github.com/typescript-eslint/typescript-eslint/blob/39c45f3/packages/eslint-plugin/src/configs/all.ts#L8-L143 */ /* // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/RULE_NAME.md '@typescript-eslint/RULE_NAME': 'error', */ module.exports = { rules: { // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/array-type.md '@typescript-eslint/array-type': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/ban-tslint-comment.md '@typescript-eslint/ban-tslint-comment': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/class-literal-property-style.md '@typescript-eslint/class-literal-property-style': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/consistent-type-assertions.md '@typescript-eslint/consistent-type-assertions': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/consistent-type-definitions.md '@typescript-eslint/consistent-type-definitions': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/consistent-type-imports.md '@typescript-eslint/consistent-type-imports': [ 'error', { prefer: 'type-imports', disallowTypeAnnotations: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/default-param-last.md // TODO: enable when it is configurable (breaks valid redux reducers) 'default-param-last': 'off', '@typescript-eslint/default-param-last': 'off', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/dot-notation.md 'dot-notation': 'off', '@typescript-eslint/dot-notation': [ 'error', { allowKeywords: true, allowPrivateClassPropertyAccess: false, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/explicit-function-return-type.md '@typescript-eslint/explicit-function-return-type': 'off', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/explicit-member-accessibility.md '@typescript-eslint/explicit-member-accessibility': [ 'error', { accessibility: 'no-public', }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/init-declarations.md 'init-declarations': 'off', '@typescript-eslint/init-declarations': [ 'error', 'never', // allows `const bar = 'stuff';` // enforces `let foo;` // as the only time we should be using `let` // is for conditional assignment { // allows `for (let i = 0; i < 1; i += 1) {}` ignoreForLoopInit: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/lines-between-class-members.md 'lines-between-class-members': 'off', '@typescript-eslint/lines-between-class-members': [ 'error', 'always', { exceptAfterSingleLine: false, exceptAfterOverload: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/member-ordering.md '@typescript-eslint/member-ordering': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/method-signature-style.md '@typescript-eslint/method-signature-style': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/naming-convention.md 'camelcase': 'off', '@typescript-eslint/naming-convention': [ 'error', { selector: 'default', format: ['camelCase'], }, { selector: 'variable', format: ['camelCase', 'UPPER_CASE'], }, // allow arrow function React components to use PascalCase { selector: 'variable', types: ['function'], format: ['camelCase', 'PascalCase'], }, { selector: 'function', format: ['camelCase', 'PascalCase'], }, { selector: 'parameter', format: ['camelCase'], leadingUnderscore: 'allow', }, { selector: 'memberLike', format: ['camelCase'], modifiers: ['private'], leadingUnderscore: 'require', }, // allow "TODO" properties and methods { selector: 'memberLike', filter: '^TODO$', format: null, }, // allow Next.js context PascalCase properties { selector: 'property', filter: '^(Component|AppTree)$', format: null, }, { selector: 'typeLike', format: ['PascalCase'], }, // Prohibit "I" prefix on interfaces // (but allow acronyms that begin with "I") { selector: 'interface', custom: { regex: '^I[A-Z](?![A-Z])', match: false, }, format: ['PascalCase'], }, // Allow unsafe React lifecycle methods, for now { selector: 'method', filter: '^UNSAFE_', format: null, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-base-to-string.md '@typescript-eslint/no-base-to-string': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-confusing-non-null-assertion.md '@typescript-eslint/no-confusing-non-null-assertion': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-dupe-class-members.md '@typescript-eslint/no-dupe-class-members': 'off', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-dynamic-delete.md '@typescript-eslint/no-dynamic-delete': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-extra-non-null-assertion.md '@typescript-eslint/no-extra-non-null-assertion': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-extraneous-class.md '@typescript-eslint/no-extraneous-class': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-implicit-any-catch.md '@typescript-eslint/no-implicit-any-catch': [ // TODO: move to "strict" variant, enable? 'off', { allowExplicitAny: false, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-invalid-this.md 'no-invalid-this': 'off', '@typescript-eslint/no-invalid-this': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-invalid-void-type.md '@typescript-eslint/no-invalid-void-type': [ 'error', { allowInGenericTypeArguments: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-loop-func.md 'no-loop-func': 'off', '@typescript-eslint/no-loop-func': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-loss-of-precision.md 'no-loss-of-precision': 'off', '@typescript-eslint/no-loss-of-precision': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-magic-numbers.md 'no-magic-numbers': 'off', '@typescript-eslint/no-magic-numbers': [ // TODO: enable? 'off', { // eslint core ignore: [], ignoreArrayIndexes: true, enforceConst: true, detectObjects: false, // this plugin ignoreNumericLiteralTypes: true, ignoreReadonlyClassProperties: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-non-null-asserted-optional-chain.md '@typescript-eslint/no-non-null-asserted-optional-chain': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-parameter-properties.md '@typescript-eslint/no-parameter-properties': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-redeclare.md 'no-redeclare': 'off', '@typescript-eslint/no-redeclare': [ 'error', { builtinGlobals: true, ignoreDeclarationMerge: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-shadow.md 'no-shadow': 'off', '@typescript-eslint/no-shadow': [ 'error', { // eslint core builtinGlobals: false, hoist: 'functions', allow: [ // ponyfills 'fetch', // namespace declaration merging 'global', ], // this plugin ignoreTypeValueShadow: true, ignoreFunctionTypeParameterNameValueShadow: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-require-imports.md '@typescript-eslint/no-require-imports': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-throw-literal.md '@typescript-eslint/no-throw-literal': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-type-alias.md '@typescript-eslint/no-type-alias': [ 'error', { // TODO: get an informed opinion about this config allowAliases: 'always', allowCallbacks: 'always', allowConditionalTypes: 'never', allowConstructors: 'never', allowLiterals: 'in-intersections', allowMappedTypes: 'never', allowTupleTypes: 'never', }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unnecessary-boolean-literal-compare.md '@typescript-eslint/no-unnecessary-boolean-literal-compare': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unnecessary-condition.md '@typescript-eslint/no-unnecessary-condition': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unnecessary-qualifier.md '@typescript-eslint/no-unnecessary-qualifier': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unnecessary-type-arguments.md '@typescript-eslint/no-unnecessary-type-arguments': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unused-expressions.md 'no-unused-expressions': 'off', '@typescript-eslint/no-unused-expressions': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unused-vars-experimental.md '@typescript-eslint/no-unused-vars-experimental': 'off', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-useless-constructor.md 'no-useless-constructor': 'off', '@typescript-eslint/no-useless-constructor': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-enum-initializers.md '@typescript-eslint/prefer-enum-initializers': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-for-of.md '@typescript-eslint/prefer-for-of': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-function-type.md '@typescript-eslint/prefer-function-type': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-includes.md '@typescript-eslint/prefer-includes': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-literal-enum-member.md '@typescript-eslint/prefer-literal-enum-member': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-nullish-coalescing.md '@typescript-eslint/prefer-nullish-coalescing': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-optional-chain.md '@typescript-eslint/prefer-optional-chain': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-readonly.md '@typescript-eslint/prefer-readonly': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-readonly-parameter-types.md '@typescript-eslint/prefer-readonly-parameter-types': 'off', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-reduce-type-parameter.md '@typescript-eslint/prefer-reduce-type-parameter': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-string-starts-ends-with.md '@typescript-eslint/prefer-string-starts-ends-with': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/prefer-ts-expect-error.md '@typescript-eslint/prefer-ts-expect-error': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/promise-function-async.md '@typescript-eslint/promise-function-async': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/require-array-sort-compare.md '@typescript-eslint/require-array-sort-compare': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/return-await.md 'no-return-await': 'off', '@typescript-eslint/return-await': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/strict-boolean-expressions.md '@typescript-eslint/strict-boolean-expressions': 'off', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/switch-exhaustiveness-check.md '@typescript-eslint/switch-exhaustiveness-check': 'error', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/typedef.md '@typescript-eslint/typedef': 'off', // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/unified-signatures.md '@typescript-eslint/unified-signatures': 'error', }, };