summaryrefslogtreecommitdiff
path: root/apps
diff options
context:
space:
mode:
authorluxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f <luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f>2010-06-13 01:18:25 +0000
committerluxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f <luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f>2010-06-13 01:18:25 +0000
commitc5a6d45415c7601f9a515d05a61ee795dc37536b (patch)
treec120b44a9cc0eea9ec69a1817053f97b22e66856 /apps
parent6657ae24658383a9841450329a518327638651c0 (diff)
updated maps.html to use google maps v3 and created custom route model using gmaps polyline tools to encode points
Diffstat (limited to 'apps')
-rw-r--r--apps/blog/signals.py9
-rw-r--r--apps/locations/admin.py55
-rw-r--r--apps/locations/models.py19
-rw-r--r--apps/locations/urls.py2
-rw-r--r--apps/locations/views.py24
-rw-r--r--apps/photos/views.py2
6 files changed, 99 insertions, 12 deletions
diff --git a/apps/blog/signals.py b/apps/blog/signals.py
index 9809f6f..23e6d3f 100644
--- a/apps/blog/signals.py
+++ b/apps/blog/signals.py
@@ -3,7 +3,7 @@ from django.conf import settings
from django.template import Context
from django.db.models import get_model
-from locations.models import Region,Country
+from locations.models import Region,Country,Route
def update_recent(sender, instance, signal, *args, **kwargs):
# Update recent entries static file
@@ -20,13 +20,14 @@ def update_recent(sender, instance, signal, *args, **kwargs):
qs = model.objects.filter(status__exact=1)
cl = Country.objects.filter(visited=True).exclude(name='default')
rl = Region.objects.all()
- c = Context({'object_list':qs, 'country_list':cl,'region_list':rl})
+ rtl = Route.objects.all()
+ c = Context({'object_list':qs, 'country_list':cl,'region_list':rl, 'route_list':rtl})
t = render_to_string('includes/map_entry_list_template.html',c)
- fpath = '%s%s' %(settings.PROJ_ROOT,'templates/includes/map_entry_list.html')
+ fpath = '%s%s' %(settings.PROJ_ROOT,'media/js/mainmap.js')
file = codecs.open(fpath, 'w','utf8')
file.write(t)
file.close()
- c = Context({'country_list':cl,'region_list':rl})
+ c = Context({'country_list':cl,'region_list':rl,'route_list':rtl})
t = render_to_string('includes/map_sidebar_template.html',c)
fpath = '%s%s' %(settings.PROJ_ROOT,'templates/includes/map_sidebar.html')
file = codecs.open(fpath, 'w','utf8')
diff --git a/apps/locations/admin.py b/apps/locations/admin.py
index 77d1bb3..a23ef28 100644
--- a/apps/locations/admin.py
+++ b/apps/locations/admin.py
@@ -1,6 +1,6 @@
from django.contrib import admin
from django.contrib.gis.admin import OSMGeoAdmin
-from locations.models import Region,Country,Location,State
+from locations.models import Region,Country,Location,State,Route
from django.contrib import databrowse
from django.contrib.gis.maps.google import GoogleMap
from django.conf import settings
@@ -240,3 +240,56 @@ class LocationAdmin(OSMGeoAdmin):
# associating the Options with the actual model
admin.site.register(Location,LocationAdmin)
+class RouteAdmin(OSMGeoAdmin):
+ # Standard Django Admin Options
+ list_display = ('name','slug',)
+ prepopulated_fields = {'slug': ('name',)}
+ search_fields = ('name',)
+ ordering = ('name',)
+ save_as = True
+ search_fields = ['name',]
+ list_select_related = True
+ fieldsets = (
+ ('Location', {'fields': ('name','slug','pub_date','template_var_name','zoom'), 'classes': ('show','extrapretty')}),
+ ('Editable Map View', {'fields': ('geometry',), 'classes': ('show', 'wide')}),
+ )
+ extra_js = [GMAP.api_url + GMAP.key]
+ map_template = 'gis/admin/google.html'
+ # Default GeoDjango OpenLayers map options
+ # Uncomment and modify as desired
+ # To learn more about this jargon visit:
+ # www.openlayers.org
+
+ #default_lon = 0
+ #default_lat = 0
+ #default_zoom = 4
+ #display_wkt = False
+ #display_srid = False
+ #extra_js = []
+ #num_zoom = 18
+ #max_zoom = False
+ #min_zoom = False
+ #units = False
+ #max_resolution = False
+ #max_extent = False
+ #modifiable = True
+ #mouse_position = True
+ #scale_text = True
+ #layerswitcher = True
+ scrollable = False
+ #admin_media_prefix = settings.ADMIN_MEDIA_PREFIX
+ map_width = 700
+ map_height = 325
+ #map_srid = 4326
+ #map_template = 'gis/admin/openlayers.html'
+ #openlayers_url = 'http://openlayers.org/api/2.6/OpenLayers.js'
+ #wms_url = 'http://labs.metacarta.com/wms/vmap0'
+ #wms_layer = 'basic'
+ #wms_name = 'OpenLayers WMS'
+ #debug = False
+ #widget = OpenLayersWidget
+
+# Finally, with these options set now register the model
+# associating the Options with the actual model
+admin.site.register(Route,RouteAdmin)
+
diff --git a/apps/locations/models.py b/apps/locations/models.py
index 47c5d65..e088697 100644
--- a/apps/locations/models.py
+++ b/apps/locations/models.py
@@ -159,6 +159,25 @@ class Location(models.Model):
def __unicode__(self): return self.name
+class Route(models.Model):
+ name = models.CharField(max_length=200)
+ slug = models.SlugField()
+ zoom = models.CharField(max_length=2, null=True)
+ template_var_name = models.CharField(max_length=10, null=True)
+ pub_date = models.DateTimeField('Date published',null=True)
+ # GeoDjango specific Polygon Field and GeoManager
+ geometry = models.MultiPointField(srid=4326)
+ # GeoManager, a subclass that adds a rich set of geospatial queryset methods
+ objects = models.GeoManager()
+
+ def get_absolute_url(self):
+ return "/locations/%s/%s/%s/" % (self.slug)
+
+
+ def __unicode__(self): return self.name
+
+
+
class WritingbyLocationSitemap(Sitemap):
changefreq = "weekly"
priority = 0.6
diff --git a/apps/locations/urls.py b/apps/locations/urls.py
index 2cad114..c49e684 100644
--- a/apps/locations/urls.py
+++ b/apps/locations/urls.py
@@ -2,6 +2,6 @@ from django.conf.urls.defaults import *
from django.views.generic.simple import redirect_to,direct_to_template
urlpatterns = patterns('',
- #(r'(?P<slug>[0-9a-zA-Z_.-]+)/$', 'locations.views.list_view_region'),
+ (r'data/(?P<id>\d+)/$', 'locations.views.data_json'),
(r'^$', direct_to_template, {'template': 'archives/map.html'}),
)
diff --git a/apps/locations/views.py b/apps/locations/views.py
index a59a2e5..f360429 100644
--- a/apps/locations/views.py
+++ b/apps/locations/views.py
@@ -2,10 +2,24 @@ from django.shortcuts import render_to_response,get_object_or_404
from django.template import RequestContext
from blog.models import Entry
-from locations.models import Location, Country, Region
+from locations.models import Location, Country, Region, Route
def list_view(request):
- qs = Entry.objects.filter(status__exact=1)
- cl = Country.objects.filter(visited=True).exclude(name='default')
- rl = Region.objects.all()
- return render_to_response('archives/map.html', {'object_list': qs,'country_list':cl,'region_list':rl}, context_instance=RequestContext(request)) \ No newline at end of file
+ context = {
+ 'object_list' : Entry.objects.filter(status__exact=1),
+ 'country_list' : Country.objects.filter(visited=True).exclude(name='default'),
+ 'region_list' : Region.objects.all()
+ }
+ return render_to_response('archives/map.html', context, context_instance=RequestContext(request))
+
+from projects.shortcuts import render_to_geojson
+
+def data_json(request, id):
+ qs = Route.objects.filter(pk=id)
+ return render_to_geojson(
+ qs,
+ included_fields=['id',],
+ geom_attribute='geometry',
+ mimetype = 'application/json',
+ pretty_print=True
+ ) \ No newline at end of file
diff --git a/apps/photos/views.py b/apps/photos/views.py
index 861f00e..a1e3459 100644
--- a/apps/photos/views.py
+++ b/apps/photos/views.py
@@ -26,7 +26,7 @@ def gallery(request,slug):
context = {
'object': PhotoGallery.objects.get(set_slug=slug)
}
- render_to_response('details/photo_galleries.html', context, context_instance = RequestContext(request))
+ return render_to_response('details/photo_galleries.html', context, context_instance = RequestContext(request))
def photo_json(request, slug):
p = PhotoGallery.objects.filter(set_slug=slug)