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 def _get_charge_init(self, cr, uid, ids, field, arg, context=None):
29 for evo in self.browse(cr, uid, ids, context=context):
30 result[evo.id] = sum([p.charge_init for p in evo.phases])
34 def _get_charge_plan(self, cr, uid, ids, field, arg, context=None):
36 for evo in self.browse(cr, uid, ids, context=context):
37 result[evo.id] = sum([p.charge_plan for p in evo.phases])
40 def _get_charge_reel(self, cr, uid, ids, field, arg, context=None):
42 for e in self.browse(cr, uid, ids, context=context):
43 result[e.id] = sum([p.quantite for p in e.charge_reel])
48 "pid": fields.integer(string="PID"),
49 "name": fields.char(string="Title", size=64, required=True),
50 "description": fields.text(string="Description"),
51 "objectif": fields.text(string="Objectif"),
52 "commentaire": fields.text(string="Commentaire"),
53 "keywords": fields.text(string="Mots clés"),
54 "priorite": fields.selection(_priorites, string="Priorité"),
55 "state": fields.selection(_statuts, string="Statut"),
56 "phases": fields.one2many("cmmi.evolution.phase",
60 "module_id": fields.many2one("cmmi.description.module",
62 "chantier_id": fields.many2one("cmmi.axes.chantier",
64 "palier_id": fields.many2one("cmmi.axes.palier",
66 "projet_id": fields.many2one("cmmi.projet",
68 "demandeur": fields.many2one("res.partner",
70 domain=_domains['human']),
72 "charge_init": fields.function(_get_charge_init,
74 string="Charge initiale"),
75 "charge_plan": fields.function(_get_charge_plan,
77 string="Charge plannifiée"),
84 def action_commencer(self, cr, uid, ids, context=None):
87 return # TODO: message d'avertissement
90 evo = self.read(cr, uid, ids, ['state'], context)
92 if evo['state'] != 'cree':
103 def action_suspendre(self, cr, uid, ids, context=None):
104 if type(ids) == list:
106 return # TODO: message d'avertissement
109 evo = self.read(cr, uid, ids, ['state'], context)
110 if evo['state'] != 'encours':
116 {'state': 'suspendu'},
121 def action_terminer(self, cr, uid, ids, context=None):
122 if type(ids) == list:
124 return # TODO: message d'avertissement
127 evo = self.read(cr, uid, ids, ['state'], context)
128 if evo['state'] != 'encours':
134 {'state': 'termine'},
139 def action_abandonner(self, cr, uid, ids, context=None):
140 if type(ids) == list:
142 return # TODO: message d'avertissement
145 evo = self.read(cr, uid, ids, ['state'], context)
147 if not ('encours', 'cree').__contains__(evo['state']):
153 {'state': 'abandonne'},
158 def action_reprendre(self, cr, uid, ids, context=None):
159 if type(ids) == list:
161 return # TODO: message d'avertissement
164 evo = self.read(cr, uid, ids, ['state'], context)
166 if evo['state'] != 'suspendu':
172 {'state': 'encours'},
178 # =========================== EVOLUTION PHASE =============================== #
179 class Phase(osv.Model):
180 _name = "cmmi.evolution.phase"
182 _description = "Phase d'une evolution."
184 def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
185 if isinstance(ids, (int, long)):
187 return dict([(i, r.phase_id.name) for i, r in
188 zip(ids, self.browse(cr, uid, ids, context=context))])
192 "name": fields.function(_get_name,
195 string="Nom de la phase"),
196 "description": fields.text(string="Description"),
197 "charge_init": fields.integer(string="Charge initiale"),
198 "charge_plan": fields.integer(string="Charge plannifiée"),
199 "phase_id": fields.many2one("cmmi.axes.palier.phase",
201 "evolution_id": fields.many2one("cmmi.evolution",
205 def create(self, cr, uid, vals, context=None):
206 # TODO: gérer la création d'une phase d'évolution.
207 # Vérifier les valeurs contenues dans vals et les modifier / rajouter si nécessaire selon les cas suivants
209 # 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).
210 # Si commentaire est vide, alors par défaut, recopie du commentaire de ?
211 # Si version est vide, alors par dégaut, recopie de la version de ?
212 # phase_model = self.pool.get("cmmi.axes.palier.phase")
213 # evolution_model = self.pool.get("cmmi.evolution")
215 # phase = phase_model.read(cr, vals["phase_id"], fields=None,context=None)
216 # evolution = evolution_model.read(cr, vals["evolution_id"], fields=None,context=None)
218 # if vals["description"] == "":
219 # vals["description"] = "" + evolution["description"] + "\n" + phase["description"]
221 # if vals["commentaire"] == "" # cmmi.evolution.phase n'a pas de commentaire
222 # vals["commentaire"] = evolution["commentaire"]
224 # if vals["version"] == "" # cmmi.evolution.phase n'a pas de version
225 # vals["version"] = phase["version"]
227 return osv.Model.create(self, cr, uid, vals, context=context)
229 def commencer(self, cr, uid, ids, context=None):
230 if type(ids) == list:
235 phase = self.read(cr, uid, ids, ['charge_plan'], context)
241 'charge_init' : phase['charge_plan'],
247 # =========================== EVOLUTION CHARGE ============================== #
248 class Charge(osv.Model):
249 _name = "cmmi.evolution.charge"
251 _description = "Charge d'une evolution."
253 _selection_qte = [("0.25", "1/4"),
258 "name": fields.char(string="Title", size=64, required=True),
259 "description": fields.text(string="Description"),
260 "date": fields.date(string="Date"),
261 "quantite": fields.selection(_selection_qte, string="Quantité"),
262 "phase_id": fields.many2one("cmmi.evolution.phase",
263 string="Phase de l'évolution",
265 "teammember_id": fields.many2one("res.partner", # TODO: Vers l'association teammember MO plutôt que MO.
266 string="Team Member",