概要
Remixのプロジェクトにおいて、チルダによる相対パスを用いたimportをするとき、動作確認は問題ないがEslintで怒られる事象の解決策をメモします。
エラー内容
Vscode上で下記が発生するが、問題なく動作する。
Unable to resolve path to module '~/utils/apis/fetchLogoutData'.eslintimport/no-unresolved
解決策
動作はするためtsconfig.jsonの設定は問題なく、.eslintrc.cjsの'plugin:import/recommended'が原因でした。これを無効化すれば改善しました。
tsconfig.json
{
"include": [
"**/*.ts",
"**/*.tsx",
"**/.server/**/*.ts",
"**/.server/**/*.tsx",
"**/.client/**/*.ts",
"**/.client/**/*.tsx"
],
"compilerOptions": {
"lib": ["DOM", "DOM.Iterable", "ES2022"],
"types": ["@remix-run/node", "vite/client"],
"isolatedModules": true,
"esModuleInterop": true,
"jsx": "react-jsx",
"module": "ESNext",
"moduleResolution": "Bundler",
"resolveJsonModule": true,
"target": "ES2022",
"strict": true,
"allowJs": true,
"skipLibCheck": true,
"forceConsistentCasingInFileNames": true,
"baseUrl": ".",
"paths": {
"~/*": ["./app/*"]
},
"noEmit": true
}
}
.eslintrc.cjs
/**
* This is intended to be a basic starting point for linting in your app.
* It relies on recommended configs out of the box for simplicity, but you can
* and should modify this configuration to best suit your team's needs.
*/
/** @type {import('eslint').Linter.Config} */
module.exports = {
root: true,
parserOptions: {
ecmaVersion: 'latest',
sourceType: 'module',
ecmaFeatures: {
jsx: true,
},
},
env: {
browser: true,
commonjs: true,
es6: true,
},
ignorePatterns: ['!**/.server', '!**/.client'],
// Base config
extends: ['eslint:recommended', 'prettier'],
rules: {
'no-useless-catch': 'off', // no-useless-catch を無効化
},
overrides: [
// React
{
files: ['**/*.{js,jsx,ts,tsx}'],
plugins: ['react', 'jsx-a11y'],
extends: [
'plugin:react/recommended',
'plugin:react/jsx-runtime',
'plugin:react-hooks/recommended',
'plugin:jsx-a11y/recommended',
],
settings: {
react: {
version: 'detect',
},
formComponents: ['Form'],
linkComponents: [
{ name: 'Link', linkAttribute: 'to' },
{ name: 'NavLink', linkAttribute: 'to' },
],
'import/resolver': {
typescript: {
project: './tsconfig.json', // tsconfig.json のパスを指定
},
},
},
},
// Typescript
{
files: ['**/*.{ts,tsx}'],
plugins: ['@typescript-eslint', 'import'],
parser: '@typescript-eslint/parser',
settings: {
'import/internal-regex': '^~/',
'import/resolver': {
node: {
extensions: ['.ts', '.tsx'],
},
typescript: {
project: './tsconfig.json', // tsconfig.json のパスを指定
alwaysTryTypes: true,
},
},
},
extends: [
'plugin:@typescript-eslint/recommended',
// 'plugin:import/recommended', // NOTE: これが原因で~による相対インポートが機能しなかった
'plugin:import/typescript',
],
},
// Node
{
files: ['.eslintrc.cjs'],
env: {
node: true,
},
},
],
};