2023-02-18 13:11:01 +03:00
|
|
|
import { faCheck as checkIcon } from '@fortawesome/free-solid-svg-icons';
|
|
|
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type { FC } from 'react';
|
2021-10-17 20:13:06 +03:00
|
|
|
import { Link } from 'react-router-dom';
|
2023-02-18 13:11:01 +03:00
|
|
|
import { UncontrolledTooltip } from 'reactstrap';
|
2023-02-18 12:40:37 +03:00
|
|
|
import type { ServerWithId } from './data';
|
|
|
|
import type { ManageServersRowDropdownProps } from './ManageServersRowDropdown';
|
2021-10-17 20:13:06 +03:00
|
|
|
|
|
|
|
export interface ManageServersRowProps {
|
|
|
|
server: ServerWithId;
|
|
|
|
hasAutoConnect: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const ManageServersRow = (
|
2021-10-22 21:26:11 +03:00
|
|
|
ManageServersRowDropdown: FC<ManageServersRowDropdownProps>,
|
2021-10-23 11:34:20 +03:00
|
|
|
): FC<ManageServersRowProps> => ({ server, hasAutoConnect }) => (
|
2021-10-22 21:26:11 +03:00
|
|
|
<tr className="responsive-table__row">
|
|
|
|
{hasAutoConnect && (
|
|
|
|
<td className="responsive-table__cell" data-th="Auto-connect">
|
|
|
|
{server.autoConnect && (
|
|
|
|
<>
|
|
|
|
<FontAwesomeIcon icon={checkIcon} className="text-primary" id="autoConnectIcon" />
|
|
|
|
<UncontrolledTooltip target="autoConnectIcon" placement="right">
|
|
|
|
Auto-connect to this server
|
|
|
|
</UncontrolledTooltip>
|
|
|
|
</>
|
|
|
|
)}
|
2021-10-17 20:13:06 +03:00
|
|
|
</td>
|
2021-10-22 21:26:11 +03:00
|
|
|
)}
|
|
|
|
<th className="responsive-table__cell" data-th="Name">
|
|
|
|
<Link to={`/server/${server.id}`}>{server.name}</Link>
|
|
|
|
</th>
|
|
|
|
<td className="responsive-table__cell" data-th="Base URL">{server.url}</td>
|
2022-03-05 15:26:28 +03:00
|
|
|
<td className="responsive-table__cell text-end">
|
2021-10-22 21:26:11 +03:00
|
|
|
<ManageServersRowDropdown server={server} />
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
);
|