Files
@ f4c4009c4db3
Branch filter:
Location: symposion_app/symposion/schedule/views.py - annotation
f4c4009c4db3
6.5 KiB
text/x-python
Merge pull request #64 from codersquid/json_placeholders
adds placeholder values for future model changes to ProposalBase
adds placeholder values for future model changes to ProposalBase
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 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 | 51709c6eaf39 51709c6eaf39 51709c6eaf39 b48d66fd9de6 db908372fffb b48d66fd9de6 0a4e626dfe9b d6a59f2e4f3b 51709c6eaf39 d6a59f2e4f3b db908372fffb 13bc9ffacb95 7601791e8cd0 0a4e626dfe9b 0a4e626dfe9b 1b2cdeffb0e9 0a4e626dfe9b 36ab6d599ffc bec6903ca1c9 1b3ef8d4247d 1b3ef8d4247d 0a4e626dfe9b 0a4e626dfe9b 0a4e626dfe9b 0a4e626dfe9b 1b2cdeffb0e9 36ab6d599ffc 1b2cdeffb0e9 1b2cdeffb0e9 1b2cdeffb0e9 2a68242a5482 36ab6d599ffc c7592bc33e26 36ab6d599ffc 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 36ab6d599ffc 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 2a68242a5482 1b2cdeffb0e9 36ab6d599ffc 1b2cdeffb0e9 c7592bc33e26 c7592bc33e26 36ab6d599ffc 6a1e59812adf 6a1e59812adf 36ab6d599ffc 0a4e626dfe9b 0a4e626dfe9b 6a1e59812adf 0a4e626dfe9b 7601791e8cd0 0a4e626dfe9b 0a4e626dfe9b 1b2cdeffb0e9 1b2cdeffb0e9 36ab6d599ffc 1b2cdeffb0e9 d98f9b82a85b 36ab6d599ffc 13bc9ffacb95 c47907b29ee5 13bc9ffacb95 13bc9ffacb95 13bc9ffacb95 13bc9ffacb95 13bc9ffacb95 b48d66fd9de6 b48d66fd9de6 36ab6d599ffc b48d66fd9de6 b48d66fd9de6 36ab6d599ffc b48d66fd9de6 b48d66fd9de6 b48d66fd9de6 b48d66fd9de6 b48d66fd9de6 b48d66fd9de6 36ab6d599ffc b48d66fd9de6 b48d66fd9de6 36ab6d599ffc b48d66fd9de6 b48d66fd9de6 b48d66fd9de6 b48d66fd9de6 d6a59f2e4f3b 0a4e626dfe9b 36ab6d599ffc d6a59f2e4f3b d6a59f2e4f3b 36ab6d599ffc 1b2cdeffb0e9 36ab6d599ffc f3e9cc9a5db3 f3e9cc9a5db3 0a4e626dfe9b 0a4e626dfe9b f3e9cc9a5db3 0a4e626dfe9b 7601791e8cd0 db908372fffb db908372fffb d6a59f2e4f3b 1b2cdeffb0e9 36ab6d599ffc d6a59f2e4f3b d6a59f2e4f3b 36ab6d599ffc 1b2cdeffb0e9 36ab6d599ffc 7c102aefa3a5 19d826ad00de 7c102aefa3a5 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 19d826ad00de 4461c2f5102f 7c102aefa3a5 19d826ad00de 7c102aefa3a5 1b2cdeffb0e9 7c102aefa3a5 7c102aefa3a5 7c102aefa3a5 7c102aefa3a5 1b3ef8d4247d 1b3ef8d4247d 1b3ef8d4247d 36ab6d599ffc 1b3ef8d4247d 97e1086b1d74 97e1086b1d74 97e1086b1d74 97e1086b1d74 36ab6d599ffc 1b3ef8d4247d 1b3ef8d4247d 97e1086b1d74 1b3ef8d4247d 1b3ef8d4247d c4db94b7e5fd c4db94b7e5fd c4db94b7e5fd 0ebcc2f1247a 0ebcc2f1247a 0ebcc2f1247a 0ebcc2f1247a 51709c6eaf39 51709c6eaf39 c4db94b7e5fd c4db94b7e5fd 51709c6eaf39 51709c6eaf39 51709c6eaf39 2b91a7296ccf 2b91a7296ccf 51709c6eaf39 51709c6eaf39 51709c6eaf39 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 2c97ec710662 51709c6eaf39 51709c6eaf39 51709c6eaf39 c4db94b7e5fd c4db94b7e5fd 51709c6eaf39 51709c6eaf39 51709c6eaf39 c4db94b7e5fd c4db94b7e5fd 2c97ec710662 51709c6eaf39 c4db94b7e5fd c4db94b7e5fd c4db94b7e5fd 2b91a7296ccf 51709c6eaf39 c4db94b7e5fd 51709c6eaf39 51709c6eaf39 51709c6eaf39 c4db94b7e5fd c4db94b7e5fd c4db94b7e5fd c4db94b7e5fd c4db94b7e5fd c4db94b7e5fd | import json
from django.core.urlresolvers import reverse
from django.http import Http404, HttpResponse
from django.shortcuts import render, get_object_or_404, redirect
from django.template import loader, Context
from django.contrib.auth.decorators import login_required
from django.contrib.sites.models import Site
from symposion.schedule.forms import SlotEditForm
from symposion.schedule.models import Schedule, Day, Slot, Presentation
from symposion.schedule.timetable import TimeTable
def fetch_schedule(slug):
qs = Schedule.objects.all()
if slug is None:
if qs.count() > 1:
raise Http404()
schedule = next(iter(qs), None)
if schedule is None:
raise Http404()
else:
schedule = get_object_or_404(qs, section__slug=slug)
return schedule
def schedule_conference(request):
schedules = Schedule.objects.filter(published=True, hidden=False)
sections = []
for schedule in schedules:
days_qs = Day.objects.filter(schedule=schedule)
days = [TimeTable(day) for day in days_qs]
sections.append({
"schedule": schedule,
"days": days,
})
ctx = {
"sections": sections,
}
return render(request, "schedule/schedule_conference.html", ctx)
def schedule_detail(request, slug=None):
schedule = fetch_schedule(slug)
if not schedule.published and not request.user.is_staff:
raise Http404()
days_qs = Day.objects.filter(schedule=schedule)
days = [TimeTable(day) for day in days_qs]
ctx = {
"schedule": schedule,
"days": days,
}
return render(request, "schedule/schedule_detail.html", ctx)
def schedule_list(request, slug=None):
schedule = fetch_schedule(slug)
presentations = Presentation.objects.filter(section=schedule.section)
presentations = presentations.exclude(cancelled=True)
ctx = {
"schedule": schedule,
"presentations": presentations,
}
return render(request, "schedule/schedule_list.html", ctx)
def schedule_list_csv(request, slug=None):
schedule = fetch_schedule(slug)
presentations = Presentation.objects.filter(section=schedule.section)
presentations = presentations.exclude(cancelled=True).order_by("id")
response = HttpResponse(mimetype="text/csv")
if slug:
file_slug = slug
else:
file_slug = "presentations"
response["Content-Disposition"] = 'attachment; filename="%s.csv"' % file_slug
response.write(loader.get_template("schedule/schedule_list.csv").render(Context({
"presentations": presentations,
})))
return response
@login_required
def schedule_edit(request, slug=None):
if not request.user.is_staff:
raise Http404()
schedule = fetch_schedule(slug)
days_qs = Day.objects.filter(schedule=schedule)
days = [TimeTable(day) for day in days_qs]
ctx = {
"schedule": schedule,
"days": days,
}
return render(request, "schedule/schedule_edit.html", ctx)
@login_required
def schedule_slot_edit(request, slug, slot_pk):
if not request.user.is_staff:
raise Http404()
slot = get_object_or_404(Slot, day__schedule__section__slug=slug, pk=slot_pk)
if request.method == "POST":
form = SlotEditForm(request.POST, slot=slot)
if form.is_valid():
save = False
if "content_override" in form.cleaned_data:
slot.content_override = form.cleaned_data["content_override"]
save = True
if "presentation" in form.cleaned_data:
presentation = form.cleaned_data["presentation"]
if presentation is None:
slot.unassign()
else:
slot.assign(presentation)
if save:
slot.save()
return redirect("schedule_edit", slug)
else:
form = SlotEditForm(slot=slot)
ctx = {
"slug": slug,
"form": form,
"slot": slot,
}
return render(request, "schedule/_slot_edit.html", ctx)
def schedule_presentation_detail(request, pk):
presentation = get_object_or_404(Presentation, pk=pk)
if presentation.slot:
schedule = presentation.slot.day.schedule
else:
schedule = None
ctx = {
"presentation": presentation,
"schedule": schedule,
}
return render(request, "schedule/presentation_detail.html", ctx)
def schedule_json(request):
slots = Slot.objects.filter(
day__schedule__published=True,
day__schedule__hidden=False
).order_by("start")
protocol = request.META.get('HTTP_X_FORWARDED_PROTO', 'http')
data = []
for slot in slots:
slot_data = {
"room": ", ".join(room["name"] for room in slot.rooms.values()),
"rooms": [room["name"] for room in slot.rooms.values()],
"start": slot.start_datetime.isoformat(),
"end": slot.end_datetime.isoformat(),
"duration": slot.length_in_minutes,
"kind": slot.kind.label,
"section": slot.day.schedule.section.slug,
"conf_key": slot.pk,
# TODO: models should be changed.
# these are model features from other conferences that have forked symposion
# these have been used almost everywhere and are good candidates for
# base proposals
"license": "CC BY",
"tags": "",
"released": True,
"contact": [],
}
if hasattr(slot.content, "proposal"):
slot_data.update({
"name": slot.content.title,
"authors": [s.name for s in slot.content.speakers()],
"contact": [
s.email for s in slot.content.speakers()
] if request.user.is_staff else ["redacted"],
"abstract": slot.content.abstract.raw,
"description": slot.content.description.raw,
"conf_url": "%s://%s%s" % (
protocol,
Site.objects.get_current().domain,
reverse("schedule_presentation_detail", args=[slot.content.pk])
),
"cancelled": slot.content.cancelled,
})
else:
slot_data.update({
"name": slot.content_override.raw if slot.content_override else "Slot",
})
data.append(slot_data)
return HttpResponse(
json.dumps({'schedule': data}),
content_type="application/json"
)
|