Skip to content

Instantly share code, notes, and snippets.

@DarlonHenrique
Created July 18, 2024 02:51
Show Gist options
  • Save DarlonHenrique/80e93895045981c993ccfe2e287ce3da to your computer and use it in GitHub Desktop.
Save DarlonHenrique/80e93895045981c993ccfe2e287ce3da to your computer and use it in GitHub Desktop.
const { resolve } = require('node:path');
const { JAVASCRIPT_FILES } = require('@vercel/style-guide/eslint/constants');
const project = resolve(__dirname, 'tsconfig.json');
/** @type {import('eslint').Linter.Config} */
module.exports = {
root: true,
extends: [
require.resolve('@vercel/style-guide/eslint/browser'),
require.resolve('@vercel/style-guide/eslint/node'),
require.resolve('@vercel/style-guide/eslint/react'),
require.resolve('@vercel/style-guide/eslint/next'),
require.resolve('@vercel/style-guide/eslint/typescript'),
],
parserOptions: { project },
settings: {
'import/resolver': { typescript: { project } },
/**
* enable MUI Joy components to be checked
* @see {@link https://github.com/jsx-eslint/eslint-plugin-jsx-a11y?tab=readme-ov-file#configurations}
*/
'jsx-a11y': {
polymorphicPropName: 'component',
components: {
Button: 'button',
Icon: 'svg',
IconButton: 'button',
Image: 'img',
Input: 'input',
Link: 'a',
List: 'ul',
ListDivider: 'li',
ListItem: 'li',
ListItemButton: 'button',
NextImage: 'img',
NextLink: 'a',
Textarea: 'textarea',
},
},
},
rules: {
'@typescript-eslint/explicit-function-return-type': 'off',
'@typescript-eslint/no-confusing-void-expression': [
'error',
{ ignoreArrowShorthand: true },
],
'@typescript-eslint/no-shadow': 'off',
'@typescript-eslint/no-misused-promises': [
'error',
{ checksVoidReturn: { attributes: false } },
],
'@typescript-eslint/restrict-template-expressions': [
'error',
{
allowAny: false,
allowBoolean: false,
allowNullish: false,
allowRegExp: false,
allowNever: false,
},
],
'react/function-component-definition': [
'warn',
{
namedComponents: 'arrow-function',
unnamedComponents: 'arrow-function',
},
],
'react/jsx-sort-props': [
'warn',
{
callbacksLast: true,
shorthandFirst: true,
multiline: 'last',
reservedFirst: true,
},
],
// sort import statements
'import/order': [
'warn',
{
groups: [
'builtin',
'external',
'internal',
'parent',
'sibling',
'index',
],
'newlines-between': 'always',
alphabetize: { order: 'asc' },
},
],
// sort named imports within an import statement
'sort-imports': ['warn', { ignoreDeclarationSort: true }],
},
overrides: [
/**
* JS files are using @babel/eslint-parser, so typed linting doesn't work there.
* @see {@link https://github.com/vercel/style-guide/blob/canary/eslint/_base.js}
* @see {@link https://typescript-eslint.io/linting/typed-linting#how-can-i-disable-type-aware-linting-for-a-subset-of-files}
*/
{
files: JAVASCRIPT_FILES,
extends: ['plugin:@typescript-eslint/disable-type-checked'],
},
// Varies file convention from libraries, e.g. Next.js App Router and Prettier
// Must use default export
{
files: [
'*.config.{mjs,ts}',
'src/app/**/{page,layout,not-found,*error,opengraph-image,apple-icon}.tsx',
'src/app/**/{sitemap,robots}.ts',
],
rules: {
'import/no-default-export': 'off',
'import/prefer-default-export': ['error', { target: 'any' }],
},
},
// module declarations
{
files: ['**/*.d.ts'],
rules: { 'import/no-default-export': 'off' },
},
],
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment