import { Button } from "@components/UI/Button.js"; import { Mono } from "@components/generic/Mono.js"; import { useAppStore } from "@core/stores/appStore.js"; import { useDeviceStore } from "@core/stores/deviceStore.js"; import { subscribeAll } from "@core/subscriptions.js"; import { randId } from "@core/utils/randId.js"; import { BleConnection, Constants } from "@meshtastic/js"; import { useCallback, useEffect, useState } from "react"; export const BLE = (): JSX.Element => { const [bleDevices, setBleDevices] = useState([]); const { addDevice } = useDeviceStore(); const { setSelectedDevice } = useAppStore(); const updateBleDeviceList = useCallback(async (): Promise => { setBleDevices(await navigator.bluetooth.getDevices()); }, []); useEffect(() => { updateBleDeviceList(); }, [updateBleDeviceList]); const onConnect = async (bleDevice: BluetoothDevice) => { const id = randId(); const device = addDevice(id); setSelectedDevice(id); const connection = new BleConnection(id); await connection.connect({ device: bleDevice, }); device.addConnection(connection); subscribeAll(device, connection); }; return (
{bleDevices.map((device) => ( ))} {bleDevices.length === 0 && ( No devices paired yet. )}
); };