#-*- coding: utf8 -*-
from openerp.osv import osv, fields
-from reportlab.lib.xmllib import _Name
-class TodoList(osv.Model):
- _name = "todolist.todolist"
- _status = [('draft', 'Brouillon'), ('pending', 'En cours'), ('done', 'Termine')]
+
+
+# ------------- CONTAINER ------------- #
+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 _tasks_progress(self, cr, uid, ids, field, arg, context=None):
+ result = {}
+ 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)
+ #================================================================================
+
+
+ def copy(self, cr, uid, id, default, context=None):
+ cr.execute("SELECT copierContainer (%s);", (id,))
+ return cr.fetchone()[0]
+
+
+ def _get_manday(self, cr, uid, ids, field, arg, context=None):
+ result={}
+ for container in self.browse(cr, uid, ids, context=context):
+ result[container.id] = sum([t.manday for t in container.tasks if t.state != "done"])
+ return result
+
+
+ _name = "todolist.container"
+
+ _inherit = "mail.thread"
+
+ _status = [("draft", "Draft"), ("pending", "Pending"), ("done", "Done")]
_columns = {
- "name": fields.char(string='Title', size=64, required=True),
+ "name": fields.char(string="Title", size=64, required=True),
"description": fields.text(string="Description"),
- "date_cible": fields.date(string='Cible'),
- "date_jalon": fields.date(string='Jalon'),
- "manday": fields.integer(string="Jours/homme"),
- "valide": fields.boolean(string='Validé'),
- "assigned": fields.many2one("res.partner", string="Assigné à", domain=[("is_company", "=", False)]),
+ "target": fields.date(string="Target", help="Target Date"),
+ "milestone": fields.date(string="Milestone", help="Due date"),
+ "manday": fields.function(_get_manday, type="integer", string="Man-Days"),
"state": fields.selection(_status, string="State", select=True),
- "actions": fields.one2many('todolist.action', 'todolist_id', string="Action"),
- "themes_id": fields.many2many('todolist.theme', 'todolist_todolist_theme_rel', 'todolist_id', 'theme_id', string='Thèmes', domain=[("actif", "=", True)]),
-
+ "tasks": fields.one2many("todolist.task", "container_id", string="Tasks"),
+ "topic_ids": fields.many2many("todolist.topic",
+ "todolist_container_topic_rel",
+ "todolist_ids",
+ "topic_ids",
+ string="Topics",
+ domain=[("activated", "=","Active")]),
+ "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 = {
_sql_constraints = [
(
- 'nom_de_la_contrainte',
- 'CHECK(name <> description)',
- 'Le nom doit être différent de la description',
+ "name_different_from_description_constraint",
+ "CHECK(name <> description)",
+ "Fields name and description should be different",
),
(
- 'cible_and_jalon_constraint',
- 'CHECK(date_cible < date_jalon)',
- 'La cible doit être inferieur au jalon',
+ "target_before_milestone_constraint",
+ "CHECK(target <= milestone)",
+ "The target date should be previous milestone date",
),
]
- def vider_description(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'description': ''}, context=context)
- return self
+ _order = "name"
def action_start(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'pending'}, context=context)
+ self.write(cr, uid, ids, {"state": "pending"}, context=context)
return self
def action_stop(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'done'}, context=context)
+ self.write(cr, uid, ids, {"state": "done"}, context=context)
return self
def action_restart(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'draft'}, context=context)
+ self.write(cr, uid, ids, {"state": "draft"}, 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)
+
+
+# ------------- TASK ------------- #
+class Task(osv.Model):
+ """TODO List : A task (something to do in a to do list)"""
-# ------------------- class Action ------------------- #
+ _name = "todolist.task"
-class Action(osv.Model):
- _name = "todolist.action"
+ _inherit = "mail.thread"
- _priorities = [('utile', 'Utile'), ('necessary', 'Nécéssaire'), ('indispensable', 'Indispensable')]
+ _priorities = [("Useful", "Useful"), ("Necessary", "Necessary"), ("Essential", "Essential")]
- _states = [('draft', 'Brouillon'), ('proposal', 'Proposition'), ('valid', 'Validé'), ('begin', 'Débute'), ('done', 'Terminé')]
+ _states = [("draft", "Draft"), ("proposal", "Proposal"), ("approved", "Approved"), ("started", "Started"), ("done", "Done")]
_columns = {
- "name": fields.char(string='Title', size=64, required=True),
- "description": fields.text(string='Description'),
- "deadline": fields.date(string='Jalon'),
- "planned": fields.date(string='Planifié'),
- "manday": fields.integer(string='Jours/homme'),
- "priority": fields.selection(_priorities, string='Priorite', select=True),
- "state": fields.selection(_states, string='State', select=True),
- "todolist_id": fields.many2one('todolist.todolist', string="TodoList", required=True),
+ "name": fields.char(string="Title", size=64, required=True),
+ "description": fields.text(string="Description"),
+ "planned": fields.date(string="Planed"),
+ "milestone": fields.date(string="Milestone", required=True),
+ "manday": fields.integer(string="Man-Days", required=True),
+ "priority": fields.selection(_priorities, string="Priority", select=True, required=True),
+ "state": fields.selection(_states, string="State", select=True),
+ "container_id": fields.many2one("todolist.container", string="To do list", required=True),
}
_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",
+ ),
+ (
+ "planned_before_milestone_constraint",
+ "CHECK(planned <= milestone)",
+ "The planned date should be previous milestone date",
+ ),
+ (
+ "manday_sup_0_constraint",
+ "CHECK(manday >= 0)",
+ "The manday should be positive",
+ ),
+ ]
+
+
def action_draft(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'draft'}, context=context)
+ self.write(cr, uid, ids, {"state": "draft"}, context=context)
return self
def action_propose(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'proposal'}, context=context)
+ self.write(cr, uid, ids, {"state": "proposal"}, context=context)
return self
- def action_validate(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'valid'}, context=context)
+ def action_approve(self, cr, uid, ids, context=None):
+ self.write(cr, uid, ids, {"state": "approved"}, context=context)
return self
- def action_begin(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'begin'}, context=context)
+ def action_start(self, cr, uid, ids, context=None):
+ self.write(cr, uid, ids, {"state": "started"}, context=context)
return self
def action_done(self, cr, uid, ids, context=None):
- self.write(cr, uid, ids, {'state': 'done'}, context=context)
+ self.write(cr, uid, ids, {"state": "done"}, context=context)
return self
+ #chaque utilisateur voit seulement ces taches
+ 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)
+
+ def write(self, cr, user, ids, vals, context=None):
+ if "milestone" in vals.keys():
+ for task in self.browse(cr, user, ids, context=context):
+ if task.container_id.milestone < vals["milestone"]:
+ vals["milestone"] = task.container_id.milestone
+ return osv.Model.write(self, cr, user, ids, vals, context)
-# ------------------- class Theme ------------------- #
+ def create(self, cr, user, vals, context=None):
+ container_model = self.pool.get("todolist.container")
+ container = container_model.read(cr, user, vals["container_id"], context=context)
+ milestone = container["milestone"]
+ if milestone < vals["milestone"]:
+ vals["milestone"] = milestone
+ return osv.Model.create(self, cr, user, vals, context=context)
-class Theme(osv.Model):
- _name = "todolist.theme"
+# ------------- TOPIC ------------- #
+class Topic(osv.Model):
+ """TODO List : Container"s Topic"""
- _states = [('Actif', 'Actif'), ('Inactif', 'Inactif')]
+ 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"
+
+ _inherit = "semantics.topic"
+
+ _states = [("Active", "Active"), ("Inactive", "Inactive")]
_columns = {
- "name": fields.char(string='Title', size=64, required=True),
- "description": fields.text(string='Description'),
- "actif": fields.selection(_states, string='Actif', select=True),
- "todolist_ids": fields.many2many('todolist.todolist', 'todolist_todolist_theme_rel', 'theme_id', 'todolist_id', string='TODO Listes'),
+ "activated": fields.selection(_states, string="State", select=True),
+ "todolist_ids": fields.many2many("todolist.container",
+ "todolist_container_topic_rel",
+ "topic_ids",
+ "todolist_ids",
+ 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 = {
- 'actif': 'actif'
- }
\ No newline at end of file
+ "activated": "Active",
+ }