diff options
author | luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f <luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f> | 2009-11-12 21:58:26 +0000 |
---|---|---|
committer | luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f <luxagraf@c63593aa-01b0-44d9-8516-4b9c7e931d7f> | 2009-11-12 21:58:26 +0000 |
commit | b0464d2bcb252c8d2cef9dfca9dd7b40ec498c55 (patch) | |
tree | f39715fefd2828fd794a25fcf5301ed1ffd14ce0 /apps | |
parent | c9022d38a303dcd756d34a2cbc4e3c49b22e0cf2 (diff) |
speed optimizations
Diffstat (limited to 'apps')
-rw-r--r-- | apps/blog/admin.py | 11 | ||||
-rw-r--r-- | apps/blog/models.py | 9 | ||||
-rw-r--r-- | apps/blog/signals.py | 34 | ||||
-rw-r--r-- | apps/blog/views.py | 14 | ||||
-rw-r--r-- | apps/links/models.py | 2 | ||||
-rw-r--r-- | apps/locations/urls.py | 3 | ||||
-rw-r--r-- | apps/photos/views.py | 7 |
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') """ |