feat: replace eslint configs on server and client side to inherit rules from eslint-config-nodebb
parent
5e6b8433a3
commit
f653a6ff6a
@ -1,115 +1,3 @@
|
|||||||
{
|
{
|
||||||
"extends": "airbnb-base",
|
"extends": "nodebb"
|
||||||
"parserOptions": {
|
|
||||||
"sourceType": "script"
|
|
||||||
},
|
|
||||||
|
|
||||||
"rules": {
|
|
||||||
// === Configure rules for our style ===
|
|
||||||
// imports must be resolvable
|
|
||||||
"import/no-unresolved": "error",
|
|
||||||
// use single quotes,
|
|
||||||
// unless a different style allows avoiding escapes
|
|
||||||
"quotes": ["error", "single", {
|
|
||||||
"avoidEscape": true,
|
|
||||||
"allowTemplateLiterals": true
|
|
||||||
}],
|
|
||||||
// allow else-if return
|
|
||||||
"no-else-return": [ "error", { "allowElseIf": true } ],
|
|
||||||
// expressions split over multiple lines
|
|
||||||
// should break after the operator
|
|
||||||
"operator-linebreak": [ "error", "after" ],
|
|
||||||
// require arrow parens only when needed
|
|
||||||
// and whenever the body is a block
|
|
||||||
"arrow-parens": ["error", "as-needed", { "requireForBlockBody": true }],
|
|
||||||
// what variables are errors in callbacks
|
|
||||||
"handle-callback-err": [ "error","^(e$|(e|(.*(_e|E)))rr)" ],
|
|
||||||
// allow dangling commas in functions
|
|
||||||
// require them everywhere else
|
|
||||||
"comma-dangle": ["error", {
|
|
||||||
"arrays": "always-multiline",
|
|
||||||
"objects": "always-multiline",
|
|
||||||
"imports": "always-multiline",
|
|
||||||
"exports": "always-multiline",
|
|
||||||
"functions": "only-multiline"
|
|
||||||
}],
|
|
||||||
// we actually encourage `return await`
|
|
||||||
"no-return-await": "off",
|
|
||||||
// allow `while (true)`
|
|
||||||
"no-constant-condition": ["error", { "checkLoops": false }],
|
|
||||||
// allow ignoring an error with `catch`
|
|
||||||
"no-empty": ["error", { "allowEmptyCatch": true }],
|
|
||||||
// allow `3 + 5 - 1`, but not `3 * 5 - 1`
|
|
||||||
"no-mixed-operators": ["error", { "allowSamePrecedence": true }],
|
|
||||||
// require `'use strict';`
|
|
||||||
"strict": ["error", "global"],
|
|
||||||
// we actually use tabs for indentation
|
|
||||||
"indent": ["error", "tab", { "SwitchCase": 1 }],
|
|
||||||
"no-tabs": "off",
|
|
||||||
// we want `== null` to also handle undefined
|
|
||||||
"no-eq-null": "off",
|
|
||||||
// allow `for (..; i++)`
|
|
||||||
"no-plusplus": ["error", { "allowForLoopAfterthoughts": true }],
|
|
||||||
// allow using functions defined later
|
|
||||||
"no-use-before-define": ["error", "nofunc"],
|
|
||||||
// require consistent newlines before and after braces
|
|
||||||
// if contents are multiline
|
|
||||||
"object-curly-newline": ["error", { "consistent": true, "multiline": true }],
|
|
||||||
// require consistent linebreaks inline function parenthesis (arguments or params)
|
|
||||||
"function-paren-newline": ["error", "consistent"],
|
|
||||||
// only require const if all parts of destructuring can be const
|
|
||||||
"prefer-const": ["error", { "destructuring": "all" }],
|
|
||||||
// don't require destructuring for arrays or assignment
|
|
||||||
"prefer-destructuring": ["error", {
|
|
||||||
"VariableDeclarator": { "array": false, "object": true },
|
|
||||||
"AssignmentExpression": { "array": false, "object": false }
|
|
||||||
}],
|
|
||||||
// identical to airbnb rule, except for allowing for..of, because we want to use it
|
|
||||||
"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."
|
|
||||||
}
|
|
||||||
],
|
|
||||||
// allow lines of up to 120 characters
|
|
||||||
"max-len": ["error", { "code": 120, "tabWidth": 2, "ignoreUrls": true, "ignoreStrings": true, "ignoreTemplateLiterals": true, "ignoreRegExpLiterals": true }],
|
|
||||||
|
|
||||||
// === Disable rules ===
|
|
||||||
// more liberal naming
|
|
||||||
"camelcase": "off",
|
|
||||||
"no-underscore-dangle": "off",
|
|
||||||
// don't require anonymous function names
|
|
||||||
"func-names": "off",
|
|
||||||
// allow console
|
|
||||||
"no-console": "off",
|
|
||||||
// allow new for side effects
|
|
||||||
// allow new with non-capitalized
|
|
||||||
"no-new": "off",
|
|
||||||
"new-cap": "off",
|
|
||||||
// allow shadowing variables (usually callbacks)
|
|
||||||
"no-shadow": "off",
|
|
||||||
// allow multiple empty lines in a row
|
|
||||||
"no-multiple-empty-lines": "off",
|
|
||||||
// allow not using object shorthand
|
|
||||||
"object-shorthand": "off",
|
|
||||||
|
|
||||||
// TODO
|
|
||||||
"consistent-return": "off",
|
|
||||||
"no-restricted-globals": "off",
|
|
||||||
"no-prototype-builtins": "off",
|
|
||||||
"import/no-extraneous-dependencies": "off",
|
|
||||||
"import/no-dynamic-require": "off",
|
|
||||||
"global-require": "off",
|
|
||||||
"no-param-reassign": "off",
|
|
||||||
"default-case": "off"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,82 +1,3 @@
|
|||||||
{
|
{
|
||||||
"globals": {
|
"extends": "nodebb/public"
|
||||||
"app": true,
|
|
||||||
"io": true,
|
|
||||||
"socket": true,
|
|
||||||
"ajaxify": true,
|
|
||||||
"config": true,
|
|
||||||
"utils": true,
|
|
||||||
"overrides": true,
|
|
||||||
"componentHandler": true,
|
|
||||||
"bootbox": true,
|
|
||||||
"Visibility": true,
|
|
||||||
"Tinycon": true,
|
|
||||||
"Promise": true
|
|
||||||
},
|
|
||||||
"env": {
|
|
||||||
"jquery": true,
|
|
||||||
"amd": true,
|
|
||||||
"browser": true,
|
|
||||||
"es6": true
|
|
||||||
},
|
|
||||||
"rules": {
|
|
||||||
"comma-dangle": ["error", {
|
|
||||||
"arrays": "always-multiline",
|
|
||||||
"objects": "always-multiline",
|
|
||||||
"imports": "always-multiline",
|
|
||||||
"exports": "always-multiline",
|
|
||||||
"functions": "never"
|
|
||||||
}],
|
|
||||||
"block-scoped-var": "off",
|
|
||||||
"no-dupe-class-members": "off",
|
|
||||||
"prefer-object-spread": "off",
|
|
||||||
"prefer-reflect": "off",
|
|
||||||
|
|
||||||
// ES6
|
|
||||||
"prefer-rest-params": "off",
|
|
||||||
"prefer-spread": "off",
|
|
||||||
"prefer-arrow-callback": "off",
|
|
||||||
"prefer-template": "off",
|
|
||||||
"no-var": "off",
|
|
||||||
"object-shorthand": "off",
|
|
||||||
"vars-on-top": "off",
|
|
||||||
"prefer-destructuring": "off",
|
|
||||||
// identical to airbnb rule
|
|
||||||
// except for allowing for..in, because for..of is unavailable on some clients
|
|
||||||
"no-restricted-syntax": [
|
|
||||||
"error",
|
|
||||||
{
|
|
||||||
"selector": "ForOfStatement",
|
|
||||||
"message": "iterators/generators require regenerator-runtime, which is too heavyweight for this guide to allow them. Separately, loops should be avoided in favor of array iterations."
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"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."
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"parserOptions": {
|
|
||||||
"ecmaVersion": 2018,
|
|
||||||
"ecmaFeatures": {
|
|
||||||
"classes": false,
|
|
||||||
"defaultParams": false,
|
|
||||||
"blockBindings": false,
|
|
||||||
"forOf": false,
|
|
||||||
"generators": false,
|
|
||||||
"globalReturn": false,
|
|
||||||
"jsx": false,
|
|
||||||
"modules": false,
|
|
||||||
"objectLiteralComputedProperties": false,
|
|
||||||
"objectLiteralDuplicateProperties": false,
|
|
||||||
"objectLiteralShorthandMethods": false,
|
|
||||||
"objectLiteralShorthandProperties": false,
|
|
||||||
"impliedStrict": false,
|
|
||||||
"restParams": false,
|
|
||||||
"superInFunctions": false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue