169 похожих чатов

Приветствую. Никто не находил/делал типизированную декларативную форму для реакта? Я думал написать,

но выходит нечто страшное (набираю по памяти, скорее чтобы концепт передать, доступа к исходникам сейчас нет):

type FormElementProps<T> = {
value: T
onChange: (newValue: T) => void
}

type AddConverters<TComponentValue, TFormValue> =
(TComponentValue extends TFormValue
? { toForm?: never }
: { toForm: (componentValue: TComponentValue) => TFormValue }
) & (
TFormValue extends TComponentValue
? { fromForm?: never }
: { fromForm?: (formValue: TFormValue) => TComponentValue }
)

type FormElementDescriptor<TValue> =
<TComponent>(Component: TComponent extends React.ComponentType<
infer TProps> ? TProps extends FormElementProps<infer TComponentValue> ? TComponent : never : never): (prop: Omit<TProps, keyof FormElementProps<any> & AddConverters<TComponentValue, TValue>) => React.ReactNode;

type FormProps<T> = FormElementProps<T> & {
[K in keyof T]: (f: FormElementDescriptor<T[K]>) => React.ReactNode
}

// usage
const model = {
a: 'ggfgjgdhh',
b: 678
}

const formProps: FormProps<typeof model> = {
value: model,
onChange: noop,
a: f => f(SomeTextInput)({
required: true,
style: {}
}),
b: f => f(SomeNumericInput)({
required: true,
style: {}
})
}

1 ответов

8 просмотров

Formik, final form

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
а чем лучше всего сделать глобальный лок, если много нодов, до сотни? ну то есть мне надо, чтобы некоторые операции с объектом не происходили одновременно. перемещение между н...
Д. П.
15
Hi guys, I'm looking for a good LLM course. Is there any course to learn LLMs in advanced? I'm aiming to use them in my apps, so a perfect course in my openion, is not only a ...
Taha
14
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
Легче писать на C++ чем на C, если полностью не изучать C++, а знать только основное?
Алмаз
8
Карта сайта