]> git.sommitrealweird.co.uk Git - sommitrealweird.git/blobdiff - sommitrealweird/bpcms/context_processors.py
Only use live items in the rss/atom blog feed
[sommitrealweird.git] / sommitrealweird / bpcms / context_processors.py
index b464307381ffc634e3bc542d6d362dec1df48cfd..c235c9b31e39db17b27da878d49a7eabada45517 100644 (file)
@@ -1,34 +1,39 @@
 from bpcms.models import Document, Folder
 from django.conf import settings
 from bpcms.models import Document, Folder
 from django.conf import settings
+from django.core.cache import cache
 import re
 
 def content_menu(request):
 import re
 
 def content_menu(request):
-    items = Document.objects.filter(folder__isnull=True, islive__exact=True)
-    menu_items = []
-    for item in items:
-        if item.slug != 'index':
-            menu_items.append(
-                {
-                    'title': item.title,
-                    'url': item.get_basic_url(),
-                }
-            )
-    folders = Folder.objects.filter(parent__isnull=True)
-    for folder in folders:
-        try:
-            items = Document.objects.filter(folder__exact=folder, islive__exact=True, slug__exact='index')
-            item = items[0]
-            menu_items.append(
-                {
-                    'title': item.title,
-                    'url': folder.get_basic_url(),
-                }
-            )
-        except:
-            pass
+    menu_items = cache.get('bpcms_mainmenu')
+
+    if not menu_items:
+        items = Document.objects.filter(folder__isnull=True, islive__exact=True)
+        menu_items = []
+        for item in items:
+            if item.slug != 'index':
+                menu_items.append(
+                    {
+                        'title': item.title,
+                        'url': item.get_absolute_url(),
+                    }
+                )
+        folders = Folder.objects.filter(parent__isnull=True)
+        for folder in folders:
+            try:
+                items = Document.objects.filter(folder__exact=folder, islive__exact=True, slug__exact='index')
+                item = items[0]
+                menu_items.append(
+                    {
+                        'title': item.title,
+                        'url': folder.get_absolute_url(),
+                    }
+                )
+            except:
+                pass
 
 
-    menu_items.sort( \
-        cmp=lambda x,y: cmp(x['title'].lower(), y['title'].lower()))
+        menu_items.sort( \
+            cmp=lambda x,y: cmp(x['title'].lower(), y['title'].lower()))
+        cache.set('bpcms_mainmenu', menu_items, 3600)
 
     return {
         'content_menu': menu_items,
 
     return {
         'content_menu': menu_items,
@@ -40,6 +45,65 @@ def content_submenu(request):
     folderpath = re.sub(u'^%s' %(settings.BPCMS_ROOT), '', folderpath)
     # right - that should be any prefix got rid of, now traverse the tree till
     # we've got something
     folderpath = re.sub(u'^%s' %(settings.BPCMS_ROOT), '', folderpath)
     # right - that should be any prefix got rid of, now traverse the tree till
     # we've got something
+    menu_items = cache.get('bpcms_contentmenu_%s' %(folderpath))
+
+    if not menu_items:
+        folder = None
+        folderpath = folderpath.split('/')
+        for part in folderpath:
+            try:
+                if folder:
+                    f = Folder.objects.get(parent__exact=folder, slug__exact=part)
+                else:
+                    f = Folder.objects.get(parent__isnull=True, slug__exact=part)
+                folder = f
+            except:
+                break
+
+        # We have the folder (in theory)
+        menu_items = []
+        if folder:
+            items = Document.objects.filter(folder__exact=folder, \
+                islive__exact=True)
+            for item in items:
+                if item.slug != 'index':
+                    menu_items.append(
+                        {
+                            'title': item.title,
+                            'url': item.get_absolute_url(),
+                        }
+                    )
+            folders = Folder.objects.filter(parent__exact=folder)
+            for folder in folders:
+                items = Document.objects.filter(folder__exact=folder, \
+                    islive__exact=True, slug__exact='index')
+                for item in items:
+                    menu_items.append(
+                        {
+                            'title': item.title,
+                            'url': folder.get_absolute_url(),
+                        }
+                    )
+
+        menu_items.sort( \
+            cmp=lambda x,y: cmp(x['title'].lower(), y['title'].lower()))
+
+        cache.set('bpcms_contentmenu_%s' %(folderpath), menu_items)
+
+    return {
+        'content_submenu': menu_items,
+    }
+
+def content_breadcrumb(request):
+    if settings.BPCMS_ROOT == "/":
+        breadcrumb = [{'url': settings.BPCMS_ROOT, 'title': "Home"}]
+    else:
+        breadcrumb = [{'url': settings.BPCMS_ROOT, 'title': settings.BPCMS_ROOT},]
+    # find where we are in the tree first
+    folderpath = request.path
+    folderpath = re.sub(u'^%s' %(settings.BPCMS_ROOT), '', folderpath)
+    # right - that should be any prefix got rid of, now traverse the tree till
+    # we've got something
     folder = None
     folderpath = folderpath.split('/')
     for part in folderpath:
     folder = None
     folderpath = folderpath.split('/')
     for part in folderpath:
@@ -49,43 +113,29 @@ def content_submenu(request):
             else:
                 f = Folder.objects.get(parent__isnull=True, slug__exact=part)
             folder = f
             else:
                 f = Folder.objects.get(parent__isnull=True, slug__exact=part)
             folder = f
+            try:
+                item = Document.objects.get(folder__exact=folder,
+                    slug__exact=u'index', islive__exact=True)
+                breadcrumb.append({'url': folder.get_absolute_url(),
+                    'title': item.title})
+            except:
+                breadcrumb.append({'url': folder.get_absolute_url(),
+                    'title': folder.title})
         except:
         except:
-            break
-
-    # We have the folder (in theory)
-    menu_items = []
-    if folder:
-        items = Document.objects.filter(folder__exact=folder, \
-            islive__exact=True)
-        for item in items:
-            if item.slug != 'index':
-                menu_items.append(
-                    {
-                        'title': item.title,
-                        'url': item.get_basic_url(),
-                    }
-                )
-        try:
-            folders = Folder.objects.filter(parent__exact=folder)
-        except:
-            pass
-        for folder in folders:
+            # must have hit the end of the tree, lets see if we can get an
+            # item...
             try:
             try:
-                items = Document.objects.filter(folder__exact=folder, \
-                    islive__exact=True, slug__exact='index')
-                for item in items:
-                    menu_items.append(
-                        {
-                            'title': item.title,
-                            'url': folder.get_basic_url(),
-                        }
-                    )
+                if folder:
+                    item = Document.objects.get(folder__exact=folder, \
+                        slug__exact=part, islive__exact=True)
+                else:
+                    item = Document.objects.get(folder__isnull=True, \
+                        slug__exact=part, islive__exact=True)
+                breadcrumb.append({'url': item.get_absolute_url(), 'title': item.title})
             except:
                 pass
             except:
                 pass
-
-    menu_items.sort( \
-        cmp=lambda x,y: cmp(x['title'].lower(), y['title'].lower()))
+            break
 
     return {
 
     return {
-        'content_submenu': menu_items,
+        'content_breadcrumb': breadcrumb,
     }
     }