5 from openerp.osv import osv, fields
8 # ================================ EVOLUTION ================================ #
9 class Evolution(osv.Model):
10 _name = "cmmi.evolution"
12 _description = "Table de reference des evolutions."
15 'human': [('is_company', '=', "False")],
18 _priorites = [("incontournable", "Incontournable"),
19 ("necessaire", "Nécéssaire"),
22 _statuts = [("cree", "Crée"), ("encours", "En cours"),
23 ("termine", "Terminé"), ("abandonne", "Abandonné"),
24 ("suspendu", "Suspendu")]
27 "pid": fields.integer(string="PID"),
28 "name": fields.char(string="Title", size=64, required=True),
29 "description": fields.text(string="Description"),
30 "objectif": fields.text(string="Objectif"),
31 "commentaire": fields.text(string="Commentaire"),
32 "keywords": fields.text(string="Mots clés"),
33 "priorite": fields.selection(_priorites, string="Priorité"),
34 "state": fields.selection(_statuts, string="Statut"),
35 # "charges": fields.one2many("cmmi.evolution.charge", # Supprimé !
39 "module_id": fields.many2one("cmmi.description.module",
41 "chantier_id": fields.many2one("cmmi.axes.chantier",
43 "palier_id": fields.many2one("cmmi.axes.palier",
45 "projet_id": fields.many2one("cmmi.projet",
47 "demandeur": fields.many2one("res.partner",
49 domain=_domains['human']),
56 def action_commencer(self, cr, uid, ids, context=None):
59 return # TODO: message d'avertissement
62 evo = self.read(cr, uid, ids, ['state'], context)
64 if evo['state'] != 'cree':
75 def action_suspendre(self, cr, uid, ids, context=None):
78 return # TODO: message d'avertissement
81 evo = self.read(cr, uid, ids, ['state'], context)
82 if evo['state'] != 'encours':
88 {'state': 'suspendu'},
93 def action_terminer(self, cr, uid, ids, context=None):
96 return # TODO: message d'avertissement
99 evo = self.read(cr, uid, ids, ['state'], context)
100 if evo['state'] != 'encours':
106 {'state': 'termine'},
111 def action_abandonner(self, cr, uid, ids, context=None):
112 if type(ids) == list:
114 return # TODO: message d'avertissement
117 evo = self.read(cr, uid, ids, ['state'], context)
119 if not ('encours', 'cree').__contains__(evo['state']):
125 {'state': 'abandonne'},
130 def action_reprendre(self, cr, uid, ids, context=None):
131 if type(ids) == list:
133 return # TODO: message d'avertissement
136 evo = self.read(cr, uid, ids, ['state'], context)
138 if evo['state'] != 'suspendu':
144 {'state': 'encours'},
150 # =========================== EVOLUTION PHASE =============================== #
151 class Phase(osv.Model):
152 _name = "cmmi.evolution.phase"
154 _description = "Phase d'une evolution."
156 def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
157 if isinstance(ids, (int, long)):
159 return dict([(i, r.phase_id.name) for i, r in
160 zip(ids, self.browse(cr, uid, ids, context=context))])
164 "name": fields.function(_get_name,
167 string="Nom de la phase"),
168 "description": fields.text(string="Description"),
169 "phase_id": fields.many2one("cmmi.axes.palier.phase",
171 "evolution_id": fields.many2one("cmmi.evolution",
175 def create(self, cr, uid, vals, context=None):
176 # TODO: gérer la création d'une phase d'évolution.
177 # Vérifier les valeurs contenues dans vals et les modifier / rajouter si nécessaire selon les cas suivants
179 # Si description est vide, alors par défaut, recopie de la description de l'evolution et de la phase (concaténés avec un retour à la ligne entre les deux).
180 # Si commentaire est vide, alors par défaut, recopie du commentaire de ?
181 # Si version est vide, alors par dégaut, recopie de la version de ?
182 # phase_model = self.pool.get("cmmi.axes.palier.phase")
183 # evolution_model = self.pool.get("cmmi.evolution")
185 # phase = phase_model.read(cr, vals["phase_id"], fields=None,context=None)
186 # evolution = evolution_model.read(cr, vals["evolution_id"], fields=None,context=None)
188 # if vals["description"] == "":
189 # vals["description"] = "" + evolution["description"] + "\n" + phase["description"]
191 # if vals["commentaire"] == "" # cmmi.evolution.phase n'a pas de commentaire
192 # vals["commentaire"] = evolution["commentaire"]
194 # if vals["version"] == "" # cmmi.evolution.phase n'a pas de version
195 # vals["version"] = phase["version"]
197 return osv.Model.create(self, cr, uid, vals, context=context)
200 # =========================== EVOLUTION CHARGE ============================== #
201 class Charge(osv.Model):
202 _name = "cmmi.evolution.charge"
204 _description = "Charge d'une evolution."
207 "name": fields.char(string="Title", size=64, required=True),
208 "description": fields.text(string="Description"),
209 "evolution_id": fields.many2one("cmmi.evolution",
211 "phase_id": fields.many2one("cmmi.evolution.phase",
212 string="Phase de l'évolution",
214 "teammember_id": fields.many2one("res.partner", # TODO: Vers l'association teammember MO plutôt que MO.
215 string="Team Member",