Files
vue-ts-example/eslint.config.ts
mini2024 c7047146e4
All checks were successful
/ depcheck (push) Successful in 2m12s
/ build-and-deploy-to-vercel (push) Successful in 2m22s
/ surge (push) Successful in 1m53s
/ playwright (push) Successful in 3m18s
chore: eslint.config.ts
2025-03-01 18:20:11 +08:00

101 lines
2.8 KiB
TypeScript

import { includeIgnoreFile } from '@eslint/compat';
import skipFormatting from '@vue/eslint-config-prettier/skip-formatting';
import { defineConfigWithVueTs, vueTsConfigs } from '@vue/eslint-config-typescript';
import pluginImport from 'eslint-plugin-import-x';
import oxlint from 'eslint-plugin-oxlint';
import perfectionist from 'eslint-plugin-perfectionist';
import pluginVue from 'eslint-plugin-vue';
import path from 'node:path';
import { fileURLToPath } from 'node:url';
const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
const gitignorePath = path.resolve(__dirname, '.gitignore');
import type { Linter } from 'eslint';
// To allow more languages other than `ts` in `.vue` files, uncomment the following lines:
import { configureVueProject } from '@vue/eslint-config-typescript';
configureVueProject({ scriptLangs: ['ts', 'tsx', 'js', 'jsx'] });
// More info at https://github.com/vuejs/eslint-config-typescript/#advanced-setup
export default defineConfigWithVueTs(
includeIgnoreFile(gitignorePath), // oxlint . --fix -D correctness --ignore-path .gitignore
{
name: 'app/files-to-lint',
files: ['**/*.{ts,mts,tsx,vue}'],
},
{
name: 'app/files-to-ignore',
ignores: ['**/dist/**', '**/dist-ssr/**', '**/coverage/**'],
},
pluginVue.configs['flat/essential'],
vueTsConfigs.recommended,
// {
// ...pluginVitest.configs.recommended,
// files: ['src/**/__tests__/*'],
// },
// {
// ...pluginCypress.configs.recommended,
// files: ['cypress/e2e/**/*.{cy,spec}.{js,ts,jsx,tsx}', 'cypress/support/**/*.{js,ts,jsx,tsx}'],
// },
oxlint.configs['flat/recommended'],
skipFormatting,
importPluginConfig(),
{
rules: {
'vue/multi-word-component-names': 'off',
'@typescript-eslint/no-explicit-any': 'off',
'vue/block-order': [
'error',
{
order: ['script', 'template', 'style'],
},
],
'vue/define-macros-order': [
'error',
{
order: ['defineOptions', 'defineProps', 'defineEmits', 'defineSlots'],
},
],
},
},
// https://perfectionist.dev/guide/getting-started
{
plugins: {
perfectionist,
},
rules: {
'perfectionist/sort-imports': ['error'],
},
},
);
function importPluginConfig(): Linter.Config[] {
return [
{
plugins: {
// @ts-expect-error - This is a dynamic import
import: pluginImport,
},
rules: {
// 'import/first': 'error',
'import/newline-after-import': 'error',
// 'import/no-duplicates': 'error',
// 'import/no-mutable-exports': 'error',
// 'import/no-named-default': 'error',
// 'import/no-self-import': 'error',
// 'import/no-unresolved': 'off',
// 'import/no-webpack-loader-syntax': 'error',
},
},
];
}