@jtbennett/create-ts-project
Version:
Create TypeScript monorepos with project references, eslint, prettier, and jest configured and ready for development.
45 lines (36 loc) • 1.63 kB
JavaScript
module.exports = {
root: true,
parser: "@typescript-eslint/parser",
parserOptions: {
tsconfigRootDir: __dirname,
project: ["./packages/*/tsconfig.json"],
},
plugins: ["@typescript-eslint", "node", "jest"],
extends: [
// Core eslint recommended rules.
"eslint:recommended",
// Override those with TypeScript versions, where necessary.
"plugin:@typescript-eslint/eslint-recommended",
// Core TypeScript recommended rules - syntax only.
"plugin:@typescript-eslint/recommended",
// Core TypeScript recommended rules - full type checking.
"plugin:@typescript-eslint/recommended-requiring-type-checking",
// Disable formatting rules that prettier will handle.
"prettier/@typescript-eslint",
],
rules: {
// Importing any package in the project will likely work in dev because
// of the symlinks that yarn workspaces creates in the root node_modules.
// We can't prevent that, but we can tell eslint to fail.
// (This rule is poorly named. It should be "no-implicit-import".)
"node/no-extraneous-import": "error",
// Be explicit when you must, but return type is usually inferred correctly.
"@typescript-eslint/explicit-function-return-type": "off",
// Avoid using "any" or "as any" wherever possible, but this is too onerous.
"@typescript-eslint/no-explicit-any": "off",
// Avoid foo!.bar wherever possible, but this is too onerous.
"@typescript-eslint/no-non-null-assertion": "off",
// Clean up unused vars before committing, but this is too onerous during dev.
"@typescript-eslint/no-unused-vars": "warn",
},
};