import React from 'react'; import { useForm } from 'react-hook-form'; import { useTranslation } from 'react-i18next'; import { FiMenu, FiSave } from 'react-icons/fi'; import { Card } from '@app/components/generic/Card'; import { Checkbox } from '@app/components/generic/form/Checkbox'; import { Input } from '@app/components/generic/form/Input.jsx'; import { IconButton } from '@app/components/generic/IconButton.jsx'; import { connection } from '@app/core/connection.js'; import { useAppSelector } from '@app/hooks/redux'; import { Button } from '@components/generic/Button'; import { PrimaryTemplate } from '@components/templates/PrimaryTemplate'; import type { RadioConfig_UserPreferences } from '@meshtastic/meshtasticjs/dist/generated'; export interface RangeTestProps { navOpen?: boolean; setNavOpen?: React.Dispatch>; } export const RangeTest = ({ navOpen, setNavOpen, }: RangeTestProps): JSX.Element => { const { t } = useTranslation(); const preferences = useAppSelector((state) => state.meshtastic.preferences); const { register, handleSubmit, formState } = useForm({ defaultValues: { rangeTestPluginEnabled: preferences.rangeTestPluginEnabled, rangeTestPluginSave: preferences.rangeTestPluginSave, rangeTestPluginSender: preferences.rangeTestPluginSender, }, }); const onSubmit = handleSubmit((data) => { console.log(data); void connection.setPreferences(data); }); return ( } onClick={(): void => { setNavOpen && setNavOpen(!navOpen); }} /> } footer={ } >
); };