summaryrefslogtreecommitdiff
path: root/apps
diff options
context:
space:
mode:
authorluxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f <luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f>2009-11-12 21:58:26 +0000
committerluxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f <luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f>2009-11-12 21:58:26 +0000
commitb0464d2bcb252c8d2cef9dfca9dd7b40ec498c55 (patch)
treef39715fefd2828fd794a25fcf5301ed1ffd14ce0 /apps
parentc9022d38a303dcd756d34a2cbc4e3c49b22e0cf2 (diff)
speed optimizations
Diffstat (limited to 'apps')
-rw-r--r--apps/blog/admin.py11
-rw-r--r--apps/blog/models.py9
-rw-r--r--apps/blog/signals.py34
-rw-r--r--apps/blog/views.py14
-rw-r--r--apps/links/models.py2
-rw-r--r--apps/locations/urls.py3
-rw-r--r--apps/photos/views.py7
7 files changed, 55 insertions, 25 deletions
diff --git a/apps/blog/admin.py b/apps/blog/admin.py
index d641b5b..78ad458 100644
--- a/apps/blog/admin.py
+++ b/apps/blog/admin.py
@@ -17,16 +17,19 @@ class EntryAdmin(OSMGeoAdmin):
else:
field = super(EntryAdmin,self).formfield_for_dbfield(db_field,**kwargs)
return field
- list_display = ('title', 'pub_date','enable_comments', 'status','region','location')
+ list_display = ('title', 'pub_date','enable_comments', 'status','region','location','photo_gallery')
search_fields = ['title', 'body_markdown']
prepopulated_fields = {"slug" : ('title',)}
list_filter = ('pub_date', 'enable_comments', 'status','region','location')
fieldsets = (
- ('Entry', {'fields': ('title','body_markdown', ('location','region'), 'pub_date', ('status','enable_comments'), 'tags', 'slug'), 'classes': ('show','extrapretty','wide')}),
+ ('Entry', {'fields': ('title','body_markdown', ('location','region'), 'pub_date', ('status','enable_comments'), 'tags', 'slug','photo_gallery'), 'classes': ('show','extrapretty','wide')}),
('Pub Location', {'fields': ('point',('thumbnail',),'dek', 'title_keywords'), 'classes': ('collapse', 'wide')}),
)
- extra_js = [GMAP.api_url + GMAP.key]
- map_template = 'gis/admin/google.html'
+
+ class Media:
+ js = ['/media/admin/custom/model.js']
+ #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:
diff --git a/apps/blog/models.py b/apps/blog/models.py
index 5093f5b..7ad415c 100644
--- a/apps/blog/models.py
+++ b/apps/blog/models.py
@@ -13,9 +13,10 @@ from tagging.models import Tag
from photos.models import PhotoGallery
from locations.models import Location,Region
#from locations.signals import create_location_item
+from blog.signals import update_recent
def get_upload_path(self, filename):
- return "images/post-thumbs/heloo/%s/%s" %(datetime.datetime.today().strftime("%Y"), filename)
+ return "images/post-thumbs/%s/%s" %(datetime.datetime.today().strftime("%Y"), filename)
def markdown_processor(md):
processed = markdown.markdown(md, safe_mode = False).split('<break>')
@@ -109,4 +110,8 @@ class LatestFull(Feed):
return Entry.objects.filter(status__exact=1).order_by('-pub_date')[:10]
-#signals.post_save.connect(create_location_item, sender=Entry) \ No newline at end of file
+from django.dispatch import dispatcher
+from django.db.models import signals
+
+signals.post_save.connect(update_recent, sender=Entry)
+
diff --git a/apps/blog/signals.py b/apps/blog/signals.py
new file mode 100644
index 0000000..0f3c9c4
--- /dev/null
+++ b/apps/blog/signals.py
@@ -0,0 +1,34 @@
+from django.template.loader import render_to_string
+from django.conf import settings
+from django.template import Context
+from django.db.models import get_model
+
+from locations.models import Region,Country
+
+def update_recent(sender, instance, signal, *args, **kwargs):
+ # Update recent entries static file
+ model = get_model('blog', 'entry')
+ qs = {'object_list': model.objects.filter(status__exact=1).order_by('-pub_date')[1:6]}
+ c = Context(qs)
+ t = render_to_string('includes/recent_entries_template.html',c)
+ fpath = '%s%s' %(settings.PROJ_ROOT,'templates/includes/recent_entries.html')
+ file = open(fpath, 'w')
+ file.write(t)
+ file.close()
+ # Update map template
+ import codecs
+ 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})
+ t = render_to_string('includes/map_entry_list_template.html',c)
+ fpath = '%s%s' %(settings.PROJ_ROOT,'templates/includes/map_entry_list.html')
+ file = codecs.open(fpath, 'w','utf8')
+ file.write(t)
+ file.close()
+ c = Context({'country_list':cl,'region_list':rl})
+ 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')
+ file.write(t)
+ file.close() \ No newline at end of file
diff --git a/apps/blog/views.py b/apps/blog/views.py
index 9641813..6ccdc28 100644
--- a/apps/blog/views.py
+++ b/apps/blog/views.py
@@ -9,10 +9,9 @@ from blog.models import Entry
from locations.models import Region, Country
def home(request):
- featured = Entry.objects.filter(status__exact=1).order_by('-pub_date')[:1].get()
+ featured = Entry.objects.filter(status__exact=1).latest()
context = {
'featured': featured,
- 'object_list': Entry.objects.all().exclude(id=featured.id).order_by('-pub_date')[:5],
}
return render_to_response('archives/homepage.html', context, context_instance = RequestContext(request))
@@ -32,13 +31,8 @@ List of all writing
def entry_list(request,page):
request.page_url = '/writing/%d/'
request.page = int(page)
- qs = Entry.objects.filter(status__exact=1).order_by('-pub_date')
- context = {
- 'country_list': Country.objects.filter(visited=True),
- 'region_list': Region.objects.all()
- }
- return object_list(request, queryset=qs, template_name='archives/writing.html',
- extra_context=context)
+ qs = Entry.objects.filter(status__exact=1).order_by('-pub_date').select_related()
+ return object_list(request, queryset=qs, template_name='archives/writing.html')
"""
@@ -57,8 +51,6 @@ def entry_list_by_area(request,slug,page):
raise Http404
context = {
'region': region,
- 'country_list': Country.objects.filter(visited=True),
- 'region_list': Region.objects.all()
}
return object_list(request, queryset=qs, template_name='archives/writing.html',
extra_context=context)
diff --git a/apps/links/models.py b/apps/links/models.py
index 4288351..e8fee43 100644
--- a/apps/links/models.py
+++ b/apps/links/models.py
@@ -26,7 +26,7 @@ class Link(models.Model):
screen_url = models.CharField(max_length=400, blank=True)
rating = models.CharField(max_length=1, choices=RATINGS)
pub_date = models.DateTimeField()
- enable_comments = models.BooleanField(blank=True, null=True)
+ enable_comments = models.NullBooleanField(default=False)
PUB_STATUS = (
(0, 'Private'),
(1, 'Public'),
diff --git a/apps/locations/urls.py b/apps/locations/urls.py
index 669b828..2cad114 100644
--- a/apps/locations/urls.py
+++ b/apps/locations/urls.py
@@ -1,6 +1,7 @@
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'^$', 'locations.views.list_view'),
+ (r'^$', direct_to_template, {'template': 'archives/map.html'}),
)
diff --git a/apps/photos/views.py b/apps/photos/views.py
index 23efbde..43591ca 100644
--- a/apps/photos/views.py
+++ b/apps/photos/views.py
@@ -18,12 +18,7 @@ def gallery_list(request,page):
request.page_url = '/photos/%d/'
request.page = int(page)
qs = PhotoGallery.objects.all().order_by('-id')
- context = {
- 'country_list': Country.objects.filter(visited=True),
- 'region_list': Region.objects.all()
- }
- return object_list(request, queryset=qs, template_name='archives/photos.html',
- extra_context=context)
+ return object_list(request, queryset=qs, template_name='archives/photos.html')
"""