Comments (4)
It's hard to tell what exactly could work for you without seeing the code.
But you could wrap it like this:
import type { TranslationFunctions } from './i18n/i18n-types'
const createRequiredValidator = (LL: TranslationFunctions) => {
return (value: string | undefined) => {
if (!value || value.length === 0) {
return LL.REQUIRED()
}
}
}
// later in your component
const required = createRequiredValidator(LL)
You would make sure to call createRequiredValidator
again every time the language changes.
from typesafe-i18n.
The last solution is better, thanks for the help!
from typesafe-i18n.
Hi @galkatz373,
thanks! I am glad to hear you like the project.
I assume you are using the library inside a 'react' application. Is this correct?
If yes, you would need to pass the LL
translation object to your validation function, to keep the language synchronized with your application.
import type { TranslationFunctions } from './i18n/i18n-types'
export const required = (LL: TranslationFunctions, value: string | undefined) => {
if (!value || value.length === 0) {
return LL.REQUIRED()
}
}
Hope this helps :)
from typesafe-i18n.
Hi @galkatz373,
thanks! I am glad to hear you like the project.I assume you are using the library inside a 'react' application. Is this correct?
If yes, you would need to pass theLL
translation object to your validation function, to keep the language synchronized with your application.import type { TranslationFunctions } from './i18n/i18n-types' export const required = (LL: TranslationFunctions, value: string | undefined) => { if (!value || value.length === 0) { return LL.REQUIRED() } }Hope this helps :)
I thought about it, but then I have to pass the translation object each time I call the validation function.
from typesafe-i18n.
Related Issues (20)
- Calling setLocale after loadNamespaceAsync does not change LL
- [typesafe-i18n] ERROR: Unsupported package manager. HOT 1
- Plural rules not working properly with specific numbers. HOT 1
- Namespaces: Maximum call stack size exceeded HOT 1
- React Docs Don't Match the React Example
- typesafe-i18n is UNMAINTAINED - Ivan Hofer passed away HOT 30
- Using `extendDictionary` does not work well with nested namespaces. HOT 2
- Translations which are displayed using @html are missing
- Not Updated to Support Latest Expo HOT 1
- Sveltkit is using shared global store server-side (SSR) HOT 2
- Argument with custom type is not passed to the formatter function HOT 2
- Vue: namespace not being loaded
- Client rendered translation parent empty object (SvelteKit - Node)
- Feature request: exhaustive plural syntax
- generator outputs weird comments in i18n-types.ts RootTranslation
- error TS1479: The current file is a CommonJS module whose imports will produce 'require' calls HOT 3
- TypeError: Cannot convert argument to a ByteString because the character at index 12 has a value of 1506 which is greater than 255.
- no error or warning when we forgot to suffix parenthesis
- Add Bun and BunX Support HOT 1
- Rest in Peace (Author of this library has passed away) HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from typesafe-i18n.