230 lines
7.7 KiB
Python
230 lines
7.7 KiB
Python
# Society Self-Service
|
|
# Copyright © 2018-2019 Yingtong Li (RunasSudo)
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
from django.contrib.auth.decorators import login_required
|
|
|
|
from django.http import HttpResponse
|
|
from django.shortcuts import render, redirect
|
|
from django.urls import reverse
|
|
from django.utils import timezone
|
|
|
|
from . import models
|
|
|
|
import datetime
|
|
|
|
@login_required
|
|
def index(request):
|
|
return render(request, 'sspromotions/index.html')
|
|
|
|
@login_required
|
|
def bulletin_list(request):
|
|
items_past = []
|
|
items_upcoming = []
|
|
items_future = []
|
|
|
|
dtbegin = timezone.now().date()
|
|
dtend = dtbegin + datetime.timedelta(days=7)
|
|
|
|
for item in models.BulletinItem.objects.all():
|
|
if not item.group.can_user_access(request.user):
|
|
continue
|
|
|
|
if item.date >= dtbegin and item.date < dtend:
|
|
items_upcoming.append(item)
|
|
elif item.date >= dtend:
|
|
items_future.append(item)
|
|
else:
|
|
items_past.append(item)
|
|
|
|
return render(request, 'sspromotions/bulletin_list.html', {
|
|
'items_past': items_past,
|
|
'items_upcoming': items_upcoming,
|
|
'items_future': items_future
|
|
})
|
|
|
|
@login_required
|
|
def bulletin_preview(request):
|
|
calbegin = timezone.now().date() + datetime.timedelta(days=1) # Start tomorrow for calendar
|
|
calend = calbegin + datetime.timedelta(days=14)
|
|
|
|
bulbegin = timezone.now().date()
|
|
bulend = bulbegin + datetime.timedelta(days=7)
|
|
|
|
return render(request, 'sspromotions/email/bulletin.html', {
|
|
'events': models.CalendarItem.objects.filter(date__gte=calbegin).filter(date__lt=calend).all(),
|
|
'groups': models.Group.objects.all(),
|
|
'more': [],
|
|
'bulbegin': bulbegin,
|
|
'bulend': bulend
|
|
})
|
|
|
|
@login_required
|
|
def bulletin_new(request):
|
|
if request.method == 'POST':
|
|
item = models.BulletinItem()
|
|
item.group = models.Group.objects.get(id=int(request.POST['group']))
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
item.title = request.POST['title']
|
|
item.date = request.POST['date']
|
|
item.content = request.POST['content']
|
|
item.link = request.POST['link']
|
|
if request.FILES:
|
|
item.image = request.FILES['image']
|
|
item.also_limit = [int(k[11:]) for k, v in request.POST.items() if k.startswith('also_limit_') and v]
|
|
item.save()
|
|
|
|
if request.POST['submit'] == 'Save':
|
|
return redirect(reverse('bulletin_list'))
|
|
else:
|
|
return redirect(reverse('bulletin_edit', kwargs={'id': item.id}))
|
|
else:
|
|
item = models.BulletinItem()
|
|
item.date = timezone.now().date()
|
|
item.date += datetime.timedelta(days=(6 - item.date.weekday() + 7) % 7) # Next Sunday (6 = Sunday)
|
|
return render(request, 'sspromotions/bulletin_edit.html', {
|
|
'item': item,
|
|
'groups': [group for group in models.Group.objects.all() if group.can_user_access(request.user)],
|
|
'all_groups': models.Group.objects.all()
|
|
})
|
|
|
|
@login_required
|
|
def bulletin_edit(request, id):
|
|
if request.method == 'POST':
|
|
item = models.BulletinItem.objects.get(id=id)
|
|
item.group = models.Group.objects.get(id=int(request.POST['group']))
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
item.title = request.POST['title']
|
|
item.date = request.POST['date']
|
|
item.content = request.POST['content']
|
|
item.link = request.POST['link']
|
|
if request.FILES:
|
|
item.image = request.FILES['image']
|
|
item.also_limit = [int(k[11:]) for k, v in request.POST.items() if k.startswith('also_limit_') and v]
|
|
item.save()
|
|
|
|
if request.POST['submit'] == 'Save':
|
|
return redirect(reverse('bulletin_list'))
|
|
else:
|
|
return redirect(reverse('bulletin_edit', kwargs={'id': item.id}))
|
|
else:
|
|
item = models.BulletinItem.objects.get(id=id)
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
return render(request, 'sspromotions/bulletin_edit.html', {
|
|
'item': item,
|
|
'groups': [group for group in models.Group.objects.all() if group.can_user_access(request.user)],
|
|
'all_groups': models.Group.objects.all()
|
|
})
|
|
|
|
@login_required
|
|
def bulletin_delete(request, id):
|
|
item = models.BulletinItem.objects.get(id=id)
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
item.delete()
|
|
|
|
return redirect(reverse('bulletin_list'))
|
|
|
|
@login_required
|
|
def calendar_list(request):
|
|
items_past = []
|
|
items_upcoming = []
|
|
items_future = []
|
|
|
|
dtbegin = timezone.now().date() + datetime.timedelta(days=1) # Start tomorrow for calendar
|
|
dtend = dtbegin + datetime.timedelta(days=14)
|
|
|
|
for item in models.CalendarItem.objects.all():
|
|
if not item.group.can_user_access(request.user):
|
|
continue
|
|
|
|
if item.date >= dtbegin and item.date < dtend:
|
|
items_upcoming.append(item)
|
|
elif item.date >= dtend:
|
|
items_future.append(item)
|
|
else:
|
|
items_past.append(item)
|
|
|
|
return render(request, 'sspromotions/calendar_list.html', {
|
|
'items_past': items_past,
|
|
'items_upcoming': items_upcoming,
|
|
'items_future': items_future
|
|
})
|
|
|
|
@login_required
|
|
def calendar_new(request):
|
|
if request.method == 'POST':
|
|
item = models.CalendarItem()
|
|
item.group = models.Group.objects.get(id=int(request.POST['group']))
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
item.title = request.POST['title']
|
|
item.date = request.POST['date']
|
|
item.link = request.POST['link']
|
|
item.also_limit = [int(k[11:]) for k, v in request.POST.items() if k.startswith('also_limit_') and v]
|
|
item.save()
|
|
|
|
if request.POST['submit'] == 'Save':
|
|
return redirect(reverse('calendar_list'))
|
|
else:
|
|
return redirect(reverse('calendar_edit', kwargs={'id': item.id}))
|
|
else:
|
|
item = models.CalendarItem()
|
|
item.date = timezone.now()
|
|
return render(request, 'sspromotions/calendar_edit.html', {
|
|
'item': item,
|
|
'groups': [group for group in models.Group.objects.all() if group.can_user_access(request.user)],
|
|
'all_groups': models.Group.objects.all()
|
|
})
|
|
|
|
@login_required
|
|
def calendar_edit(request, id):
|
|
if request.method == 'POST':
|
|
item = models.CalendarItem.objects.get(id=id)
|
|
item.group = models.Group.objects.get(id=int(request.POST['group']))
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
item.title = request.POST['title']
|
|
item.date = request.POST['date']
|
|
item.link = request.POST['link']
|
|
item.also_limit = [int(k[11:]) for k, v in request.POST.items() if k.startswith('also_limit_') and v]
|
|
item.save()
|
|
|
|
if request.POST['submit'] == 'Save':
|
|
return redirect(reverse('calendar_list'))
|
|
else:
|
|
return redirect(reverse('calendar_edit', kwargs={'id': item.id}))
|
|
else:
|
|
item = models.CalendarItem.objects.get(id=id)
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
return render(request, 'sspromotions/calendar_edit.html', {
|
|
'item': item,
|
|
'groups': [group for group in models.Group.objects.all() if group.can_user_access(request.user)],
|
|
'all_groups': models.Group.objects.all()
|
|
})
|
|
|
|
@login_required
|
|
def calendar_delete(request, id):
|
|
item = models.CalendarItem.objects.get(id=id)
|
|
if not item.group.can_user_access(request.user):
|
|
return HttpResponse('Unauthorized', status=401)
|
|
item.delete()
|
|
|
|
return redirect(reverse('calendar_list'))
|