mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
chore(ui): use new eslint config, add some overrides
This commit is contained in:
parent
aa134a2db8
commit
26c3378ede
@ -1,131 +1,9 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
env: {
|
extends: ['@invoke-ai/eslint-config-react'],
|
||||||
browser: true,
|
|
||||||
es6: true,
|
|
||||||
node: true,
|
|
||||||
},
|
|
||||||
extends: [
|
|
||||||
'eslint:recommended',
|
|
||||||
'plugin:@typescript-eslint/recommended',
|
|
||||||
'plugin:react/recommended',
|
|
||||||
'plugin:react-hooks/recommended',
|
|
||||||
'plugin:react/jsx-runtime',
|
|
||||||
'prettier',
|
|
||||||
'plugin:storybook/recommended',
|
|
||||||
],
|
|
||||||
parser: '@typescript-eslint/parser',
|
|
||||||
parserOptions: {
|
|
||||||
ecmaFeatures: {
|
|
||||||
jsx: true,
|
|
||||||
},
|
|
||||||
ecmaVersion: 2018,
|
|
||||||
sourceType: 'module',
|
|
||||||
},
|
|
||||||
plugins: [
|
|
||||||
'react',
|
|
||||||
'@typescript-eslint',
|
|
||||||
'eslint-plugin-react-hooks',
|
|
||||||
'i18next',
|
|
||||||
'path',
|
|
||||||
'unused-imports',
|
|
||||||
'simple-import-sort',
|
|
||||||
'eslint-plugin-import',
|
|
||||||
// These rules are too strict for normal usage, but are useful for optimizing rerenders
|
|
||||||
// '@arthurgeron/react-usememo',
|
|
||||||
],
|
|
||||||
root: true,
|
|
||||||
rules: {
|
rules: {
|
||||||
'path/no-relative-imports': ['error', { maxDepth: 0 }],
|
// TODO(psyche): Enable this rule. Requires no default exports in components - many changes.
|
||||||
curly: 'error',
|
'react-refresh/only-export-components': 'off',
|
||||||
'i18next/no-literal-string': 'warn',
|
// TODO(psyche): Enable this rule. Requires a lot of eslint-disable-next-line comments.
|
||||||
'react/jsx-no-bind': ['error', { allowBind: true }],
|
'@typescript-eslint/consistent-type-assertions': 'off',
|
||||||
'react/jsx-curly-brace-presence': [
|
|
||||||
'error',
|
|
||||||
{ props: 'never', children: 'never' },
|
|
||||||
],
|
|
||||||
'react-hooks/exhaustive-deps': 'error',
|
|
||||||
'no-var': 'error',
|
|
||||||
'brace-style': 'error',
|
|
||||||
'prefer-template': 'error',
|
|
||||||
'import/no-duplicates': 'error',
|
|
||||||
radix: 'error',
|
|
||||||
'space-before-blocks': 'error',
|
|
||||||
'import/prefer-default-export': '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: '^_',
|
|
||||||
},
|
|
||||||
],
|
|
||||||
// These rules are too strict for normal usage, but are useful for optimizing rerenders
|
|
||||||
// '@arthurgeron/react-usememo/require-usememo': [
|
|
||||||
// 'warn',
|
|
||||||
// {
|
|
||||||
// strict: false,
|
|
||||||
// checkHookReturnObject: false,
|
|
||||||
// fix: { addImports: true },
|
|
||||||
// checkHookCalls: false,
|
|
||||||
|
|
||||||
// },
|
|
||||||
// ],
|
|
||||||
// '@arthurgeron/react-usememo/require-memo': 'warn',
|
|
||||||
'@typescript-eslint/ban-ts-comment': 'warn',
|
|
||||||
'@typescript-eslint/no-explicit-any': 'warn',
|
|
||||||
'@typescript-eslint/no-empty-interface': [
|
|
||||||
'error',
|
|
||||||
{
|
|
||||||
allowSingleExtends: true,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
'@typescript-eslint/consistent-type-imports': [
|
|
||||||
'error',
|
|
||||||
{
|
|
||||||
prefer: 'type-imports',
|
|
||||||
fixStyle: 'separate-type-imports',
|
|
||||||
disallowTypeAnnotations: true,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
'@typescript-eslint/no-import-type-side-effects': 'error',
|
|
||||||
'simple-import-sort/imports': 'error',
|
|
||||||
'simple-import-sort/exports': 'error',
|
|
||||||
// Prefer @invoke-ai/ui components over chakra
|
|
||||||
'no-restricted-imports': 'off',
|
|
||||||
'@typescript-eslint/no-restricted-imports': [
|
|
||||||
'warn',
|
|
||||||
{
|
|
||||||
paths: [
|
|
||||||
{
|
|
||||||
name: '@chakra-ui/react',
|
|
||||||
message: "Please import from '@invoke-ai/ui' instead.",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '@chakra-ui/layout',
|
|
||||||
message: "Please import from '@invoke-ai/ui' instead.",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: '@chakra-ui/portal',
|
|
||||||
message: "Please import from '@invoke-ai/ui' instead.",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
overrides: [
|
|
||||||
{
|
|
||||||
files: ['*.stories.tsx'],
|
|
||||||
rules: {
|
|
||||||
'i18next/no-literal-string': 'off',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
],
|
|
||||||
settings: {
|
|
||||||
react: {
|
|
||||||
version: 'detect',
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user