Display location on map node details

This commit is contained in:
maciejhirsz
2018-07-18 16:59:47 +02:00
parent 3696d7c46e
commit 5c1480f9f5
11 changed files with 30 additions and 17 deletions
+1 -1
View File
@@ -2,7 +2,7 @@ declare module 'iplocation' {
namespace iplocation {
export interface LocationData {
as?: string;
city?: string;
city: string;
country?: string;
countryCode?: string;
isp?: string;
+1 -1
View File
@@ -57,7 +57,7 @@ export default class Feed {
public static locatedNode(node: Node, location: Location): FeedMessage.Message {
return {
action: Actions.LocatedNode,
payload: [node.id, location.lat, location.lon]
payload: [node.id, location.lat, location.lon, location.city]
};
}
+1 -5
View File
@@ -98,8 +98,6 @@ export default class Node {
return;
}
console.log('node', ip, 'located at', location);
this.location = location;
this.events.emit('location', location);
@@ -107,8 +105,6 @@ export default class Node {
}
public static fromSocket(socket: WebSocket, ip: string): Promise<Node> {
console.log('node ip', ip);
return new Promise((resolve, reject) => {
function cleanup() {
clearTimeout(timeout);
@@ -160,7 +156,7 @@ export default class Node {
public nodeLocation(): Maybe<Types.NodeLocation> {
const { location } = this;
return location ? [location.lat, location.lon] : null;
return location ? [location.lat, location.lon, location.city] : null;
}
public get average(): number {
+5 -3
View File
@@ -4,6 +4,7 @@ import { Maybe, Types } from '@dotstats/common';
export interface Location {
lat: Types.Latitude;
lon: Types.Longitude;
city: Types.City;
}
const cache = new Map<string, Location>();
@@ -12,7 +13,8 @@ export async function locate(ip: string): Promise<Maybe<Location>> {
if (ip === '127.0.0.1') {
return Promise.resolve({
lat: 52.5166667 as Types.Latitude,
lon: 13.4 as Types.Longitude
lon: 13.4 as Types.Longitude,
city: 'Berlin' as Types.City,
});
}
@@ -30,8 +32,8 @@ export async function locate(ip: string): Promise<Maybe<Location>> {
return resolve(null);
}
const { latitude: lat, longitude: lon } = result;
const location = { lat, lon } as Location;
const { latitude: lat, longitude: lon, city } = result;
const location = { lat, lon, city } as Location;
cache.set(ip, location);
+2 -1
View File
@@ -3,6 +3,7 @@ import {
FeedVersion,
Latitude,
Longitude,
City,
NodeId,
NodeCount,
NodeDetails,
@@ -60,7 +61,7 @@ export namespace Variants {
export interface LocatedNodeMessage extends MessageBase {
action: typeof Actions.LocatedNode;
payload: [NodeId, Latitude, Longitude];
payload: [NodeId, Latitude, Longitude, City];
}
export interface ImportedBlockMessage extends MessageBase {
+1 -1
View File
@@ -6,4 +6,4 @@ import * as FeedMessage from './feed';
export { Types, FeedMessage };
export const VERSION: Types.FeedVersion = 4 as Types.FeedVersion;
export const VERSION: Types.FeedVersion = 5 as Types.FeedVersion;
+2 -1
View File
@@ -18,8 +18,9 @@ export type PeerCount = Opaque<number, 'PeerCount'>;
export type TransactionCount = Opaque<number, 'TransactionCount'>;
export type Latitude = Opaque<number, 'Latitude'>;
export type Longitude = Opaque<number, 'Longitude'>;
export type City = Opaque<string, 'City'>;
export type BlockDetails = [BlockNumber, BlockHash, Milliseconds, Timestamp, Maybe<PropagationTime>];
export type NodeDetails = [NodeName, NodeImplementation, NodeVersion];
export type NodeStats = [PeerCount, TransactionCount];
export type NodeLocation = [Latitude, Longitude];
export type NodeLocation = [Latitude, Longitude, City];
+2 -2
View File
@@ -139,14 +139,14 @@ export class Connection {
}
case Actions.LocatedNode: {
const [id, latitude, longitude] = message.payload;
const [id, latitude, longitude, city] = message.payload;
const node = nodes.get(id);
if (!node) {
return;
}
node.location = [latitude, longitude];
node.location = [latitude, longitude, city];
break;
}
+1 -1
View File
@@ -118,7 +118,7 @@ export class Chain extends React.Component<Chain.Props, Chain.State> {
}
{
this.nodes().map((node) => {
const location = node.location || [0, 0] as Types.NodeLocation;
const location = node.location || [0, 0, ''] as Types.NodeLocation;
// const location = [51.4825891, -0.0164137] as Types.NodeLocation; // Greenwich
// const location = [52.2330653, 20.921111] as Types.NodeLocation; // Warsaw
// const location = [48.8589507, 2.2770201] as Types.NodeLocation; // Paris
@@ -12,6 +12,11 @@
cursor: pointer;
}
.Node-Location:hover {
z-index: 2;
background: #fff;
}
.Node-details {
display: none;
min-width: 335px;
+9 -1
View File
@@ -5,6 +5,7 @@ import { Types, Maybe } from '@dotstats/common';
import nodeIcon from '../icons/server.svg';
import nodeTypeIcon from '../icons/terminal.svg';
import nodeLocationIcon from '../icons/location.svg';
import peersIcon from '../icons/broadcast.svg';
import transactionsIcon from '../icons/inbox.svg';
import blockIcon from '../icons/package.svg';
@@ -68,10 +69,14 @@ export namespace Node {
}
export function Location(props: Props & PixelPosition) {
const { left, top } = props;
const { left, top, location } = props;
const [name, implementation, version] = props.nodeDetails;
const [height, hash, blockTime, blockTimestamp, propagationTime] = props.blockDetails;
if (!location) {
return null;
}
return (
<div className="Node-Location" style={{ left, top }}>
<table className="Node-details">
@@ -82,6 +87,9 @@ export namespace Node {
<tr>
<td><Icon src={nodeTypeIcon} alt="Implementation" /></td><td colSpan={5}>{implementation} v{version}</td>
</tr>
<tr>
<td><Icon src={nodeLocationIcon} alt="Location" /></td><td colSpan={5}>{location[2]}</td>
</tr>
<tr>
<td><Icon src={blockIcon} alt="Block" /></td><td colSpan={5}>#{formatNumber(height)}</td>
</tr>