- if parsed_url.path == app_config['prefix'] + '/calendar':
- params_to_encode += [('start', postvars['start'][0] if len(postvars['start'][0]) > 0 else '-')]
- params_to_encode += [('end', postvars['end'][0] if len(postvars['end'][0]) > 0 else '-')]
-
- elif parsed_url.path == app_config['prefix'] + '/todo':
- task_uuid = postvars['task_uuid'][0]
- date = postvars['date'][0]
- params_to_encode += [('task', task_uuid), ('date', date)]
- db.update_todo(task_uuid, date, postvars['day_effort'][0], 'done' in postvars.keys(), postvars['comment'][0], postvars['joined_day_tags'][0], collect_checked('day_tag_', postvars), postvars['importance'][0])
-
- elif parsed_url.path == app_config['prefix'] + '/task':
- id_ = postvars['id'][0]
- params_to_encode += [('id', id_)]
- if 'title' in postvars.keys():
- db.update_task(id_, postvars['title'][0], postvars['default_effort'][0], postvars['joined_tags'][0], collect_checked('tag_', postvars), collect_checked('link_', postvars))
-
- elif parsed_url.path == app_config['prefix'] + '/day':
- # always store the two hide params in the URL if possible … TODO: find out if really necessary
- if 'expect_unchosen_done' in postvars.keys():
- params_to_encode += [('hide_unchosen', int('hide_unchosen' in postvars.keys()))] + [('hide_done', int('hide_done' in postvars.keys()))]
-
- if 'selected_date' in postvars.keys():
- db.selected_date = postvars['selected_date'][0]
- if 'day_comment' in postvars.keys():
- db.selected_day.comment = postvars['day_comment'][0]
- params_to_encode += [('selected_date', db.selected_date)]
-
- # handle todo list updates via task UUIDs
- if 't_uuid' in postvars.keys():
- for i, uuid in enumerate(postvars['t_uuid']):
- task = db.tasks[uuid]
- old_todo = None if not uuid in db.selected_day.todos.keys() else db.selected_day.todos[uuid]
- selects_as_todo = 'choose' in postvars and uuid in postvars['choose']
- too_much_keepworthy_data = ('done' in postvars and uuid in postvars['done']) or postvars['day_effort'][i] != '' or (old_todo and not old_todo.internals_empty())
- if old_todo and too_much_keepworthy_data and not selects_as_todo:
- raise PlomException('cannot deselect task as todo of preserve-worthy values')
- elif old_todo and not selects_as_todo:
- del db.selected_day.todos[uuid]
+ if 'tasks' == site:
+ redir_params += [('search', postvars.get('search', ''))]
+
+ elif 'todo' == site:
+ todo_id = postvars.get('todo_id')
+ redir_params += [('id', todo_id)]
+ old_todo = db.todos[todo_id] if todo_id in db.todos.keys() else None
+ efforts = {}
+ latest_date = db.selected_date
+ for i, date in enumerate(postvars.get_all('effort_date', [])):
+ if '' == date:
+ continue
+ latest_date = date
+ efforts[date] = None
+ if not (old_todo and old_todo.deps):
+ efforts[date] = postvars.get_at_index('effort', i, on_empty=None,
+ float_if_possible=True)
+ if postvars.has('delete'):
+ has_day_effort = len([e for e in efforts.values() if e is not None]) > 0
+ if postvars.has('done')\
+ or postvars.get('comment')\
+ or postvars.get_all('tag', [])\
+ or has_day_effort:
+ raise PlomException('will not remove todo of preserve-worthy values')
+ db.delete_todo(todo_id)
+ postvars.set('return_to', 'calendar')
+ elif postvars.has('update'):
+ if postvars.has('delete_effort'):
+ for date in postvars.get_all('delete_effort'):
+ db.delete_effort(old_todo, date)
+ del efforts[date]
+ deps = [db.todos[id_] for id_ in postvars.get_all('adopt_dep', [])
+ if id_ in db.todos.keys()]
+ for dep in deps:
+ if not todo_id in [t.id_ for t in dep.dependers]:
+ dep.dependers += [db.todos[todo_id]]
+ birth_dep_ids = postvars.get_all('birth_dep', [])
+ for id_ in [id_ for id_ in birth_dep_ids if not id_ in db.tasks.keys()]:
+ raise PlomException('submitted illegal dep ID')
+ tasks_to_birth = [db.tasks[id_] for id_ in birth_dep_ids]
+ for task in tasks_to_birth:
+ deps += [db.add_todo(task=task, efforts={latest_date: None}, parenthood=todo_parenthood)]
+ db.update_todo(id_=todo_id,
+ efforts=efforts,
+ done=postvars.has('done'),
+ comment=postvars.get('comment', ''),
+ tags=postvars.get_all('tag', []),
+ importance=float(postvars.get('importance')),
+ deps=deps)
+
+ elif 'task' == site:
+ task_id = postvars.get('task_id')
+ if (postvars.has('delete') or postvars.has('fork')) and (not task_id in db.tasks.keys()):
+ if not task_id in db.tasks.keys():
+ raise PlomException('can only do this on Task that already exists')
+ if postvars.has('delete'):
+ if [t for t in db.todos.values() if task_id == t.task.id_]:
+ raise PlomException('will not remove Task describing existing Todos')
+ if postvars.get('title', '')\
+ or postvars.get_all('tag', [])\
+ or postvars.get_all('dep', [])\
+ or postvars.get('comment', ''):
+ raise PlomException('will not remove Task of preserve-worthy values')
+ db.delete_task(task_id)
+ elif postvars.has('update'):
+ dep_ids = postvars.get_all('dep', [])
+ for id_ in [id_ for id_ in dep_ids if not id_ in db.tasks.keys()]:
+ raise PlomException('submitted illegal dep ID')
+ depender_ids = postvars.get_all('depender', [])
+ for id_ in [id_ for id_ in depender_ids if not id_ in db.tasks.keys()]:
+ raise PlomException('submitted illegal dep ID')
+ task = db.update_task(
+ id_=task_id,
+ title=postvars.get('title', ''),
+ default_effort=postvars.get('default_effort', float_if_possible=True),
+ tags=postvars.get_all('tag', []),
+ comment=postvars.get('comment', ''),
+ dep_ids=dep_ids,
+ depender_ids=depender_ids)
+ if postvars.has('add_as_todo'):
+ db.add_todo(task=task, efforts={postvars.get('new_todo_date'): None})
+ elif postvars.has('fork'):
+ t = db.fork_task(task_id)
+ task_id = t.id_
+
+ # dep_ids = postvars.get_all('dep', [])
+ # for id_ in [id_ for id_ in dep_ids if not id_ in db.tasks.keys()]:
+ # raise PlomException('submitted illegal dep ID')
+ # depender_ids = postvars.get_all('depender', [])
+ # for id_ in [id_ for id_ in depender_ids if not id_ in db.tasks.keys()]:
+ # raise PlomException('submitted illegal dep ID')
+ # task = db.update_task(
+ # id_=task_id,
+ # title=postvars.get('title', ''),
+ # default_effort=postvars.get('default_effort', float_if_possible=True),
+ # tags=postvars.get_all('tag', []),
+ # comment=postvars.get('comment', ''),
+ # dep_ids=dep_ids,
+ # depender_ids=depender_ids)
+ # if postvars.has('add_as_todo'):
+ # db.add_todo(task=task, efforts={postvars.get('new_todo_date'): None})
+
+ redir_params += [('id', task_id)]
+
+ elif 'day_todos' == site:
+ if postvars.has('update'):
+ db.selected_date = postvars.get('date')
+ redir_params += [('date', db.selected_date)]
+ db.selected_day.comment = postvars.get('day_comment', '')
+ task_id = postvars.get('choose_task', None)
+ if task_id:
+ if task_id not in db.tasks.keys():
+ raise PlomException('illegal task ID entered')
+ db.add_todo(task=db.tasks[task_id], efforts={db.selected_date: None},
+ parenthood=todo_parenthood)
+ for id_ in postvars.get_all('choose_todo', []):
+ db.todos[id_].efforts[db.selected_date] = None
+ for i, todo_id in enumerate(postvars.get_all('todo_id', [])):
+ old_todo = db.todos[todo_id]
+ done = todo_id in postvars.get_all('done', [])
+ day_effort_input = postvars.get_at_index('effort', i, '')
+ day_effort = float(day_effort_input) if len(day_effort_input) > 0 else None
+ comment = postvars.get_at_index('effort_comment', i, '')
+ if (day_effort is not None) and (not done) and day_effort < 0 and 0 == len(comment):
+ if len(old_todo.efforts) > 1:
+ db.delete_effort(old_todo, db.selected_date)