Files
web/src/components/PageComponents/ModuleConfig/RangeTest.tsx
2023-07-09 13:59:31 +10:00

63 lines
1.7 KiB
TypeScript

import type { RangeTestValidation } from "@app/validation/moduleConfig/rangeTest.js";
import { useDevice } from "@core/stores/deviceStore.js";
import { Protobuf } from "@meshtastic/meshtasticjs";
import { DynamicForm } from "@components/Form/DynamicForm.js";
export const RangeTest = (): JSX.Element => {
const { moduleConfig, setWorkingModuleConfig } = useDevice();
const onSubmit = (data: RangeTestValidation) => {
setWorkingModuleConfig(
new Protobuf.ModuleConfig({
payloadVariant: {
case: "rangeTest",
value: data,
},
}),
);
};
return (
<DynamicForm<RangeTestValidation>
onSubmit={onSubmit}
defaultValues={moduleConfig.rangeTest}
fieldGroups={[
{
label: "Range Test Settings",
description: "Settings for the Range Test module",
fields: [
{
type: "toggle",
name: "enabled",
label: "Module Enabled",
description: "Enable Range Test",
},
{
type: "number",
name: "sender",
label: "Message Interval",
description: "How long to wait between sending test packets",
disabledBy: [
{
fieldName: "enabled",
},
],
},
{
type: "toggle",
name: "save",
label: "Save CSV to storage",
description: "ESP32 Only",
disabledBy: [
{
fieldName: "enabled",
},
],
},
],
},
]}
/>
);
};