You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I think the problem is that the schema is defined at the top of the file but not inside the react comonent.
I could move it in there, but then the schema gets recreated every time the component rerenders.
I could also use it with useMemo, but then I have to always import the resolved language to include it in the dependency array, even if it is not required by the component.
Also useMemo comes with a cost.
The other aproach of using t('passwordRequired') for every validation is quite tedious and since yup support dynamic fields in the error message there is no need to set a translation string for every field.
So whats the best aproach for this case?
Best would be having dynamic locales (by opt-in) I guess.
BennyAlex
changed the title
How to change the locale globally, not only for the current file?
How to use yup react and developer friendly?
Apr 17, 2024
@jquense
Could we have setLocale behave that it will (optionally) reinstanciate the messages?
In my opinion this is the resonable and expected behavior, if you change the language you normally do not want only some parts of your app to be translated.
I have a react app built with react-i18n.
I try to change the yup locale depending on the resolved language:
All children will only be rendered if langSetup is true, but still I only see the default error messages.
When changing the locale manually at the top of a component it works fine:
yup.setLocale(yupLocales.de);
How do that automatically affecting all components?
The text was updated successfully, but these errors were encountered: