Skip to content

Commit

Permalink
chore: support eslint flat config
Browse files Browse the repository at this point in the history
  • Loading branch information
solufa committed Jul 12, 2024
1 parent e59e9bf commit c882903
Show file tree
Hide file tree
Showing 11 changed files with 311 additions and 133 deletions.
1 change: 0 additions & 1 deletion .dockerignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,4 @@
data
**/node_modules
README.md
.gitignore
**/.env
75 changes: 0 additions & 75 deletions .eslintrc.js

This file was deleted.

13 changes: 13 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,19 @@ tsconfig.tsbuildinfo
data/*
!data/.gitkeep
.env
**/$*.ts

# debug
npm-debug.log*

# client
client/.next/
client/out/
client/api/*
**/*.css.d.ts
**/*.css.d.ts.map

# server
server/index.js
server/index.js.map
server/coverage/
12 changes: 0 additions & 12 deletions client/.gitignore

This file was deleted.

9 changes: 2 additions & 7 deletions client/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,11 @@
"dev:client": "next dev -p 5051",
"dev:hcm": "hcm '**/*.module.css' -w",
"dev:aspida": "aspida --watch",
"dev:path": "pathpida --ignorePath .gitignore -s -w",
"dev:path": "pathpida --ignorePath ../.gitignore -s -w",
"build": "npm run generate && next build",
"lint": "run-p lint:js lint:prettier lint:style",
"lint:js": "eslint --ext .ts,.tsx,.js --ignore-path .gitignore .",
"lint:prettier": "prettier --check \"./**/*.{ts,tsx,js}\" --ignore-path .gitignore",
"lint:style": "stylelint \"**/*.css\" --ignore-path .gitignore",
"lint:fix": "npm run lint:js -- --fix && prettier --write \"./**/*.{ts,tsx,js}\" --ignore-path .gitignore && npm run lint:style -- --fix",
"generate": "run-p generate:*",
"generate:aspida": "aspida",
"generate:path": "pathpida --ignorePath .gitignore -s",
"generate:path": "pathpida --ignorePath ../.gitignore -s",
"hcm": "hcm '**/*.module.css'",
"test": "vitest run",
"test:watch": "vitest",
Expand Down
78 changes: 78 additions & 0 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
import js from '@eslint/js';
import gitignore from 'eslint-config-flat-gitignore';
import prettierConfig from 'eslint-config-prettier';
import importPlugin from 'eslint-plugin-import';
import reactPlugin from 'eslint-plugin-react';
import globals from 'globals';
import tseslint from 'typescript-eslint';

export default tseslint.config(
{ files: ['**/*.(ts,js,tsx)'] },
gitignore(),
js.configs.recommended,
...tseslint.configs.recommended,
{
languageOptions: {
globals: {
...globals.browser,
...globals.node,
...globals.es2020,
},
},
plugins: {
react: reactPlugin,
import: importPlugin,
},
settings: {
react: {
version: 'detect',
},
},
rules: {
eqeqeq: 'error',
'no-param-reassign': 'error',
'object-shorthand': ['error', 'always'],
'prefer-template': 'error',
'@typescript-eslint/consistent-type-imports': 'error',
'@typescript-eslint/explicit-module-boundary-types': 'off',
'@typescript-eslint/no-non-null-assertion': 'error',
'@typescript-eslint/no-explicit-any': 'error',
complexity: ['error', 5],
'max-depth': ['error', 2],
'max-nested-callbacks': ['error', 3],
'max-lines': ['error', 200],
'@typescript-eslint/no-unused-vars': [
'warn',
{
argsIgnorePattern: '^_',
varsIgnorePattern: '^_',
caughtErrorsIgnorePattern: '^_',
destructuredArrayIgnorePattern: '^_',
},
],
},
},
{
files: ['*.tsx'],
rules: {
'react/react-in-jsx-scope': 'off',
'react/prop-types': 'off',
'react/self-closing-comp': 'error',
'react-hooks/rules-of-hooks': 'error',
'react-hooks/exhaustive-deps': 'error',
},
},
{
files: ['server/**/*.ts'],
rules: { '@typescript-eslint/explicit-function-return-type': ['error'] },
},
{
files: ['server/api/**/controller.ts', 'server/api/**/hooks.ts'],
rules: { '@typescript-eslint/explicit-function-return-type': ['off'] },
},
{
files: ['**/*.js'],
rules: { '@typescript-eslint/no-var-requires': ['off'] },
},
prettierConfig,
);
Loading

0 comments on commit c882903

Please sign in to comment.