Browse Source

move to RsBuild

pull/313/head
Sacha Weatherstone 2 years ago
parent
commit
42068ad3d8
Failed to extract signature
  1. 14
      package.json
  2. 658
      pnpm-lock.yaml
  3. 27
      rsbuild.config.ts
  4. 24
      src/App.tsx
  5. 4
      src/DeviceWrapper.tsx
  6. 12
      src/PageRouter.tsx
  7. 6
      src/components/CommandPalette.tsx
  8. 10
      src/components/DeviceSelector.tsx
  9. 10
      src/components/Dialog/DeviceNameDialog.tsx
  10. 14
      src/components/Dialog/DialogManager.tsx
  11. 14
      src/components/Dialog/ImportDialog.tsx
  12. 14
      src/components/Dialog/NewDeviceDialog.tsx
  13. 4
      src/components/Dialog/PkiRegenerateDialog.tsx
  14. 8
      src/components/Dialog/QRDialog.tsx
  15. 8
      src/components/Dialog/RebootDialog.tsx
  16. 8
      src/components/Dialog/RemoveNodeDialog.tsx
  17. 8
      src/components/Dialog/ShutdownDialog.tsx
  18. 10
      src/components/Form/DynamicForm.tsx
  19. 8
      src/components/Form/DynamicFormField.tsx
  20. 4
      src/components/Form/FormInput.tsx
  21. 4
      src/components/Form/FormPasswordGenerator.tsx
  22. 4
      src/components/Form/FormSelect.tsx
  23. 4
      src/components/Form/FormToggle.tsx
  24. 2
      src/components/Form/FormWrapper.tsx
  25. 8
      src/components/PageComponents/Channel.tsx
  26. 6
      src/components/PageComponents/Config/Bluetooth.tsx
  27. 6
      src/components/PageComponents/Config/Device.tsx
  28. 6
      src/components/PageComponents/Config/Display.tsx
  29. 6
      src/components/PageComponents/Config/LoRa.tsx
  30. 8
      src/components/PageComponents/Config/Network.tsx
  31. 6
      src/components/PageComponents/Config/Position.tsx
  32. 6
      src/components/PageComponents/Config/Power.tsx
  33. 6
      src/components/PageComponents/Config/Security.tsx
  34. 12
      src/components/PageComponents/Connect/BLE.tsx
  35. 16
      src/components/PageComponents/Connect/HTTP.tsx
  36. 12
      src/components/PageComponents/Connect/Serial.tsx
  37. 10
      src/components/PageComponents/Messages/ChannelChat.tsx
  38. 2
      src/components/PageComponents/Messages/Message.tsx
  39. 6
      src/components/PageComponents/Messages/MessageInput.tsx
  40. 2
      src/components/PageComponents/Messages/TraceRoute.tsx
  41. 6
      src/components/PageComponents/ModuleConfig/AmbientLighting.tsx
  42. 6
      src/components/PageComponents/ModuleConfig/Audio.tsx
  43. 6
      src/components/PageComponents/ModuleConfig/CannedMessage.tsx
  44. 6
      src/components/PageComponents/ModuleConfig/DetectionSensor.tsx
  45. 6
      src/components/PageComponents/ModuleConfig/ExternalNotification.tsx
  46. 6
      src/components/PageComponents/ModuleConfig/MQTT.tsx
  47. 6
      src/components/PageComponents/ModuleConfig/NeighborInfo.tsx
  48. 6
      src/components/PageComponents/ModuleConfig/Paxcounter.tsx
  49. 6
      src/components/PageComponents/ModuleConfig/RangeTest.tsx
  50. 6
      src/components/PageComponents/ModuleConfig/Serial.tsx
  51. 6
      src/components/PageComponents/ModuleConfig/StoreForward.tsx
  52. 6
      src/components/PageComponents/ModuleConfig/Telemetry.tsx
  53. 2
      src/components/PageLayout.tsx
  54. 10
      src/components/Sidebar.tsx
  55. 4
      src/components/Toaster.tsx
  56. 2
      src/components/UI/Button.tsx
  57. 2
      src/components/UI/Checkbox.tsx
  58. 4
      src/components/UI/Command.tsx
  59. 2
      src/components/UI/Dialog.tsx
  60. 2
      src/components/UI/DropdownMenu.tsx
  61. 6
      src/components/UI/Generator.tsx
  62. 2
      src/components/UI/Input.tsx
  63. 2
      src/components/UI/Label.tsx
  64. 2
      src/components/UI/Menubar.tsx
  65. 2
      src/components/UI/Popover.tsx
  66. 2
      src/components/UI/ScrollArea.tsx
  67. 2
      src/components/UI/Select.tsx
  68. 2
      src/components/UI/Seperator.tsx
  69. 2
      src/components/UI/Sidebar/SidebarSection.tsx
  70. 2
      src/components/UI/Sidebar/sidebarButton.tsx
  71. 2
      src/components/UI/Switch.tsx
  72. 2
      src/components/UI/Tabs.tsx
  73. 2
      src/components/UI/Toast.tsx
  74. 2
      src/components/UI/Tooltip.tsx
  75. 2
      src/components/UI/Typography/H4.tsx
  76. 2
      src/components/UI/Typography/Subtle.tsx
  77. 2
      src/components/generic/ThemeController.tsx
  78. 38
      src/core/hooks/useToast.ts
  79. 2
      src/core/subscriptions.ts
  80. 2
      src/index.tsx
  81. 10
      src/pages/Channels.tsx
  82. 20
      src/pages/Config/DeviceConfig.tsx
  83. 26
      src/pages/Config/ModuleConfig.tsx
  84. 16
      src/pages/Config/index.tsx
  85. 12
      src/pages/Dashboard/index.tsx
  86. 16
      src/pages/Map.tsx
  87. 16
      src/pages/Messages.tsx
  88. 12
      src/pages/Nodes.tsx
  89. 2
      src/validation/rasterSource.ts
  90. 3
      tsconfig.json

14
package.json

@ -5,11 +5,12 @@
"description": "Meshtastic web client", "description": "Meshtastic web client",
"license": "GPL-3.0-only", "license": "GPL-3.0-only",
"scripts": { "scripts": {
"dev": "vite --host", "build": "rsbuild build",
"build": "tsc && pnpm check && vite build ",
"check": "biome check .", "check": "biome check .",
"check:fix": "pnpm check --write", "check:fix": "pnpm check --write",
"preview": "vite preview", "dev": "rsbuild dev --open",
"format": "biome format --write",
"preview": "rsbuild preview",
"package": "gzipper c -i html,js,css,png,ico,svg,webmanifest,txt dist dist/output && tar -cvf dist/build.tar -C ./dist/output/ $(ls ./dist/output/)" "package": "gzipper c -i html,js,css,png,ico,svg,webmanifest,txt dist dist/output && tar -cvf dist/build.tar -C ./dist/output/ $(ls ./dist/output/)"
}, },
"repository": { "repository": {
@ -66,13 +67,14 @@
"devDependencies": { "devDependencies": {
"@biomejs/biome": "^1.8.2", "@biomejs/biome": "^1.8.2",
"@buf/meshtastic_protobufs.bufbuild_es": "1.10.0-20240906232734-3da561588c55.1", "@buf/meshtastic_protobufs.bufbuild_es": "1.10.0-20240906232734-3da561588c55.1",
"@rsbuild/core": "^1.0.10",
"@rsbuild/plugin-react": "^1.0.3",
"@types/chrome": "^0.0.263", "@types/chrome": "^0.0.263",
"@types/node": "^20.14.9", "@types/node": "^20.14.9",
"@types/react": "^18.3.3", "@types/react": "^18.3.3",
"@types/react-dom": "^18.3.0", "@types/react-dom": "^18.3.0",
"@types/w3c-web-serial": "^1.0.6", "@types/w3c-web-serial": "^1.0.6",
"@types/web-bluetooth": "^0.0.20", "@types/web-bluetooth": "^0.0.20",
"@vitejs/plugin-react": "^4.3.1",
"autoprefixer": "^10.4.19", "autoprefixer": "^10.4.19",
"gzipper": "^7.2.0", "gzipper": "^7.2.0",
"postcss": "^8.4.38", "postcss": "^8.4.38",
@ -80,8 +82,6 @@
"tailwindcss": "^3.4.4", "tailwindcss": "^3.4.4",
"tar": "^6.2.1", "tar": "^6.2.1",
"tslib": "^2.6.3", "tslib": "^2.6.3",
"typescript": "^5.5.2", "typescript": "^5.5.2"
"vite": "^5.3.1",
"vite-plugin-environment": "^1.1.3"
} }
} }

658
pnpm-lock.yaml

File diff suppressed because it is too large

27
rsbuild.config.ts

@ -0,0 +1,27 @@
import { defineConfig } from "@rsbuild/core";
import { pluginReact } from "@rsbuild/plugin-react";
import { execSync } from "node:child_process";
let hash = "";
try {
hash = execSync("git rev-parse --short HEAD").toString().trim();
} catch (error) {
hash = "DEV";
}
export default defineConfig({
plugins: [pluginReact()],
source: {
define: {
"process.env.COMMIT_HASH": JSON.stringify(hash),
},
alias: {
"@app": "./src",
"@pages": "./src/pages",
"@components": "./src/components",
"@core": "./src/core",
"@layouts": "./src/layouts",
},
},
});

24
src/App.tsx

@ -1,15 +1,15 @@
import { DeviceWrapper } from "@app/DeviceWrapper.js"; import { DeviceWrapper } from "@app/DeviceWrapper.tsx";
import { PageRouter } from "@app/PageRouter.js"; import { PageRouter } from "@app/PageRouter.tsx";
import { CommandPalette } from "@components/CommandPalette.js"; import { CommandPalette } from "@components/CommandPalette.tsx";
import { DeviceSelector } from "@components/DeviceSelector.js"; import { DeviceSelector } from "@components/DeviceSelector.tsx";
import { DialogManager } from "@components/Dialog/DialogManager.js"; import { DialogManager } from "@components/Dialog/DialogManager.tsx";
import { NewDeviceDialog } from "@components/Dialog/NewDeviceDialog.js"; import { NewDeviceDialog } from "@components/Dialog/NewDeviceDialog.tsx";
import { Toaster } from "@components/Toaster.js"; import { Toaster } from "@components/Toaster.tsx";
import Footer from "@components/UI/Footer.js"; import Footer from "@components/UI/Footer.tsx";
import { ThemeController } from "@components/generic/ThemeController.js"; import { ThemeController } from "@components/generic/ThemeController.tsx";
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import { useDeviceStore } from "@core/stores/deviceStore.js"; import { useDeviceStore } from "@core/stores/deviceStore.ts";
import { Dashboard } from "@pages/Dashboard/index.js"; import { Dashboard } from "@pages/Dashboard/index.tsx";
import { MapProvider } from "react-map-gl"; import { MapProvider } from "react-map-gl";
export const App = (): JSX.Element => { export const App = (): JSX.Element => {

4
src/DeviceWrapper.tsx

@ -1,5 +1,5 @@
import { DeviceContext } from "@core/stores/deviceStore.js"; import { DeviceContext } from "@core/stores/deviceStore.ts";
import type { Device } from "@core/stores/deviceStore.js"; import type { Device } from "@core/stores/deviceStore.ts";
import type { ReactNode } from "react"; import type { ReactNode } from "react";
export interface DeviceWrapperProps { export interface DeviceWrapperProps {

12
src/PageRouter.tsx

@ -1,9 +1,9 @@
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { ChannelsPage } from "@pages/Channels.js"; import { ChannelsPage } from "@pages/Channels.tsx";
import { ConfigPage } from "@pages/Config/index.js"; import { ConfigPage } from "@pages/Config/index.tsx";
import { MapPage } from "@pages/Map.js"; import { MapPage } from "@pages/Map.tsx";
import { MessagesPage } from "@pages/Messages.js"; import { MessagesPage } from "@pages/Messages.tsx";
import { NodesPage } from "@pages/Nodes.js"; import { NodesPage } from "@pages/Nodes.tsx";
export const PageRouter = (): JSX.Element => { export const PageRouter = (): JSX.Element => {
const { activePage } = useDevice(); const { activePage } = useDevice();

6
src/components/CommandPalette.tsx

@ -5,9 +5,9 @@ import {
CommandInput, CommandInput,
CommandItem, CommandItem,
CommandList, CommandList,
} from "@components/UI/Command.js"; } from "@components/UI/Command.tsx";
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import { useDevice, useDeviceStore } from "@core/stores/deviceStore.js"; import { useDevice, useDeviceStore } from "@core/stores/deviceStore.ts";
import { Hashicon } from "@emeraldpay/hashicon-react"; import { Hashicon } from "@emeraldpay/hashicon-react";
import { useCommandState } from "cmdk"; import { useCommandState } from "cmdk";
import { import {

10
src/components/DeviceSelector.tsx

@ -1,8 +1,8 @@
import { DeviceSelectorButton } from "@components/DeviceSelectorButton.js"; import { DeviceSelectorButton } from "@components/DeviceSelectorButton.tsx";
import { Separator } from "@components/UI/Seperator.js"; import { Separator } from "@components/UI/Seperator.tsx";
import { Code } from "@components/UI/Typography/Code.js"; import { Code } from "@components/UI/Typography/Code.tsx";
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import { useDeviceStore } from "@core/stores/deviceStore.js"; import { useDeviceStore } from "@core/stores/deviceStore.ts";
import { Hashicon } from "@emeraldpay/hashicon-react"; import { Hashicon } from "@emeraldpay/hashicon-react";
import { import {
HomeIcon, HomeIcon,

10
src/components/Dialog/DeviceNameDialog.tsx

@ -1,5 +1,5 @@
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
@ -7,9 +7,9 @@ import {
DialogFooter, DialogFooter,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { Label } from "@components/UI/Label.js"; import { Label } from "@components/UI/Label.tsx";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
import { useForm } from "react-hook-form"; import { useForm } from "react-hook-form";

14
src/components/Dialog/DialogManager.tsx

@ -1,10 +1,10 @@
import { RemoveNodeDialog } from "@app/components/Dialog/RemoveNodeDialog.js"; import { RemoveNodeDialog } from "@app/components/Dialog/RemoveNodeDialog.tsx";
import { DeviceNameDialog } from "@components/Dialog/DeviceNameDialog.js"; import { DeviceNameDialog } from "@components/Dialog/DeviceNameDialog.tsx";
import { ImportDialog } from "@components/Dialog/ImportDialog.js"; import { ImportDialog } from "@components/Dialog/ImportDialog.tsx";
import { QRDialog } from "@components/Dialog/QRDialog.js"; import { QRDialog } from "@components/Dialog/QRDialog.tsx";
import { RebootDialog } from "@components/Dialog/RebootDialog.js"; import { RebootDialog } from "@components/Dialog/RebootDialog.tsx";
import { ShutdownDialog } from "@components/Dialog/ShutdownDialog.js"; import { ShutdownDialog } from "@components/Dialog/ShutdownDialog.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
export const DialogManager = (): JSX.Element => { export const DialogManager = (): JSX.Element => {
const { channels, config, dialog, setDialogOpen } = useDevice(); const { channels, config, dialog, setDialogOpen } = useDevice();

14
src/components/Dialog/ImportDialog.tsx

@ -1,5 +1,5 @@
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Checkbox } from "@components/UI/Checkbox.js"; import { Checkbox } from "@components/UI/Checkbox.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
@ -7,11 +7,11 @@ import {
DialogFooter, DialogFooter,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { Label } from "@components/UI/Label.js"; import { Label } from "@components/UI/Label.tsx";
import { Switch } from "@components/UI/Switch.js"; import { Switch } from "@components/UI/Switch.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
import { toByteArray } from "base64-js"; import { toByteArray } from "base64-js";
import { useEffect, useState } from "react"; import { useEffect, useState } from "react";

14
src/components/Dialog/NewDeviceDialog.tsx

@ -1,20 +1,20 @@
import { BLE } from "@components/PageComponents/Connect/BLE.js"; import { BLE } from "@components/PageComponents/Connect/BLE.tsx";
import { HTTP } from "@components/PageComponents/Connect/HTTP.js"; import { HTTP } from "@components/PageComponents/Connect/HTTP.tsx";
import { Serial } from "@components/PageComponents/Connect/Serial.js"; import { Serial } from "@components/PageComponents/Connect/Serial.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
import { import {
Tabs, Tabs,
TabsContent, TabsContent,
TabsList, TabsList,
TabsTrigger, TabsTrigger,
} from "@components/UI/Tabs.js"; } from "@components/UI/Tabs.tsx";
import { Link } from "@components/UI/Typography/Link.js"; import { Link } from "@components/UI/Typography/Link.tsx";
import { Subtle } from "@components/UI/Typography/Subtle.js"; import { Subtle } from "@components/UI/Typography/Subtle.tsx";
export interface TabElementProps { export interface TabElementProps {
closeDialog: () => void; closeDialog: () => void;

4
src/components/Dialog/PkiRegenerateDialog.tsx

@ -1,4 +1,4 @@
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
@ -6,7 +6,7 @@ import {
DialogFooter, DialogFooter,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
export interface PkiRegenerateDialogProps { export interface PkiRegenerateDialogProps {
open: boolean; open: boolean;

8
src/components/Dialog/QRDialog.tsx

@ -1,4 +1,4 @@
import { Checkbox } from "@components/UI/Checkbox.js"; import { Checkbox } from "@components/UI/Checkbox.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
@ -6,9 +6,9 @@ import {
DialogFooter, DialogFooter,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { Label } from "@components/UI/Label.js"; import { Label } from "@components/UI/Label.tsx";
import { Protobuf, type Types } from "@meshtastic/js"; import { Protobuf, type Types } from "@meshtastic/js";
import { fromByteArray } from "base64-js"; import { fromByteArray } from "base64-js";
import { ClipboardIcon } from "lucide-react"; import { ClipboardIcon } from "lucide-react";

8
src/components/Dialog/RebootDialog.tsx

@ -1,13 +1,13 @@
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
DialogDescription, DialogDescription,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { ClockIcon, RefreshCwIcon } from "lucide-react"; import { ClockIcon, RefreshCwIcon } from "lucide-react";
import { useState } from "react"; import { useState } from "react";

8
src/components/Dialog/RemoveNodeDialog.tsx

@ -1,6 +1,6 @@
import { useAppStore } from "@app/core/stores/appStore"; import { useAppStore } from "@app/core/stores/appStore";
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
@ -8,8 +8,8 @@ import {
DialogFooter, DialogFooter,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
import { Label } from "@components/UI/Label.js"; import { Label } from "@components/UI/Label.tsx";
export interface RemoveNodeDialogProps { export interface RemoveNodeDialogProps {
open: boolean; open: boolean;

8
src/components/Dialog/ShutdownDialog.tsx

@ -1,13 +1,13 @@
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { import {
Dialog, Dialog,
DialogContent, DialogContent,
DialogDescription, DialogDescription,
DialogHeader, DialogHeader,
DialogTitle, DialogTitle,
} from "@components/UI/Dialog.js"; } from "@components/UI/Dialog.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { ClockIcon, PowerIcon } from "lucide-react"; import { ClockIcon, PowerIcon } from "lucide-react";
import { useState } from "react"; import { useState } from "react";

10
src/components/Form/DynamicForm.tsx

@ -1,11 +1,11 @@
import { import {
DynamicFormField, DynamicFormField,
type FieldProps, type FieldProps,
} from "@components/Form/DynamicFormField.js"; } from "@components/Form/DynamicFormField.tsx";
import { FieldWrapper } from "@components/Form/FormWrapper.js"; import { FieldWrapper } from "@components/Form/FormWrapper.tsx";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { H4 } from "@components/UI/Typography/H4.js"; import { H4 } from "@components/UI/Typography/H4.tsx";
import { Subtle } from "@components/UI/Typography/Subtle.js"; import { Subtle } from "@components/UI/Typography/Subtle.tsx";
import { import {
type Control, type Control,
type DefaultValues, type DefaultValues,

8
src/components/Form/DynamicFormField.tsx

@ -1,19 +1,19 @@
import { import {
GenericInput, GenericInput,
type InputFieldProps, type InputFieldProps,
} from "@components/Form/FormInput.js"; } from "@components/Form/FormInput.tsx";
import { import {
PasswordGenerator, PasswordGenerator,
type PasswordGeneratorProps, type PasswordGeneratorProps,
} from "@components/Form/FormPasswordGenerator.js"; } from "@components/Form/FormPasswordGenerator.tsx";
import { import {
type SelectFieldProps, type SelectFieldProps,
SelectInput, SelectInput,
} from "@components/Form/FormSelect.js"; } from "@components/Form/FormSelect.tsx";
import { import {
type ToggleFieldProps, type ToggleFieldProps,
ToggleInput, ToggleInput,
} from "@components/Form/FormToggle.js"; } from "@components/Form/FormToggle.tsx";
import type { Control, FieldValues } from "react-hook-form"; import type { Control, FieldValues } from "react-hook-form";
export type FieldProps<T> = export type FieldProps<T> =

4
src/components/Form/FormInput.tsx

@ -1,8 +1,8 @@
import type { import type {
BaseFormBuilderProps, BaseFormBuilderProps,
GenericFormElementProps, GenericFormElementProps,
} from "@components/Form/DynamicForm.js"; } from "@components/Form/DynamicForm.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import type { LucideIcon } from "lucide-react"; import type { LucideIcon } from "lucide-react";
import { Eye, EyeOff } from "lucide-react"; import { Eye, EyeOff } from "lucide-react";
import type { ChangeEventHandler } from "react"; import type { ChangeEventHandler } from "react";

4
src/components/Form/FormPasswordGenerator.tsx

@ -1,8 +1,8 @@
import type { import type {
BaseFormBuilderProps, BaseFormBuilderProps,
GenericFormElementProps, GenericFormElementProps,
} from "@components/Form/DynamicForm.js"; } from "@components/Form/DynamicForm.tsx";
import { Generator } from "@components/UI/Generator.js"; import { Generator } from "@components/UI/Generator.tsx";
import { Eye, EyeOff } from "lucide-react"; import { Eye, EyeOff } from "lucide-react";
import type { ChangeEventHandler, MouseEventHandler } from "react"; import type { ChangeEventHandler, MouseEventHandler } from "react";
import { useState } from "react"; import { useState } from "react";

4
src/components/Form/FormSelect.tsx

@ -1,14 +1,14 @@
import type { import type {
BaseFormBuilderProps, BaseFormBuilderProps,
GenericFormElementProps, GenericFormElementProps,
} from "@components/Form/DynamicForm.js"; } from "@components/Form/DynamicForm.tsx";
import { import {
Select, Select,
SelectContent, SelectContent,
SelectItem, SelectItem,
SelectTrigger, SelectTrigger,
SelectValue, SelectValue,
} from "@components/UI/Select.js"; } from "@components/UI/Select.tsx";
import { Controller, type FieldValues } from "react-hook-form"; import { Controller, type FieldValues } from "react-hook-form";
export interface SelectFieldProps<T> extends BaseFormBuilderProps<T> { export interface SelectFieldProps<T> extends BaseFormBuilderProps<T> {

4
src/components/Form/FormToggle.tsx

@ -1,8 +1,8 @@
import type { import type {
BaseFormBuilderProps, BaseFormBuilderProps,
GenericFormElementProps, GenericFormElementProps,
} from "@components/Form/DynamicForm.js"; } from "@components/Form/DynamicForm.tsx";
import { Switch } from "@components/UI/Switch.js"; import { Switch } from "@components/UI/Switch.tsx";
import type { ChangeEvent } from "react"; import type { ChangeEvent } from "react";
import { Controller, type FieldValues } from "react-hook-form"; import { Controller, type FieldValues } from "react-hook-form";

2
src/components/Form/FormWrapper.tsx

@ -1,4 +1,4 @@
import { Label } from "@components/UI/Label.js"; import { Label } from "@components/UI/Label.tsx";
export interface FieldWrapperProps { export interface FieldWrapperProps {
label: string; label: string;

8
src/components/PageComponents/Channel.tsx

@ -1,7 +1,7 @@
import type { ChannelValidation } from "@app/validation/channel.js"; import type { ChannelValidation } from "@app/validation/channel.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useToast } from "@core/hooks/useToast.js"; import { useToast } from "@core/hooks/useToast.ts";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
import { fromByteArray, toByteArray } from "base64-js"; import { fromByteArray, toByteArray } from "base64-js";
import cryptoRandomString from "crypto-random-string"; import cryptoRandomString from "crypto-random-string";

6
src/components/PageComponents/Config/Bluetooth.tsx

@ -1,6 +1,6 @@
import type { BluetoothValidation } from "@app/validation/config/bluetooth.js"; import type { BluetoothValidation } from "@app/validation/config/bluetooth.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Bluetooth = (): JSX.Element => { export const Bluetooth = (): JSX.Element => {

6
src/components/PageComponents/Config/Device.tsx

@ -1,6 +1,6 @@
import type { DeviceValidation } from "@app/validation/config/device.js"; import type { DeviceValidation } from "@app/validation/config/device.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Device = (): JSX.Element => { export const Device = (): JSX.Element => {

6
src/components/PageComponents/Config/Display.tsx

@ -1,6 +1,6 @@
import type { DisplayValidation } from "@app/validation/config/display.js"; import type { DisplayValidation } from "@app/validation/config/display.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Display = (): JSX.Element => { export const Display = (): JSX.Element => {

6
src/components/PageComponents/Config/LoRa.tsx

@ -1,6 +1,6 @@
import type { LoRaValidation } from "@app/validation/config/lora.js"; import type { LoRaValidation } from "@app/validation/config/lora.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const LoRa = (): JSX.Element => { export const LoRa = (): JSX.Element => {

8
src/components/PageComponents/Config/Network.tsx

@ -1,10 +1,10 @@
import type { NetworkValidation } from "@app/validation/config/network.js"; import type { NetworkValidation } from "@app/validation/config/network.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { import {
convertIntToIpAddress, convertIntToIpAddress,
convertIpAddressToInt, convertIpAddressToInt,
} from "@core/utils/ip.js"; } from "@core/utils/ip.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Network = (): JSX.Element => { export const Network = (): JSX.Element => {

6
src/components/PageComponents/Config/Position.tsx

@ -1,6 +1,6 @@
import type { PositionValidation } from "@app/validation/config/position.js"; import type { PositionValidation } from "@app/validation/config/position.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Position = (): JSX.Element => { export const Position = (): JSX.Element => {

6
src/components/PageComponents/Config/Power.tsx

@ -1,6 +1,6 @@
import type { PowerValidation } from "@app/validation/config/power.js"; import type { PowerValidation } from "@app/validation/config/power.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Power = (): JSX.Element => { export const Power = (): JSX.Element => {

6
src/components/PageComponents/Config/Security.tsx

@ -1,11 +1,11 @@
import { PkiRegenerateDialog } from "@app/components/Dialog/PkiRegenerateDialog"; import { PkiRegenerateDialog } from "@app/components/Dialog/PkiRegenerateDialog";
import { DynamicForm } from "@app/components/Form/DynamicForm.js"; import { DynamicForm } from "@app/components/Form/DynamicForm.tsx";
import { import {
getX25519PrivateKey, getX25519PrivateKey,
getX25519PublicKey, getX25519PublicKey,
} from "@app/core/utils/x25519"; } from "@app/core/utils/x25519";
import type { SecurityValidation } from "@app/validation/config/security.js"; import type { SecurityValidation } from "@app/validation/config/security.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
import { fromByteArray, toByteArray } from "base64-js"; import { fromByteArray, toByteArray } from "base64-js";
import { Eye, EyeOff } from "lucide-react"; import { Eye, EyeOff } from "lucide-react";

12
src/components/PageComponents/Connect/BLE.tsx

@ -1,10 +1,10 @@
import type { TabElementProps } from "@app/components/Dialog/NewDeviceDialog"; import type { TabElementProps } from "@app/components/Dialog/NewDeviceDialog";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Mono } from "@components/generic/Mono.js"; import { Mono } from "@components/generic/Mono.tsx";
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import { useDeviceStore } from "@core/stores/deviceStore.js"; import { useDeviceStore } from "@core/stores/deviceStore.ts";
import { subscribeAll } from "@core/subscriptions.js"; import { subscribeAll } from "@core/subscriptions.ts";
import { randId } from "@core/utils/randId.js"; import { randId } from "@core/utils/randId.ts";
import { BleConnection, Constants } from "@meshtastic/js"; import { BleConnection, Constants } from "@meshtastic/js";
import { useCallback, useEffect, useState } from "react"; import { useCallback, useEffect, useState } from "react";

16
src/components/PageComponents/Connect/HTTP.tsx

@ -1,12 +1,12 @@
import type { TabElementProps } from "@app/components/Dialog/NewDeviceDialog"; import type { TabElementProps } from "@app/components/Dialog/NewDeviceDialog";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { Label } from "@components/UI/Label.js"; import { Label } from "@components/UI/Label.tsx";
import { Switch } from "@components/UI/Switch.js"; import { Switch } from "@components/UI/Switch.tsx";
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import { useDeviceStore } from "@core/stores/deviceStore.js"; import { useDeviceStore } from "@core/stores/deviceStore.ts";
import { subscribeAll } from "@core/subscriptions.js"; import { subscribeAll } from "@core/subscriptions.ts";
import { randId } from "@core/utils/randId.js"; import { randId } from "@core/utils/randId.ts";
import { HttpConnection } from "@meshtastic/js"; import { HttpConnection } from "@meshtastic/js";
import { useState } from "react"; import { useState } from "react";
import { Controller, useForm, useWatch } from "react-hook-form"; import { Controller, useForm, useWatch } from "react-hook-form";

12
src/components/PageComponents/Connect/Serial.tsx

@ -1,10 +1,10 @@
import type { TabElementProps } from "@app/components/Dialog/NewDeviceDialog"; import type { TabElementProps } from "@app/components/Dialog/NewDeviceDialog";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Mono } from "@components/generic/Mono.js"; import { Mono } from "@components/generic/Mono.tsx";
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import { useDeviceStore } from "@core/stores/deviceStore.js"; import { useDeviceStore } from "@core/stores/deviceStore.ts";
import { subscribeAll } from "@core/subscriptions.js"; import { subscribeAll } from "@core/subscriptions.ts";
import { randId } from "@core/utils/randId.js"; import { randId } from "@core/utils/randId.ts";
import { SerialConnection } from "@meshtastic/js"; import { SerialConnection } from "@meshtastic/js";
import { useCallback, useEffect, useState } from "react"; import { useCallback, useEffect, useState } from "react";

10
src/components/PageComponents/Messages/ChannelChat.tsx

@ -1,11 +1,11 @@
import { Subtle } from "@app/components/UI/Typography/Subtle.js"; import { Subtle } from "@app/components/UI/Typography/Subtle.tsx";
import { import {
type MessageWithState, type MessageWithState,
useDevice, useDevice,
} from "@app/core/stores/deviceStore.js"; } from "@app/core/stores/deviceStore.ts";
import { Message } from "@components/PageComponents/Messages/Message.js"; import { Message } from "@components/PageComponents/Messages/Message.tsx";
import { MessageInput } from "@components/PageComponents/Messages/MessageInput.js"; import { MessageInput } from "@components/PageComponents/Messages/MessageInput.tsx";
import { TraceRoute } from "@components/PageComponents/Messages/TraceRoute.js"; import { TraceRoute } from "@components/PageComponents/Messages/TraceRoute.tsx";
import type { Protobuf, Types } from "@meshtastic/js"; import type { Protobuf, Types } from "@meshtastic/js";
import { InboxIcon } from "lucide-react"; import { InboxIcon } from "lucide-react";

2
src/components/PageComponents/Messages/Message.tsx

@ -1,4 +1,4 @@
import type { MessageWithState } from "@app/core/stores/deviceStore.js"; import type { MessageWithState } from "@app/core/stores/deviceStore.ts";
import { Hashicon } from "@emeraldpay/hashicon-react"; import { Hashicon } from "@emeraldpay/hashicon-react";
import type { Protobuf } from "@meshtastic/js"; import type { Protobuf } from "@meshtastic/js";
import { import {

6
src/components/PageComponents/Messages/MessageInput.tsx

@ -1,6 +1,6 @@
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import type { Types } from "@meshtastic/js"; import type { Types } from "@meshtastic/js";
import { SendIcon } from "lucide-react"; import { SendIcon } from "lucide-react";

2
src/components/PageComponents/Messages/TraceRoute.tsx

@ -1,4 +1,4 @@
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import type { Protobuf } from "@meshtastic/js"; import type { Protobuf } from "@meshtastic/js";
import { numberToHexUnpadded } from "@noble/curves/abstract/utils"; import { numberToHexUnpadded } from "@noble/curves/abstract/utils";

6
src/components/PageComponents/ModuleConfig/AmbientLighting.tsx

@ -1,6 +1,6 @@
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import type { AmbientLightingValidation } from "@app/validation/moduleConfig/ambientLighting.js"; import type { AmbientLightingValidation } from "@app/validation/moduleConfig/ambientLighting.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const AmbientLighting = (): JSX.Element => { export const AmbientLighting = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/Audio.tsx

@ -1,6 +1,6 @@
import type { AudioValidation } from "@app/validation/moduleConfig/audio.js"; import type { AudioValidation } from "@app/validation/moduleConfig/audio.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Audio = (): JSX.Element => { export const Audio = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/CannedMessage.tsx

@ -1,6 +1,6 @@
import type { CannedMessageValidation } from "@app/validation/moduleConfig/cannedMessage.js"; import type { CannedMessageValidation } from "@app/validation/moduleConfig/cannedMessage.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const CannedMessage = (): JSX.Element => { export const CannedMessage = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/DetectionSensor.tsx

@ -1,6 +1,6 @@
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import type { DetectionSensorValidation } from "@app/validation/moduleConfig/detectionSensor.js"; import type { DetectionSensorValidation } from "@app/validation/moduleConfig/detectionSensor.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const DetectionSensor = (): JSX.Element => { export const DetectionSensor = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/ExternalNotification.tsx

@ -1,6 +1,6 @@
import type { ExternalNotificationValidation } from "@app/validation/moduleConfig/externalNotification.js"; import type { ExternalNotificationValidation } from "@app/validation/moduleConfig/externalNotification.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const ExternalNotification = (): JSX.Element => { export const ExternalNotification = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/MQTT.tsx

@ -1,6 +1,6 @@
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import type { MqttValidation } from "@app/validation/moduleConfig/mqtt.js"; import type { MqttValidation } from "@app/validation/moduleConfig/mqtt.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const MQTT = (): JSX.Element => { export const MQTT = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/NeighborInfo.tsx

@ -1,6 +1,6 @@
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import type { NeighborInfoValidation } from "@app/validation/moduleConfig/neighborInfo.js"; import type { NeighborInfoValidation } from "@app/validation/moduleConfig/neighborInfo.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const NeighborInfo = (): JSX.Element => { export const NeighborInfo = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/Paxcounter.tsx

@ -1,6 +1,6 @@
import type { PaxcounterValidation } from "@app/validation/moduleConfig/paxcounter.js"; import type { PaxcounterValidation } from "@app/validation/moduleConfig/paxcounter.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Paxcounter = (): JSX.Element => { export const Paxcounter = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/RangeTest.tsx

@ -1,6 +1,6 @@
import type { RangeTestValidation } from "@app/validation/moduleConfig/rangeTest.js"; import type { RangeTestValidation } from "@app/validation/moduleConfig/rangeTest.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const RangeTest = (): JSX.Element => { export const RangeTest = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/Serial.tsx

@ -1,6 +1,6 @@
import type { SerialValidation } from "@app/validation/moduleConfig/serial.js"; import type { SerialValidation } from "@app/validation/moduleConfig/serial.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Serial = (): JSX.Element => { export const Serial = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/StoreForward.tsx

@ -1,6 +1,6 @@
import type { StoreForwardValidation } from "@app/validation/moduleConfig/storeForward.js"; import type { StoreForwardValidation } from "@app/validation/moduleConfig/storeForward.ts";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const StoreForward = (): JSX.Element => { export const StoreForward = (): JSX.Element => {

6
src/components/PageComponents/ModuleConfig/Telemetry.tsx

@ -1,6 +1,6 @@
import type { TelemetryValidation } from "@app/validation/moduleConfig/telemetry.js"; import type { TelemetryValidation } from "@app/validation/moduleConfig/telemetry.tsx";
import { DynamicForm } from "@components/Form/DynamicForm.js"; import { DynamicForm } from "@components/Form/DynamicForm.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
export const Telemetry = (): JSX.Element => { export const Telemetry = (): JSX.Element => {

2
src/components/PageLayout.tsx

@ -1,4 +1,4 @@
import { cn } from "@app/core/utils/cn.js"; import { cn } from "@app/core/utils/cn.ts";
import { AlignLeftIcon, type LucideIcon } from "lucide-react"; import { AlignLeftIcon, type LucideIcon } from "lucide-react";
import Footer from "./UI/Footer"; import Footer from "./UI/Footer";

10
src/components/Sidebar.tsx

@ -1,8 +1,8 @@
import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.js"; import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.tsx";
import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.js"; import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.tsx";
import { Subtle } from "@components/UI/Typography/Subtle.js"; import { Subtle } from "@components/UI/Typography/Subtle.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import type { Page } from "@core/stores/deviceStore.js"; import type { Page } from "@core/stores/deviceStore.ts";
import { import {
BatteryMediumIcon, BatteryMediumIcon,
CpuIcon, CpuIcon,

4
src/components/Toaster.tsx

@ -1,4 +1,4 @@
import { useToast } from "@core/hooks/useToast.js"; import { useToast } from "@core/hooks/useToast.ts";
import { import {
Toast, Toast,
@ -7,7 +7,7 @@ import {
ToastProvider, ToastProvider,
ToastTitle, ToastTitle,
ToastViewport, ToastViewport,
} from "@components/UI/Toast.js"; } from "@components/UI/Toast.tsx";
export function Toaster() { export function Toaster() {
const { toasts } = useToast(); const { toasts } = useToast();

2
src/components/UI/Button.tsx

@ -1,7 +1,7 @@
import { type VariantProps, cva } from "class-variance-authority"; import { type VariantProps, cva } from "class-variance-authority";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const buttonVariants = cva( const buttonVariants = cva(
"inline-flex items-center justify-center rounded-md text-sm font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-slate-400 focus:ring-offset-2 dark:hover:bg-slate-800 dark:hover:text-slate-100 disabled:opacity-50 dark:focus:ring-slate-400 disabled:pointer-events-none dark:focus:ring-offset-slate-900 data-[state=open]:bg-slate-100 dark:data-[state=open]:bg-slate-800", "inline-flex items-center justify-center rounded-md text-sm font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-slate-400 focus:ring-offset-2 dark:hover:bg-slate-800 dark:hover:text-slate-100 disabled:opacity-50 dark:focus:ring-slate-400 disabled:pointer-events-none dark:focus:ring-offset-slate-900 data-[state=open]:bg-slate-100 dark:data-[state=open]:bg-slate-800",

2
src/components/UI/Checkbox.tsx

@ -2,7 +2,7 @@ import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
import { Check } from "lucide-react"; import { Check } from "lucide-react";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Checkbox = React.forwardRef< const Checkbox = React.forwardRef<
React.ElementRef<typeof CheckboxPrimitive.Root>, React.ElementRef<typeof CheckboxPrimitive.Root>,

4
src/components/UI/Command.tsx

@ -3,8 +3,8 @@ import { Command as CommandPrimitive } from "cmdk";
import { Search } from "lucide-react"; import { Search } from "lucide-react";
import * as React from "react"; import * as React from "react";
import { Dialog, DialogContent } from "@components/UI/Dialog.js"; import { Dialog, DialogContent } from "@components/UI/Dialog.tsx";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Command = React.forwardRef< const Command = React.forwardRef<
React.ElementRef<typeof CommandPrimitive>, React.ElementRef<typeof CommandPrimitive>,

2
src/components/UI/Dialog.tsx

@ -2,7 +2,7 @@ import * as DialogPrimitive from "@radix-ui/react-dialog";
import { X } from "lucide-react"; import { X } from "lucide-react";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Dialog = DialogPrimitive.Root; const Dialog = DialogPrimitive.Root;

2
src/components/UI/DropdownMenu.tsx

@ -2,7 +2,7 @@ import * as DropdownMenuPrimitive from "@radix-ui/react-dropdown-menu";
import { Check, ChevronRight, Circle } from "lucide-react"; import { Check, ChevronRight, Circle } from "lucide-react";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const DropdownMenu = DropdownMenuPrimitive.Root; const DropdownMenu = DropdownMenuPrimitive.Root;

6
src/components/UI/Generator.tsx

@ -1,14 +1,14 @@
import * as React from "react"; import * as React from "react";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Input } from "@components/UI/Input.js"; import { Input } from "@components/UI/Input.tsx";
import { import {
Select, Select,
SelectContent, SelectContent,
SelectItem, SelectItem,
SelectTrigger, SelectTrigger,
SelectValue, SelectValue,
} from "@components/UI/Select.js"; } from "@components/UI/Select.tsx";
import type { LucideIcon } from "lucide-react"; import type { LucideIcon } from "lucide-react";
export interface GeneratorProps extends React.BaseHTMLAttributes<HTMLElement> { export interface GeneratorProps extends React.BaseHTMLAttributes<HTMLElement> {

2
src/components/UI/Input.tsx

@ -1,6 +1,6 @@
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
import { type VariantProps, cva } from "class-variance-authority"; import { type VariantProps, cva } from "class-variance-authority";
import type { LucideIcon } from "lucide-react"; import type { LucideIcon } from "lucide-react";

2
src/components/UI/Label.tsx

@ -1,7 +1,7 @@
import * as LabelPrimitive from "@radix-ui/react-label"; import * as LabelPrimitive from "@radix-ui/react-label";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Label = React.forwardRef< const Label = React.forwardRef<
React.ElementRef<typeof LabelPrimitive.Root>, React.ElementRef<typeof LabelPrimitive.Root>,

2
src/components/UI/Menubar.tsx

@ -2,7 +2,7 @@ import * as MenubarPrimitive from "@radix-ui/react-menubar";
import { Check, ChevronRight, Circle } from "lucide-react"; import { Check, ChevronRight, Circle } from "lucide-react";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const MenubarMenu = MenubarPrimitive.Menu; const MenubarMenu = MenubarPrimitive.Menu;

2
src/components/UI/Popover.tsx

@ -1,7 +1,7 @@
import * as PopoverPrimitive from "@radix-ui/react-popover"; import * as PopoverPrimitive from "@radix-ui/react-popover";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Popover = PopoverPrimitive.Root; const Popover = PopoverPrimitive.Root;

2
src/components/UI/ScrollArea.tsx

@ -1,7 +1,7 @@
import * as ScrollAreaPrimitive from "@radix-ui/react-scroll-area"; import * as ScrollAreaPrimitive from "@radix-ui/react-scroll-area";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const ScrollArea = React.forwardRef< const ScrollArea = React.forwardRef<
React.ElementRef<typeof ScrollAreaPrimitive.Root>, React.ElementRef<typeof ScrollAreaPrimitive.Root>,

2
src/components/UI/Select.tsx

@ -2,7 +2,7 @@ import * as SelectPrimitive from "@radix-ui/react-select";
import { Check, ChevronDown } from "lucide-react"; import { Check, ChevronDown } from "lucide-react";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Select = SelectPrimitive.Root; const Select = SelectPrimitive.Root;

2
src/components/UI/Seperator.tsx

@ -1,7 +1,7 @@
import * as SeparatorPrimitive from "@radix-ui/react-separator"; import * as SeparatorPrimitive from "@radix-ui/react-separator";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Separator = React.forwardRef< const Separator = React.forwardRef<
React.ElementRef<typeof SeparatorPrimitive.Root>, React.ElementRef<typeof SeparatorPrimitive.Root>,

2
src/components/UI/Sidebar/SidebarSection.tsx

@ -1,4 +1,4 @@
import { H4 } from "@components/UI/Typography/H4.js"; import { H4 } from "@components/UI/Typography/H4.tsx";
export interface SidebarSectionProps { export interface SidebarSectionProps {
label: string; label: string;

2
src/components/UI/Sidebar/sidebarButton.tsx

@ -1,4 +1,4 @@
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import type { LucideIcon } from "lucide-react"; import type { LucideIcon } from "lucide-react";
export interface SidebarButtonProps { export interface SidebarButtonProps {

2
src/components/UI/Switch.tsx

@ -1,7 +1,7 @@
import * as SwitchPrimitives from "@radix-ui/react-switch"; import * as SwitchPrimitives from "@radix-ui/react-switch";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Switch = React.forwardRef< const Switch = React.forwardRef<
React.ElementRef<typeof SwitchPrimitives.Root>, React.ElementRef<typeof SwitchPrimitives.Root>,

2
src/components/UI/Tabs.tsx

@ -1,7 +1,7 @@
import * as TabsPrimitive from "@radix-ui/react-tabs"; import * as TabsPrimitive from "@radix-ui/react-tabs";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const Tabs = TabsPrimitive.Root; const Tabs = TabsPrimitive.Root;

2
src/components/UI/Toast.tsx

@ -3,7 +3,7 @@ import { type VariantProps, cva } from "class-variance-authority";
import { X } from "lucide-react"; import { X } from "lucide-react";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const ToastProvider = ToastPrimitives.Provider; const ToastProvider = ToastPrimitives.Provider;

2
src/components/UI/Tooltip.tsx

@ -1,7 +1,7 @@
import * as TooltipPrimitive from "@radix-ui/react-tooltip"; import * as TooltipPrimitive from "@radix-ui/react-tooltip";
import * as React from "react"; import * as React from "react";
import { cn } from "@core/utils/cn.js"; import { cn } from "@core/utils/cn.ts";
const TooltipProvider = TooltipPrimitive.Provider; const TooltipProvider = TooltipPrimitive.Provider;

2
src/components/UI/Typography/H4.tsx

@ -1,4 +1,4 @@
import { cn } from "@app/core/utils/cn.js"; import { cn } from "@app/core/utils/cn.ts";
export interface H4Props { export interface H4Props {
className?: string; className?: string;

2
src/components/UI/Typography/Subtle.tsx

@ -1,4 +1,4 @@
import { cn } from "@app/core/utils/cn.js"; import { cn } from "@app/core/utils/cn.ts";
export interface SubtleProps { export interface SubtleProps {
className?: string; className?: string;

2
src/components/generic/ThemeController.tsx

@ -1,4 +1,4 @@
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import type { ReactNode } from "react"; import type { ReactNode } from "react";
export interface ThemeControllerProps { export interface ThemeControllerProps {

38
src/core/hooks/useToast.ts

@ -1,6 +1,6 @@
import { type ReactNode, useSyncExternalStore } from "react"; import { type ReactNode, useSyncExternalStore } from "react";
import type { ToastActionElement, ToastProps } from "@components/UI/Toast.js"; import type { ToastActionElement, ToastProps } from "@components/UI/Toast.tsx";
const TOAST_LIMIT = 1; const TOAST_LIMIT = 1;
const TOAST_REMOVE_DELAY = 1000000; const TOAST_REMOVE_DELAY = 1000000;
@ -30,21 +30,21 @@ type ActionType = typeof actionTypes;
type Action = type Action =
| { | {
type: ActionType["ADD_TOAST"]; type: ActionType["ADD_TOAST"];
toast: ToasterToast; toast: ToasterToast;
} }
| { | {
type: ActionType["UPDATE_TOAST"]; type: ActionType["UPDATE_TOAST"];
toast: Partial<ToasterToast>; toast: Partial<ToasterToast>;
} }
| { | {
type: ActionType["DISMISS_TOAST"]; type: ActionType["DISMISS_TOAST"];
toastId?: ToasterToast["id"]; toastId?: ToasterToast["id"];
} }
| { | {
type: ActionType["REMOVE_TOAST"]; type: ActionType["REMOVE_TOAST"];
toastId?: ToasterToast["id"]; toastId?: ToasterToast["id"];
}; };
interface State { interface State {
toasts: ToasterToast[]; toasts: ToasterToast[];
@ -80,7 +80,7 @@ export const reducer = (state: State, action: Action): State => {
return { return {
...state, ...state,
toasts: state.toasts.map((t) => toasts: state.toasts.map((t) =>
t.id === action.toast.id ? { ...t, ...action.toast } : t, t.id === action.toast.id ? { ...t, ...action.toast } : t
), ),
}; };
@ -102,10 +102,10 @@ export const reducer = (state: State, action: Action): State => {
toasts: state.toasts.map((t) => toasts: state.toasts.map((t) =>
t.id === toastId || toastId === undefined t.id === toastId || toastId === undefined
? { ? {
...t, ...t,
open: false, open: false,
} }
: t, : t
), ),
}; };
} }
@ -190,4 +190,4 @@ function useToast() {
}; };
} }
export { useToast, toast }; export { toast, useToast };

2
src/core/subscriptions.ts

@ -1,4 +1,4 @@
import type { Device } from "@core/stores/deviceStore.js"; import type { Device } from "@core/stores/deviceStore.ts";
import { Protobuf, type Types } from "@meshtastic/js"; import { Protobuf, type Types } from "@meshtastic/js";
export const subscribeAll = ( export const subscribeAll = (

2
src/index.tsx

@ -4,7 +4,7 @@ import "maplibre-gl/dist/maplibre-gl.css";
import { StrictMode } from "react"; import { StrictMode } from "react";
import { createRoot } from "react-dom/client"; import { createRoot } from "react-dom/client";
import { App } from "@app/App.js"; import { App } from "@app/App.tsx";
const container = document.getElementById("root") as HTMLElement; const container = document.getElementById("root") as HTMLElement;
const root = createRoot(container); const root = createRoot(container);

10
src/pages/Channels.tsx

@ -3,11 +3,11 @@ import {
TabsContent, TabsContent,
TabsList, TabsList,
TabsTrigger, TabsTrigger,
} from "@app/components/UI/Tabs.js"; } from "@app/components/UI/Tabs.tsx";
import { Channel } from "@components/PageComponents/Channel.js"; import { Channel } from "@components/PageComponents/Channel.tsx";
import { PageLayout } from "@components/PageLayout.js"; import { PageLayout } from "@components/PageLayout.tsx";
import { Sidebar } from "@components/Sidebar.js"; import { Sidebar } from "@components/Sidebar.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Types } from "@meshtastic/js"; import { Types } from "@meshtastic/js";
import type { Protobuf } from "@meshtastic/js"; import type { Protobuf } from "@meshtastic/js";
import { ImportIcon, QrCodeIcon } from "lucide-react"; import { ImportIcon, QrCodeIcon } from "lucide-react";

20
src/pages/Config/DeviceConfig.tsx

@ -1,18 +1,18 @@
import { Bluetooth } from "@components/PageComponents/Config/Bluetooth.js"; import { Bluetooth } from "@components/PageComponents/Config/Bluetooth.tsx";
import { Device } from "@components/PageComponents/Config/Device.js"; import { Device } from "@components/PageComponents/Config/Device.tsx";
import { Display } from "@components/PageComponents/Config/Display.js"; import { Display } from "@components/PageComponents/Config/Display.tsx";
import { LoRa } from "@components/PageComponents/Config/LoRa.js"; import { LoRa } from "@components/PageComponents/Config/LoRa.tsx";
import { Network } from "@components/PageComponents/Config/Network.js"; import { Network } from "@components/PageComponents/Config/Network.tsx";
import { Position } from "@components/PageComponents/Config/Position.js"; import { Position } from "@components/PageComponents/Config/Position.tsx";
import { Power } from "@components/PageComponents/Config/Power.js"; import { Power } from "@components/PageComponents/Config/Power.tsx";
import { Security } from "@components/PageComponents/Config/Security.js"; import { Security } from "@components/PageComponents/Config/Security.tsx";
import { import {
Tabs, Tabs,
TabsContent, TabsContent,
TabsList, TabsList,
TabsTrigger, TabsTrigger,
} from "@components/UI/Tabs.js"; } from "@components/UI/Tabs.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
export const DeviceConfig = (): JSX.Element => { export const DeviceConfig = (): JSX.Element => {
const { metadata } = useDevice(); const { metadata } = useDevice();

26
src/pages/Config/ModuleConfig.tsx

@ -1,21 +1,21 @@
import { AmbientLighting } from "@app/components/PageComponents/ModuleConfig/AmbientLighting.js"; import { AmbientLighting } from "@app/components/PageComponents/ModuleConfig/AmbientLighting.tsx";
import { DetectionSensor } from "@app/components/PageComponents/ModuleConfig/DetectionSensor.js"; import { DetectionSensor } from "@app/components/PageComponents/ModuleConfig/DetectionSensor.tsx";
import { NeighborInfo } from "@app/components/PageComponents/ModuleConfig/NeighborInfo.js"; import { NeighborInfo } from "@app/components/PageComponents/ModuleConfig/NeighborInfo.tsx";
import { Audio } from "@components/PageComponents/ModuleConfig/Audio.js"; import { Audio } from "@components/PageComponents/ModuleConfig/Audio.tsx";
import { CannedMessage } from "@components/PageComponents/ModuleConfig/CannedMessage.js"; import { CannedMessage } from "@components/PageComponents/ModuleConfig/CannedMessage.tsx";
import { ExternalNotification } from "@components/PageComponents/ModuleConfig/ExternalNotification.js"; import { ExternalNotification } from "@components/PageComponents/ModuleConfig/ExternalNotification.tsx";
import { MQTT } from "@components/PageComponents/ModuleConfig/MQTT.js"; import { MQTT } from "@components/PageComponents/ModuleConfig/MQTT.tsx";
import { Paxcounter } from "@components/PageComponents/ModuleConfig/Paxcounter.js"; import { Paxcounter } from "@components/PageComponents/ModuleConfig/Paxcounter.tsx";
import { RangeTest } from "@components/PageComponents/ModuleConfig/RangeTest.js"; import { RangeTest } from "@components/PageComponents/ModuleConfig/RangeTest.tsx";
import { Serial } from "@components/PageComponents/ModuleConfig/Serial.js"; import { Serial } from "@components/PageComponents/ModuleConfig/Serial.tsx";
import { StoreForward } from "@components/PageComponents/ModuleConfig/StoreForward.js"; import { StoreForward } from "@components/PageComponents/ModuleConfig/StoreForward.tsx";
import { Telemetry } from "@components/PageComponents/ModuleConfig/Telemetry.js"; import { Telemetry } from "@components/PageComponents/ModuleConfig/Telemetry.tsx";
import { import {
Tabs, Tabs,
TabsContent, TabsContent,
TabsList, TabsList,
TabsTrigger, TabsTrigger,
} from "@components/UI/Tabs.js"; } from "@components/UI/Tabs.tsx";
export const ModuleConfig = (): JSX.Element => { export const ModuleConfig = (): JSX.Element => {
const tabs = [ const tabs = [

16
src/pages/Config/index.tsx

@ -1,11 +1,11 @@
import { useDevice } from "@app/core/stores/deviceStore.js"; import { useDevice } from "@app/core/stores/deviceStore.ts";
import { PageLayout } from "@components/PageLayout.js"; import { PageLayout } from "@components/PageLayout.tsx";
import { Sidebar } from "@components/Sidebar.js"; import { Sidebar } from "@components/Sidebar.tsx";
import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.js"; import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.tsx";
import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.js"; import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.tsx";
import { useToast } from "@core/hooks/useToast.js"; import { useToast } from "@core/hooks/useToast.ts";
import { DeviceConfig } from "@pages/Config/DeviceConfig.js"; import { DeviceConfig } from "@pages/Config/DeviceConfig.tsx";
import { ModuleConfig } from "@pages/Config/ModuleConfig.js"; import { ModuleConfig } from "@pages/Config/ModuleConfig.tsx";
import { BoxesIcon, SaveIcon, SettingsIcon } from "lucide-react"; import { BoxesIcon, SaveIcon, SettingsIcon } from "lucide-react";
import { useState } from "react"; import { useState } from "react";

12
src/pages/Dashboard/index.tsx

@ -1,9 +1,9 @@
import { useAppStore } from "@app/core/stores/appStore.js"; import { useAppStore } from "@app/core/stores/appStore.ts";
import { useDeviceStore } from "@app/core/stores/deviceStore.js"; import { useDeviceStore } from "@app/core/stores/deviceStore.ts";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Separator } from "@components/UI/Seperator.js"; import { Separator } from "@components/UI/Seperator.tsx";
import { H3 } from "@components/UI/Typography/H3.js"; import { H3 } from "@components/UI/Typography/H3.tsx";
import { Subtle } from "@components/UI/Typography/Subtle.js"; import { Subtle } from "@components/UI/Typography/Subtle.tsx";
import { import {
BluetoothIcon, BluetoothIcon,
ListPlusIcon, ListPlusIcon,

16
src/pages/Map.tsx

@ -1,11 +1,11 @@
import { Subtle } from "@app/components/UI/Typography/Subtle.js"; import { Subtle } from "@app/components/UI/Typography/Subtle.tsx";
import { cn } from "@app/core/utils/cn.js"; import { cn } from "@app/core/utils/cn.ts";
import { PageLayout } from "@components/PageLayout.js"; import { PageLayout } from "@components/PageLayout.tsx";
import { Sidebar } from "@components/Sidebar.js"; import { Sidebar } from "@components/Sidebar.tsx";
import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.js"; import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.tsx";
import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.js"; import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.tsx";
import { useAppStore } from "@core/stores/appStore.js"; import { useAppStore } from "@core/stores/appStore.ts";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Hashicon } from "@emeraldpay/hashicon-react"; import { Hashicon } from "@emeraldpay/hashicon-react";
import { numberToHexUnpadded } from "@noble/curves/abstract/utils"; import { numberToHexUnpadded } from "@noble/curves/abstract/utils";
import { bbox, lineString } from "@turf/turf"; import { bbox, lineString } from "@turf/turf";

16
src/pages/Messages.tsx

@ -1,14 +1,14 @@
import { ChannelChat } from "@components/PageComponents/Messages/ChannelChat.js"; import { ChannelChat } from "@components/PageComponents/Messages/ChannelChat.tsx";
import { PageLayout } from "@components/PageLayout.js"; import { PageLayout } from "@components/PageLayout.tsx";
import { Sidebar } from "@components/Sidebar.js"; import { Sidebar } from "@components/Sidebar.tsx";
import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.js"; import { SidebarSection } from "@components/UI/Sidebar/SidebarSection.tsx";
import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.js"; import { SidebarButton } from "@components/UI/Sidebar/sidebarButton.tsx";
import { useToast } from "@core/hooks/useToast.js"; import { useToast } from "@core/hooks/useToast.ts";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Hashicon } from "@emeraldpay/hashicon-react"; import { Hashicon } from "@emeraldpay/hashicon-react";
import { Protobuf, Types } from "@meshtastic/js"; import { Protobuf, Types } from "@meshtastic/js";
import { numberToHexUnpadded } from "@noble/curves/abstract/utils"; import { numberToHexUnpadded } from "@noble/curves/abstract/utils";
import { getChannelName } from "@pages/Channels.js"; import { getChannelName } from "@pages/Channels.tsx";
import { HashIcon, LockIcon, LockOpenIcon, WaypointsIcon } from "lucide-react"; import { HashIcon, LockIcon, LockOpenIcon, WaypointsIcon } from "lucide-react";
import { useState } from "react"; import { useState } from "react";

12
src/pages/Nodes.tsx

@ -1,11 +1,11 @@
import Footer from "@app/components/UI/Footer"; import Footer from "@app/components/UI/Footer";
import { useAppStore } from "@app/core/stores/appStore"; import { useAppStore } from "@app/core/stores/appStore";
import { Sidebar } from "@components/Sidebar.js"; import { Sidebar } from "@components/Sidebar.tsx";
import { Button } from "@components/UI/Button.js"; import { Button } from "@components/UI/Button.tsx";
import { Mono } from "@components/generic/Mono.js"; import { Mono } from "@components/generic/Mono.tsx";
import { Table } from "@components/generic/Table/index.js"; import { Table } from "@components/generic/Table/index.tsx";
import { TimeAgo } from "@components/generic/Table/tmp/TimeAgo.js"; import { TimeAgo } from "@components/generic/Table/tmp/TimeAgo.tsx";
import { useDevice } from "@core/stores/deviceStore.js"; import { useDevice } from "@core/stores/deviceStore.ts";
import { Hashicon } from "@emeraldpay/hashicon-react"; import { Hashicon } from "@emeraldpay/hashicon-react";
import { Protobuf } from "@meshtastic/js"; import { Protobuf } from "@meshtastic/js";
import { numberToHexUnpadded } from "@noble/curves/abstract/utils"; import { numberToHexUnpadded } from "@noble/curves/abstract/utils";

2
src/validation/rasterSource.ts

@ -1,6 +1,6 @@
import { IsArray, IsBoolean, IsNumber, IsString, IsUrl } from "class-validator"; import { IsArray, IsBoolean, IsNumber, IsString, IsUrl } from "class-validator";
import type { RasterSource } from "@core/stores/appStore.js"; import type { RasterSource } from "@core/stores/appStore.ts";
export class MapValidation { export class MapValidation {
@IsArray() @IsArray()

3
tsconfig.json

@ -34,6 +34,7 @@
"@types/w3c-web-serial" "@types/w3c-web-serial"
], ],
"strictPropertyInitialization": false, "strictPropertyInitialization": false,
"experimentalDecorators": true "experimentalDecorators": true,
"allowImportingTsExtensions": true,
} }
} }

Loading…
Cancel
Save