-
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy patheslint.config.js
80 lines (75 loc) · 2.03 KB
/
eslint.config.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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import js from '@eslint/js';
import ts from 'typescript-eslint';
import svelte from 'eslint-plugin-svelte';
import prettier from 'eslint-config-prettier';
import globals from 'globals';
const __dirname = import.meta.dirname;
import pkg from 'eslint-gitignore';
const { readGitignoreFiles } = pkg;
function removeDuplicates(arr) {
return arr.filter((value, index, self) => self.indexOf(value) === index);
}
/** @type {import('eslint').Linter.FlatConfig[]} */
export default [
js.configs.recommended,
...ts.configs.recommended,
...svelte.configs['flat/recommended'],
prettier,
...svelte.configs['flat/prettier'],
{
languageOptions: {
globals: {
...globals.browser,
...globals.node,
NodeJS: true
}
}
},
{
files: ['**/*.svelte'],
languageOptions: {
parser: svelte.parser,
parserOptions: {
parser: ts.parser,
svelteFeatures: {
experimentalGenerics: true
}
}
}
},
{
ignores: removeDuplicates([
...readGitignoreFiles({ cwd: __dirname }),
'**/.svelte-kit/',
'**/_app/',
'package/'
])
},
{
rules: {
eqeqeq: 'error',
'prefer-const': 'off',
'@typescript-eslint/no-explicit-any': 'off',
// this will configure:
// const _a = 'unused, with underscore, no warning'
// const b = 'unused, no underscore, warning'
// note you must disable the base rule
// as it can report incorrect errors
'no-unused-vars': 'off',
'@typescript-eslint/no-unused-vars': [
'warn', // or "error"
{
argsIgnorePattern: '^_',
varsIgnorePattern: '^_',
caughtErrorsIgnorePattern: '^_'
}
],
// We need to use {@html} in the demo site for code highlight
'svelte/no-at-html-tags': 'off',
// css is global and incorrectly reported as unused by the linter
'svelte/valid-compile': 'off',
'@typescript-eslint/ban-ts-comment': 'off',
'@typescript-eslint/no-unused-expressions': 'off'
}
}
];