Files
wifi-densepose/mobile/src/hooks/useRssiScanner.ts
Yossi Elkrief 779bf8ff43 feat: Phase 3 — services, stores, navigation, design system
Services: ws.service, api.service, simulation.service, rssi.service (android+ios)
Stores: poseStore, settingsStore, matStore (Zustand)
Types: sensing, mat, api, navigation
Hooks: usePoseStream, useRssiScanner, useServerReachability
Theme: colors, typography, spacing, ThemeContext
Navigation: MainTabs (5 tabs), RootNavigator, types
Components: GaugeArc, SparklineChart, OccupancyGrid, StatusDot, ConnectionBanner, SignalBar, +more
Utils: ringBuffer, colorMap, formatters, urlValidator

Verified: tsc 0 errors, jest passes
2026-03-02 12:53:45 +02:00

32 lines
897 B
TypeScript

import { useEffect, useState } from 'react';
import { rssiService, type WifiNetwork } from '@/services/rssi.service';
import { useSettingsStore } from '@/stores/settingsStore';
export function useRssiScanner(): { networks: WifiNetwork[]; isScanning: boolean } {
const enabled = useSettingsStore((state) => state.rssiScanEnabled);
const [networks, setNetworks] = useState<WifiNetwork[]>([]);
const [isScanning, setIsScanning] = useState(false);
useEffect(() => {
if (!enabled) {
rssiService.stopScanning();
setIsScanning(false);
return;
}
const unsubscribe = rssiService.subscribe((result) => {
setNetworks(result);
});
rssiService.startScanning(2000);
setIsScanning(true);
return () => {
unsubscribe();
rssiService.stopScanning();
setIsScanning(false);
};
}, [enabled]);
return { networks, isScanning };
}