-
-
Notifications
You must be signed in to change notification settings - Fork 697
Open
@dwjohnston
Description
Checklist
- I have tried restarting my IDE and the issue persists.
- I have read the FAQ and my problem is not listed.
Tell us about your environment
- ESLint version: eslint@9.34.0
- eslint-plugin-vue version: eslint-plugin-vue@10.3.0
- Vue version: vue@3.5.21
- Node version:: v22.19.0
- Operating System: MacOS 15.6.1
Please show your full configuration:
import { globalIgnores } from 'eslint/config' import { defineConfigWithVueTs, vueTsConfigs } from '@vue/eslint-config-typescript' import pluginVue from 'eslint-plugin-vue' // import typescriptEslint from 'typescript-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'] }) // More info at https://github.com/vuejs/eslint-config-typescript/#advanced-setup export default defineConfigWithVueTs( { name: 'app/files-to-lint', files: ['**/*.{ts,mts,tsx,vue}'], }, globalIgnores(['**/dist/**', '**/dist-ssr/**', '**/coverage/**']), pluginVue.configs['flat/essential'], // typescriptEslint.configs.recommended, vueTsConfigs.recommended, { name: "other", rules: { "vue/prop-name-casing": "error" // "@typescript-eslint/no-floating-promises":"error", // "@typescript-eslint/return-await": ["error", "always"], } } )
What did you do?
<template> <div > {{ foo }} </div> </template> <script setup lang="ts"> import { computed } from 'vue'; import type { SomeType } from './types'; // no error here! defineProps<SomeType>() // no error here! const foo = computed(() => { return "hello"; }); </script>
where SomeType is
//types.ts export type SomeType = { foo: string; "kebab-case-property": string; }
What did you expect to happen?
If I use these types directly, then the plugin behaves fine
<template> <div > {{ foo }} </div> </template> <script setup lang="ts"> import { computed } from 'vue'; defineProps<{ foo: string; //Prop "kebab-case-property" is not in camelCase.eslintvue/prop-name-casing "kebab-case-property": string; }>() //Duplicate key 'foo'. May cause name collision in script or template tag.eslintvue/no-dupe-keys const foo = computed(() => { return "hello"; }); </script>
What actually happened?
There is no error for either vue/no-dupe-keys
or vue/prop-name-casing
when referencing a type.
What's interesting, and how I discovered this, is that if you add the @typescript-eslint/no-floating-promises
rule, then all of a sudden this starts working!
export default defineConfigWithVueTs( { name: 'app/files-to-lint', files: ['**/*.{ts,mts,tsx,vue}'], }, globalIgnores(['**/dist/**', '**/dist-ssr/**', '**/coverage/**']), pluginVue.configs['flat/essential'], // typescriptEslint.configs.recommended, vueTsConfigs.recommended, { plugins: { "@typescript-eslint": typescriptEslint.plugin //👈 }, name: "other", rules: { "vue/prop-name-casing": "error", "@typescript-eslint/no-floating-promises":"error", //👈 } } )
Repository to reproduce this issue
Metadata
Metadata
Assignees
Labels
No labels