сделать тупым.
на инпуте висит обработчик onKeyDown, который в зависимости от нажатой клавиши (Escape, Enter и т.д) вызывает либо onSubmit или onCancel
Как вынести логику обработки клавиш, чтобы я в пропсы компоненту мог передать value, onSubmit и onCancel (а не императивный onKeyDown)?
Пполучается, я не могу логику нормально вынести, тем более она специфична именно для этого компонента. У него ещё кстати и стейт есть, для скрывания инпута 😐
в данном кейсе, у тебя component-specific логика прито минимальная
чистым он может быть только когда будет полностью контролируемым value, onChange
ты чета как то усложняешься, у тебя там два хока напрашиваются и один чистый, проблемы вообще не вижу, то что ты будешь чистому скидывать onKeyDown так это норм в принципе
👆Вот у меня исходный компонент. Логика: обработка клавиш и стейт isEditing Это редактируемый элемент списка, к примеру. Надо разделить логику и view, чтобы можно было их переиспользовать: 1) Логику в хук + компонент, который юзает хук 2) Логику в хук + тупой вью + обёртка над вью, которая юзает хук 3) Логику в обёртку над вью + тупой вью
Обсуждают сегодня