mirror of
https://github.com/twentyhq/twenty.git
synced 2024-12-18 17:12:53 +03:00
3c4ab605db
* Fixed color rule * Fixed naming * Fix effect component rule * Deactivated broken rules * Fixed lint * Complete eslint-plugin-twenty work --------- Co-authored-by: Charles Bochet <charles@twenty.com>
94 lines
2.6 KiB
JavaScript
94 lines
2.6 KiB
JavaScript
module.exports = {
|
|
parser: '@typescript-eslint/parser',
|
|
parserOptions: {
|
|
project: 'tsconfig.json',
|
|
tsconfigRootDir: __dirname,
|
|
sourceType: 'module',
|
|
},
|
|
plugins: [
|
|
'@typescript-eslint/eslint-plugin',
|
|
'unused-imports',
|
|
'simple-import-sort',
|
|
'prefer-arrow',
|
|
'twenty',
|
|
],
|
|
extends: [
|
|
'plugin:@typescript-eslint/recommended',
|
|
'plugin:prettier/recommended',
|
|
'plugin:storybook/recommended',
|
|
'react-app',
|
|
],
|
|
root: true,
|
|
env: {
|
|
node: true,
|
|
jest: true,
|
|
},
|
|
overrides: [
|
|
{
|
|
files: ['*.js', '*.jsx', '*.ts', '*.tsx'],
|
|
rules: {
|
|
'no-control-regex': 0,
|
|
'simple-import-sort/imports': [
|
|
'error',
|
|
{
|
|
groups: [
|
|
['^react', '^@?\\w'],
|
|
['^(@|~)(/.*|$)'],
|
|
['^\\u0000'],
|
|
['^\\.\\.(?!/?$)', '^\\.\\./?$'],
|
|
['^\\./(?=.*/)(?!/?$)', '^\\.(?!/?$)', '^\\./?$'],
|
|
['^.+\\.?(css)$']
|
|
]
|
|
}
|
|
],
|
|
'prefer-arrow/prefer-arrow-functions': [
|
|
'error',
|
|
{
|
|
"disallowPrototype": true,
|
|
"singleReturnOnly": false,
|
|
"classPropertiesAllowed": false
|
|
}
|
|
]
|
|
}
|
|
},
|
|
],
|
|
ignorePatterns: ['.eslintrc.js', 'codegen.js', '**/generated/*', '*.config.js'],
|
|
rules: {
|
|
'@typescript-eslint/interface-name-prefix': 'off',
|
|
'@typescript-eslint/explicit-function-return-type': 'off',
|
|
'@typescript-eslint/explicit-module-boundary-types': 'off',
|
|
'@typescript-eslint/no-explicit-any': 'off',
|
|
'simple-import-sort/imports': 'error',
|
|
'simple-import-sort/exports': 'error',
|
|
'twenty/effect-components': 'error',
|
|
'twenty/no-hardcoded-colors': 'error',
|
|
'twenty/matching-state-variable': 'error',
|
|
'twenty/sort-css-properties-alphabetically': 'error',
|
|
'twenty/styled-components-prefixed-with-styled': 'error',
|
|
'func-style':['error', 'declaration', { 'allowArrowFunctions': true }],
|
|
"@typescript-eslint/no-unused-vars": "off",
|
|
"no-unused-vars": "off",
|
|
"react-hooks/exhaustive-deps": [
|
|
"warn", {
|
|
"additionalHooks": "useRecoilCallback"
|
|
}
|
|
],
|
|
"unused-imports/no-unused-imports": "warn",
|
|
"unused-imports/no-unused-vars": [
|
|
"warn",
|
|
{ "vars": "all", "varsIgnorePattern": "^_", "args": "after-used", "argsIgnorePattern": "^_" }
|
|
],
|
|
'no-restricted-imports': [
|
|
'error',
|
|
{
|
|
'patterns': [
|
|
{
|
|
'group': ['@tabler/icons-react'],
|
|
'message': 'Icon imports are only allowed for `@/ui/icon`',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
}
|
|
};
|