469 lines
16 KiB
JavaScript
469 lines
16 KiB
JavaScript
module.exports = {
|
|
rules: {
|
|
// enforce line breaks after opening and before closing array brackets
|
|
// http://eslint.org/docs/rules/array-bracket-newline
|
|
// TODO: enable? semver-major
|
|
'array-bracket-newline': ['off', 'consistent'], // object option alternative: { multiline: true, minItems: 3 }
|
|
|
|
// enforce line breaks between array elements
|
|
// http://eslint.org/docs/rules/array-element-newline
|
|
// TODO: enable? semver-major
|
|
'array-element-newline': ['off', { multiline: true, minItems: 3 }],
|
|
|
|
// enforce spacing inside array brackets
|
|
'array-bracket-spacing': ['error', 'never'],
|
|
|
|
// enforce spacing inside single-line blocks
|
|
// http://eslint.org/docs/rules/block-spacing
|
|
'block-spacing': ['error', 'always'],
|
|
|
|
// enforce one true brace style
|
|
'brace-style': ['error', '1tbs', { allowSingleLine: true }],
|
|
|
|
// require camel case names
|
|
camelcase: ['error', { properties: 'never' }],
|
|
|
|
// enforce or disallow capitalization of the first letter of a comment
|
|
// http://eslint.org/docs/rules/capitalized-comments
|
|
'capitalized-comments': ['off', 'never', {
|
|
line: {
|
|
ignorePattern: '.*',
|
|
ignoreInlineComments: true,
|
|
ignoreConsecutiveComments: true,
|
|
},
|
|
block: {
|
|
ignorePattern: '.*',
|
|
ignoreInlineComments: true,
|
|
ignoreConsecutiveComments: true,
|
|
},
|
|
}],
|
|
|
|
// require trailing commas in multiline object literals
|
|
'comma-dangle': ['error', {
|
|
arrays: 'always-multiline',
|
|
objects: 'always-multiline',
|
|
imports: 'always-multiline',
|
|
exports: 'always-multiline',
|
|
functions: 'always-multiline',
|
|
}],
|
|
|
|
// enforce spacing before and after comma
|
|
'comma-spacing': ['error', { before: false, after: true }],
|
|
|
|
// enforce one true comma style
|
|
'comma-style': ['error', 'last'],
|
|
|
|
// disallow padding inside computed properties
|
|
'computed-property-spacing': ['error', 'never'],
|
|
|
|
// enforces consistent naming when capturing the current execution context
|
|
'consistent-this': 'off',
|
|
|
|
// enforce newline at the end of file, with no multiple empty lines
|
|
'eol-last': ['error', 'always'],
|
|
|
|
// enforce spacing between functions and their invocations
|
|
// http://eslint.org/docs/rules/func-call-spacing
|
|
'func-call-spacing': ['error', 'never'],
|
|
|
|
// requires function names to match the name of the variable or property to which they are
|
|
// assigned
|
|
// http://eslint.org/docs/rules/func-name-matching
|
|
'func-name-matching': ['off', 'always', {
|
|
includeCommonJSModuleExports: false
|
|
}],
|
|
|
|
// require function expressions to have a name
|
|
// http://eslint.org/docs/rules/func-names
|
|
'func-names': 'warn',
|
|
|
|
// enforces use of function declarations or expressions
|
|
// http://eslint.org/docs/rules/func-style
|
|
// TODO: enable
|
|
'func-style': ['off', 'expression'],
|
|
|
|
// enforce consistent line breaks inside function parentheses
|
|
// https://eslint.org/docs/rules/function-paren-newline
|
|
'function-paren-newline': ['error', 'multiline'],
|
|
|
|
// Blacklist certain identifiers to prevent them being used
|
|
// http://eslint.org/docs/rules/id-blacklist
|
|
'id-blacklist': 'off',
|
|
|
|
// this option enforces minimum and maximum identifier lengths
|
|
// (variable names, property names etc.)
|
|
'id-length': 'off',
|
|
|
|
// require identifiers to match the provided regular expression
|
|
'id-match': 'off',
|
|
|
|
// this option sets a specific tab width for your code
|
|
// http://eslint.org/docs/rules/indent
|
|
indent: ['error', 2, {
|
|
SwitchCase: 1,
|
|
VariableDeclarator: 1,
|
|
outerIIFEBody: 1,
|
|
// MemberExpression: null,
|
|
FunctionDeclaration: {
|
|
parameters: 1,
|
|
body: 1
|
|
},
|
|
FunctionExpression: {
|
|
parameters: 1,
|
|
body: 1
|
|
},
|
|
CallExpression: {
|
|
arguments: 1
|
|
},
|
|
ArrayExpression: 1,
|
|
ObjectExpression: 1,
|
|
ImportDeclaration: 1,
|
|
flatTernaryExpressions: false,
|
|
ignoredNodes: ['JSXElement', 'JSXElement *']
|
|
}],
|
|
|
|
// specify whether double or single quotes should be used in JSX attributes
|
|
// http://eslint.org/docs/rules/jsx-quotes
|
|
'jsx-quotes': ['off', 'prefer-double'],
|
|
|
|
// enforces spacing between keys and values in object literal properties
|
|
'key-spacing': ['error', { beforeColon: false, afterColon: true }],
|
|
|
|
// require a space before & after certain keywords
|
|
'keyword-spacing': ['error', {
|
|
before: true,
|
|
after: true,
|
|
overrides: {
|
|
return: { after: true },
|
|
throw: { after: true },
|
|
case: { after: true }
|
|
}
|
|
}],
|
|
|
|
// enforce position of line comments
|
|
// http://eslint.org/docs/rules/line-comment-position
|
|
// TODO: enable?
|
|
'line-comment-position': ['off', {
|
|
position: 'above',
|
|
ignorePattern: '',
|
|
applyDefaultPatterns: true,
|
|
}],
|
|
|
|
// disallow mixed 'LF' and 'CRLF' as linebreaks
|
|
// http://eslint.org/docs/rules/linebreak-style
|
|
'linebreak-style': ['error', 'unix'],
|
|
|
|
// require or disallow an empty line between class members
|
|
// https://eslint.org/docs/rules/lines-between-class-members
|
|
// TODO: semver-major: enable
|
|
'lines-between-class-members': ['off', 'always', { exceptAfterSingleLine: false }],
|
|
|
|
// enforces empty lines around comments
|
|
'lines-around-comment': 'off',
|
|
|
|
// require or disallow newlines around directives
|
|
// http://eslint.org/docs/rules/lines-around-directive
|
|
'lines-around-directive': ['error', {
|
|
before: 'always',
|
|
after: 'always',
|
|
}],
|
|
|
|
// specify the maximum depth that blocks can be nested
|
|
'max-depth': ['off', 4],
|
|
|
|
// specify the maximum length of a line in your program
|
|
// http://eslint.org/docs/rules/max-len
|
|
'max-len': ['error', 100, 2, {
|
|
ignoreUrls: true,
|
|
ignoreComments: false,
|
|
ignoreRegExpLiterals: true,
|
|
ignoreStrings: true,
|
|
ignoreTemplateLiterals: true,
|
|
}],
|
|
|
|
// specify the max number of lines in a file
|
|
// http://eslint.org/docs/rules/max-lines
|
|
'max-lines': ['off', {
|
|
max: 300,
|
|
skipBlankLines: true,
|
|
skipComments: true
|
|
}],
|
|
|
|
// specify the maximum depth callbacks can be nested
|
|
'max-nested-callbacks': 'off',
|
|
|
|
// limits the number of parameters that can be used in the function declaration.
|
|
'max-params': ['off', 3],
|
|
|
|
// specify the maximum number of statement allowed in a function
|
|
'max-statements': ['off', 10],
|
|
|
|
// restrict the number of statements per line
|
|
// http://eslint.org/docs/rules/max-statements-per-line
|
|
'max-statements-per-line': ['off', { max: 1 }],
|
|
|
|
// enforce a particular style for multiline comments
|
|
// https://eslint.org/docs/rules/multiline-comment-style
|
|
'multiline-comment-style': ['off', 'starred-block'],
|
|
|
|
// require multiline ternary
|
|
// http://eslint.org/docs/rules/multiline-ternary
|
|
// TODO: enable?
|
|
'multiline-ternary': ['off', 'never'],
|
|
|
|
// require a capital letter for constructors
|
|
'new-cap': ['error', {
|
|
newIsCap: true,
|
|
newIsCapExceptions: [],
|
|
capIsNew: false,
|
|
capIsNewExceptions: ['Immutable.Map', 'Immutable.Set', 'Immutable.List'],
|
|
}],
|
|
|
|
// disallow the omission of parentheses when invoking a constructor with no arguments
|
|
// http://eslint.org/docs/rules/new-parens
|
|
'new-parens': 'error',
|
|
|
|
// allow/disallow an empty newline after var statement
|
|
'newline-after-var': 'off',
|
|
|
|
// http://eslint.org/docs/rules/newline-before-return
|
|
'newline-before-return': 'off',
|
|
|
|
// enforces new line after each method call in the chain to make it
|
|
// more readable and easy to maintain
|
|
// http://eslint.org/docs/rules/newline-per-chained-call
|
|
'newline-per-chained-call': ['error', { ignoreChainWithDepth: 4 }],
|
|
|
|
// disallow use of the Array constructor
|
|
'no-array-constructor': 'error',
|
|
|
|
// disallow use of bitwise operators
|
|
// http://eslint.org/docs/rules/no-bitwise
|
|
'no-bitwise': 'error',
|
|
|
|
// disallow use of the continue statement
|
|
// http://eslint.org/docs/rules/no-continue
|
|
'no-continue': 'error',
|
|
|
|
// disallow comments inline after code
|
|
'no-inline-comments': 'off',
|
|
|
|
// disallow if as the only statement in an else block
|
|
// http://eslint.org/docs/rules/no-lonely-if
|
|
'no-lonely-if': 'error',
|
|
|
|
// disallow un-paren'd mixes of different operators
|
|
// http://eslint.org/docs/rules/no-mixed-operators
|
|
'no-mixed-operators': ['error', {
|
|
groups: [
|
|
['+', '-', '*', '/', '%', '**'],
|
|
['&', '|', '^', '~', '<<', '>>', '>>>'],
|
|
['==', '!=', '===', '!==', '>', '>=', '<', '<='],
|
|
['&&', '||'],
|
|
['in', 'instanceof']
|
|
],
|
|
allowSamePrecedence: false
|
|
}],
|
|
|
|
// disallow mixed spaces and tabs for indentation
|
|
'no-mixed-spaces-and-tabs': 'error',
|
|
|
|
// disallow use of chained assignment expressions
|
|
// http://eslint.org/docs/rules/no-multi-assign
|
|
'no-multi-assign': ['error'],
|
|
|
|
// disallow multiple empty lines and only one newline at the end
|
|
'no-multiple-empty-lines': ['error', { max: 2, maxEOF: 1 }],
|
|
|
|
// disallow negated conditions
|
|
// http://eslint.org/docs/rules/no-negated-condition
|
|
'no-negated-condition': 'off',
|
|
|
|
// disallow nested ternary expressions
|
|
'no-nested-ternary': 'error',
|
|
|
|
// disallow use of the Object constructor
|
|
'no-new-object': 'error',
|
|
|
|
// disallow use of unary operators, ++ and --
|
|
// http://eslint.org/docs/rules/no-plusplus
|
|
'no-plusplus': 'error',
|
|
|
|
// disallow certain syntax forms
|
|
// http://eslint.org/docs/rules/no-restricted-syntax
|
|
'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: '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.',
|
|
},
|
|
],
|
|
|
|
// disallow space between function identifier and application
|
|
'no-spaced-func': 'error',
|
|
|
|
// disallow tab characters entirely
|
|
'no-tabs': 'error',
|
|
|
|
// disallow the use of ternary operators
|
|
'no-ternary': 'off',
|
|
|
|
// disallow trailing whitespace at the end of lines
|
|
'no-trailing-spaces': ['error', {
|
|
skipBlankLines: false,
|
|
ignoreComments: false,
|
|
}],
|
|
|
|
// disallow dangling underscores in identifiers
|
|
'no-underscore-dangle': ['error', {
|
|
allow: [],
|
|
allowAfterThis: false,
|
|
allowAfterSuper: false,
|
|
enforceInMethodNames: false,
|
|
}],
|
|
|
|
// disallow the use of Boolean literals in conditional expressions
|
|
// also, prefer `a || b` over `a ? a : b`
|
|
// http://eslint.org/docs/rules/no-unneeded-ternary
|
|
'no-unneeded-ternary': ['error', { defaultAssignment: false }],
|
|
|
|
// disallow whitespace before properties
|
|
// http://eslint.org/docs/rules/no-whitespace-before-property
|
|
'no-whitespace-before-property': 'error',
|
|
|
|
// enforce the location of single-line statements
|
|
// http://eslint.org/docs/rules/nonblock-statement-body-position
|
|
'nonblock-statement-body-position': 'off',
|
|
|
|
// require padding inside curly braces
|
|
'object-curly-spacing': ['error', 'always'],
|
|
|
|
// enforce line breaks between braces
|
|
// http://eslint.org/docs/rules/object-curly-newline
|
|
'object-curly-newline': ['error', {
|
|
ObjectExpression: { minProperties: 4, multiline: true, consistent: true },
|
|
ObjectPattern: { minProperties: 4, multiline: true, consistent: true }
|
|
}],
|
|
|
|
// enforce "same line" or "multiple line" on object properties.
|
|
// http://eslint.org/docs/rules/object-property-newline
|
|
'object-property-newline': ['error', {
|
|
allowMultiplePropertiesPerLine: true,
|
|
}],
|
|
|
|
// allow just one var statement per function
|
|
'one-var': ['error', 'never'],
|
|
|
|
// require a newline around variable declaration
|
|
// http://eslint.org/docs/rules/one-var-declaration-per-line
|
|
'one-var-declaration-per-line': ['error', 'always'],
|
|
|
|
// require assignment operator shorthand where possible or prohibit it entirely
|
|
// http://eslint.org/docs/rules/operator-assignment
|
|
'operator-assignment': ['error', 'always'],
|
|
|
|
// enforce operators to be placed before or after line breaks
|
|
'operator-linebreak': 'off',
|
|
|
|
// disallow padding within blocks
|
|
'padded-blocks': ['error', { blocks: 'never', classes: 'never', switches: 'never' }],
|
|
|
|
// Require or disallow padding lines between statements
|
|
// http://eslint.org/docs/rules/padding-line-between-statements
|
|
'padding-line-between-statements': 'off',
|
|
|
|
// require quotes around object literal property names
|
|
// http://eslint.org/docs/rules/quote-props.html
|
|
'quote-props': ['error', 'as-needed', { keywords: false, unnecessary: true, numbers: false }],
|
|
|
|
// specify whether double or single quotes should be used
|
|
quotes: ['error', 'single', { avoidEscape: true }],
|
|
|
|
// do not require jsdoc
|
|
// http://eslint.org/docs/rules/require-jsdoc
|
|
'require-jsdoc': 'off',
|
|
|
|
// require or disallow use of semicolons instead of ASI
|
|
semi: ['error', 'always'],
|
|
|
|
// enforce spacing before and after semicolons
|
|
'semi-spacing': ['error', { before: false, after: true }],
|
|
|
|
// Enforce location of semicolons
|
|
// http://eslint.org/docs/rules/semi-style
|
|
'semi-style': ['error', 'last'],
|
|
|
|
// requires object keys to be sorted
|
|
'sort-keys': ['off', 'asc', { caseSensitive: false, natural: true }],
|
|
|
|
// sort variables within the same declaration block
|
|
'sort-vars': 'off',
|
|
|
|
// require or disallow space before blocks
|
|
'space-before-blocks': 'error',
|
|
|
|
// require or disallow space before function opening parenthesis
|
|
// http://eslint.org/docs/rules/space-before-function-paren
|
|
'space-before-function-paren': ['error', {
|
|
anonymous: 'always',
|
|
named: 'never',
|
|
asyncArrow: 'always'
|
|
}],
|
|
|
|
// require or disallow spaces inside parentheses
|
|
'space-in-parens': ['error', 'never'],
|
|
|
|
// require spaces around operators
|
|
'space-infix-ops': 'error',
|
|
|
|
// Require or disallow spaces before/after unary operators
|
|
// http://eslint.org/docs/rules/space-unary-ops
|
|
'space-unary-ops': ['error', {
|
|
words: true,
|
|
nonwords: false,
|
|
overrides: {
|
|
},
|
|
}],
|
|
|
|
// require or disallow a space immediately following the // or /* in a comment
|
|
// http://eslint.org/docs/rules/spaced-comment
|
|
'spaced-comment': ['error', 'always', {
|
|
line: {
|
|
exceptions: ['-', '+'],
|
|
markers: ['=', '!'], // space here to support sprockets directives
|
|
},
|
|
block: {
|
|
exceptions: ['-', '+'],
|
|
markers: ['=', '!'], // space here to support sprockets directives
|
|
balanced: true,
|
|
}
|
|
}],
|
|
|
|
// Enforce spacing around colons of switch statements
|
|
// http://eslint.org/docs/rules/switch-colon-spacing
|
|
'switch-colon-spacing': ['error', { after: true, before: false }],
|
|
|
|
// Require or disallow spacing between template tags and their literals
|
|
// http://eslint.org/docs/rules/template-tag-spacing
|
|
'template-tag-spacing': ['error', 'never'],
|
|
|
|
// require or disallow the Unicode Byte Order Mark
|
|
// http://eslint.org/docs/rules/unicode-bom
|
|
'unicode-bom': ['error', 'never'],
|
|
|
|
// require regex literals to be wrapped in parentheses
|
|
'wrap-regex': 'off'
|
|
}
|
|
};
|