123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529 |
- const semver = require('semver');
- const eslintPkg = require('eslint/package.json');
- module.exports = {
- rules: {
- // enforce line breaks after opening and before closing array brackets
- // https://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
- // https://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
- // https://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', ignoreDestructuring: false }],
- // enforce or disallow capitalization of the first letter of a comment
- // https://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', {
- exceptions: {
- ArrayExpression: false,
- ArrayPattern: false,
- ArrowFunctionExpression: false,
- CallExpression: false,
- FunctionDeclaration: false,
- FunctionExpression: false,
- ImportDeclaration: false,
- ObjectExpression: false,
- ObjectPattern: false,
- VariableDeclaration: false,
- NewExpression: false,
- }
- }],
- // 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'],
- // https://eslint.org/docs/rules/function-call-argument-newline
- 'function-call-argument-newline': ['error', 'consistent'],
- // enforce spacing between functions and their invocations
- // https://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
- // https://eslint.org/docs/rules/func-name-matching
- 'func-name-matching': ['off', 'always', {
- includeCommonJSModuleExports: false,
- considerPropertyDescriptor: true,
- }],
- // require function expressions to have a name
- // https://eslint.org/docs/rules/func-names
- 'func-names': 'warn',
- // enforces use of function declarations or expressions
- // https://eslint.org/docs/rules/func-style
- // TODO: enable
- 'func-style': ['off', 'expression'],
- // require line breaks inside function parentheses if there are line breaks between parameters
- // https://eslint.org/docs/rules/function-paren-newline
- 'function-paren-newline': ['error', semver.satisfies(eslintPkg.version, '>= 6') ? 'multiline-arguments' : 'consistent'],
- // disallow specified identifiers
- // https://eslint.org/docs/rules/id-denylist
- 'id-denylist': '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',
- // Enforce the location of arrow function bodies with implicit returns
- // https://eslint.org/docs/rules/implicit-arrow-linebreak
- 'implicit-arrow-linebreak': ['error', 'beside'],
- // this option sets a specific tab width for your code
- // https://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,
- // list derived from https://github.com/benjamn/ast-types/blob/HEAD/def/jsx.js
- ignoredNodes: ['JSXElement', 'JSXElement > *', 'JSXAttribute', 'JSXIdentifier', 'JSXNamespacedName', 'JSXMemberExpression', 'JSXSpreadAttribute', 'JSXExpressionContainer', 'JSXOpeningElement', 'JSXClosingElement', 'JSXFragment', 'JSXOpeningFragment', 'JSXClosingFragment', 'JSXText', 'JSXEmptyExpression', 'JSXSpreadChild'],
- ignoreComments: false
- }],
- // specify whether double or single quotes should be used in JSX attributes
- // https://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
- // https://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
- // https://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
- 'lines-between-class-members': ['error', 'always', { exceptAfterSingleLine: false }],
- // enforces empty lines around comments
- 'lines-around-comment': 'off',
- // require or disallow newlines around directives
- // https://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
- // https://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
- // https://eslint.org/docs/rules/max-lines
- 'max-lines': ['off', {
- max: 300,
- skipBlankLines: true,
- skipComments: true
- }],
- // enforce a maximum function length
- // https://eslint.org/docs/rules/max-lines-per-function
- 'max-lines-per-function': ['off', {
- max: 50,
- skipBlankLines: true,
- skipComments: true,
- IIFEs: 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
- // https://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
- // https://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
- // https://eslint.org/docs/rules/new-parens
- 'new-parens': 'error',
- // allow/disallow an empty newline after var statement
- 'newline-after-var': 'off',
- // https://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
- // https://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
- // https://eslint.org/docs/rules/no-bitwise
- 'no-bitwise': 'error',
- // disallow use of the continue statement
- // https://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
- // https://eslint.org/docs/rules/no-lonely-if
- 'no-lonely-if': 'error',
- // disallow un-paren'd mixes of different operators
- // https://eslint.org/docs/rules/no-mixed-operators
- 'no-mixed-operators': ['error', {
- // the list of arithmetic groups disallows mixing `%` and `**`
- // with other arithmetic operators.
- groups: [
- ['%', '**'],
- ['%', '+'],
- ['%', '-'],
- ['%', '*'],
- ['%', '/'],
- ['/', '*'],
- ['&', '|', '<<', '>>', '>>>'],
- ['==', '!=', '===', '!=='],
- ['&&', '||'],
- ],
- allowSamePrecedence: false
- }],
- // disallow mixed spaces and tabs for indentation
- 'no-mixed-spaces-and-tabs': 'error',
- // disallow use of chained assignment expressions
- // https://eslint.org/docs/rules/no-multi-assign
- 'no-multi-assign': ['error'],
- // disallow multiple empty lines, only one newline at the end, and no new lines at the beginning
- // https://eslint.org/docs/rules/no-multiple-empty-lines
- 'no-multiple-empty-lines': ['error', { max: 1, maxBOF: 0, maxEOF: 0 }],
- // disallow negated conditions
- // https://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 --
- // https://eslint.org/docs/rules/no-plusplus
- 'no-plusplus': 'error',
- // disallow certain syntax forms
- // https://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
- // https://eslint.org/docs/rules/no-underscore-dangle
- 'no-underscore-dangle': ['error', {
- allow: [],
- allowAfterThis: false,
- allowAfterSuper: false,
- enforceInMethodNames: true,
- }],
- // disallow the use of Boolean literals in conditional expressions
- // also, prefer `a || b` over `a ? a : b`
- // https://eslint.org/docs/rules/no-unneeded-ternary
- 'no-unneeded-ternary': ['error', { defaultAssignment: false }],
- // disallow whitespace before properties
- // https://eslint.org/docs/rules/no-whitespace-before-property
- 'no-whitespace-before-property': 'error',
- // enforce the location of single-line statements
- // https://eslint.org/docs/rules/nonblock-statement-body-position
- 'nonblock-statement-body-position': ['error', 'beside', { overrides: {} }],
- // require padding inside curly braces
- 'object-curly-spacing': ['error', 'always'],
- // enforce line breaks between braces
- // https://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 },
- ImportDeclaration: { minProperties: 4, multiline: true, consistent: true },
- ExportDeclaration: { minProperties: 4, multiline: true, consistent: true },
- }],
- // enforce "same line" or "multiple line" on object properties.
- // https://eslint.org/docs/rules/object-property-newline
- 'object-property-newline': ['error', {
- allowAllPropertiesOnSameLine: true,
- }],
- // allow just one var statement per function
- 'one-var': ['error', 'never'],
- // require a newline around variable declaration
- // https://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
- // https://eslint.org/docs/rules/operator-assignment
- 'operator-assignment': ['error', 'always'],
- // Requires operator at the beginning of the line in multiline statements
- // https://eslint.org/docs/rules/operator-linebreak
- 'operator-linebreak': ['error', 'before', { overrides: { '=': 'none' } }],
- // disallow padding within blocks
- 'padded-blocks': ['error', {
- blocks: 'never',
- classes: 'never',
- switches: 'never',
- }, {
- allowSingleLineBlocks: true,
- }],
- // Require or disallow padding lines between statements
- // https://eslint.org/docs/rules/padding-line-between-statements
- 'padding-line-between-statements': 'off',
- // Disallow the use of Math.pow in favor of the ** operator
- // https://eslint.org/docs/rules/prefer-exponentiation-operator
- 'prefer-exponentiation-operator': 'error',
- // Prefer use of an object spread over Object.assign
- // https://eslint.org/docs/rules/prefer-object-spread
- 'prefer-object-spread': 'error',
- // require quotes around object literal property names
- // https://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
- // https://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
- // https://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
- // https://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
- // https://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
- // https://eslint.org/docs/rules/spaced-comment
- 'spaced-comment': ['error', 'always', {
- line: {
- exceptions: ['-', '+'],
- markers: ['=', '!', '/'], // space here to support sprockets directives, slash for TS /// comments
- },
- block: {
- exceptions: ['-', '+'],
- markers: ['=', '!', ':', '::'], // space here to support sprockets directives and flow comment types
- balanced: true,
- }
- }],
- // Enforce spacing around colons of switch statements
- // https://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
- // https://eslint.org/docs/rules/template-tag-spacing
- 'template-tag-spacing': ['error', 'never'],
- // require or disallow the Unicode Byte Order Mark
- // https://eslint.org/docs/rules/unicode-bom
- 'unicode-bom': ['error', 'never'],
- // require regex literals to be wrapped in parentheses
- 'wrap-regex': 'off'
- }
- };
|