mirror of
https://github.com/danog/telegram-tt.git
synced 2024-11-26 12:24:46 +01:00
115 lines
3.4 KiB
Plaintext
115 lines
3.4 KiB
Plaintext
{
|
|
"extends": [
|
|
"react-app",
|
|
"plugin:teactn/recommended",
|
|
"airbnb",
|
|
"airbnb-typescript"
|
|
],
|
|
"plugins": [
|
|
"no-async-without-await",
|
|
"teactn",
|
|
"no-null"
|
|
],
|
|
"rules": {
|
|
"indent": [
|
|
"error",
|
|
2,
|
|
{
|
|
"SwitchCase": 1
|
|
}
|
|
],
|
|
"max-len": [
|
|
"error",
|
|
120
|
|
],
|
|
"array-bracket-newline": [
|
|
2,
|
|
"consistent"
|
|
],
|
|
"no-null/no-null": 2,
|
|
"no-console": "error",
|
|
"semi": "error",
|
|
"no-implicit-coercion": "error",
|
|
"react-hooks/exhaustive-deps": "error",
|
|
"arrow-body-style": "off",
|
|
"no-else-return": "off",
|
|
"no-plusplus": "off",
|
|
"no-void": "off",
|
|
"no-continue": "off",
|
|
"default-case": "off",
|
|
"no-param-reassign": "off",
|
|
"no-prototype-builtins": "off",
|
|
"no-await-in-loop": "off",
|
|
"no-nested-ternary": "off",
|
|
"function-paren-newline": ["error", "consistent"],
|
|
"prefer-destructuring": "off",
|
|
// Allow for...of. Edited from:
|
|
// https://github.com/airbnb/javascript/blob/b4377fb03089dd7f08955242695860d47f9caab4/packages/eslint-config-airbnb-base/rules/style.js#L333
|
|
"no-restricted-syntax": [
|
|
"error",
|
|
{
|
|
"selector": "ForInStatement",
|
|
"message": "for..in loops iterate over the entire prototype chain, which is virtually never what you want. Use Object.{keys,values,entries}, and iterate over the resulting array."
|
|
},
|
|
{
|
|
"selector": "LabeledStatement",
|
|
"message": "Labels are a form of GOTO; using them makes code confusing and hard to maintain and understand."
|
|
},
|
|
{
|
|
"selector": "WithStatement",
|
|
"message": "`with` is disallowed in strict mode because it makes code impossible to predict and optimize."
|
|
}
|
|
],
|
|
"import/no-extraneous-dependencies": "off",
|
|
"import/prefer-default-export": "off",
|
|
"import/named": "off",
|
|
"import/no-webpack-loader-syntax": "off",
|
|
"react/prop-types": "off",
|
|
"react/jsx-one-expression-per-line": "off",
|
|
"react/button-has-type": "off",
|
|
"react/require-default-props": "off",
|
|
"react/function-component-definition": "off",
|
|
// Teact feature
|
|
"react/style-prop-object": "off",
|
|
"react/jsx-no-bind": ["error", {
|
|
"ignoreRefs": true,
|
|
"allowArrowFunctions": false,
|
|
"allowFunctions": false,
|
|
"allowBind": false,
|
|
"ignoreDOMComponents": true
|
|
}],
|
|
"jsx-a11y/click-events-have-key-events": "off",
|
|
"jsx-a11y/no-static-element-interactions": "off",
|
|
"jsx-a11y/label-has-associated-control": "off",
|
|
"jsx-a11y/anchor-is-valid": "off",
|
|
"jsx-a11y/no-noninteractive-element-to-interactive-role": "off",
|
|
"jsx-a11y/media-has-caption": "off",
|
|
"no-async-without-await/no-async-without-await": 1,
|
|
"@typescript-eslint/no-use-before-define": [
|
|
"error",
|
|
{
|
|
"functions": false
|
|
}
|
|
],
|
|
"@typescript-eslint/camelcase": "off",
|
|
"@typescript-eslint/member-delimiter-style": "error",
|
|
"@typescript-eslint/default-param-last": "off",
|
|
"@typescript-eslint/return-await": ["error", "in-try-catch"],
|
|
"@typescript-eslint/consistent-type-imports": [
|
|
"error",
|
|
{
|
|
"prefer": "type-imports",
|
|
"disallowTypeAnnotations": false
|
|
}
|
|
],
|
|
"teactn/prefer-separate-component-file": "off"
|
|
},
|
|
"settings": {
|
|
"import/resolver": "webpack",
|
|
"import/core-modules": ["fs", "path"]
|
|
},
|
|
"parserOptions": {
|
|
"project": "./tsconfig.json"
|
|
}
|
|
}
|