Plan/Plan/react/dashboard/src/components/cards/player/ConnectionsCard.jsx

45 lines
1.8 KiB
JavaScript

import React from 'react';
import {useTranslation} from "react-i18next";
import {useTheme} from "../../../hooks/themeHook";
import {Card} from "react-bootstrap";
import {FontAwesomeIcon as Fa} from "@fortawesome/react-fontawesome";
import {faGlobe, faWifi} from "@fortawesome/free-solid-svg-icons";
import Scrollable from "../../Scrollable";
import {faClock} from "@fortawesome/free-regular-svg-icons";
const ConnectionsCard = ({connections}) => {
const {t} = useTranslation();
const {nightModeEnabled} = useTheme();
return (
<Card>
<Card.Header>
<h6 className="col-black">
<Fa icon={faWifi}/> {t('html.label.connectionInfo')}
</h6>
</Card.Header>
<Scrollable>
<table className={"table table-striped mb-0" + (nightModeEnabled ? " table-dark" : '')}>
<thead className="bg-green">
<tr>
<th><Fa icon={faGlobe}/> {t('html.label.country')}</th>
<th><Fa icon={faClock}/> {t('html.label.lastConnected')}</th>
</tr>
</thead>
{Boolean(connections?.length) && <tbody>
{connections.map(connection => (<tr key={JSON.stringify(connection)}>
<td>{connection.geolocation.replace('Local Machine', t('html.value.localMachine'))}</td>
<td>{connection.date}</td>
</tr>))}
</tbody>}
{!connections?.length && <tbody>
<tr>
<td colSpan={2}>{t('generic.noData')}</td>
</tr>
</tbody>}
</table>
</Scrollable>
</Card>
)
}
export default ConnectionsCard