-
Notifications
You must be signed in to change notification settings - Fork 13
Expand file tree
/
Copy patheslint.config.ts
More file actions
128 lines (125 loc) · 3.96 KB
/
eslint.config.ts
File metadata and controls
128 lines (125 loc) · 3.96 KB
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
import os from 'node:os'
import antfu from '@antfu/eslint-config'
import eslintPluginBetterTailwindcss from 'eslint-plugin-better-tailwindcss'
import * as mdx from 'eslint-plugin-mdx'
const isWindows = os.platform() === 'win32'
const lineBreakStyle = isWindows ? 'windows' : 'unix'
export default antfu({
ignores: ['**/.angular/**', '**/.astro/**'],
formatters: true,
react: true,
astro: true,
vue: true,
pnpm: false,
}, {
ignores: ['**/*.mdx'],
files: ['**/*.ts', '**/*.tsx'],
rules: {
curly: ['error', 'multi-line'],
'antfu/if-newline': 'off',
'style/quote-props': ['error', 'as-needed'],
'style/brace-style': ['warn', '1tbs', { allowSingleLine: true }],
'style/jsx-first-prop-new-line': ['error', 'multiline'],
'style/jsx-self-closing-comp': ['error', {
component: true,
html: true,
}],
'react-hooks/set-state-in-effect': 'off',
'react-hooks/purity': 'off',
'react-hooks/refs': 'off',
'react-refresh/only-export-components': 'off',
'react/static-components': 'off',
},
}, {
files: ['**/*.mdx'],
ignores: [
'content/blog/univer-doc-architecture.mdx',
'content/blog/univer-doc-architecture.zh-CN.mdx',
'content/blog/this-is-univer.mdx',
'content/blog/this-is-univer.zh-CN.mdx',
'content/reference/facade/**/*.mdx',
],
...mdx.flat,
// optional, if you want to lint code blocks at the same
processor: mdx.createRemarkProcessor({
lintCodeBlocks: true,
// optional, if you want to disable language mapper, set it to `false`
// if you want to override the default language mapper inside, you can provide your own
languageMapper: {},
}),
rules: {
'style/indent': 'off',
'style/jsx-closing-bracket-location': 'off',
'ts/no-redeclare': 'off',
'unused-imports/no-unused-imports': 'off',
'unused-imports/no-unused-vars': 'off',
'style/jsx-one-expression-per-line': 'off',
'style/jsx-tag-spacing': 'off',
'no-unused-vars': 'off',
'react/component-hook-factories': 'off',
'react/rules-of-hooks': 'off',
'eslint-comments/no-unlimited-disable': 'off',
'style/max-statements-per-line': 'off',
'no-undef': 'off',
},
}, {
files: ['**/*.mdx'],
ignores: ['content/reference/facade/**/*.mdx'],
...mdx.flatCodeBlocks,
rules: {
...mdx.flatCodeBlocks.rules,
// if you want to override some rules for code blocks
'prefer-const': 'error',
'ts/no-redeclare': 'off',
'unused-imports/no-unused-imports': 'off',
'unused-imports/no-unused-vars': 'off',
'style/jsx-tag-spacing': 'off',
'no-console': 'off',
'no-var': 'error',
'no-restricted-syntax': 'off',
'no-new': 'off',
'node/prefer-global/process': 'off',
'prefer-rest-params': 'off',
'antfu/no-top-level-await': 'off',
'ts/prefer-literal-enum-member': 'off',
'no-useless-return': 'off',
'react-hooks/rules-of-hooks': 'off',
'react-dom/no-render': 'off',
'react/component-hook-factories': 'off',
'react/rules-of-hooks': 'off',
'react-refresh/only-export-components': 'off',
'import/no-duplicates': 'off',
'react/dom-no-render': 'off',
},
}, {
files: ['**/*.tsx'],
languageOptions: {
parserOptions: {
ecmaFeatures: {
jsx: true,
},
},
},
plugins: {
'better-tailwindcss': eslintPluginBetterTailwindcss,
},
settings: {
'better-tailwindcss': {
// tailwindcss 4: the path to the entry file of the css based tailwind config (eg: `src/global.css`)
entryPoint: 'app/[lang]/global.css',
},
},
rules: {
// enable all recommended rules to warn
...eslintPluginBetterTailwindcss.configs['recommended-warn'].rules,
// enable all recommended rules to error
...eslintPluginBetterTailwindcss.configs['recommended-error'].rules,
// or configure rules individually
'better-tailwindcss/enforce-consistent-line-wrapping': ['error', {
printWidth: 120,
group: 'newLine',
lineBreakStyle,
}],
'better-tailwindcss/no-unknown-classes': 'warn',
},
})