Update map frontend and REST API
This commit is contained in:
		
							
								
								
									
										20
									
								
								apps/map/migrations/0003_auto_20170521_0643.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								apps/map/migrations/0003_auto_20170521_0643.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
| # Generated by Django 1.10.7 on 2017-05-21 06:43 | ||||
| from __future__ import unicode_literals | ||||
|  | ||||
| from django.db import migrations | ||||
|  | ||||
|  | ||||
| class Migration(migrations.Migration): | ||||
|  | ||||
|     dependencies = [ | ||||
|         ('map', '0002_auto_20170520_0139'), | ||||
|     ] | ||||
|  | ||||
|     operations = [ | ||||
|         migrations.RenameField( | ||||
|             model_name='casestudy', | ||||
|             old_name='geom', | ||||
|             new_name='location', | ||||
|         ), | ||||
|     ] | ||||
| @ -26,7 +26,7 @@ class CaseStudy(models.Model): | ||||
|     ) | ||||
|  | ||||
|     # Location of map pin | ||||
|     geom = models.PointField() | ||||
|     location = models.PointField() | ||||
|  | ||||
|     project_name = models.CharField(max_length=128) | ||||
|     supply_chain = models.CharField( | ||||
|  | ||||
| @ -1,3 +1,4 @@ | ||||
| {% load bootstrap3 %} | ||||
| {% load i18n %} | ||||
| {% load leaflet_tags %} | ||||
| <!DOCTYPE html> | ||||
| @ -5,22 +6,48 @@ | ||||
| <head> | ||||
| 	<meta charset="UTF-8"> | ||||
| 	<title>{% trans "Ojuso Platform Map" %}</title> | ||||
| 	<meta name="viewport" content"width=device-width, initial-scale=2"> | ||||
| 	{% bootstrap_css %} | ||||
| 	{% leaflet_js %} | ||||
|   {% leaflet_css %} | ||||
| 	{% leaflet_css %} | ||||
| 	<style> | ||||
| 	  html, body, #main { | ||||
| 		  width: 100%; | ||||
| 			height:100%; | ||||
| 		} | ||||
| 	</style> | ||||
| </head> | ||||
| <body> | ||||
| 	<h1>Ojuso Platform Map</h1> | ||||
|   {% leaflet_map "main" callback="main_app_init" %} | ||||
| 	{% leaflet_map "main" callback="main_app_init" %} | ||||
| 	<div id="modals"></div> | ||||
| 	<script src="https://code.jquery.com/jquery-3.2.1.min.js" | ||||
| 				  integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" | ||||
| 					crossorigin="anonymous"> | ||||
| 	</script> | ||||
| 	{% bootstrap_javascript %} | ||||
| 	<script type="text/javascript"> | ||||
| 		function create(htmlStr) { | ||||
| 			    var frag = document.createDocumentFragment(), | ||||
| 				        temp = document.createElement('div'); | ||||
| 			    temp.innerHTML = htmlStr; | ||||
| 			    while (temp.firstChild) { | ||||
| 						        frag.appendChild(temp.firstChild); | ||||
| 						    } | ||||
| 			    return frag; | ||||
| 		} | ||||
|   	function main_app_init(map, options) { | ||||
| 			var dataurl = '{% url "data" %}'; | ||||
| 			// Download GeoJSON | ||||
| 			$.getJSON(dataurl, function (data) { | ||||
| 				L.geoJson(data).addTo(map); | ||||
| 			$.getJSON('/api/case-studies/', function (data) { | ||||
| 				L.geoJson(data, { | ||||
| 					onEachFeature: function (feature, layer) { | ||||
| 						var modalname = "case-study-"+feature.id | ||||
| 					  layer.bindPopup( | ||||
| 							"<h3>"+feature.properties.project_name+"</h3>"+"<button type='button' class='btn btn-primary btn-block' data-toggle='modal' data-target='#"+modalname+"'>"+"<span class='glyphicon glyphicon-file' aria-hidden='true'></span>"+"View Details"+"</button>" | ||||
| 						); | ||||
| 						var modal = create("<div class='modal fade' id='"+modalname+"' tabindex='-1' role='dialog' aria-labelledby='"+modalname+"-label'><div class='modal-dialog' role='document'><div class='modal-content'><div class='modal-header'><button type='button' class='close' data-dismiss='modal' aria-label='Close'><span aria-hidden='true'>×</span></button><h4 class='modal-title' id='"+modalname+"-label'>"+feature.properties.project_name+"</h4></div><div class='modal-body'><p>"+feature.properties.description+"</p></div><div class='modal-footer'><button type='button' class='btn btn-default' data-dismiss='modal'>Close</button><button type='button' class='btn btn-primary'>Save changes</button></div></div></div></div>"); | ||||
| 						document.getElementById('modals').appendChild(modal); | ||||
| 				  } | ||||
| 				}).addTo(map); | ||||
| 			}); | ||||
| 		} | ||||
| 	</script>		 | ||||
|  | ||||
| @ -6,5 +6,7 @@ from . import views | ||||
|  | ||||
| urlpatterns = [ | ||||
|     url(r'^$', views.index, name='index'), | ||||
|     url(r'^data.geojson$', GeoJSONLayerView.as_view(model=CaseStudy), name='data') | ||||
|     url(r'^data.geojson$', | ||||
|         GeoJSONLayerView.as_view(model=CaseStudy, geometry_field='location'), | ||||
|         name='data') | ||||
| ] | ||||
|  | ||||
		Reference in New Issue
	
	Block a user