mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-07 08:19:52 +03:00
75 lines
2.3 KiB
TypeScript
75 lines
2.3 KiB
TypeScript
import { FC, useContext } from 'react';
|
|
|
|
import { Avatar, Badge, List, ListItem, ListItemAvatar, ListItemIcon, ListItemText } from '@mui/material';
|
|
|
|
import LockOpenIcon from '@mui/icons-material/LockOpen';
|
|
import LockIcon from '@mui/icons-material/Lock';
|
|
import WifiIcon from '@mui/icons-material/Wifi';
|
|
|
|
import { MessageBox } from '../../components';
|
|
|
|
import { WiFiEncryptionType, WiFiNetwork, WiFiNetworkList } from '../../types';
|
|
|
|
import { WiFiConnectionContext } from './WiFiConnectionContext';
|
|
|
|
import { useI18nContext } from '../../i18n/i18n-react';
|
|
|
|
interface WiFiNetworkSelectorProps {
|
|
networkList: WiFiNetworkList;
|
|
}
|
|
|
|
export const isNetworkOpen = ({ encryption_type }: WiFiNetwork) =>
|
|
encryption_type === WiFiEncryptionType.WIFI_AUTH_OPEN;
|
|
|
|
export const networkSecurityMode = ({ encryption_type }: WiFiNetwork) => {
|
|
switch (encryption_type) {
|
|
case WiFiEncryptionType.WIFI_AUTH_WEP:
|
|
return 'WEP';
|
|
case WiFiEncryptionType.WIFI_AUTH_WPA_PSK:
|
|
return 'WPA';
|
|
case WiFiEncryptionType.WIFI_AUTH_WPA2_PSK:
|
|
return 'WPA2';
|
|
case WiFiEncryptionType.WIFI_AUTH_WPA_WPA2_PSK:
|
|
return 'WPA/WPA2';
|
|
case WiFiEncryptionType.WIFI_AUTH_WPA2_ENTERPRISE:
|
|
return 'WPA2 Enterprise';
|
|
case WiFiEncryptionType.WIFI_AUTH_OPEN:
|
|
return 'None';
|
|
default:
|
|
return 'Unknown';
|
|
}
|
|
};
|
|
|
|
const WiFiNetworkSelector: FC<WiFiNetworkSelectorProps> = ({ networkList }) => {
|
|
const { LL } = useI18nContext();
|
|
|
|
const wifiConnectionContext = useContext(WiFiConnectionContext);
|
|
|
|
const renderNetwork = (network: WiFiNetwork) => {
|
|
return (
|
|
<ListItem key={network.bssid} button onClick={() => wifiConnectionContext.selectNetwork(network)}>
|
|
<ListItemAvatar>
|
|
<Avatar>{isNetworkOpen(network) ? <LockOpenIcon /> : <LockIcon />}</Avatar>
|
|
</ListItemAvatar>
|
|
<ListItemText
|
|
primary={network.ssid}
|
|
secondary={'Security: ' + networkSecurityMode(network) + ', Ch: ' + network.channel}
|
|
/>
|
|
<ListItemIcon>
|
|
<Badge badgeContent={network.rssi + 'db'}>
|
|
<WifiIcon />
|
|
</Badge>
|
|
</ListItemIcon>
|
|
</ListItem>
|
|
);
|
|
};
|
|
|
|
if (networkList.networks.length === 0) {
|
|
return <MessageBox mt={2} mb={1} message={LL.NETWORK_NO_WIFI()} level="info" />;
|
|
}
|
|
|
|
return <List>{networkList.networks.map(renderNetwork)}</List>;
|
|
};
|
|
|
|
export default WiFiNetworkSelector;
|