import type React from 'react'; import { useEffect, useState } from 'react'; import { useForm } from 'react-hook-form'; import { Checkbox } from '@components/generic/form/Checkbox'; import { Form } from '@components/generic/form/Form'; import { Input } from '@components/generic/form/Input'; import { Select } from '@components/generic/form/Select'; import { connection } from '@core/connection'; import { useAppSelector } from '@hooks/useAppSelector'; import { Protobuf } from '@meshtastic/meshtasticjs'; export const LoRa = (): JSX.Element => { const preferences = useAppSelector( (state) => state.meshtastic.radio.preferences, ); const [loading, setLoading] = useState(false); const { register, handleSubmit, formState, reset } = useForm({ defaultValues: preferences, }); useEffect(() => { reset(preferences); }, [reset, preferences]); const onSubmit = handleSubmit((data) => { setLoading(true); void connection.setPreferences(data, async () => { reset({ ...data }); setLoading(false); await Promise.resolve(); }); }); return (