-
Notifications
You must be signed in to change notification settings - Fork 26
/
.eslintrc.cjs
153 lines (134 loc) · 6.13 KB
/
.eslintrc.cjs
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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
module.exports = {
// https://eslint.org/docs/user-guide/configuring#configuration-cascading-and-hierarchy
// This option interrupts the configuration hierarchy at this file
// Remove this if you have an higher level ESLint config file (it usually happens into a monorepos)
root: true,
// https://eslint.vuejs.org/user-guide/#how-to-use-a-custom-parser
// Must use parserOptions instead of "parser" to allow vue-eslint-parser to keep working
// `parser: 'vue-eslint-parser'` is already included with any 'plugin:vue/**' config and should be omitted
parserOptions: {
parser: require.resolve('@typescript-eslint/parser'),
extraFileExtensions: ['.vue'],
},
env: {
browser: true,
es2021: true,
node: true,
},
// Rules order is important, please avoid shuffling them
extends: [
// Base ESLint recommended rules
'eslint:recommended',
// https://github.com/typescript-eslint/typescript-eslint/tree/master/packages/eslint-plugin#usage
// ESLint typescript rules
'plugin:@typescript-eslint/strict',
'plugin:@typescript-eslint/stylistic',
'plugin:perfectionist/recommended-natural-legacy',
// See https://eslint.vuejs.org/rules/#available-rules
'plugin:vue/vue3-recommended',
// https://github.com/prettier/eslint-config-prettier#installation
// usage with Prettier, provided by 'eslint-config-prettier'.
'prettier',
],
plugins: [
// required to apply rules which need type information
'@typescript-eslint',
// https://eslint.vuejs.org/user-guide/#why-doesn-t-it-work-on-vue-files
// required to lint *.vue files
'vue',
// https://github.com/typescript-eslint/typescript-eslint/issues/389#issuecomment-509292674
// Prettier has not been included as plugin to avoid performance impact
// add it as an extension for your IDE
'perfectionist',
],
globals: {
ga: 'readonly', // Google Analytics
cordova: 'readonly',
__statics: 'readonly',
__QUASAR_SSR__: 'readonly',
__QUASAR_SSR_SERVER__: 'readonly',
__QUASAR_SSR_CLIENT__: 'readonly',
__QUASAR_SSR_PWA__: 'readonly',
process: 'readonly',
Capacitor: 'readonly',
chrome: 'readonly',
},
// add your custom rules here
rules: {
// eslint rules
'array-callback-return': 'error',
'no-constant-binary-expression': 'error',
'no-constructor-return': 'error',
'no-template-curly-in-string': 'error',
'no-unreachable-loop': 'error',
'no-unmodified-loop-condition': 'error',
'no-duplicate-imports': 'error',
'no-self-compare': 'error',
'no-new-native-nonconstructor': 'error',
'no-promise-executor-return': 'error',
'prefer-promise-reject-errors': 'off',
// vue rules
'vue/block-lang': ['error', { script: { lang: 'ts' } }],
'vue/block-order': 'error',
'vue/component-api-style': ['error', ['script-setup']],
'vue/define-props-declaration': 'error',
'vue/enforce-style-attribute': 'error',
'vue/no-boolean-default': 'error',
'vue/prefer-true-attribute-shorthand': 'error',
// typescript-eslint rules
'@typescript-eslint/consistent-type-imports': 'error',
'@typescript-eslint/no-import-type-side-effects': 'error',
quotes: ['warn', 'single', { avoidEscape: true }],
// this rule, if on, would require explicit return type on the `render` function
'@typescript-eslint/explicit-function-return-type': 'off',
// in plain CommonJS modules, you can't use `import foo = require('foo')` to pass this rule, so it has to be disabled
'@typescript-eslint/no-var-requires': 'off',
// The core 'no-unused-vars' rules (in the eslint:recommended ruleset)
// does not work with type definitions
'no-undef': 'off',
'no-unused-vars': 'off',
// allow debugger during development only
'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
'perfectionist/sort-vue-attributes': [
'error',
{
// Based on: https://eslint.vuejs.org/rules/attributes-order.html
// Note: I think this matches on attribute strings for everything that comes BEFORE the equal sign (=), if there is one. This makes some things impossible to match.
// See issue: https://github.com/azat-io/eslint-plugin-perfectionist/issues/112
// See guide on extended glob matching: https://www.linuxjournal.com/content/bash-extended-globbing
customGroups: {
/* eslint-disable perfectionist/sort-objects */
DEFINITION: '@(is|v-is)',
LIST_RENDERING: 'v-for',
CONDITIONALS: 'v-@(if|else-if|else|show|cloak)',
RENDER_MODIFIERS: 'v-@(pre|once)',
GLOBAL: '@(id|:id)',
UNIQUE: '@(ref|:ref|key|:key)',
SLOT: '@(v-slot|slot|#*)',
TWO_WAY_BINDING: '@(v-model|v-model:*)',
OTHER_DIRECTIVES: '@(v-!(on|bind|html|text))', // Matches all "v-" directives except v-on, v-bind, v-html, v-text (these are defined separately below, which are lower in the order of operations)
ATTR_DYNAMIC: '@(v-bind:*|:*)', // For dynamic bindings, like v-bind:prop or :prop.
// ATTR_STATIC: "", // For normal props, like prop="example". No glob patterns possible since we are matching on everything BEFORE the equal sign (=), if there is one. Therefore we can't differentiate boolean props from static props.
// ATTR_SHORTHAND_BOOL: "", // For boolean props, like custom-prop. No glob patterns possible since we are matching on everything BEFORE the equal sign (=), if there is one. Therefore we can't differentiate boolean props from static props.
EVENTS: '@(v-on|@*)',
CONTENT: 'v-@(html|text)',
/* eslint-enable perfectionist/sort-objects */
},
groups: [
'DEFINITION',
'LIST_RENDERING',
'CONDITIONALS',
'RENDER_MODIFIERS',
'GLOBAL',
['UNIQUE', 'SLOT'],
'TWO_WAY_BINDING',
'OTHER_DIRECTIVES',
['ATTR_DYNAMIC', 'unknown', 'multiline', 'shorthand'], // 'unknown' is a workaround because perfectionist/sort-vue-attributes cannot match on ATTR_STATIC or ATTR_SHORTHAND_BOOL
'EVENTS',
'CONTENT',
],
type: 'natural',
},
],
},
};