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
53import { defineConfig } from "eslint/config";
import globals from "globals";
import js from "@eslint/js";
import tseslint from "typescript-eslint";
import pluginVue from "eslint-plugin-vue";
export default defineConfig([
// Base files (applies to everything)
{ files: ["**/*.{js,mjs,cjs,ts,vue}"] },
// Browser globals for regular files
{
files: ["**/*.{js,mjs,cjs,ts,vue}"],
languageOptions: {
globals: globals.browser,
},
},
// Node globals for config files like babel.config.cjs
{
files: ["**/*.cjs"],
languageOptions: {
globals: globals.node,
},
},
// JS rules with semicolon enforcement
{
files: ["**/*.{js,mjs,cjs,ts,vue}"],
plugins: { js },
extends: ["js/recommended"],
rules: {
semi: ["error", "always"], // ๐ Enforce semicolon usage
},
},
// TypeScript rules
tseslint.configs.recommended,
// Vue rules
pluginVue.configs["flat/essential"],
// Vue with TS parser
{
files: ["**/*.vue"],
languageOptions: {
parserOptions: {
parser: tseslint.parser,
},
},
},
]);