Skip to content
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

react-i18next <Trans /> component values are not type safe #1772

Open
samuelpucat opened this issue Jul 16, 2024 · 4 comments
Open

react-i18next <Trans /> component values are not type safe #1772

samuelpucat opened this issue Jul 16, 2024 · 4 comments

Comments

@samuelpucat
Copy link

🐛 Bug Report

When using react-i18next <Trans /> component, prop values provides no intellisense and throws no TS errors.

To Reproduce

I followed these tutorials:

  1. I generated /src/@types/resources.d.ts with i18next-resources-for-ts interface -i ./public/locales/en -o ./src/@types/resources.d.ts script:
// resources.d.ts

interface Resources {
  "translation": {
    ...
    "title": "Title: <strong>{{appName}}</strong>",
    ...
  },
  ...
}
export default Resources;
  1. I created /src/@types/i18next.d.ts:
// i18next.d.ts

import Resources from './resources'

declare module 'i18next' {
    interface CustomTypeOptions {
        defaultNS: 'translation';
        resources: Resources;
        allowObjectInHTMLChildren: true;
    }
}
  1. I added /public/locales/en/translation.json
{
    "title": "Title: <strong>{{appName}}</strong>"
}
  1. I used the translation like this:
<Trans
  t={t}
  i18nKey="title"
  values={{
    appName: 'Super duper app',
    // wrong value key but no TS error
    // apName: 'Super duper app',
  }}
/>

or this:

<Trans
  t={t}
  i18nKey="title"
>
  {/* wrong value key but no TS error */}
  Title <strong>{{apName: 'Super duper app'}}</strong>
</Trans>

i18nKey had good intellisense and threw TS error when I typed a different key but wrong values key didn't throw any error.

Expected behavior

I would expect same error as when using t function with wrong value keys:

{/* wrong value key with correct TS error */}
{t('title', { apName: appName })}

throws error:

Argument of type '["title", { apName: "Super duper app"; }]' is not assignable to parameter of type '[key: "title" | "title"[], options?: ({ readonly apName: "Super duper app"; } & { appName: unknown; }) | undefined] | [key: string | string[], options: { readonly apName: "Super duper app"; } & $Dictionary & { ...; }] | [key: ...]'.
  Type '["title", { apName: "Super duper app"; }]' is not assignable to type '[key: string | string[], defaultValue: string, options?: ({ readonly apName: "Super duper app"; } & $Dictionary) | undefined]'.
    Type at position 1 in source is not compatible with type at position 1 in target.
      Type '{ apName: "Super duper app"; }' is not assignable to type 'string'.

Your Environment

  • node version: v20.14.0
  • typescript version: 5.2.2
  • i18next version: 23.12.1
  • react-i18next version: 14.1.2
  • i18next-resources-for-ts version: 1.5.0

Thanks

P.S.: If this issue belongs to react-i18next package, please let me know and I'll move it there.

@adrai
Copy link
Member

adrai commented Jul 16, 2024

Yes, this belongs to react-i18next, but to just answer you here... the types are safe, since it checks for the i18nKey to exist...
image

@adrai adrai transferred this issue from i18next/i18next-resources-for-ts Jul 16, 2024
@marcalexiei marcalexiei removed their assignment Jul 16, 2024
@marcalexiei
Copy link
Contributor

If anyone has time, feel free to open a PR to address this issue

@GorvGoyl
Copy link

following up on this.. is there any way possible to have typesafe translation for nested react components?
cc: @marcalexiei @adrai 👀

@adrai
Copy link
Member

adrai commented Oct 16, 2024

Feel free to try to create a PR for this, if you like.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants