UNPKG

eslint-config-ts-strict

Version:

Very strict ESLint config for projects using TypeScript, React and Prettier. ESLint v9 flat config only. Formatting rules disabled to prevent Prettier conflicts.

513 lines (400 loc) 27.3 kB
export default { rules: { // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/adjacent-overload-signatures.md "@typescript-eslint/adjacent-overload-signatures": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/array-type.md "@typescript-eslint/array-type": ["error", { default: "array" }], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/await-thenable.md "@typescript-eslint/await-thenable": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/ban-ts-comment.md "@typescript-eslint/ban-ts-comment": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/ban-tslint-comment.md "@typescript-eslint/ban-tslint-comment": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/class-literal-property-style.md "@typescript-eslint/class-literal-property-style": ["error", "fields"], // https://typescript-eslint.io/rules/consistent-generic-constructors/ "@typescript-eslint/consistent-generic-constructors": [ "warn", "constructor", ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/consistent-indexed-object-style.md "@typescript-eslint/consistent-indexed-object-style": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/consistent-type-assertions.md "@typescript-eslint/consistent-type-assertions": [ "error", { assertionStyle: "as", objectLiteralTypeAssertions: "allow", }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/consistent-type-definitions.md "@typescript-eslint/consistent-type-definitions": ["error", "interface"], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/consistent-type-exports.md "@typescript-eslint/consistent-type-exports": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/consistent-type-imports.md "@typescript-eslint/consistent-type-imports": [ "error", { prefer: "type-imports" }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/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/main/packages/eslint-plugin/docs/rules/explicit-module-boundary-types.md "@typescript-eslint/explicit-module-boundary-types": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/init-declarations.md // enforce or disallow variable initializations at definition "init-declarations": "off", "@typescript-eslint/init-declarations": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/method-signature-style.md "@typescript-eslint/method-signature-style": ["error", "property"], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/naming-convention.md // The `@typescript-eslint/naming-convention` rule allows `leadingUnderscore` and `trailingUnderscore` settings. However, the existing `no-underscore-dangle` rule already takes care of this. "naming-convention": "off", "@typescript-eslint/naming-convention": [ "error", // Allow camelCase variables (23.2), PascalCase variables (23.8), and UPPER_CASE variables (23.10) { selector: "variable", format: ["camelCase", "PascalCase", "UPPER_CASE"], }, // Allow camelCase functions (23.2), and PascalCase functions (23.8) { selector: "function", format: ["camelCase", "PascalCase"], }, // Airbnb recommends PascalCase for classes (23.3), and although Airbnb does not make TypeScript recommendations, we are assuming this rule would similarly apply to anything "type like", including interfaces, type aliases, and enums { selector: "typeLike", format: ["PascalCase"], }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/default-param-last.md "default-param-last": "off", "@typescript-eslint/default-param-last": "error", // Replace Airbnb 'dot-notation' rule with '@typescript-eslint' version // 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 }], "@typescript-eslint/no-deprecated": "error", "@typescript-eslint/no-restricted-types": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/no-array-constructor.md "no-array-constructor": "off", "@typescript-eslint/no-array-constructor": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/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/main/packages/eslint-plugin/docs/rules/no-confusing-void-expression.md "@typescript-eslint/no-confusing-void-expression": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-dupe-class-members.md "no-dupe-class-members": "off", "@typescript-eslint/no-dupe-class-members": "error", // deprecated // replaced by https://github.com/benmosher/eslint-plugin-import/blob/master/docs/rules/no-duplicates.md // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-duplicate-imports.md "no-duplicate-imports": "off", "@typescript-eslint/no-duplicate-imports": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-dynamic-delete.md "@typescript-eslint/no-dynamic-delete": "error", // https://typescript-eslint.io/rules/no-empty-interface/ "no-empty-interface": "off", "@typescript-eslint/no-empty-interface": 0, // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-empty-function.md "no-empty-function": "off", "@typescript-eslint/no-empty-function": [ "error", { allow: ["arrowFunctions", "functions", "methods"], }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-explicit-any.md "@typescript-eslint/no-explicit-any": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/packages/eslint-plugin/docs/rules/no-extra-parens.md "no-extra-parens": "off", "@typescript-eslint/no-extra-parens": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-extra-semi.md // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-extraneous-class.md "@typescript-eslint/no-extraneous-class": [ "error", { allowConstructorOnly: true, allowEmpty: true, allowStaticOnly: true }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-floating-promises.md "@typescript-eslint/no-floating-promises": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-for-in-array.md "@typescript-eslint/no-for-in-array": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-implied-eval.md "no-implied-eval": "off", "@typescript-eslint/no-implied-eval": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-inferrable-types.md "@typescript-eslint/no-inferrable-types": "error", // disallow this keywords outside of classes or class-like objects // https://eslint.org/docs/rules/no-invalid-this "no-invalid-this": "off", "@typescript-eslint/no-invalid-this": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-invalid-void-type.md "@typescript-eslint/no-invalid-void-type": "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-loop-func.md "no-loop-func": "off", "@typescript-eslint/no-loop-func": "error", // https://eslint.org/docs/latest/rules/no-magic-numbers "no-magic-numbers": "off", "@typescript-eslint/no-magic-numbers": [ "off", { ignore: [-1, 0, 1, 2], ignoreEnums: true, ignoreNumericLiteralTypes: true, ignoreReadonlyClassProperties: true, ignoreTypeIndexes: true, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-meaningless-void-operator.md "@typescript-eslint/no-meaningless-void-operator": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-misused-new.md "@typescript-eslint/no-misused-new": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-misused-promises.md "@typescript-eslint/no-misused-promises": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-namespace.md "@typescript-eslint/no-namespace": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-non-null-asserted-nullish-coalescing.md "@typescript-eslint/no-non-null-asserted-nullish-coalescing": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/packages/eslint-plugin/docs/rules/no-non-null-assertion.md "@typescript-eslint/no-non-null-assertion": "error", // Deprecated // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-parameter-properties.md "@typescript-eslint/no-parameter-properties": "off", // https://typescript-eslint.io/rules/no-redundant-type-constituents/ "@typescript-eslint/no-redundant-type-constituents": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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-redeclare.md "no-redeclare": "off", "@typescript-eslint/no-redeclare": "error", // disallow specific imports // https://eslint.org/docs/rules/no-restricted-imports "no-restricted-imports": [ "off", { paths: [], patterns: [], }, ], "@typescript-eslint/no-restricted-imports": "off", // 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", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-this-alias.md "@typescript-eslint/no-this-alias": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-type-alias.md "@typescript-eslint/no-type-alias": [ "off", { allowAliases: "in-unions", allowGenerics: "always" }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/packages/eslint-plugin/docs/rules/no-unnecessary-condition.md "@typescript-eslint/no-unnecessary-condition": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-unnecessary-qualifier.md "@typescript-eslint/no-unnecessary-qualifier": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/packages/eslint-plugin/docs/rules/no-unnecessary-type-arguments.md "@typescript-eslint/no-unnecessary-type-assertion": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-unnecessary-type-constraint.md "@typescript-eslint/no-unnecessary-type-constraint": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-unsafe-argument.md "@typescript-eslint/no-unsafe-argument": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-unsafe-assignment.md "@typescript-eslint/no-unsafe-assignment": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-unsafe-call.md "@typescript-eslint/no-unsafe-call": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-unsafe-member-access.md "@typescript-eslint/no-unsafe-member-access": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-unsafe-return.md "@typescript-eslint/no-unsafe-return": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-useless-empty-export.md "@typescript-eslint/no-useless-empty-export": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-var-requires.md "@typescript-eslint/no-var-requires": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/non-nullable-type-assertion-style.md "@typescript-eslint/non-nullable-type-assertion-style": "error", // Require or disallow padding lines between statements // https://eslint.org/docs/rules/padding-line-between-statements "padding-line-between-statements": "off", "@typescript-eslint/padding-line-between-statements": "off", // https://typescript-eslint.io/rules/parameter-properties/ "@typescript-eslint/parameter-properties": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-as-const.md "@typescript-eslint/prefer-as-const": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-enum-initializers.md "@typescript-eslint/prefer-enum-initializers": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-for-of.md "@typescript-eslint/prefer-for-of": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-function-type.md "@typescript-eslint/prefer-function-type": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-includes.md "@typescript-eslint/prefer-includes": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/packages/eslint-plugin/docs/rules/prefer-namespace-keyword.md "@typescript-eslint/prefer-namespace-keyword": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-nullish-coalescing.md "@typescript-eslint/prefer-nullish-coalescing": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-optional-chain.md "@typescript-eslint/prefer-optional-chain": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-readonly.md "@typescript-eslint/prefer-readonly": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/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/main/packages/eslint-plugin/docs/rules/prefer-regexp-exec.md "@typescript-eslint/prefer-regexp-exec": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/prefer-return-this-type.md "@typescript-eslint/prefer-return-this-type": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/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/main/packages/eslint-plugin/docs/rules/promise-function-async.md "@typescript-eslint/promise-function-async": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/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/main/packages/eslint-plugin/docs/rules/restrict-plus-operands.md "@typescript-eslint/restrict-plus-operands": [ "error" ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/restrict-template-expressions.md "@typescript-eslint/restrict-template-expressions": [ "error", { allowNumber: true }, ], // https://typescript-eslint.io/rules/sort-type-constituents "@typescript-eslint/sort-type-constituents": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/strict-boolean-expressions.md "@typescript-eslint/strict-boolean-expressions": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/switch-exhaustiveness-check.md "@typescript-eslint/switch-exhaustiveness-check": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/triple-slash-reference.md "@typescript-eslint/triple-slash-reference": [ "error", { types: "prefer-import" }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/typedef.md "@typescript-eslint/typedef": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/unbound-method.md "@typescript-eslint/unbound-method": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/unified-signatures.md "@typescript-eslint/unified-signatures": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/docs/rules/no-duplicate-enum-values.md "@typescript-eslint/no-duplicate-enum-values": "error", // allows to throw only Error objects // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-throw-literal.md "no-throw-literal": "off", // Disabled to work with CosmosError class that implements Error interface "@typescript-eslint/no-throw-literal": "off", // 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", { allowShortCircuit: false, allowTernary: false, allowTaggedTemplates: false, }, ], // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-unused-vars.md // https://github.com/sweepline/eslint-plugin-unused-imports "no-unused-vars": "off", "unused-imports/no-unused-vars-ts": "off", "unused-imports/no-unused-imports-ts": "off", "unused-imports/no-unused-vars": "off", "@typescript-eslint/no-unused-vars": ["error", { "ignoreRestSiblings": true }], "unused-imports/no-unused-imports": "error", // https://typescript-eslint.io/rules/no-unsafe-declaration-merging/ "@typescript-eslint/no-unsafe-declaration-merging": "error", // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/no-use-before-define.md "no-use-before-define": "off", "@typescript-eslint/no-use-before-define": [ "warn", { functions: true, classes: true, variables: true }, ], // 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/require-await.md "require-await": "off", "@typescript-eslint/require-await": "off", // https://github.com/typescript-eslint/typescript-eslint/blob/master/packages/eslint-plugin/docs/rules/return-await.md // https://eslint.org/docs/latest/rules/no-return-await "no-return-await": "off", "@typescript-eslint/return-await": ["error", "in-try-catch"], "@typescript-eslint/no-duplicate-type-constituents": "error", "@typescript-eslint/no-import-type-side-effects": "error", "@typescript-eslint/no-mixed-enums": "error", "@typescript-eslint/no-unsafe-enum-comparison": "error", "@typescript-eslint/class-methods-use-this": "off", "@typescript-eslint/max-params": ["error", { max: 4 }], "@typescript-eslint/no-unsafe-unary-minus": "error", "@typescript-eslint/prefer-destructuring": "error", "@typescript-eslint/no-array-delete": "error", "@typescript-eslint/no-unnecessary-template-expression": "error", "@typescript-eslint/prefer-find": "error", "@typescript-eslint/prefer-promise-reject-errors": "error", "@typescript-eslint/no-unnecessary-template-expression": "error", "@typescript-eslint/use-unknown-in-catch-callback-variable": "off", "@typescript-eslint/no-empty-object-type": "error", "@typescript-eslint/only-throw-error": "error", "@typescript-eslint/no-unnecessary-parameter-property-assignment": "error", "@typescript-eslint/no-unsafe-function-type": "error", "@typescript-eslint/no-unnecessary-type-parameters": "error", "@typescript-eslint/no-unnecessary-type-conversion": "error", "@typescript-eslint/no-wrapper-object-types": "error", "@typescript-eslint/no-unsafe-type-assertion": "warn", "@typescript-eslint/related-getter-setter-pairs": "error", "@typescript-eslint/no-misused-spread": "error", }, overrides: [ { files: ["*.ts", "*.tsx"], rules: { // The following rules are checked (more thoroughly) by the TypeScript compiler // Some of the rules also fail in TypeScript files, for example: https://github.com/typescript-eslint/typescript-eslint/issues/662#issuecomment-507081586 // Rules are inspired by: https://github.com/typescript-eslint/typescript-eslint/blob/main/packages/eslint-plugin/src/configs/eslint-recommended.ts "constructor-super": "off", "getter-return": "off", "no-const-assign": "off", "no-dupe-args": "off", "no-dupe-class-members": "off", "no-dupe-keys": "off", "no-func-assign": "off", "no-import-assign": "off", "no-new-symbol": "off", "no-obj-calls": "off", "no-redeclare": "off", "no-setter-return": "off", "no-this-before-super": "off", "no-undef": "off", "no-unreachable": "off", "no-unsafe-negation": "off", "valid-typeof": "off", // The following rules are enabled in Airbnb config, but are recommended to be disabled within TypeScript projects // See: https://github.com/typescript-eslint/typescript-eslint/blob/13583e65f5973da2a7ae8384493c5e00014db51b/docs/linting/TROUBLESHOOTING.md#eslint-plugin-import "import/named": "off", "import/no-named-as-default-member": "off", // Disable `import/no-unresolved`, see README.md for details "import/no-unresolved": "off", }, }, ], };