TypeScript eslint - Extensão / importação de arquivo "ts" ausente / extensões

33

Eu tenho um aplicativo simples Node / Express feito com Typescript. E eslint me dê o erro

Missing file extension "ts" for "./lib/env" import/extensions

Aqui está o meu arquivo .eslintrc

    {
  "extends": [
    "airbnb",
    "plugin:@typescript-eslint/recommended",
    "prettier",
    "prettier/react",
    "plugin:import/errors",
    "plugin:import/warnings",
    "plugin:import/typescript"
  ],
  "parser": "@typescript-eslint/parser",
  "plugins": ["@typescript-eslint", "prettier", "import"],
  "settings": {
    "import/extensions": [".js", ".jsx", ".ts", ".tsx"],
    "import/parsers": {
      "@typescript-eslint/parser": [".ts", ".tsx"]
    },
    "import/resolver": {
      "typescript": {
        "directory": "./tsconfig.json"
      },
      "node": {
        "extensions": [".js", ".jsx", ".ts", ".tsx"]
      }
    }
  },
  "rules": {
    "@typescript-eslint/indent": [2, 2],
    "no-console": "off",
    "import/no-unresolved": [2, { "commonjs": true, "amd": true }],
    "import/named": 2,
    "import/namespace": 2,
    "import/default": 2,
    "import/export": 2
  }
}

Eu instalei o eslint-plugin-impor e o eslint-import-resolver-typescript. E não consigo entender por que, recebi esse erro.

Nolat
fonte

Respostas:

69

Adicione o seguinte código a rules:

"rules": {
   "import/extensions": [
      "error",
      "ignorePackages",
      {
        "js": "never",
        "jsx": "never",
        "ts": "never",
        "tsx": "never"
      }
   ]
}

airbnbA configuração do ESLint lidera o problema.

superoryco
fonte
9
Trabalhou! Obrigado. (outros leitores: certifique-se de colocá-lo em "regras" e não em "configurações" ...)
Venryx