From d64ee2d284fc79f8db6795beac198f29043c9917 Mon Sep 17 00:00:00 2001 From: Braden Rich Date: Thu, 5 Dec 2024 14:45:23 -0500 Subject: [PATCH 1/2] Update ESLint config --- .../linters/eslint/eslint_generator.rb | 2 +- .../linters/eslint/templates/.eslintrc.cjs | 130 ------------------ .../linters/eslint/templates/eslint.config.js | 98 +++++++++++++ 3 files changed, 99 insertions(+), 131 deletions(-) delete mode 100644 lib/generators/rolemodel/linters/eslint/templates/.eslintrc.cjs create mode 100644 lib/generators/rolemodel/linters/eslint/templates/eslint.config.js diff --git a/lib/generators/rolemodel/linters/eslint/eslint_generator.rb b/lib/generators/rolemodel/linters/eslint/eslint_generator.rb index c0f70d3d..def4722f 100644 --- a/lib/generators/rolemodel/linters/eslint/eslint_generator.rb +++ b/lib/generators/rolemodel/linters/eslint/eslint_generator.rb @@ -20,7 +20,7 @@ def install_eslint end def add_config - template '.eslintrc.cjs', '.eslintrc.cjs' + template 'eslint.config.js', 'eslint.config.js' end def add_eslint_command_to_package_json diff --git a/lib/generators/rolemodel/linters/eslint/templates/.eslintrc.cjs b/lib/generators/rolemodel/linters/eslint/templates/.eslintrc.cjs deleted file mode 100644 index 06223cc0..00000000 --- a/lib/generators/rolemodel/linters/eslint/templates/.eslintrc.cjs +++ /dev/null @@ -1,130 +0,0 @@ -module.exports = { - root: true, - env: { - browser: true, - es6: true - }, - settings: { - react: { - version: 'detect' - } - }, - extends: ['airbnb'], - parserOptions: { - ecmaFeatures: { - jsx: true - }, - ecmaVersion: 'latest' - }, - ignorePatterns: ['app/assets/builds'], - rules: { - 'no-unused-vars': [ - 'error', - { - argsIgnorePattern: '^_', // Allow unused arguments starting with an underscore - varsIgnorePattern: '^_' // Allow unused variables starting with an underscore - } - ], - - // No semicolons - semi: ['error', 'never'], - 'no-unexpected-multiline': 'error', - - // 1. We follow the convention of naming "private" properties with a leading underscore - // 2. This conflicts with the no-unused-vars config - 'no-underscore-dangle': 'off', - - // Don't need trailing commas everywhere - 'comma-dangle': ['error', 'never'], - - // Multiple variable declarations (without assignment) on the same line - // without multiple let/const - 'one-var': ['error', { initialized: 'never', uninitialized: 'always' }], - 'one-var-declaration-per-line': ['error', 'initializations'], - - // Don't require naming all non-arrow functions. Modern browsers can usually - // detect the correct name if it's assigned to a variable or property. - 'func-names': 'off', - - // Don't require instance methods to use `this` (the rule name is confusing) - 'class-methods-use-this': 'off', - - // Allow console.log and similar - 'no-console': 'off', - - // Turning this on addresses some quirks with using `var`. It's unnecessary - // for `let` and `const`. - 'no-loop-func': 'off', - - // Turning this on requires destructuring in too many cases - 'prefer-destructuring': 'off', - - // Turning this on prevents directly importing sub-dependencies - 'import/no-extraneous-dependencies': 'off', - - // One-liner methods can be readable without the extra spacing - 'lines-between-class-members': ['error', 'always', { exceptAfterSingleLine: true }], - - // Allow assigning to properties of arguments (might consider completely disabling this rule) - 'no-param-reassign': ['error', { props: false }], - - // This rule complains about use of things like PropTypes.object. We could - // use more-specific types, but that could be a pain with smart objects. - 'react/forbid-prop-types': 'off', - - // This rule enforces either always or never destructuring state and props. - // There is no "sometimes" option. - 'react/destructuring-assignment': 'off', - - // Sufficiently high that it won't be too annoying - 'max-len': ['warn', 120], - - // Disabled to allow interpolating text and components - 'react/jsx-one-expression-per-line': 'off', - - // Disabled because it complains if you mix `return` with `return ` in a function - 'consistent-return': 'off', - - // Don't require function components in an app that prefers class components - 'react/prefer-stateless-function': 'off', - - // Default requires the label to both wrap the input and have htmlFor set. - // One or the other is usually sufficient. - 'jsx-a11y/label-has-associated-control': [ - 'error', - { - assert: 'either', - controlComponents: [], // Put custom input components here - depth: 25, - labelAttributes: [], - labelComponents: [] - } - ], - - // ES Modules require file extensions by default - 'import/extensions': ['warn', 'ignorePackages'], - - // Whether a prop is required or optional isn't really related to if it has a default value - 'react/require-default-props': 'off', - - // Sometimes you want to wrap a component and forward all props to it - 'react/jsx-props-no-spreading': 'off', - - // Allow patterns like `while ((a = getNextValue()))` - 'no-cond-assign': ['error', 'except-parens'], - - // Default disallows mixing exponentiation with other arithmetic operators - 'no-mixed-operators': [ - 'error', - { - allowSamePrecedence: false, // Could also make this true - groups: [ - ['&', '|', '^', '~', '<<', '>>', '>>>'], - ['==', '!=', '===', '!==', '>', '>=', '<', '<='], - ['&&', '||'], - ['in', 'instanceof'] - ] - } - ] - } -} diff --git a/lib/generators/rolemodel/linters/eslint/templates/eslint.config.js b/lib/generators/rolemodel/linters/eslint/templates/eslint.config.js new file mode 100644 index 00000000..0f99d34f --- /dev/null +++ b/lib/generators/rolemodel/linters/eslint/templates/eslint.config.js @@ -0,0 +1,98 @@ +import globals from 'globals' + +export default [ + { + ignores: ['app/assets/builds/**/*'] + }, + { name: 'airbnb' }, + { + languageOptions: { + parserOptions: { + ecmaFeatures: { + jsx: true + }, + ecmaVersion: 'latest', + globals: { + ...globals.browser, + ...globals.es6 + } + } + }, + rules: { + 'no-unused-vars': [ + 'error', + { + argsIgnorePattern: '^_', // Allow unused arguments starting with an underscore + varsIgnorePattern: '^_' // Allow unused variables starting with an underscore + } + ], + + // No semicolons + semi: ['error', 'never'], + 'no-unexpected-multiline': 'error', + + // 1. We follow the convention of naming "private" properties with a leading underscore + // 2. This conflicts with the no-unused-vars config + 'no-underscore-dangle': 'off', + + // Don't need trailing commas everywhere + 'comma-dangle': ['error', 'never'], + + // Multiple variable declarations (without assignment) on the same line + // without multiple let/const + 'one-var': ['error', { initialized: 'never', uninitialized: 'always' }], + 'one-var-declaration-per-line': ['error', 'initializations'], + + // Don't require naming all non-arrow functions. Modern browsers can usually + // detect the correct name if it's assigned to a variable or property. + 'func-names': 'off', + + // Don't require instance methods to use `this` (the rule name is confusing) + 'class-methods-use-this': 'off', + + // Allow console.log and similar + 'no-console': 'off', + + // Turning this on addresses some quirks with using `var`. It's unnecessary + // for `let` and `const`. + 'no-loop-func': 'off', + + // Turning this on requires destructuring in too many cases + 'prefer-destructuring': 'off', + + // Turning this on prevents directly importing sub-dependencies + 'import/no-extraneous-dependencies': 'off', + + // One-liner methods can be readable without the extra spacing + 'lines-between-class-members': ['error', 'always', { exceptAfterSingleLine: true }], + + // Allow assigning to properties of arguments (might consider completely disabling this rule) + 'no-param-reassign': ['error', { props: false }], + + // Sufficiently high that it won't be too annoying + 'max-len': ['warn', 130], + + // Disabled because it complains if you mix `return` with `return ` in a function + 'consistent-return': 'off', + + // Allow patterns like `while ((a = getNextValue()))` + 'no-cond-assign': ['error', 'except-parens'], + + // 'import/extensions': ['warn', 'ignorePackages'], + + // Default disallows mixing exponentiation with other arithmetic operators + 'no-mixed-operators': [ + 'error', + { + allowSamePrecedence: false, // Could also make this true + groups: [ + ['&', '|', '^', '~', '<<', '>>', '>>>'], + ['==', '!=', '===', '!==', '>', '>=', '<', '<='], + ['&&', '||'], + ['in', 'instanceof'] + ] + } + ] + } + } +] From 48f2194cca13073e225e24aeb6e4cb161b954b52 Mon Sep 17 00:00:00 2001 From: Braden Rich Date: Thu, 5 Dec 2024 15:41:42 -0500 Subject: [PATCH 2/2] Update ESLint config --- .../rolemodel/linters/eslint/templates/eslint.config.js | 6 ------ 1 file changed, 6 deletions(-) diff --git a/lib/generators/rolemodel/linters/eslint/templates/eslint.config.js b/lib/generators/rolemodel/linters/eslint/templates/eslint.config.js index 0f99d34f..c0f960e9 100644 --- a/lib/generators/rolemodel/linters/eslint/templates/eslint.config.js +++ b/lib/generators/rolemodel/linters/eslint/templates/eslint.config.js @@ -35,9 +35,6 @@ export default [ // 2. This conflicts with the no-unused-vars config 'no-underscore-dangle': 'off', - // Don't need trailing commas everywhere - 'comma-dangle': ['error', 'never'], - // Multiple variable declarations (without assignment) on the same line // without multiple let/const 'one-var': ['error', { initialized: 'never', uninitialized: 'always' }], @@ -50,9 +47,6 @@ export default [ // Don't require instance methods to use `this` (the rule name is confusing) 'class-methods-use-this': 'off', - // Allow console.log and similar - 'no-console': 'off', - // Turning this on addresses some quirks with using `var`. It's unnecessary // for `let` and `const`. 'no-loop-func': 'off',