@@ -55,12 +53,12 @@ export const DeviceSelector = (): JSX.Element => {
-
setDarkMode(!darkMode)} className="bg-backgroundPrimary py-5 px-4 hover:brightness-hover active:brightness-press text-textSecondary hover:text-textPrimary">{
- darkMode ? (
-
- ) : (
-
- )}
+
setDarkMode(!darkMode)}
+ className="bg-backgroundPrimary py-5 px-4 text-textSecondary hover:text-textPrimary hover:brightness-hover active:brightness-press"
+ >
+ {darkMode ? : }
+

{
const { channels, config, dialog, setDialogOpen } = useDevice();
diff --git a/src/components/Dialog/ImportDialog.tsx b/src/components/Dialog/ImportDialog.tsx
index fc20c466..db3d6ceb 100644
--- a/src/components/Dialog/ImportDialog.tsx
+++ b/src/components/Dialog/ImportDialog.tsx
@@ -1,20 +1,14 @@
-import type React from "react";
import { useEffect, useState } from "react";
-
-import { fromByteArray, toByteArray } from "base64-js";
-import { toast } from "react-hot-toast";
-import { QRCode } from "react-qrcode-logo";
-
+import { toByteArray } from "base64-js";
import { Checkbox } from "@components/form/Checkbox.js";
import { Input } from "@components/form/Input.js";
import { Dialog } from "@components/generic/Dialog.js";
-import { ClipboardIcon } from "@heroicons/react/24/outline";
import { Protobuf } from "@meshtastic/meshtasticjs";
-import { Select } from "../form/Select.js";
-import { renderOptions } from "@app/core/utils/selectEnumOptions.js";
-import { Toggle } from "../form/Toggle.js";
-import { Button } from "../form/Button.js";
-import { useDevice } from "@app/core/providers/useDevice.js";
+import { Select } from "@components/form/Select.js";
+import { renderOptions } from "@core/utils/selectEnumOptions.js";
+import { Toggle } from "@components/form/Toggle.js";
+import { Button } from "@components/form/Button.js";
+import { useDevice } from "@core/providers/useDevice.js";
export interface ImportDialogProps {
isOpen: boolean;
diff --git a/src/components/Dialog/QRDialog.tsx b/src/components/Dialog/QRDialog.tsx
index fb25180d..2648fb7f 100644
--- a/src/components/Dialog/QRDialog.tsx
+++ b/src/components/Dialog/QRDialog.tsx
@@ -1,10 +1,7 @@
-import type React from "react";
import { useEffect, useState } from "react";
-
import { fromByteArray } from "base64-js";
import { toast } from "react-hot-toast";
import { QRCode } from "react-qrcode-logo";
-
import { Checkbox } from "@components/form/Checkbox.js";
import { Input } from "@components/form/Input.js";
import { Dialog } from "@components/generic/Dialog.js";
diff --git a/src/components/Dialog/RebootDialog.tsx b/src/components/Dialog/RebootDialog.tsx
index 385476b9..7ee89420 100644
--- a/src/components/Dialog/RebootDialog.tsx
+++ b/src/components/Dialog/RebootDialog.tsx
@@ -1,12 +1,9 @@
-import type React from "react";
import { useState } from "react";
-
-import { useDevice } from "@app/core/providers/useDevice.js";
+import { useDevice } from "@core/providers/useDevice.js";
import { Dialog } from "@components/generic/Dialog.js";
import { ArrowPathIcon, ClockIcon } from "@heroicons/react/24/outline";
-
-import { Button } from "../form/Button.js";
-import { Input } from "../form/Input.js";
+import { Button } from "@components/form/Button.js";
+import { Input } from "@components/form/Input.js";
export interface RebootDialogProps {
isOpen: boolean;
diff --git a/src/components/Dialog/ShutdownDialog.tsx b/src/components/Dialog/ShutdownDialog.tsx
index 74a8bfdf..18b8e1e5 100644
--- a/src/components/Dialog/ShutdownDialog.tsx
+++ b/src/components/Dialog/ShutdownDialog.tsx
@@ -1,12 +1,9 @@
-import type React from "react";
import { useState } from "react";
-
-import { useDevice } from "@app/core/providers/useDevice.js";
+import { useDevice } from "@core/providers/useDevice.js";
import { Dialog } from "@components/generic/Dialog.js";
import { ClockIcon, PowerIcon } from "@heroicons/react/24/outline";
-
-import { Button } from "../form/Button.js";
-import { Input } from "../form/Input.js";
+import { Button } from "@components/form/Button.js";
+import { Input } from "@components/form/Input.js";
export interface ShutdownDialogProps {
isOpen: boolean;
diff --git a/src/components/Drawer/Metrics.tsx b/src/components/Drawer/Metrics.tsx
index 405a13a0..6399de81 100644
--- a/src/components/Drawer/Metrics.tsx
+++ b/src/components/Drawer/Metrics.tsx
@@ -1,7 +1,4 @@
import "chartjs-adapter-date-fns";
-
-import type React from "react";
-
import {
Chart as ChartJS,
Filler,
@@ -13,8 +10,7 @@ import {
Tooltip
} from "chart.js";
import { Line } from "react-chartjs-2";
-
-import { useDevice } from "@app/core/providers/useDevice.js";
+import { useDevice } from "@core/providers/useDevice.js";
export const Metrics = (): JSX.Element => {
const { nodes, hardware } = useDevice();
diff --git a/src/components/Drawer/Sensor.tsx b/src/components/Drawer/Sensor.tsx
index 34ad5d6d..fbbfe16d 100644
--- a/src/components/Drawer/Sensor.tsx
+++ b/src/components/Drawer/Sensor.tsx
@@ -1,7 +1,5 @@
import "chartjs-adapter-date-fns";
-import type React from "react";
-
import {
Chart as ChartJS,
Filler,
@@ -14,7 +12,7 @@ import {
} from "chart.js";
import { Line } from "react-chartjs-2";
-import { useDevice } from "@app/core/providers/useDevice.js";
+import { useDevice } from "@core/providers/useDevice.js";
export const Sensor = (): JSX.Element => {
const { nodes, hardware } = useDevice();
diff --git a/src/components/Drawer/index.tsx b/src/components/Drawer/index.tsx
index f3a2a9a2..b222b083 100644
--- a/src/components/Drawer/index.tsx
+++ b/src/components/Drawer/index.tsx
@@ -1,6 +1,4 @@
-import type React from "react";
import { useState } from "react";
-
import { Metrics } from "@components/Drawer/Metrics.js";
import { Notifications } from "@components/Drawer/Notifications.js";
import { Sensor } from "@components/Drawer/Sensor.js";
diff --git a/src/components/NewDevice.tsx b/src/components/NewDevice.tsx
index 28fd19f6..dd89eb5d 100644
--- a/src/components/NewDevice.tsx
+++ b/src/components/NewDevice.tsx
@@ -4,7 +4,7 @@ import { TabbedContent, TabType } from "@components/generic/TabbedContent.js";
import { BLE } from "@components/PageComponents/Connect/BLE.js";
import { HTTP } from "@components/PageComponents/Connect/HTTP.js";
import { Serial } from "@components/PageComponents/Connect/Serial.js";
-import { useAppStore } from "@app/core/stores/appStore.js";
+import { useAppStore } from "@core/stores/appStore.js";
import { MoonIcon, SunIcon } from "@heroicons/react/24/outline";
export const NewDevice = () => {
@@ -37,9 +37,7 @@ export const NewDevice = () => {
return (
-
+
);
};
diff --git a/src/components/PageComponents/AppConfig/Map.tsx b/src/components/PageComponents/AppConfig/Map.tsx
index 94e62bea..516836f7 100644
--- a/src/components/PageComponents/AppConfig/Map.tsx
+++ b/src/components/PageComponents/AppConfig/Map.tsx
@@ -1,13 +1,10 @@
-import type React from "react";
-
import { Controller, useFieldArray, useForm } from "react-hook-form";
-
-import { Button } from "@app/components/form/Button.js";
-import { IconButton } from "@app/components/form/IconButton.js";
-import { InfoWrapper } from "@app/components/form/InfoWrapper.js";
-import { Input } from "@app/components/form/Input.js";
-import { Toggle } from "@app/components/form/Toggle.js";
-import { useAppStore } from "@app/core/stores/appStore.js";
+import { Button } from "@components/form/Button.js";
+import { IconButton } from "@components/form/IconButton.js";
+import { InfoWrapper } from "@components/form/InfoWrapper.js";
+import { Input } from "@components/form/Input.js";
+import { Toggle } from "@components/form/Toggle.js";
+import { useAppStore } from "@core/stores/appStore.js";
import { MapValidation } from "@app/validation/appConfig/map.js";
import { Form } from "@components/form/Form";
import { TrashIcon } from "@heroicons/react/24/outline";
diff --git a/src/components/PageComponents/Channel.tsx b/src/components/PageComponents/Channel.tsx
index 499ae450..ddc99c70 100644
--- a/src/components/PageComponents/Channel.tsx
+++ b/src/components/PageComponents/Channel.tsx
@@ -1,10 +1,7 @@
-import type React from "react";
import { useEffect, useState } from "react";
-
import { fromByteArray, toByteArray } from "base64-js";
import { Controller, useForm } from "react-hook-form";
import { toast } from "react-hot-toast";
-
import { ChannelSettingsValidation } from "@app/validation/channelSettings.js";
import { Form } from "@components/form/Form";
import { Input } from "@components/form/Input.js";
diff --git a/src/components/PageComponents/Config/Bluetooth.tsx b/src/components/PageComponents/Config/Bluetooth.tsx
index 8d4937ba..39431788 100644
--- a/src/components/PageComponents/Config/Bluetooth.tsx
+++ b/src/components/PageComponents/Config/Bluetooth.tsx
@@ -1,12 +1,8 @@
-import type React from "react";
import { useEffect } from "react";
-
import { Controller, useForm, useWatch } from "react-hook-form";
-import { toast } from "react-hot-toast";
-
-import { Input } from "@app/components/form/Input.js";
-import { Select } from "@app/components/form/Select.js";
-import { Toggle } from "@app/components/form/Toggle.js";
+import { Input } from "@components/form/Input.js";
+import { Select } from "@components/form/Select.js";
+import { Toggle } from "@components/form/Toggle.js";
import { BluetoothValidation } from "@app/validation/config/bluetooth.js";
import { Form } from "@components/form/Form";
import { useDevice } from "@core/providers/useDevice.js";
@@ -17,17 +13,12 @@ import { Protobuf } from "@meshtastic/meshtasticjs";
export const Bluetooth = (): JSX.Element => {
const { config, setWorkingConfig } = useDevice();
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- control,
- reset
- } = useForm
({
- mode: "onChange",
- defaultValues: config.bluetooth,
- resolver: classValidatorResolver(BluetoothValidation)
- });
+ const { register, handleSubmit, control, reset } =
+ useForm({
+ mode: "onChange",
+ defaultValues: config.bluetooth,
+ resolver: classValidatorResolver(BluetoothValidation)
+ });
useEffect(() => {
reset(config.bluetooth);
diff --git a/src/components/PageComponents/Config/Device.tsx b/src/components/PageComponents/Config/Device.tsx
index 89b329cb..d59ae960 100644
--- a/src/components/PageComponents/Config/Device.tsx
+++ b/src/components/PageComponents/Config/Device.tsx
@@ -1,12 +1,8 @@
-import type React from "react";
import { useEffect } from "react";
-
import { Controller, useForm } from "react-hook-form";
-import { toast } from "react-hot-toast";
-
-import { Input } from "@app/components/form/Input.js";
-import { Select } from "@app/components/form/Select.js";
-import { Toggle } from "@app/components/form/Toggle.js";
+import { Input } from "@components/form/Input.js";
+import { Select } from "@components/form/Select.js";
+import { Toggle } from "@components/form/Toggle.js";
import { DeviceValidation } from "@app/validation/config/device.js";
import { Form } from "@components/form/Form";
import { useDevice } from "@core/providers/useDevice.js";
@@ -16,13 +12,7 @@ import { Protobuf } from "@meshtastic/meshtasticjs";
export const Device = (): JSX.Element => {
const { config, setWorkingConfig } = useDevice();
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- control,
- reset
- } = useForm({
+ const { register, handleSubmit, control, reset } = useForm({
mode: "onChange",
defaultValues: config.device,
resolver: classValidatorResolver(DeviceValidation)
@@ -80,14 +70,12 @@ export const Device = (): JSX.Element => {
label="Button Pin"
description="Button pin override"
type="number"
- error={errors.buttonGpio?.message}
{...register("buttonGpio", { valueAsNumber: true })}
/>
diff --git a/src/components/PageComponents/Config/Display.tsx b/src/components/PageComponents/Config/Display.tsx
index 92d5a671..f3681681 100644
--- a/src/components/PageComponents/Config/Display.tsx
+++ b/src/components/PageComponents/Config/Display.tsx
@@ -1,12 +1,8 @@
-import type React from "react";
import { useEffect } from "react";
-
import { Controller, useForm } from "react-hook-form";
-import { toast } from "react-hot-toast";
-
-import { Input } from "@app/components/form/Input.js";
-import { Select } from "@app/components/form/Select.js";
-import { Toggle } from "@app/components/form/Toggle.js";
+import { Input } from "@components/form/Input.js";
+import { Select } from "@components/form/Select.js";
+import { Toggle } from "@components/form/Toggle.js";
import { DisplayValidation } from "@app/validation/config/display.js";
import { Form } from "@components/form/Form";
import { useDevice } from "@core/providers/useDevice.js";
@@ -16,17 +12,13 @@ import { Protobuf } from "@meshtastic/meshtasticjs";
export const Display = (): JSX.Element => {
const { config, setWorkingConfig } = useDevice();
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- reset,
- control
- } = useForm({
- mode: "onChange",
- defaultValues: config.display,
- resolver: classValidatorResolver(DisplayValidation)
- });
+ const { register, handleSubmit, reset, control } = useForm(
+ {
+ mode: "onChange",
+ defaultValues: config.display,
+ resolver: classValidatorResolver(DisplayValidation)
+ }
+ );
useEffect(() => {
reset(config.display);
diff --git a/src/components/PageComponents/Config/LoRa.tsx b/src/components/PageComponents/Config/LoRa.tsx
index 658ad989..f944ddf6 100644
--- a/src/components/PageComponents/Config/LoRa.tsx
+++ b/src/components/PageComponents/Config/LoRa.tsx
@@ -1,13 +1,9 @@
-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 { Select } from "@app/components/form/Select.js";
-import { Toggle } from "@app/components/form/Toggle.js";
+import { FormSection } from "@components/form/FormSection.js";
+import { Input } from "@components/form/Input.js";
+import { Select } from "@components/form/Select.js";
+import { Toggle } from "@components/form/Toggle.js";
import { LoRaValidation } from "@app/validation/config/lora.js";
import { Form } from "@components/form/Form";
import { useDevice } from "@core/providers/useDevice.js";
@@ -18,13 +14,7 @@ import { Protobuf } from "@meshtastic/meshtasticjs";
export const LoRa = (): JSX.Element => {
const { config, setWorkingConfig } = useDevice();
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- control,
- reset
- } = useForm({
+ const { register, handleSubmit, control, reset } = useForm({
mode: "onChange",
defaultValues: config.lora,
resolver: classValidatorResolver(LoRaValidation)
@@ -81,7 +71,6 @@ export const LoRa = (): JSX.Element => {
description="Channel bandwidth in MHz"
type="number"
suffix="MHz"
- error={errors.bandwidth?.message}
{...register("bandwidth", {
valueAsNumber: true
})}
@@ -91,7 +80,6 @@ export const LoRa = (): JSX.Element => {
description="Indicates the number of chirps per symbol"
type="number"
suffix="CPS"
- error={errors.spreadFactor?.message}
{...register("spreadFactor", {
valueAsNumber: true
})}
@@ -100,7 +88,6 @@ export const LoRa = (): JSX.Element => {
label="Coding Rate"
description="The denominator of the coding rate"
type="number"
- error={errors.codingRate?.message}
{...register("codingRate", {
valueAsNumber: true
})}
@@ -132,14 +119,12 @@ export const LoRa = (): JSX.Element => {
label="Transmit Power"
description="Max transmit power in dBm"
type="number"
- error={errors.txPower?.message}
{...register("txPower", { valueAsNumber: true })}
/>
{
description="Frequency offset to correct for crystal calibration errors"
suffix="Hz"
type="number"
- error={errors.frequencyOffset?.message}
{...register("frequencyOffset", { valueAsNumber: true })}
/>
{
description="Maximum number of hops"
suffix="Hops"
type="number"
- error={errors.hopLimit?.message}
{...register("hopLimit", { valueAsNumber: true })}
/>
diff --git a/src/components/PageComponents/Config/Network.tsx b/src/components/PageComponents/Config/Network.tsx
index 9a781d17..68d28f0c 100644
--- a/src/components/PageComponents/Config/Network.tsx
+++ b/src/components/PageComponents/Config/Network.tsx
@@ -1,15 +1,11 @@
-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 { IPInput } from "@app/components/form/IPInput.js";
-import { Select } from "@app/components/form/Select.js";
-import { Toggle } from "@app/components/form/Toggle.js";
-import { renderOptions } from "@app/core/utils/selectEnumOptions.js";
+import { FormSection } from "@components/form/FormSection.js";
+import { Input } from "@components/form/Input.js";
+import { IPInput } from "@components/form/IPInput.js";
+import { Select } from "@components/form/Select.js";
+import { Toggle } from "@components/form/Toggle.js";
+import { renderOptions } from "@core/utils/selectEnumOptions.js";
import { NetworkValidation } from "@app/validation/config/network.js";
import { Form } from "@components/form/Form";
import { useDevice } from "@core/providers/useDevice.js";
@@ -19,17 +15,13 @@ import { Protobuf } from "@meshtastic/meshtasticjs";
export const Network = (): JSX.Element => {
const { config, setWorkingConfig } = useDevice();
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- control,
- reset
- } = useForm({
- mode: "onChange",
- defaultValues: config.network,
- resolver: classValidatorResolver(NetworkValidation)
- });
+ const { register, handleSubmit, control, reset } = useForm(
+ {
+ mode: "onChange",
+ defaultValues: config.network,
+ resolver: classValidatorResolver(NetworkValidation)
+ }
+ );
const wifiEnabled = useWatch({
control,
@@ -66,19 +58,6 @@ export const Network = (): JSX.Element => {
return (
diff --git a/src/components/PageComponents/Config/Position.tsx b/src/components/PageComponents/Config/Position.tsx
index 18c30fbe..e0be95fe 100644
--- a/src/components/PageComponents/Config/Position.tsx
+++ b/src/components/PageComponents/Config/Position.tsx
@@ -1,13 +1,9 @@
-import type React from "react";
import { useEffect } from "react";
-
import { Controller, useForm, useWatch } from "react-hook-form";
-import { toast } from "react-hot-toast";
-
-import { BitwiseSelect } from "@app/components/form/BitwiseSelect.js";
-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 { BitwiseSelect } from "@components/form/BitwiseSelect.js";
+import { FormSection } from "@components/form/FormSection.js";
+import { Input } from "@components/form/Input.js";
+import { Toggle } from "@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";
@@ -19,22 +15,17 @@ export const Position = (): JSX.Element => {
const myNode = nodes.find((n) => n.data.num === hardware.myNodeNum);
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- reset,
- control
- } = useForm({
- mode: "onChange",
- 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 { register, handleSubmit, reset, control } =
+ useForm({
+ mode: "onChange",
+ 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,
@@ -153,7 +144,6 @@ export const Position = (): JSX.Element => {
{
suffix="m"
label="Altitude"
type="number"
- error={errors.fixedAlt?.message}
disabled={!fixedPositionEnabled}
{...register("fixedAlt", { valueAsNumber: true })}
/>
@@ -188,7 +177,6 @@ export const Position = (): JSX.Element => {
suffix="°"
label="Latitude"
type="number"
- error={errors.fixedLat?.message}
disabled={!fixedPositionEnabled}
{...register("fixedLat", { valueAsNumber: true })}
/>
@@ -196,7 +184,6 @@ export const Position = (): JSX.Element => {
suffix="°"
label="Longitude"
type="number"
- error={errors.fixedLng?.message}
disabled={!fixedPositionEnabled}
{...register("fixedLng", { valueAsNumber: true })}
/>
@@ -209,7 +196,6 @@ export const Position = (): JSX.Element => {
label="Broadcast Interval"
description="How often your position is sent out over the mesh"
type="number"
- error={errors.positionBroadcastSecs?.message}
{...register("positionBroadcastSecs", { valueAsNumber: true })}
/>
{
label="GPS Update Interval"
description="How often a GPS fix should be acquired"
type="number"
- error={errors.gpsUpdateInterval?.message}
{...register("gpsUpdateInterval", { valueAsNumber: true })}
/>
{
label="Fix Attempt Duration"
description="How long the device will try to get a fix for"
type="number"
- error={errors.gpsAttemptTime?.message}
{...register("gpsAttemptTime", { valueAsNumber: true })}
/>
@@ -233,14 +217,12 @@ export const Position = (): JSX.Element => {
label="RX Pin"
description="GPS Module RX pin override"
type="number"
- error={errors.rxGpio?.message}
{...register("rxGpio", { valueAsNumber: true })}
/>
diff --git a/src/components/PageComponents/Config/Power.tsx b/src/components/PageComponents/Config/Power.tsx
index 172fb5bb..f8be2773 100644
--- a/src/components/PageComponents/Config/Power.tsx
+++ b/src/components/PageComponents/Config/Power.tsx
@@ -1,12 +1,8 @@
-import type React from "react";
import { useEffect } from "react";
-
import { Controller, useForm } 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 { FormSection } from "@components/form/FormSection.js";
+import { Input } from "@components/form/Input.js";
+import { Toggle } from "@components/form/Toggle.js";
import { PowerValidation } from "@app/validation/config/power.js";
import { Form } from "@components/form/Form";
import { useDevice } from "@core/providers/useDevice.js";
@@ -15,13 +11,7 @@ import { Protobuf } from "@meshtastic/meshtasticjs";
export const Power = (): JSX.Element => {
const { config, setWorkingConfig } = useDevice();
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- reset,
- control
- } = useForm({
+ const { register, handleSubmit, reset, control } = useForm({
mode: "onChange",
defaultValues: config.power,
resolver: classValidatorResolver(PowerValidation)
@@ -49,7 +39,6 @@ export const Power = (): JSX.Element => {
description="Automatically shutdown node after this long when on battery, 0 for indefinite"
suffix="Seconds"
type="number"
- error={errors.onBatteryShutdownAfterSecs?.message}
{...register("onBatteryShutdownAfterSecs", { valueAsNumber: true })}
/>
{
label="ADC Multiplier Override ratio"
description="Used for tweaking battery voltage reading"
type="number"
- error={errors.adcMultiplierOverride?.message}
{...register("adcMultiplierOverride", { valueAsNumber: true })}
/>
@@ -77,7 +65,6 @@ export const Power = (): JSX.Element => {
description="Minimum amount of time the device will stay awake for after receiving a packet"
suffix="Seconds"
type="number"
- error={errors.minWakeSecs?.message}
{...register("minWakeSecs", { valueAsNumber: true })}
/>
{
description="The device will enter super deep sleep after this time"
suffix="Seconds"
type="number"
- error={errors.meshSdsTimeoutSecs?.message}
{...register("meshSdsTimeoutSecs", { valueAsNumber: true })}
/>
{
description="How long the device will be in super deep sleep for"
suffix="Seconds"
type="number"
- error={errors.sdsSecs?.message}
{...register("sdsSecs", { valueAsNumber: true })}
/>
{
description="How long the device will be in light sleep for"
suffix="Seconds"
type="number"
- error={errors.lsSecs?.message}
{...register("lsSecs", { valueAsNumber: true })}
/>
@@ -110,7 +94,6 @@ export const Power = (): JSX.Element => {
description="If the device does not receive a Bluetooth connection, the BLE radio will be disabled after this long"
suffix="Seconds"
type="number"
- error={errors.waitBluetoothSecs?.message}
{...register("waitBluetoothSecs", { valueAsNumber: true })}
/>
diff --git a/src/components/PageComponents/Config/User.tsx b/src/components/PageComponents/Config/User.tsx
index e93e336c..df180c2b 100644
--- a/src/components/PageComponents/Config/User.tsx
+++ b/src/components/PageComponents/Config/User.tsx
@@ -1,18 +1,14 @@
-import type React from "react";
import { useEffect } from "react";
-
import { Controller, useForm } from "react-hook-form";
import { toast } from "react-hot-toast";
import { base16 } from "rfc4648";
-
-import { Input } from "@app/components/form/Input.js";
-import { Select } from "@app/components/form/Select.js";
-import { Toggle } from "@app/components/form/Toggle.js";
+import { Input } from "@components/form/Input.js";
+import { Select } from "@components/form/Select.js";
+import { Toggle } from "@components/form/Toggle.js";
import { UserValidation } from "@app/validation/config/user.js";
import { Form } from "@components/form/Form";
import { useDevice } from "@core/providers/useDevice.js";
import { renderOptions } from "@core/utils/selectEnumOptions.js";
-import { ErrorMessage } from "@hookform/error-message";
import { classValidatorResolver } from "@hookform/resolvers/class-validator";
import { Protobuf } from "@meshtastic/meshtasticjs";
@@ -21,13 +17,7 @@ export const User = (): JSX.Element => {
const myNode = nodes.find((n) => n.data.num === hardware.myNodeNum);
- const {
- register,
- handleSubmit,
- formState: { errors, isDirty },
- reset,
- control
- } = useForm({
+ const { register, handleSubmit, reset, control } = useForm({
defaultValues: myNode?.data.user,
resolver: classValidatorResolver(UserValidation)
});
@@ -61,12 +51,7 @@ export const User = (): JSX.Element => {
});
return (
-