e101fb8212
Conflicts: openslides/agenda/static/styles/agenda.css openslides/agenda/templates/agenda/config.html openslides/agenda/templates/agenda/item_row.html openslides/agenda/templates/agenda/overview.html openslides/locale/de/LC_MESSAGES/django.mo openslides/locale/de/LC_MESSAGES/django.po openslides/static/styles/base.css requirements.txt
268 lines
8.4 KiB
Python
268 lines
8.4 KiB
Python
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
"""
|
|
openslides.agenda.views
|
|
~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Views for the agenda app.
|
|
|
|
:copyright: 2011, 2012 by the OpenSlides team, see AUTHORS.
|
|
:license: GNU GPL, see LICENSE for more details.
|
|
"""
|
|
from reportlab.platypus import Paragraph
|
|
|
|
from django.core.urlresolvers import reverse
|
|
from django.contrib import messages
|
|
from django.db import transaction
|
|
from django.db.models import Model
|
|
from django.utils.translation import ugettext as _, ugettext_lazy
|
|
from django.views.generic.detail import SingleObjectMixin
|
|
|
|
from openslides.config.models import config
|
|
from openslides.agenda.forms import ConfigForm
|
|
from openslides.utils.pdf import stylesheet
|
|
from openslides.utils.views import (
|
|
TemplateView, RedirectView, UpdateView, CreateView, DeleteView, PDFView,
|
|
DetailView, FormView)
|
|
from openslides.utils.template import Tab
|
|
from openslides.utils.utils import html_strong
|
|
from openslides.projector.api import get_active_slide
|
|
from openslides.projector.projector import Widget, SLIDE
|
|
from .models import Item
|
|
from .forms import ItemOrderForm, ItemForm
|
|
from datetime import datetime, timedelta
|
|
|
|
|
|
class Overview(TemplateView):
|
|
"""
|
|
Show all agenda items, and update there range via post.
|
|
"""
|
|
permission_required = 'agenda.can_see_agenda'
|
|
template_name = 'agenda/overview.html'
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
context = super(Overview, self).get_context_data(**kwargs)
|
|
|
|
if self.request.user.has_perm('agenda.can_see_orga_items'):
|
|
items = Item.objects.all()
|
|
else:
|
|
items = Item.objects.filter(type__exact=Item.AGENDA_ITEM)
|
|
|
|
start = config['agenda_start_event_date_time']
|
|
if start is None or len(start) == 0:
|
|
start = None
|
|
else:
|
|
start = datetime.strptime(start, '%d.%m.%Y %H:%M')
|
|
|
|
duration = timedelta()
|
|
|
|
for item in items:
|
|
if not item.closed and len(item.duration) > 0:
|
|
duration_list = item.duration.split(':')
|
|
duration += timedelta(hours=int(duration_list[0]),
|
|
minutes=int(duration_list[1]))
|
|
if not start is None:
|
|
item.tooltip = start + duration
|
|
|
|
if start is None:
|
|
end = None
|
|
else:
|
|
end = start + duration
|
|
|
|
duration = u'%d:%02d' % ((duration.days * 24 + duration.seconds / 3600), (duration.seconds / 60 % 60))
|
|
|
|
context.update({
|
|
'items': items,
|
|
'active_sid': get_active_slide(only_sid=True),
|
|
'duration': duration,
|
|
'start': start,
|
|
'end': end,
|
|
})
|
|
return context
|
|
|
|
@transaction.commit_manually
|
|
def post(self, request, *args, **kwargs):
|
|
context = self.get_context_data(**kwargs)
|
|
if not request.user.has_perm('agenda.can_manage_agenda'):
|
|
messages.error(
|
|
request,
|
|
_('You are not authorized to manage the agenda.'))
|
|
return self.render_to_response(context)
|
|
transaction.commit()
|
|
for item in Item.objects.all():
|
|
form = ItemOrderForm(request.POST, prefix="i%d" % item.id)
|
|
if form.is_valid():
|
|
try:
|
|
parent = Item.objects.get(id=form.cleaned_data['parent'])
|
|
except Item.DoesNotExist:
|
|
parent = None
|
|
item.weight = form.cleaned_data['weight']
|
|
item.parent = parent
|
|
Model.save(item)
|
|
else:
|
|
transaction.rollback()
|
|
messages.error(
|
|
request, _('Errors when reordering of the agenda'))
|
|
return self.render_to_response(context)
|
|
Item.objects.rebuild()
|
|
# TODO: assure, that it is a valid tree
|
|
transaction.commit()
|
|
return self.render_to_response(context)
|
|
|
|
|
|
class View(DetailView):
|
|
"""
|
|
Show an agenda item.
|
|
"""
|
|
permission_required = 'agenda.can_see_agenda'
|
|
template_name = 'agenda/view.html'
|
|
model = Item
|
|
context_object_name = 'item'
|
|
|
|
|
|
class SetClosed(RedirectView, SingleObjectMixin):
|
|
"""
|
|
Close or open an item.
|
|
"""
|
|
permission_required = 'agenda.can_manage_agenda'
|
|
allow_ajax = True
|
|
url_name = 'item_overview'
|
|
model = Item
|
|
|
|
def get_ajax_context(self, **kwargs):
|
|
context = super(SetClosed, self).get_ajax_context(**kwargs)
|
|
closed = kwargs['closed']
|
|
if closed:
|
|
link = reverse('item_open', args=[self.object.id])
|
|
else:
|
|
link = reverse('item_close', args=[self.object.id])
|
|
context.update({
|
|
'closed': kwargs['closed'],
|
|
'link': link,
|
|
})
|
|
return context
|
|
|
|
def pre_redirect(self, request, *args, **kwargs):
|
|
self.object = self.get_object()
|
|
closed = kwargs['closed']
|
|
self.object.set_closed(closed)
|
|
return super(SetClosed, self).pre_redirect(request, *args, **kwargs)
|
|
|
|
|
|
class ItemUpdate(UpdateView):
|
|
"""
|
|
Update an existing item.
|
|
"""
|
|
permission_required = 'agenda.can_manage_agenda'
|
|
template_name = 'agenda/edit.html'
|
|
model = Item
|
|
context_object_name = 'item'
|
|
form_class = ItemForm
|
|
success_url_name = 'item_overview'
|
|
|
|
|
|
class ItemCreate(CreateView):
|
|
"""
|
|
Create a new item.
|
|
"""
|
|
permission_required = 'agenda.can_manage_agenda'
|
|
template_name = 'agenda/edit.html'
|
|
model = Item
|
|
context_object_name = 'item'
|
|
form_class = ItemForm
|
|
success_url_name = 'item_overview'
|
|
|
|
|
|
class ItemDelete(DeleteView):
|
|
"""
|
|
Delete an item.
|
|
"""
|
|
permission_required = 'agenda.can_manage_agenda'
|
|
model = Item
|
|
question_url_name = 'item_overview'
|
|
success_url_name = 'item_overview'
|
|
|
|
def get_answer_options(self):
|
|
if self.object.children.exists():
|
|
return [('all', _("Yes, with all child items."))] + self.answer_options
|
|
else:
|
|
return self.answer_options
|
|
|
|
def pre_post_redirect(self, request, *args, **kwargs):
|
|
if self.get_answer() == 'all':
|
|
self.object.delete(with_children=True)
|
|
messages.success(
|
|
request, _("Item %s and his children were successfully deleted.")
|
|
% html_strong(self.object))
|
|
elif self.get_answer() == 'yes':
|
|
self.object.delete(with_children=False)
|
|
messages.success(
|
|
request, _("Item %s was successfully deleted.")
|
|
% html_strong(self.object))
|
|
|
|
|
|
class AgendaPDF(PDFView):
|
|
"""
|
|
Create a full agenda-PDF.
|
|
"""
|
|
permission_required = 'agenda.can_see_agenda'
|
|
filename = ugettext_lazy('Agenda')
|
|
document_title = ugettext_lazy('Agenda')
|
|
|
|
def append_to_pdf(self, story):
|
|
for item in Item.objects.filter(type__exact=Item.AGENDA_ITEM):
|
|
ancestors = item.get_ancestors()
|
|
if ancestors:
|
|
space = " " * 6 * ancestors.count()
|
|
story.append(Paragraph(
|
|
"%s%s" % (space, item.get_title()),
|
|
stylesheet['Subitem']))
|
|
else:
|
|
story.append(Paragraph(item.get_title(), stylesheet['Item']))
|
|
|
|
class Config(FormView):
|
|
"""
|
|
Config page for the agenda app.
|
|
"""
|
|
permission_required = 'config.can_manage_config'
|
|
form_class = ConfigForm
|
|
template_name = 'agenda/config.html'
|
|
|
|
def get_initial(self):
|
|
return {
|
|
'agenda_start_event_date_time': config['agenda_start_event_date_time'],
|
|
}
|
|
|
|
def form_valid(self, form):
|
|
config['agenda_start_event_date_time'] = form.cleaned_data['agenda_start_event_date_time']
|
|
messages.success(self.request, _('Agenda settings successfully saved.'))
|
|
return super(Config, self).form_valid(form)
|
|
|
|
def register_tab(request):
|
|
"""
|
|
register the agenda tab.
|
|
"""
|
|
selected = request.path.startswith('/agenda/')
|
|
return Tab(
|
|
title=_('Agenda'),
|
|
app='agenda',
|
|
url=reverse('item_overview'),
|
|
permission=(request.user.has_perm('agenda.can_see_agenda') or
|
|
request.user.has_perm('agenda.can_manage_agenda')),
|
|
selected=selected)
|
|
|
|
|
|
def get_widgets(request):
|
|
"""
|
|
return the agenda widget for the projector-tab.
|
|
"""
|
|
return [Widget(
|
|
name='agenda',
|
|
display_name=_('Agenda'),
|
|
template='agenda/widget.html',
|
|
context={
|
|
'agenda': SLIDE['agenda'],
|
|
'items': Item.objects.all()},
|
|
permission_required='projector.can_manage_projector')]
|