summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorlxf <sng@luxagraf.net>2022-01-02 14:30:04 -0500
committerlxf <sng@luxagraf.net>2022-01-02 14:30:04 -0500
commit1123d655bd6708fba056d9800af61e9f2e8bd6eb (patch)
tree0d9b054f0927e950f6df04c5e1b358c0fc1ecfdb
parent0025ca538247df8f24d21ef59c1d587d00176fcc (diff)
loc: made walks display track on map
-rw-r--r--app/locations/models.py10
-rw-r--r--app/locations/templates/locations/track_detail.html70
-rw-r--r--app/utils/static/image-loader.js6
3 files changed, 84 insertions, 2 deletions
diff --git a/app/locations/models.py b/app/locations/models.py
index e27e6cc..9580132 100644
--- a/app/locations/models.py
+++ b/app/locations/models.py
@@ -499,6 +499,16 @@ class Track(models.Model):
def get_rating(self):
return int(self.rating)
+
+ @property
+ def lon(self):
+ '''Get the site's longitude.'''
+ return self.point.x
+
+ @property
+ def lat(self):
+ '''Get the site's latitude.'''
+ return self.point.y
@property
def ratings_range(cls):
diff --git a/app/locations/templates/locations/track_detail.html b/app/locations/templates/locations/track_detail.html
index 6339852..df71d94 100644
--- a/app/locations/templates/locations/track_detail.html
+++ b/app/locations/templates/locations/track_detail.html
@@ -1,5 +1,7 @@
{% extends 'base.html' %}
{% load typogrify_tags %}
+{% block extrahead %}
+{% endblock %}
{%block bodyid%}class="detail"{%endblock%}
{% block breadcrumbs %}{% include "lib/breadcrumbs.html" with breadcrumbs=breadcrumbs %}{% endblock %}
{% block primary %}
@@ -21,7 +23,7 @@
</header>
<div class="e-content entry-content post-body" itemprop="articleBody">
- <img src="{{object.get_image_url}}" alt="{{object.title}} map" />
+ <div id=map></div>
<div class="-cover">
<dl class="book-metadata">
{% if object.distance %}<dt>Distance</dt>
@@ -74,4 +76,70 @@
</nav>{%endwith%}{%endwith%}
</div>
</main>
+{{ object.gpx_file.raw_data|json_script:"track" }}
+{% endblock %}
+{% block js %}
+<script src="/media/js/leaflet-1.7.1/leaflet.js"></script>
+<script src="/media/js/gpx.min.js"></script>
+<script>
+var map = document.getElementById("map");
+map.style.height = "300px"
+map.style.width= "100%"
+var centerCoord = new L.LatLng({{object.lat}}, {{object.lon}});
+var zoom = 13;
+var themap = L.map('map', { scrollWheelZoom: "onFocus" }).setView(centerCoord, zoom);
+L.tileLayer('http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
+ attribution: 'Map data &copy; <a href="http://www.osm.org">OpenStreetMap</a>'
+}).addTo(themap);
+map.style.height = "300px"
+map.style.width= "100%"
+var gpx = JSON.parse(document.getElementById('track').textContent);
+new L.GPX(gpx, {
+ async: true,
+ polyline_options: {
+ color: 'green',
+ opacity: 0.75,
+ weight: 2,
+ lineCap: 'round'
+ },
+ marker_options: {
+ startIconUrl: '',
+ endIconUrl: '',
+ shadowUrl: ''
+ }
+}).on('loaded', function(e) {
+ themap.fitBounds(e.target.getBounds());
+}).addTo(themap);
+get_distance_imp()
+</script>
{% endblock %}
+{% comment %}
+<script src="/media/js/leaflet-master/leaflet-mod.js"></script>
+<script src="/media/js/detail.min.js"></script>
+<script src="/media/js/GPXParser.js"></script>
+{{ object.gpx_file.raw_data|json_script:"track" }}
+<script>
+var gpx = new gpxParser(); //Create gpxParser Object
+var track = JSON.parse(document.getElementById('track').textContent);
+gpx.parse(track); //parse gpx file from string data
+var totalDistance = gpx.tracks[0].distance.total;
+var map = document.getElementById("map");
+map.style.height = "300px"
+map.style.width= "100%"
+var centerCoord = new L.LatLng({{object.lat}}, {{object.lon}});
+var zoom = 13;
+var themap = L.map('map', { scrollWheelZoom: "onFocus" }).setView(centerCoord, zoom);
+L.tileLayer.provider('Esri.WorldTopoMap', {maxZoom: 18,attribution: 'Map data &copy; <a href="http://openstreetmap.org">OpenStreetMap</a>'}).addTo(themap);
+
+
+function drawTrack(track) {
+ let coordinates = track.points.map(p => [p.lat.toFixed(5), p.lon.toFixed(5)]);
+ var polyline = L.polyline(coordinates, {weight: 6, color: 'darkred'});
+ console.log(polyline);
+ polyline.addTo(themap);
+ // zoom the map to the polyline
+ //themap.fitBounds(polyline.getBounds());
+}
+drawTrack(gpx.tracks[0]);
+</script>
+{% endcomment %}
diff --git a/app/utils/static/image-loader.js b/app/utils/static/image-loader.js
index 707c1c5..5a5b3b4 100644
--- a/app/utils/static/image-loader.js
+++ b/app/utils/static/image-loader.js
@@ -41,7 +41,11 @@ function add_images(){
}
document.addEventListener("DOMContentLoaded", function(event) {
add_images();
- md = document.forms["post_form"].elements["body_markdown"];
+ if (document.forms["post_form"]) {
+ md = document.forms["post_form"].elements["body_markdown"];
+ } else {
+ md = document.forms["track_form"].elements["body_markdown"];
+ }
md.style.maxHeight = "300rem";
md.style.maxWidth = "300rem";
});