pn add -D eslint @eslint/js eslint-plugin-simple-import-sort eslint-plugin-unused-imports typescript-eslint @typescript-eslint/parser
touch eslint.config.js
import pluginJs from "@eslint/js";
import simpleImportSort from "eslint-plugin-simple-import-sort";
import unusedImports from "eslint-plugin-unused-imports";
import globals from "globals";
import pluginTs from "typescript-eslint";
export default [
{ files: ["**/*.{js,mjs,cjs,ts,astro}"] },
{ ignores: [".astro/**/*", "dist/**/*", "**/static/"] },
{ languageOptions: { globals: globals.browser } },
pluginJs.configs.recommended,
...pluginTs.configs.recommended,
{
rules: {
"no-undef": "off",
"@typescript-eslint/ban-ts-comment": "off",
"@typescript-eslint/no-unused-expressions": [
"error",
{ allowShortCircuit: true },
],
},
},
// @see https://github.com/lydell/eslint-plugin-simple-import-sort
{
plugins: {
"simple-import-sort": simpleImportSort,
},
rules: {
"simple-import-sort/imports": "error",
"simple-import-sort/exports": "error",
},
},
// @see https://github.com/sweepline/eslint-plugin-unused-imports
{
plugins: {
"unused-imports": unusedImports,
},
rules: {
"no-unused-vars": "off",
"@typescript-eslint/no-unused-vars": "off",
"unused-imports/no-unused-imports": "error",
"unused-imports/no-unused-vars": [
"warn",
{
vars: "all",
varsIgnorePattern: "^_",
args: "after-used",
argsIgnorePattern: "^_",
},
],
},
},
];
for next.js
import { FlatCompat } from '@eslint/eslintrc';
import pluginJs from '@eslint/js';
import simpleImportSort from 'eslint-plugin-simple-import-sort';
import unusedImports from 'eslint-plugin-unused-imports';
import globals from 'globals';
import pluginTs from 'typescript-eslint';
const compat = new FlatCompat({
baseDirectory: import.meta.dirname,
});
const eslintConfig = [
{ files: ['**/*.{js,mjs,cjs,ts,astro}'] },
{ ignores: ['.astro/**/*', 'dist/**/*', '**/static/'] },
{ languageOptions: { globals: globals.browser } },
pluginJs.configs.recommended,
...pluginTs.configs.recommended,
...compat.config({
extends: ['next'],
}),
{
rules: {
'no-undef': 'off',
'@typescript-eslint/ban-ts-comment': 'off',
'@typescript-eslint/no-unused-expressions': [
'error',
{ allowShortCircuit: true },
],
},
},
// @see https://github.com/lydell/eslint-plugin-simple-import-sort
{
plugins: {
'simple-import-sort': simpleImportSort,
},
rules: {
'simple-import-sort/imports': 'error',
'simple-import-sort/exports': 'error',
},
},
// @see https://github.com/sweepline/eslint-plugin-unused-imports
{
plugins: {
'unused-imports': unusedImports,
},
rules: {
'no-unused-vars': 'off',
'@typescript-eslint/no-unused-vars': 'off',
'unused-imports/no-unused-imports': 'error',
'unused-imports/no-unused-vars': [
'warn',
{
vars: 'all',
varsIgnorePattern: '^_',
args: 'after-used',
argsIgnorePattern: '^_',
},
],
},
},
];
export default eslintConfig;