Rushabh Mehta | 2886b95 | 2012-02-24 11:26:31 +0530 | [diff] [blame] | 1 | import webnotes |
| 2 | from webnotes.model.doc import Document |
| 3 | |
| 4 | @webnotes.whitelist() |
| 5 | def get(arg=None): |
| 6 | """get todo list""" |
| 7 | return webnotes.conn.sql("""select name, owner, description, date, |
| 8 | priority, checked, reference_type, reference_name, assigned_by |
| 9 | from `tabToDo Item` where owner=%s |
| 10 | order by field(priority, 'High', 'Medium', 'Low') asc, date asc""", |
| 11 | webnotes.session['user'], as_dict=1) |
| 12 | |
| 13 | @webnotes.whitelist() |
| 14 | def edit(arg=None): |
| 15 | args = webnotes.form_dict |
| 16 | |
| 17 | d = Document('ToDo Item', args.get('name') or None) |
| 18 | d.description = args['description'] |
| 19 | d.date = args['date'] |
| 20 | d.priority = args['priority'] |
| 21 | d.checked = args.get('checked', 0) |
| 22 | d.owner = webnotes.session['user'] |
| 23 | d.save(not args.get('name') and 1 or 0) |
| 24 | |
| 25 | if args.get('name') and d.checked: |
| 26 | notify_assignment(d) |
| 27 | |
| 28 | return d.name |
| 29 | |
| 30 | @webnotes.whitelist() |
| 31 | def delete(arg=None): |
| 32 | name = webnotes.form_dict['name'] |
| 33 | d = Document('ToDo Item', name) |
| 34 | if d and d.name: |
| 35 | notify_assignment(d) |
| 36 | webnotes.conn.sql("delete from `tabToDo Item` where name = %s", name) |
| 37 | |
| 38 | def notify_assignment(d): |
| 39 | doc_type = d.reference_type |
| 40 | doc_name = d.reference_name |
| 41 | assigned_by = d.assigned_by |
| 42 | |
| 43 | if doc_type and doc_name and assigned_by: |
| 44 | from webnotes.widgets.form import assign_to |
| 45 | assign_to.notify_assignment(assigned_by, d.owner, doc_type, doc_name) |
| 46 | |