show ip of onion path on hover of country name

pull/1937/head
Audric Ackermann 4 years ago
parent 0382d703c5
commit 76100903cb
No known key found for this signature in database
GPG Key ID: 999F434D76324AD4

@ -1095,6 +1095,7 @@ input {
flex-direction: column; flex-direction: column;
margin: $session-margin-sm; margin: $session-margin-sm;
align-items: flex-start; align-items: flex-start;
min-width: 10vw;
position: relative; position: relative;
.onion__node { .onion__node {

@ -19,6 +19,8 @@ import { Flex } from '../basic/Flex';
import { SessionIcon, SessionIconButton } from '../session/icon'; import { SessionIcon, SessionIconButton } from '../session/icon';
import { SessionSpinner } from '../session/SessionSpinner'; import { SessionSpinner } from '../session/SessionSpinner';
import { SessionWrapperModal } from '../session/SessionWrapperModal'; import { SessionWrapperModal } from '../session/SessionWrapperModal';
// tslint:disable-next-line: no-submodule-imports
import useHover from 'react-use/lib/useHover';
export type StatusLightType = { export type StatusLightType = {
glowStartDelay: number; glowStartDelay: number;
@ -26,6 +28,25 @@ export type StatusLightType = {
color?: string; color?: string;
}; };
const OnionCountryDisplay = ({
index,
labelText,
snodeIp,
}: {
snodeIp?: string;
labelText: string;
index: number;
}) => {
const element = (hovered: boolean) => (
<div className="onion__node__country" key={`country-${index}`}>
{hovered && snodeIp ? snodeIp : labelText}
</div>
);
const [hoverable] = useHover(element);
return hoverable;
};
const OnionPathModalInner = () => { const OnionPathModalInner = () => {
const onionPath = useSelector(getFirstOnionPath); const onionPath = useSelector(getFirstOnionPath);
const isOnline = useSelector(getIsOnline); const isOnline = useSelector(getIsOnline);
@ -69,14 +90,12 @@ const OnionPathModalInner = () => {
{nodes.map((snode: Snode | any, index: number) => { {nodes.map((snode: Snode | any, index: number) => {
let labelText = snode.label let labelText = snode.label
? snode.label ? snode.label
: `${countryLookup.byIso(ip2country(snode.ip))?.country} [${snode.ip}]`; : `${countryLookup.byIso(ip2country(snode.ip))?.country}`;
if (!labelText) { if (!labelText) {
labelText = window.i18n('unknownCountry'); labelText = window.i18n('unknownCountry');
} }
return labelText ? ( return labelText ? (
<div className="onion__node__country" key={`country-${index}`}> <OnionCountryDisplay index={index} labelText={labelText} snodeIp={snode.ip} />
{labelText}
</div>
) : null; ) : null;
})} })}
</Flex> </Flex>

Loading…
Cancel
Save