import React from 'react'; import { useForm } from 'react-hook-form'; import { FiCode, FiMenu } from 'react-icons/fi'; import JSONPretty from 'react-json-pretty'; import { FormFooter } from '@app/components/FormFooter'; import { connection } from '@app/core/connection'; import { useAppSelector } from '@app/hooks/redux'; import { Card } from '@components/generic/Card'; import { Cover } from '@components/generic/Cover'; import { Checkbox } from '@components/generic/form/Checkbox'; import { Input } from '@components/generic/form/Input'; import { Select } from '@components/generic/form/Select'; import { IconButton } from '@components/generic/IconButton'; import { PrimaryTemplate } from '@components/templates/PrimaryTemplate'; import { Protobuf } from '@meshtastic/meshtasticjs'; export interface PositionProps { navOpen?: boolean; setNavOpen?: React.Dispatch>; } export const Position = ({ navOpen, setNavOpen, }: PositionProps): JSX.Element => { const preferences = useAppSelector((state) => state.meshtastic.preferences); const [debug, setDebug] = React.useState(false); const [loading, setLoading] = React.useState(false); const { register, handleSubmit, formState, reset } = useForm({ defaultValues: { ...preferences, positionBroadcastSecs: preferences.positionBroadcastSecs === 0 ? preferences.isRouter ? 43200 : 900 : preferences.positionBroadcastSecs, }, }); const onSubmit = handleSubmit((data) => { setLoading(true); void connection.setPreferences(data, async () => { await Promise.resolve(); setLoading(false); }); }); return ( } onClick={(): void => { setNavOpen && setNavOpen(!navOpen); }} /> } rightButton={ } active={debug} onClick={(): void => { setDebug(!debug); }} /> } footer={ } > } />
); };