2 from flask import request, abort, redirect, url_for, flash, render_template
4 import sqlalchemy as sa
5 import wradmin.model as model
6 from wradmin.genshi import render_genshi_template, TemplateContext
9 class BerichtController:
11 def _add_dates_to_c(self, c, date_invalid):
12 now = datetime.datetime.today()
13 if date_invalid is None: date_invalid = now
15 c.date_no_change = date_invalid
16 c.date_tomorrow = now + datetime.timedelta(1)
17 c.date_one_week = now + datetime.timedelta(7)
18 c.date_two_weeks = now + datetime.timedelta(14)
19 c.date_one_week_more = date_invalid + datetime.timedelta(7)
20 c.date_end_of_saison = datetime.datetime(now.year if now.month < 7 else now.year + 1, 7, 1)
23 """Lists all reports"""
24 q = model.meta.Session.query(model.WrReport)
25 q = q.order_by(sa.sql.expression.desc(model.WrReport.id))
26 paginator = paginate.Page(q.all(), page=int(request.args.get('page', 1)),
27 url_maker=lambda page: url_for('bericht_list', page=page),
29 return render_template('bericht_list.html', paginator=paginator)
32 """Displays a report"""
33 q = model.meta.Session.query(model.WrReport)
35 c.wrreport = q.get(id)
36 if c.wrreport is None:
38 self._add_dates_to_c(c, c.wrreport.date_invalid)
39 return render_genshi_template('bericht_view.html', c=c)
41 def change_date_invalid(self, id=None):
42 assert request.method == 'POST'
45 wrreport_q = model.meta.Session.query(model.WrReport)
46 wrreport = wrreport_q.get(id)
50 self._add_dates_to_c(c, wrreport.date_invalid)
51 date = request.form['date_invalid']
52 if date == 'tomorrow': wrreport.date_invalid = c.date_tomorrow
53 elif date == 'one_week': wrreport.date_invalid = c.date_one_week
54 elif date == 'two_weeks': wrreport.date_invalid = c.date_two_weeks
55 elif date == 'one_week_more': wrreport.date_invalid = c.date_one_week_more
56 elif date == 'end_of_saison': wrreport.date_invalid = c.date_end_of_saison
57 elif date == 'now': wrreport.date_invalid = c.date_now
58 elif date == 'userdefined':
59 date_userdefined = request.form['date_userdefined']
61 date_userdefined = datetime.datetime.strptime(date_userdefined, '%Y-%m-%d %H:%M')
62 except ValueError as e:
64 return redirect(url_for('bericht_view', id=id))
65 wrreport.date_invalid = date_userdefined
66 model.meta.Session.commit()
67 flash('Datum wurde erfolgreich geƤndert')
68 return redirect(url_for('bericht_view', id=id))