diff --git a/.unimportedrc.json b/.unimportedrc.json index 14a2d972..4c58a4fa 100644 --- a/.unimportedrc.json +++ b/.unimportedrc.json @@ -5,7 +5,14 @@ "ignoreUnused": [], "extensions": [".ts", ".js", ".tsx", ".jsx"], "aliases": { - "#views/*": ["./src/views/*"], - "#utils/*": ["./src/utils/*"] + "#generated/*": ["./generated/*"], + "#assets/*": ["./src/assets/*"], + "#components/*": ["./src/components/*"], + "#config": ["./src/config"], + "#contexts/*": ["./src/contexts/*"], + "#hooks/*": ["./src/hooks/*"], + "#strings/*": ["./src/strings/*"], + "#utils/*": ["./src/utils/*"], + "#views/*": ["./src/views/*"] } } diff --git a/docker-compose.yml b/docker-compose.yml index 3f19cad0..0ff5e2f8 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -2,9 +2,7 @@ version: '3.8' services: react: build: . - command: sh -c 'yarn install && yarn dev --host' - environment: - APP_TITLE: ${APP_TITLE:-React Base App} + command: sh -c 'yarn install && yarn start --host' volumes: - .:/code ports: diff --git a/eslint.config.js b/eslint.config.js index 7c802424..891f8a8a 100644 --- a/eslint.config.js +++ b/eslint.config.js @@ -1,10 +1,8 @@ import { FlatCompat } from '@eslint/eslintrc'; import js from '@eslint/js'; -import path from 'path'; -import { fileURLToPath } from 'url'; +import process from 'process'; -const filename = fileURLToPath(import.meta.url); -const dirname = path.dirname(filename); +const dirname = process.cwd(); const compat = new FlatCompat({ baseDirectory: dirname, @@ -13,9 +11,11 @@ const compat = new FlatCompat({ const appConfigs = compat.config({ env: { + node: true, browser: true, es2020: true, }, + root: true, extends: [ 'airbnb', 'airbnb/hooks', @@ -30,14 +30,18 @@ const appConfigs = compat.config({ plugins: [ '@typescript-eslint', 'react-refresh', + 'simple-import-sort', + 'import-newlines' ], settings: { 'import/parsers': { - '@typescript-eslint/parser': ['.ts', '.tsx'] + '@typescript-eslint/parser': ['.ts', '.tsx'] }, 'import/resolver': { - typescript: { - project: './tsconfig.json', + typescript: { + project: [ + './tsconfig.json', + ], }, }, }, @@ -72,6 +76,7 @@ const appConfigs = compat.config({ 'import/no-cycle': ['error', { allowUnsafeDynamicCyclicDependency: true }], 'react/react-in-jsx-scope': 'off', + 'camelcase': 'off', 'react/jsx-indent': ['error', 4], 'react/jsx-indent-props': ['error', 4], @@ -83,10 +88,39 @@ const appConfigs = compat.config({ 'react-hooks/exhaustive-deps': 'warn', 'react/require-default-props': ['warn', { ignoreFunctionalComponents: true }], + 'simple-import-sort/imports': 'warn', + 'simple-import-sort/exports': 'warn', + 'import-newlines/enforce': ['warn', 1] }, + overrides: [ + { + files: ['*.js', '*.jsx', '*.ts', '*.tsx'], + rules: { + 'simple-import-sort/imports': [ + 'error', + { + 'groups': [ + // side effect imports + ['^\\u0000'], + // packages `react` related packages come first + ['^react', '^@?\\w'], + // internal packages + ['^#.+$'], + // parent imports. Put `..` last + // other relative imports. Put same-folder imports and `.` last + ['^\\.\\.(?!/?$)', '^\\.\\./?$', '^\\./(?=.*/)(?!/?$)', '^\\.(?!/?$)', '^\\./?$'], + // style imports + ['^.+\\.json$', '^.+\\.module.css$'], + ] + } + ] + } + } + ] }).map((conf) => ({ ...conf, files: ['src/**/*.tsx', 'src/**/*.jsx', 'src/**/*.ts', 'src/**/*.js'], + ignores: ['src/generated/types.ts'], })); const otherConfig = { diff --git a/index.html b/index.html index e0322f2c..0a4bb375 100644 --- a/index.html +++ b/index.html @@ -8,7 +8,7 @@