Ajout de boutons permettant le contrôle de l'état d'une évolution
[OpenERP/cmmi.git] / evolution.py
index 3c68f5c..4921278 100644 (file)
@@ -31,7 +31,7 @@ class Evolution(osv.Model):
         "commentaire": fields.text(string="Commentaire"),
         "keywords": fields.text(string="Mots clés"),
         "priorite": fields.selection(_priorites, string="Priorité"),
-        "statut": fields.selection(_statuts, string="Statut"),
+        "state": fields.selection(_statuts, string="Statut"),
 #        "charges": fields.one2many("cmmi.evolution.charge", # Supprimé !
 #                                   "evolution_id",
 #                                   string="Charges"),
@@ -49,8 +49,105 @@ class Evolution(osv.Model):
                                      domain=_domains['human']),
     }
 
+    _defaults = {
+        "state": "cree",
+    }
 
-# ================================== PHASE ================================== #
+    def action_commencer(self, cr, uid, ids, context=None):
+        if type(ids) == list:
+            if len(ids) != 1:
+                return # TODO: message d'avertissement
+            ids = ids[0]
+
+        evo = self.read(cr, uid, ids, ['state'], context)
+
+        if evo['state'] != 'cree':
+            return
+        self.write(
+            cr,
+            uid,
+            ids,
+            {'state': 'encours'},
+            context,
+        )
+        return self
+
+    def action_suspendre(self, cr, uid, ids, context=None):
+        if type(ids) == list:
+            if len(ids) != 1:
+                return # TODO: message d'avertissement
+            ids = ids[0]
+
+        evo = self.read(cr, uid, ids, ['state'], context)
+        if evo['state'] != 'encours':
+            return
+        self.write(
+            cr,
+            uid,
+            ids,
+            {'state': 'suspendu'},
+            context,
+        )
+        return self
+
+    def action_terminer(self, cr, uid, ids, context=None):
+        if type(ids) == list:
+            if len(ids) != 1:
+                return # TODO: message d'avertissement
+            ids = ids[0]
+
+        evo = self.read(cr, uid, ids, ['state'], context)
+        if evo['state'] != 'encours':
+            return
+        self.write(
+            cr,
+            uid,
+            ids,
+            {'state': 'termine'},
+            context,
+        )
+        return self
+
+    def action_abandonner(self, cr, uid, ids, context=None):
+        if type(ids) == list:
+            if len(ids) != 1:
+                return # TODO: message d'avertissement
+            ids = ids[0]
+
+        evo = self.read(cr, uid, ids, ['state'], context)
+
+        if not ('encours', 'cree').__contains__(evo['state']):
+            return
+        self.write(
+            cr,
+            uid,
+            ids,
+            {'state': 'abandonne'},
+            context,
+        )
+        return self
+
+    def action_reprendre(self, cr, uid, ids, context=None):
+        if type(ids) == list:
+            if len(ids) != 1:
+                return # TODO: message d'avertissement
+            ids = ids[0]
+
+        evo = self.read(cr, uid, ids, ['state'], context)
+
+        if evo['state'] != 'suspendu':
+            return
+        self.write(
+            cr,
+            uid,
+            ids,
+            {'state': 'encours'},
+            context,
+        )
+        return self
+
+
+# =========================== EVOLUTION PHASE =============================== #
 class Phase(osv.Model):
     _name = "cmmi.evolution.phase"
 
@@ -100,7 +197,7 @@ class Phase(osv.Model):
         return osv.Model.create(self, cr, uid, vals, context=context)
 
 
-# ================================== CHARGE ================================= #
+# =========================== EVOLUTION CHARGE ============================== #
 class Charge(osv.Model):
     _name = "cmmi.evolution.charge"