Vérification de la milestone des taches a la creation
[OpenERP/todolist.git] / todolist.py
index cc15f7f..7eeb05c 100644 (file)
@@ -114,9 +114,9 @@ class Task(osv.Model):
         "name": fields.char(string="Title", size=64, required=True),
         "description": fields.text(string="Description"),
         "planned": fields.date(string="Planed"),
-        "milestone": fields.date(string="Milestone"),
-        "manday": fields.integer(string="Man-Days"),
-        "priority": fields.selection(_priorities, string="Priority", select=True),
+        "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),
     }
@@ -128,6 +128,25 @@ class Task(osv.Model):
 
     _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)
         return self
@@ -148,13 +167,28 @@ class Task(osv.Model):
         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)
 
+    def create(self, cr, user, vals, context=None):
+        import pdb; pdb.set_trace()
+        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 Topic(osv.Model):
@@ -206,3 +240,12 @@ class Topic(osv.Model):
     _defaults = {
         "activated": "Active",
     }
+
+
+    _sql_constraints = [
+        (
+            "name_different_from_description_constraint",
+            "CHECK(name <> description)",
+            "Fields name and description should be different",
+        ),
+    ]