diff options
author | lxf <sng@luxagraf.net> | 2022-01-02 14:30:04 -0500 |
---|---|---|
committer | lxf <sng@luxagraf.net> | 2022-01-02 14:30:04 -0500 |
commit | 1123d655bd6708fba056d9800af61e9f2e8bd6eb (patch) | |
tree | 0d9b054f0927e950f6df04c5e1b358c0fc1ecfdb | |
parent | 0025ca538247df8f24d21ef59c1d587d00176fcc (diff) |
loc: made walks display track on map
-rw-r--r-- | app/locations/models.py | 10 | ||||
-rw-r--r-- | app/locations/templates/locations/track_detail.html | 70 | ||||
-rw-r--r-- | app/utils/static/image-loader.js | 6 |
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 © <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 © <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"; }); |