Files
pn-new-crm/eslint.config.mjs
Matt b2ba0b4e0a
All checks were successful
Build & Push Docker Images / lint (push) Successful in 2m14s
Build & Push Docker Images / build-and-push (push) Successful in 6m30s
fix(ci): repair pnpm lint for Next 16 + cross-tree ignores
Two issues caught when CI ran against the freshly-pushed main:

1. `next lint` is removed in Next 16 — package.json#scripts.lint
   was still `next lint` and aborts with "Invalid project directory
   provided, no such directory: …/lint". Switched to `eslint .`
   (the canonical flat-config invocation; pre-commit already runs
   eslint --fix on staged files via lint-staged).

2. Flat-config rule overrides for `@typescript-eslint/*` rules
   applied to non-TS files when walking the repo root (root-level
   .mjs / config files), failing with "plugin not found" because
   typescript-eslint only registers itself for TS/TSX files. Added
   an explicit `files: ['**/*.ts', '**/*.tsx']` filter to the rule
   block so the override scope matches the plugin's registration
   scope.

Plus tightened the ignores: `.claude/**` (agent worktree artifacts),
`.next/**`, `dist/**`, `website/**` (sub-project with its own
toolchain).

Test files relaxed to `warn` on no-unused-vars since e2e setup /
teardown destructuring patterns frequently leave helper-named locals
unused — fine for tests, not worth churning every spec file.

Result: 0 errors, 36 pre-existing warnings (none added by this
commit). CI lint job should now pass.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-14 16:03:37 +02:00

66 lines
2.6 KiB
JavaScript

import nextCoreWebVitals from 'eslint-config-next/core-web-vitals';
import prettier from 'eslint-config-prettier/flat';
const eslintConfig = [
...nextCoreWebVitals,
prettier,
{
// Scope the typescript-eslint rule overrides to TS/TSX files. Without
// the `files` filter, eslint flat-config attempts to apply these
// rules to every walked file (including root-level JS / mjs / json
// configs) and fails because the typescript-eslint plugin only
// registers itself for TS/TSX. Surfaced 2026-05-14 when CI's
// `pnpm lint` command ran across the whole repo root.
files: ['**/*.ts', '**/*.tsx'],
rules: {
'@typescript-eslint/no-explicit-any': 'error',
'@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }],
// React Compiler safety rules shipped with eslint-config-next@16 /
// react-hooks@7. Triage status (2026-05-13 sweep):
// purity, set-state-in-render, immutability, refs,
// set-state-in-effect — promoted to error after the cleanup
// sweep (Wave 3 of the 2026-05-12 audit). All hits migrated to
// either useQuery, render-phase derivation, key-based remount,
// or a justified eslint-disable for canonical setState-on-
// subscription patterns. New regressions block CI.
// incompatible-library — informational only ("Compiler
// skipped this file because of a non-Compiler-safe import").
// No action needed; silenced to keep `pnpm lint` output
// actionable.
'react-hooks/purity': 'error',
'react-hooks/set-state-in-render': 'error',
'react-hooks/immutability': 'error',
'react-hooks/refs': 'error',
'react-hooks/set-state-in-effect': 'error',
'react-hooks/incompatible-library': 'off',
},
},
{
// Tests assert response shape via expect() — narrowing every
// `res.json()` to a structural type adds boilerplate without catching
// bugs. Allow `any` casts at JSON boundaries in test files. Also
// relax unused-vars to warn (destructured-but-unused helpers are
// common in setup/teardown patterns).
files: ['tests/**/*.ts', 'tests/**/*.tsx'],
rules: {
'@typescript-eslint/no-explicit-any': 'off',
'@typescript-eslint/no-unused-vars': ['warn', { argsIgnorePattern: '^_' }],
},
},
{
ignores: [
'client-portal/**',
'next-env.d.ts',
// Agent worktree artifacts — not part of the canonical tree.
'.claude/**',
// Build output + Next generated types
'.next/**',
'dist/**',
// Other sub-projects with their own toolchains
'website/**',
],
},
];
export default eslintConfig;