import type React from "react"; import { useEffect } from "react"; import { Controller, useForm, useWatch } from "react-hook-form"; import { toast } from "react-hot-toast"; import { FormSection } from "@app/components/form/FormSection.js"; import { Input } from "@app/components/form/Input.js"; import { Toggle } from "@app/components/form/Toggle.js"; import { PositionValidation } from "@app/validation/config/position.js"; import { Form } from "@components/form/Form"; import { useDevice } from "@core/providers/useDevice.js"; import { classValidatorResolver } from "@hookform/resolvers/class-validator"; import { Protobuf } from "@meshtastic/meshtasticjs"; export const Position = (): JSX.Element => { const { config, connection, nodes, hardware } = useDevice(); const myNode = nodes.find((n) => n.data.num === hardware.myNodeNum); const { register, handleSubmit, formState: { errors, isDirty }, reset, control, } = useForm({ defaultValues: { fixedAlt: myNode?.data.position?.altitude, fixedLat: (myNode?.data.position?.latitudeI ?? 0) / 1e7, fixedLng: (myNode?.data.position?.longitudeI ?? 0) / 1e7, ...config.position, }, resolver: classValidatorResolver(PositionValidation), }); const fixedPositionEnabled = useWatch({ control, name: "fixedPosition", defaultValue: false, }); useEffect(() => { reset({ fixedAlt: myNode?.data.position?.altitude, fixedLat: (myNode?.data.position?.latitudeI ?? 0) / 1e7, fixedLng: (myNode?.data.position?.longitudeI ?? 0) / 1e7, ...config.position, }); }, [reset, config.position, myNode?.data.position]); const onSubmit = handleSubmit((data) => { const { fixedAlt, fixedLat, fixedLng, ...rest } = data; const configHasChanged = !Protobuf.Config_PositionConfig.equals( config.position, Protobuf.Config_PositionConfig.create(rest) ); if (connection) { void toast.promise( connection.sendPacket( Protobuf.Position.toBinary( Protobuf.Position.create({ altitude: fixedAlt, latitudeI: fixedLat * 1e7, longitudeI: fixedLng * 1e7, }) ), Protobuf.PortNum.POSITION_APP, undefined, true, undefined, true, false, async () => { reset({ ...data }); await Promise.resolve(); } ), { loading: "Saving...", success: "Saved Channel", error: "No response received", } ); if (configHasChanged) { void toast.promise( connection.setConfig( { payloadVariant: { oneofKind: "position", position: rest, }, }, async () => { reset({ ...data }); await Promise.resolve(); } ), { loading: "Saving...", success: "Saved Position Config, Restarting Node", error: "No response received", } ); } } }); return (
reset(config.position)} dirty={isDirty} onSubmit={onSubmit} > ( )} /> ( )} /> ( )} /> {/* { const { value, onChange, ...rest } = field; const { error } = fieldState; const options = Object.entries( Protobuf.Config_PositionConfig_PositionFlags ) .filter((value) => typeof value[1] !== "number") .filter( (value) => parseInt(value[0]) !== Protobuf.Config_PositionConfig_PositionFlags.UNSET ) .map((value) => { return { value: parseInt(value[0]), label: value[1].toString().replace("POS_", "").toLowerCase(), }; }); const selected = bitwiseDecode( value, Protobuf.Config_PositionConfig_PositionFlags ).map((flag) => Protobuf.Config_PositionConfig_PositionFlags[flag] .replace("POS_", "") .toLowerCase() ); // onChange={(e: { value: number; label: string }[]): void => // onChange(bitwiseEncode(e.map((v) => v.value))) // } return ( { // const selected = [...selectedItemsState, item.value] // const selectedItems = selected // const selectedItemsLength = selectedItems.length // let selectedNames = '' // if (selectedItemsLength === 0) { // selectedNames = '' // } else if (selectedItemsLength === 1) { // selectedNames = selectedItems.toString() // } else if (selectedItemsLength > 1) { // selectedNames = selectedItemsLength.toString() + ' selected...' // } // setSelectedItems(selectedItems) // setSelectedItemNames(selectedNames) // }} // onDeselect={(item) => { // const deselectedItemIndex = selectedItemsState.indexOf(item.value) // const selectedItems = selectedItemsState.filter((_item, i) => i !== deselectedItemIndex) // const selectedItemsLength = selectedItems.length // let selectedNames = '' // if (selectedItemsLength === 0) { // selectedNames = '' // } else if (selectedItemsLength === 1) { // selectedNames = selectedItems.toString() // } else if (selectedItemsLength > 1) { // selectedNames = selectedItemsLength.toString() + ' selected...' // } // setSelectedItems(selectedItems) // setSelectedItemNames(selectedNames) // }} > ); }} /> */} ); };