class Container(osv.Model):
"""TODO List : Tasks container"""
+ def _get_nb_tasks(self, cr, uid, ids, field, arg, context=None):
+ result = {}
+ for container in self.browse(cr, uid, ids, context=context):
+ result[container.id] = len(container.tasks)
+ return result
+# OR : return dict((c.id, len(c.tasks)) for c in self.browse(cr, uid, ids, context=context))
+
+
+ def _get_nb_tasks_done(self, cr, uid, ids, field, arg, context=None):
+ result={}
+ for c in self.browse(cr, uid, ids, context=context):
+ result[c.id] = len([t for t in c.tasks if t.state == "done"])
+ return result
+
- def _get_nb_task(self, cr, uid, ids, field, arg, context=None):
+ def _tasks_progress(self, cr, uid, ids, field, arg, context=None):
result = {}
- for tasks in self.browse(cr, uid, ids, context=context):
- result[tasks.id] = len(tasks.tasks)
+ for c in self.browse(cr, uid, ids, context=context):
+ result[c.id] = c.number_tasks and c.number_tasks_done*100./c.number_tasks or 0.
return result
+ def copy(self, cr, uid, id, default, context=None):
+ container = self.browse(cr, uid, id, context=context)
+ new_name = "Copy of %s" % container.name
+ # =like is the original LIKE operator from SQL
+ others_count = self.search(cr, uid, [('name', '=like', new_name+'%')],
+ count=True, context=context)
+ if others_count > 0:
+ new_name = "%s (%s)" % (new_name, others_count+1)
+ default['name'] = new_name
+ return osv.Model.copy(self, cr, uid, id, default, context=context)
+
+
_name = "todolist.container"
_status = [("draft", "Draft"), ("pending", "Pending"), ("done", "Done")]
"state": fields.selection(_status, string="State", select=True),
"tasks": fields.one2many("todolist.task", "container_id", string="Tasks"),
"topics_id": fields.many2many("todolist.topic", "todolist_container_topic_rel", "container_id", "topic_id", string="Topics", domain=[("activated", "=","Active")]),
- "number_tasks": fields.function(_get_nb_task, type="integer", string="Number of tasks"),
+ "number_tasks": fields.function(_get_nb_tasks, type="integer", string="Number of tasks"),
+ "number_tasks_done": fields.function(_get_nb_tasks_done, type="integer", string="Number of tasks done"),
+ "progress_tasks": fields.function(_tasks_progress, type="float", string="Progression"),
}
_defaults = {
),
]
+ _order = "name"
+
def action_start(self, cr, uid, ids, context=None):
self.write(cr, uid, ids, {"state": "pending"}, context=context)
return self
return self
+ def search(self, cr, user, args=[], offset=0, limit=None, order=None, context=None, count=False):
+ args.append(("create_uid", "=", user))
+ if len(args) != 1:
+ args.insert(0, "&")
+ return osv.Model.search(self, cr, user, args, offset, limit, order, context, count)
class Task(osv.Model):
_name = "todolist.task"
- _priorities = [("useful", "Useful"), ("necessary", "Necessary"), ("essential", "Essential")]
+ _priorities = [("Useful", "Useful"), ("Necessary", "Necessary"), ("Essential", "Essential")]
_states = [("draft", "Draft"), ("proposal", "Proposal"), ("approved", "Approved"), ("started", "Started"), ("done", "Done")]
}
_defaults = {
- "state": "draft"
+ "state": "draft",
+ "priority": "useful"
}
+ _order = "planned"
+
+ _sql_constraints = [
+ (
+ "name_different_from_description_constraint",
+ "CHECK(name <> description)",
+ "Fields name and description should be different",
+ ),
+ ]
+
+
def action_draft(self, cr, uid, ids, context=None):
self.write(cr, uid, ids, {"state": "draft"}, context=context)
return self
self.write(cr, uid, ids, {"state": "done"}, context=context)
return self
+ def search(self, cr, user, args=[], offset=0, limit=None, order=None, context=None, count=False):
+ args.append(("create_uid", "=", user))
+ if len(args) != 1:
+ args.insert(0, "&")
+ return osv.Model.search(self, cr, user, args, offset, limit, order, context, count)
+
+
-# ------------------- class Theme ------------------- #
class Topic(osv.Model):
"""TODO List : Container"s Topic"""
+ def _get_nb_lists(self, cr, uid, ids, field, arg, context=None):
+ result = {}
+ for topic in self.browse(cr, uid, ids, context=context):
+ result[topic.id] = len(topic.todolist_ids)
+ return result
+
+
+ def _get_number_tasks(self, cr, uid, ids, field, arg, context=None):
+ result = {}
+ for topic in self.browse(cr, uid, ids, context=context):
+ result[topic.id] = sum([t.number_tasks for t in topic.todolist_ids])
+ return result
+
+
+ def _get_number_tasks_done(self, cr, uid, ids, field, arg, context=None):
+ result = {}
+ for topic in self.browse(cr, uid, ids, context=context):
+ result[topic.id] = sum([t.number_tasks_done for t in topic.todolist_ids])
+ return result
+
+
+ def _progress_tasks(self, cr, uid, ids, field, arg, context=None):
+ result = {}
+ for t in self.browse(cr, uid, ids, context=context):
+ result[t.id] = t.number_tasks and t.number_tasks_done*100./t.number_tasks or 0.
+ return result
+
+
_name = "todolist.topic"
_states = [("Active", "Active"), ("Inactive", "Inactive")]
"description": fields.text(string="Description"),
"activated": fields.selection(_states, string="State", select=True),
"todolist_ids": fields.many2many("todolist.container", "todolist_container_topic_rel", "topic_id", "Container_id", string="TO DO Lists"),
+ "nb_lists": fields.function(_get_nb_lists, type="integer", string="Number of lists"),
+ "number_tasks": fields.function(_get_number_tasks, type="integer", string="Number of tasks"),
+ "number_tasks_done": fields.function(_get_number_tasks_done, type="integer", string="Number of tasks done"),
+ "progress_tasks": fields.function(_progress_tasks, type="float", string="Number of lists"),
}
_defaults = {
"activated": "Active",
}
+
+
+ _sql_constraints = [
+ (
+ "name_different_from_description_constraint",
+ "CHECK(name <> description)",
+ "Fields name and description should be different",
+ ),
+ ]