I'm still a newbie in typescript and been searching in google about this for almost 2 hours now.
I want to create a type that is an object that will contain multiple values. The key of one value in the object would be the same as the keys of another value in that same object, except this time they will be functions.
Example value of this would be:
{ values: { email: '', password: '' }, validators: { email: () => { /* some function that does something and returns a string */ }, password: () => { /* some function that does something and returns a string */ }, }};
In the example above, you see that the keys of validators
are the same as the keys of values
, except validators
are composed of functions.
I can do:
export type Options = { values: Record<string, unknown>, validators: Record<string, unknown>};
but this is not robust because I want the autocomplete to happen, I want validators
to be a record which keys are the same as the keys of values
, except all those are optional and should be functions.
I'm thinking of using generics, but I don't know what to pass to it
type FormValidator<T> = { [P in keyof T]?: (values: Record<string, unknown>) => string;};export type FormOptions = { values: Record<string, unknown>; validators?: FormValidator<this.values>; // WHAT DO I PASS HERE SO THAT IT WILL GET THE KEYS OF VALUES?};
EDIT 1:
One thing that I think works the same as I want this to work is this:
Notice how the autocomplete works, and if you add something else that's not in values
, it will also throw an error that's basically how I want it but I want it defined in that one type: type FormOptions
EDIT 2:
I'm wanting to do this in ReactJS / ReactNative and just plain NodeJS/TypeScript (that is, without using any frameworks)