import type React from 'react'; import { useEffect, useState } from 'react'; import { useForm, useWatch } from 'react-hook-form'; import { FiSave } from 'react-icons/fi'; import { IconButton } from '@components/generic/button/IconButton'; import { Checkbox } from '@components/generic/form/Checkbox'; import { Form } from '@components/generic/form/Form'; import { Input } from '@components/generic/form/Input'; import { connection } from '@core/connection'; import { useAppSelector } from '@hooks/useAppSelector'; import type { Protobuf } from '@meshtastic/meshtasticjs'; export const SerialSettingsPanel = (): JSX.Element => { const [loading, setLoading] = useState(false); const preferences = useAppSelector( (state) => state.meshtastic.radio.preferences, ); const { register, handleSubmit, formState, reset, control } = useForm({ defaultValues: preferences, }); useEffect(() => { reset(preferences); }, [reset, preferences]); const onSubmit = handleSubmit(async (data) => { setLoading(true); await connection.setPreferences(data, async (): Promise => { reset({ ...data }); setLoading(false); await Promise.resolve(); }); }); const pluginEnabled = useWatch({ control, name: 'serialpluginEnabled', defaultValue: false, }); return ( <>
=> { await onSubmit(); }} icon={} />
); };