// 引入vue模版的eslint
import pluginVue from 'eslint-plugin-vue'
import eslint from '@eslint/js'
// ts-eslint解析器,使 eslint 可以解析 ts 语法
import tseslint from 'typescript-eslint'
// vue文件解析器
import vueParser from 'vue-eslint-parser'
import prettier from 'eslint-plugin-prettier'

export default tseslint.config({
    // ignores: ['node_modules', 'prettier.config.cjs', 'dist*'],
    files: ['src/**/*.ts', 'src/**/*.tsx', 'src/**/*.vue'],
    // tseslint.config添加了extends扁平函数,直接用。否则是eslint9.0版本是没有extends的
    extends: [
        eslint.configs.recommended,
        ...tseslint.configs.recommended,
        ...pluginVue.configs['flat/essential']
    ],
    plugins: {
        prettier
    },
    languageOptions: {
        parser: vueParser, // 使用vue解析器,这个可以识别vue文件
        parserOptions: {
            parser: tseslint.parser, // 在vue文件上使用ts解析器
            sourceType: 'module',
            ecmaVersion: 2020,
            ecmaFeatures: {
                jsx: true
            }
        }
    },
    rules: {
        'prettier/prettier': 'error',
        'no-useless-escape': 0,
        'no-undef': 0,
        'vue/no-setup-props-destructure': 0,
        'vue/script-setup-uses-vars': 1,
        'vue/no-reserved-component-names': 0,
        '@typescript-eslint/ban-ts-ignore': 0,
        '@typescript-eslint/explicit-function-return-type': 0,
        '@typescript-eslint/no-explicit-any': 0,
        '@typescript-eslint/no-var-requires': 0,
        '@typescript-eslint/no-empty-function': 0,
        'vue/custom-event-name-casing': 0,
        'no-use-before-define': 0,
        '@typescript-eslint/no-use-before-define': 0,
        '@typescript-eslint/ban-ts-comment': 0,
        '@typescript-eslint/ban-types': 0,
        '@typescript-eslint/no-non-null-assertion': 0,
        '@typescript-eslint/explicit-module-boundary-types': 0,
        '@typescript-eslint/no-unused-vars': 0,
        'no-unused-vars': 0,
        'space-before-function-paren': 0,

        'vue/attributes-order': 0,
        'vue/one-component-per-file': 0,
        'vue/html-closing-bracket-newline': 0,
        'vue/max-attributes-per-line': 0,
        'vue/multiline-html-element-content-newline': 0,
        'vue/singleline-html-element-content-newline': 0,
        'vue/attribute-hyphenation': 0,
        'vue/require-default-prop': 0,
        'vue/require-explicit-emits': 0,
        'vue/html-self-closing': [
            1,
            {
                html: {
                    void: 'always',
                    normal: 'never',
                    component: 'always'
                },
                svg: 'always',
                math: 'always'
            }
        ],
        'vue/multi-word-component-names': 0,
        'vue/no-v-html': 0,
        'vue/require-toggle-inside-transition': 0
    }
})