| 
						 | 
						- 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'
 -   }
 - };
 
 
  |