-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy path.eslintrc.js
61 lines (58 loc) · 1.72 KB
/
.eslintrc.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
'use strict';
// Copied from https://github.com/ember-cli/eslint-plugin-ember/pull/2107/files
const typescriptEslintRecommendedRules =
require('@typescript-eslint/eslint-plugin').configs['eslint-recommended']
.overrides[0].rules;
module.exports = {
root: true,
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaVersion: 'latest',
},
plugins: ['ember', '@typescript-eslint'],
extends: ['eslint:recommended', 'plugin:ember/recommended', 'prettier'],
env: {
browser: true,
},
rules: {},
overrides: [
// ts files
{
files: ['**/*.{gts,ts}'],
extends: ['plugin:@typescript-eslint/recommended'],
rules: {
// https://github.com/ember-cli/eslint-plugin-ember/issues/2106
// TODO: remove this when eslint-plugin-ember ships it, or when we switch to the flat config setup
...typescriptEslintRecommendedRules,
// This works around an issue in Glint https://github.com/typed-ember/glint/issues/697
// It also makes adding state to a component easier, since no other code changes would be needed.
'ember/no-empty-glimmer-component-classes': 'off',
},
},
// node files
{
files: [
'./.eslintrc.js',
'./.prettierrc.js',
'./.stylelintrc.js',
'./.template-lintrc.js',
'./ember-cli-build.js',
'./index.js',
'./testem.js',
'./blueprints/*/index.js',
'./config/**/*.js',
'./tests/dummy/config/**/*.js',
],
env: {
browser: false,
node: true,
},
extends: ['plugin:n/recommended'],
},
{
// test files
files: ['tests/**/*-test.{js,ts,gts}'],
extends: ['plugin:qunit/recommended'],
},
],
};