-
-
Notifications
You must be signed in to change notification settings - Fork 42
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Type instantiation is excessively deep and possibly infinite #485
Comments
This is an issue with your setup. Check intlify/bundle-tools#272 and intlify/vue-i18n#1119 (comment) This is not an ESLint error, since TypeScript doesn't have anything to do with ESLint. |
There's something wrong when using this plugin with @nuxtjs/i18n module, but not only. As I stated above, the problem appears even with just simply installing this plugin as a dependency. @ferferga thank you for the links, I'll try to check that later. |
I'm currently experiencing this problem My Environment: TS2589 Type instantiation is excessively deep and possibly infinite. // test.vue
<template>
<div v-for="(item, index) in tm('aboutUs.details.4.detail.desc')" :key="index"> // There's no problem here.
{{ $rt(item) }}
</div>
</template>
<script lang="ts" setup>
import { useI18n } from 'vue-i18n'
const { tm } = useI18n()
const a = tm('aboutUs.details.4.detail.desc') // TS2589 Type instantiation is excessively deep and possibly infinite.
</script> // i18n.ts
import { createI18n } from 'vue-i18n'
import messages from '@intlify/unplugin-vue-i18n/messages'
const cacheKey = 'locale'
type MessageSchema = NonNullable<typeof messages>['zh-CN']
type MessagesKey = keyof NonNullable<typeof messages>
export const locales: { value: MessagesKey; label: string }[] = [
{ value: 'zh-CN', label: '简体中文' },
{ value: 'en-US', label: 'English' }
]
function localeFormat(lang: string): string {
if (/^zh/.test(lang)) {
lang = 'zh-CN'
} else if (/^en/.test(lang)) {
lang = 'en-US'
}
lang = lang || 'zh-CN'
return lang.replace(/_/g, '-')
}
export const i18n = createI18n<[MessageSchema], MessagesKey, false>({
legacy: false,
locale: localeFormat(localStorage.getItem(cacheKey) || window.navigator.language),
fallbackLocale: 'zh-CN',
missingWarn: false,
fallbackWarn: false,
messages
}) |
This plugin attempts to be a great help with making the code clear, so first of all, I want to thank you for creating it.
There's a problem now when using this plugin. Starting from version
3.0.0-next.2
and up to the current3.0.0-next.7
it causedtypecheck
command to fail with an error:error TS2589: Type instantiation is excessively deep and possibly infinite.
Please, note that before
next
version it was working properly and didn't inflict such a thing.Tell us about your environment
Please show your full configuration:
I prepared the reproduction repository with a couple of branches with different configurations (see below).
What did you do?
Just try to use some translation in a vue file template:
What did you expect to happen?
Everything works well and running
typecheck
didn't show the mentioned error.What actually happened?
When launching
pnpm typecheck
it fails with an error:Please, note that even without specifying the plugin in eslint configuration or even without eslint setup in project at all, it caused
typecheck
to fail - just by having the plugin installed as a dev dependency (see theinitial
branch of reproduction repository for that case).Repository to reproduce this issue
As mentioned, I created a repository with a couple of branches for several configurations:
Launching
pnpm typecheck
in any of the branches above fails with an error.The text was updated successfully, but these errors were encountered: