|
|
|
@ -9,6 +9,7 @@ import { useDevice } from "@core/stores/deviceStore.ts"; |
|
|
|
import { Protobuf } from "@meshtastic/js"; |
|
|
|
import { numberToHexUnpadded } from "@noble/curves/abstract/utils"; |
|
|
|
import { LockIcon, LockOpenIcon, TrashIcon } from "lucide-react"; |
|
|
|
import { useState } from "react"; |
|
|
|
import { Fragment, type JSX } from "react"; |
|
|
|
import { base16 } from "rfc4648"; |
|
|
|
|
|
|
|
@ -20,15 +21,27 @@ export interface DeleteNoteDialogProps { |
|
|
|
const NodesPage = (): JSX.Element => { |
|
|
|
const { nodes, hardware, setDialogOpen } = useDevice(); |
|
|
|
const { setNodeNumToBeRemoved } = useAppStore(); |
|
|
|
const [searchTerm, setSearchTerm] = useState<string>(""); |
|
|
|
|
|
|
|
const filteredNodes = Array.from(nodes.values()).filter( |
|
|
|
(n) => n.num !== hardware.myNodeNum, |
|
|
|
); |
|
|
|
const filteredNodes = Array.from(nodes.values()).filter((node) => { |
|
|
|
if (node.num === hardware.myNodeNum) return false; |
|
|
|
const nodeName = node.user?.longName ?? `!${numberToHexUnpadded(node.num)}`; |
|
|
|
return nodeName.toLowerCase().includes(searchTerm.toLowerCase()); |
|
|
|
}); |
|
|
|
|
|
|
|
return ( |
|
|
|
<> |
|
|
|
<Sidebar /> |
|
|
|
<div className="flex flex-col w-full"> |
|
|
|
<div className="p-4"> |
|
|
|
<input |
|
|
|
type="text" |
|
|
|
placeholder="Search nodes..." |
|
|
|
value={searchTerm} |
|
|
|
onChange={(e) => setSearchTerm(e.target.value)} |
|
|
|
className="w-full p-2 border border-gray-300 rounded bg-white text-black" |
|
|
|
/> |
|
|
|
</div> |
|
|
|
<div className="overflow-y-auto h-full"> |
|
|
|
<Table |
|
|
|
headings={[ |
|
|
|
|