1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
from itertools import chain
import json
from django.urls import reverse
from django.http import Http404, HttpResponse
from django.views.generic import ListView, DetailView
from django.apps import apps
from django.shortcuts import render
from django.template import RequestContext
from media.models import LuxImage, LuxVideo, LuxAudio
from recordings.models import Audio
BREADCRUMBS = {
'SrcPost':'SRC',
'AP':'dialogue',
'Book':'Book Notes',
'Entry':'Jrnl',
'NewsletterMailing':'lttr',
'LuxImage':'lttr',
'Sighting':'dialogue'
}
class PaginatedListView(ListView):
"""
handles my own pagination system and breadcrumbs
"""
context_object_name = 'object_list'
def dispatch(self, request, *args, **kwargs):
path = request.path.split('/')[1:-1]
if path[-1] == self.kwargs['page']:
path = "/".join(t for t in path[:-1])
request.page_url = "/" + path + '/%d/'
else:
request.page_url = request.path + '%d/'
request.page = int(self.kwargs['page'])
request.base_path = path
return super(PaginatedListView, self).dispatch(request, *args, **kwargs)
def get_context_data(self, **kwargs):
'''
Adds breadcrumb path to every view
'''
# Call the base implementation first to get a context
context = super(PaginatedListView, self).get_context_data(**kwargs)
print('model=', self.model)
try:
context['breadcrumbs'] = (BREADCRUMBS[self.model.__name__],)
except KeyError:
context['breadcrumbs'] = (self.model._meta.verbose_name_plural,)
return context
class LuxDetailView(DetailView):
"""
handles breadcrumbs for detail pages
"""
def get_context_data(self, **kwargs):
'''
Adds breadcrumb path to every view
'''
# Call the base implementation first to get a context
context = super(LuxDetailView, self).get_context_data(**kwargs)
print(self.object._meta.verbose_name_plural)
try:
context['breadcrumbs'] = (BREADCRUMBS[self.object._meta.label.split(".")[1]],)
except KeyError:
if self.object._meta.verbose_name_plural == 'posts':
if self.object.get_post_type_display() != 'src':
context['breadcrumbs'] = (self.object.get_post_type_display()+"s",)
else:
context['breadcrumbs'] = (self.object.get_post_type_display(),)
context['crumb_url'] = "/%ss/" % self.object.get_post_type_display()
else:
context['breadcrumbs'] = (self.object._meta.verbose_name_plural,)
try:
context['crumb_url']
except KeyError:
try:
context['crumb_url'] = reverse('%s:list' % slugify(self.object._meta.verbose_name_plural))
except:
# special case for books:
if self.object._meta.verbose_name_plural == 'books':
context['crumb_url'] = reverse('books:list')
elif self.object._meta.verbose_name_plural == 'Animal/Plant':
context['crumb_url'] = reverse('sightings:list')
else:
# special case for pages:
context['breadcrumbs'] = (self.object.title,)
context['crumb_url'] = None
return context
def insert_image(request):
"""
The view that handles the admin insert image/video feature
"""
images = LuxImage.objects.all()[:80]
videos = LuxVideo.objects.all()[:10]
audio = LuxAudio.objects.all()[:40]
object_list = sorted(
chain(images, videos, audio),
key=lambda instance: instance.pub_date,
reverse=True
)
return render(request, 'admin/insert_images.html', {'object_list': object_list, 'textarea_id': request.GET['textarea']})
def nav_json(request, app, model, pk):
model = apps.get_model(app_label=app, model_name=model)
p = model.objects.get(pk=pk)
data = {}
data['prev'] = p.get_previous_admin_url
data['next'] = p.get_next_admin_url
data = json.dumps(data)
return HttpResponse(data)
|