// eslint-disable-next-line import/no-extraneous-dependencies const loadIgnorePatterns = require( 'jetpack-js-tools/load-eslint-ignore.js' ); module.exports = { root: true, extends: [ require.resolve( 'jetpack-js-tools/eslintrc/base' ), // @todo: Uncomment this: // require.resolve( 'jetpack-js-tools/eslintrc/react' ), require.resolve( 'jetpack-js-tools/eslintrc/wp-eslint-plugin/recommended' ), ], ignorePatterns: [ '**/stories/*.stories.tsx', ...loadIgnorePatterns( __dirname ) ], parserOptions: { tsconfigRootDir: __dirname, project: [ './tsconfig.json', './tsconfig.eslint.json' ], }, overrides: [ // .js and .cjs files in the root are not part of the TypeScript project. { files: [ '*.js', '*.cjs' ], parserOptions: { project: null, }, }, ], rules: { // Enforce the use of the jetpack-boost textdomain. '@wordpress/i18n-text-domain': [ 'error', { allowedTextDomain: 'jetpack-boost', }, ], // Apparently, we like dangling commas 'comma-dangle': 0, 'jsdoc/no-undefined-types': [ 1, { definedTypes: [ 'TemplateVars', 'ErrorSet', 'Readable' ], }, ], // This is not a react project. 'react-hooks/rules-of-hooks': 0, 'import/no-unresolved': 0, 'import/order': 0, 'no-nested-ternary': 0, 'prettier/prettier': 0, camelcase: 0, // Boost should just use our standard eslint rulesets, that already does this. '@typescript-eslint/no-unused-vars': [ 'warn', { argsIgnorePattern: '^_' } ], }, };