improve map page

main
lza_menace 8 months ago
parent 5bc00debc3
commit a44da731e9

@ -7,7 +7,7 @@ from urllib.parse import urlparse
from xmrnodes.helpers import rw_cache, get_highest_block from xmrnodes.helpers import rw_cache, get_highest_block
from xmrnodes.forms import SubmitNode from xmrnodes.forms import SubmitNode
from xmrnodes.models import Node from xmrnodes.models import Node, Peer
from xmrnodes import config from xmrnodes import config
bp = Blueprint("meta", "meta") bp = Blueprint("meta", "meta")
@ -64,7 +64,7 @@ def index():
@bp.route("/map") @bp.route("/map")
def map(): def map():
try: try:
peers = rw_cache("map_peers") peers = Peer.select()
nodes = Node.select().where(Node.datetime_checked) nodes = Node.select().where(Node.datetime_checked)
except: except:
flash("Couldn't load the map. Try again later.") flash("Couldn't load the map. Try again later.")

Binary file not shown.

After

Width:  |  Height:  |  Size: 198 KiB

@ -19,8 +19,8 @@
<meta name="application-name" content="XMR Nodes"> <meta name="application-name" content="XMR Nodes">
<meta name="msapplication-TileColor" content="#da532c"> <meta name="msapplication-TileColor" content="#da532c">
<meta name="keywords" content="wownero, monero, xmr, bitmonero, cryptocurrency"> <meta name="keywords" content="wownero, monero, xmr, bitmonero, cryptocurrency">
<link rel="stylesheet" href="//cdn.jsdelivr.net/gh/openlayers/openlayers.github.io@master/en/v6.5.0/css/ol.css" type="text/css"> <link rel="preload stylesheet" href="//cdn.jsdelivr.net/gh/openlayers/openlayers.github.io@master/en/v6.5.0/css/ol.css" type="text/css">
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/4.5.0/css/bootstrap.min.css" type="text/css"> <link rel="preload stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/4.5.0/css/bootstrap.min.css" type="text/css">
<style> <style>
.map { .map {
height: 600px; height: 600px;
@ -56,139 +56,150 @@
{% endwith %} {% endwith %}
<div class="center info"> <div class="center info">
<p>Peers seen ~2 weeks: {{ peers | length }}</p> <p>Recent Peers: {{ peers | length }}</p>
<p>Source Node: {{ source_node }}</p> <p>Source Node: {{ source_node }}</p>
<p> <p>
This is not a full representation of the entire Monero network, This is not a full representation of the entire Monero network,
just a look into the peers being recursively crawled from the source node ({{ source_node }}). just a look into the peers being recursively crawled from the source node ({{ source_node }}).
New peers are searched for once per week on average. New peers are searched every hour and unresponsive nodes are removed.
Older peers are shown as more transparent and will be removed
if not seen again after some time.
</p> </p>
<br> <br>
<a href="/">Go home</a> <a href="/">Go home</a>
</div> </div>
<div id="map" class="map"></div> <div id="map" class="map">
<div id="loadingContainer" style="width: 100%; text-align: center;">
<img id="loading" src="/static/images/helping.gif" style="width: 30%;" />
</div>
</div>
<div id="popup" class="popup" title="Welcome to OpenLayers"></div> <div id="popup" class="popup" title="Welcome to OpenLayers"></div>
<script> <script>
// Marker layer function loadMap() {
markerLayer = new ol.layer.Vector({
source: new ol.source.Vector({
features: [],
projection: 'EPSG:3857'
})
});
// Create the map // Marker layer
var map = new ol.Map({ markerLayer = new ol.layer.Vector({
target: 'map', source: new ol.source.Vector({
layers: [ features: [],
new ol.layer.Tile({ projection: 'EPSG:3857'
source: new ol.source.OSM() })
}), });
markerLayer
],
view: new ol.View({
center: ol.proj.fromLonLat([0, 25]),
zoom: 1
})
});
{% for peer in nodes %} // Create the map
{% if peer.datetime_checked | hours_elapsed > 24 %} var map = new ol.Map({
target: 'map',
layers: [
new ol.layer.Tile({
source: new ol.source.OSM()
}),
markerLayer
],
view: new ol.View({
center: ol.proj.fromLonLat([0, 25]),
zoom: 1
})
});
{% for peer in nodes %}
{% if peer.datetime_checked | hours_elapsed > 24 %}
{% set fill_color = 'rgba(1,1,45,.2)' %} {% set fill_color = 'rgba(1,1,45,.2)' %}
{% elif peer.datetime_checked | hours_elapsed > 16 %} {% elif peer.datetime_checked | hours_elapsed > 16 %}
{% set fill_color = 'rgba(1,1,45,.4)' %} {% set fill_color = 'rgba(1,1,45,.4)' %}
{% elif peer.datetime_checked | hours_elapsed > 8 %} {% elif peer.datetime_checked | hours_elapsed > 8 %}
{% set fill_color = 'rgba(1,1,45,.6)' %} {% set fill_color = 'rgba(1,1,45,.6)' %}
{% elif peer.datetime_checked | hours_elapsed > 4 %} {% elif peer.datetime_checked | hours_elapsed > 4 %}
{% set fill_color = 'rgba(1,1,45,.8)' %} {% set fill_color = 'rgba(1,1,45,.8)' %}
{% else %} {% else %}
{% set fill_color = 'rgba(1,1,45,1)' %} {% set fill_color = 'rgba(1,1,45,1)' %}
{% endif %} {% endif %}
var feature = new ol.Feature( var feature = new ol.Feature(
new ol.geom.Point(ol.proj.transform(['{{ peer.lon }}', '{{ peer.lat }}'], 'EPSG:4326', 'EPSG:3857')) new ol.geom.Point(ol.proj.transform(['{{ peer.lon }}', '{{ peer.lat }}'], 'EPSG:4326', 'EPSG:3857'))
); );
feature.description = [ feature.description = [
'Node {{ peer.url }}', 'Node {{ peer.url }}',
'Last seen {{ peer.datetime_checked | humanize }}' 'Last seen {{ peer.datetime_checked | humanize }}'
]; ];
feature.setStyle(new ol.style.Style({ feature.setStyle(new ol.style.Style({
image: new ol.style.Circle({ image: new ol.style.Circle({
radius: 6, radius: 6,
fill: new ol.style.Fill({ fill: new ol.style.Fill({
color: '{{ fill_color }}', color: '{{ fill_color }}',
}), }),
stroke: new ol.style.Stroke({ stroke: new ol.style.Stroke({
color: '#fff', color: '#fff',
width: 1 width: 1
})
}) })
}) })
); }));
markerLayer.getSource().addFeature(feature); markerLayer.getSource().addFeature(feature);
{% endfor %} {% endfor %}
{% for peer in peers %} {% for peer in peers %}
{% if peer.datetime | hours_elapsed > 24 %} {% if peer.datetime | hours_elapsed > 24 %}
{% set fill_color = 'rgba(238,111,45,.2)' %} {% set fill_color = 'rgba(238,111,45,.2)' %}
{% elif peer.datetime | hours_elapsed > 16 %} {% elif peer.datetime | hours_elapsed > 16 %}
{% set fill_color = 'rgba(238,111,45,.4)' %} {% set fill_color = 'rgba(238,111,45,.4)' %}
{% elif peer.datetime | hours_elapsed > 8 %} {% elif peer.datetime | hours_elapsed > 8 %}
{% set fill_color = 'rgba(238,111,45,.6)' %} {% set fill_color = 'rgba(238,111,45,.6)' %}
{% elif peer.datetime | hours_elapsed > 4 %} {% elif peer.datetime | hours_elapsed > 4 %}
{% set fill_color = 'rgba(238,111,45,.8)' %} {% set fill_color = 'rgba(238,111,45,.8)' %}
{% else %} {% else %}
{% set fill_color = 'rgba(238,111,45,1)' %} {% set fill_color = 'rgba(238,111,45,1)' %}
{% endif %} {% endif %}
var feature = new ol.Feature( var feature = new ol.Feature(
new ol.geom.Point(ol.proj.transform(['{{ peer.lon }}', '{{ peer.lat }}'], 'EPSG:4326', 'EPSG:3857')) new ol.geom.Point(ol.proj.transform(['{{ peer.lon }}', '{{ peer.lat }}'], 'EPSG:4326', 'EPSG:3857'))
); );
feature.description = [ feature.description = [
'Peer {{ peer.url }}', 'Peer {{ peer.url }}',
'Last seen {{ peer.datetime | humanize }}' 'Last seen {{ peer.datetime | humanize }}'
]; ];
feature.setStyle(new ol.style.Style({ feature.setStyle(new ol.style.Style({
image: new ol.style.Circle({ image: new ol.style.Circle({
radius: 6, radius: 6,
fill: new ol.style.Fill({ fill: new ol.style.Fill({
color: '{{ fill_color }}', color: '{{ fill_color }}',
}), }),
stroke: new ol.style.Stroke({ stroke: new ol.style.Stroke({
color: '#fff', color: '#fff',
width: 1 width: 1
})
}) })
}) })
); }));
markerLayer.getSource().addFeature(feature); markerLayer.getSource().addFeature(feature);
{% endfor %} {% endfor %}
// Setup popup // Setup popup
var popup = new ol.Overlay({ var popup = new ol.Overlay({
element: $('#popup')[0], element: $('#popup')[0],
}); });
map.addOverlay(popup); map.addOverlay(popup);
// Show details on each pixel // Show details on each pixel
map.on("click", function(e) { map.on("click", function(e) {
var element = popup.getElement(); var element = popup.getElement();
$(element).popover('dispose') $(element).popover('dispose')
map.forEachFeatureAtPixel(e.pixel, function (feature, layer) { map.forEachFeatureAtPixel(e.pixel, function (feature, layer) {
var coordinate = e.coordinate; var coordinate = e.coordinate;
$(element).popover('dispose'); $(element).popover('dispose');
popup.setPosition(coordinate); popup.setPosition(coordinate);
element.title = feature.description[0] element.title = feature.description[0]
$(element).popover({ $(element).popover({
container: element, container: element,
placement: 'top', placement: 'top',
animation: false, animation: false,
html: true, html: true,
content: '<p>' + feature.description[1] + '</p>', content: '<p>' + feature.description[1] + '</p>',
}); });
$(element).popover('show'); $(element).popover('show');
}); });
});
// Remove loader
document.getElementById('loadingContainer').remove();
}
// Wait for full load
addEventListener("DOMContentLoaded", (event) => {
setTimeout(loadMap, 1000);
}); });
</script> </script>

Loading…
Cancel
Save