Corretion aux bugs du dernier commit + modification vue form évolution
[OpenERP/cmmi.git] / evolution.py
1 #-*- coding: utf8 -*-
2 '''
3 '''
4
5 from openerp.osv import osv, fields
6
7
8 # ================================ EVOLUTION ================================ #
9 class Evolution(osv.Model):
10     _name = "cmmi.evolution"
11
12     _description = "Table de reference des evolutions."
13
14     _domains = {
15         'human': [('is_company', '=', "False")],
16     }
17
18     _priorites = [("incontournable", "Incontournable"),
19                   ("necessaire", "Nécéssaire"),
20                   ("utile", "Utile")]
21
22     _statuts = [("cree", "Crée"), ("encours", "En cours"),
23                 ("termine", "Terminé"), ("abandonne", "Abandonné"),
24                 ("suspendu", "Suspendu")]
25
26
27     def _get_charge_init(self, cr, uid, ids, field, arg, context=None):
28         result = {}
29         for evo in self.browse(cr, uid, ids, context=context):
30             result[evo.id] = sum([p.charge_init for p in evo.phases])
31         return result
32
33
34     def _get_charge_plan(self, cr, uid, ids, field, arg, context=None):
35         result = {}
36         for evo in self.browse(cr, uid, ids, context=context):
37             result[evo.id] = sum([p.charge_plan for p in evo.phases])
38         return result
39
40
41     _columns = {
42         "pid": fields.integer(string="PID"),
43         "name": fields.char(string="Title", size=64, required=True),
44         "description": fields.text(string="Description"),
45         "objectif": fields.text(string="Objectif"),
46         "commentaire": fields.text(string="Commentaire"),
47         "keywords": fields.text(string="Mots clés"),
48         "priorite": fields.selection(_priorites, string="Priorité"),
49         "state": fields.selection(_statuts, string="Statut"),
50 #        "charges": fields.one2many("cmmi.evolution.charge", # Supprimé !
51 #                                   "evolution_id",
52 #                                   string="Charges"),
53         "phases": fields.one2many("cmmi.evolution.phase",
54                                   "evolution_id",
55                                   string="Phases"),
56         # Backrefs
57         "module_id": fields.many2one("cmmi.description.module",
58                                      string="Modules"),
59         "chantier_id": fields.many2one("cmmi.axes.chantier",
60                                        string="Chantier"),
61         "palier_id": fields.many2one("cmmi.axes.palier",
62                                      string="Palier"),
63         "projet_id": fields.many2one("cmmi.projet",
64                                      string="Projet"),
65         "demandeur": fields.many2one("res.partner",
66                                      string="Demandeur",
67                                      domain=_domains['human']),
68         # Functions
69         "charge_init": fields.function(_get_charge_init,
70                                        type="integer",
71                                        string="Charge initiale"),
72         "charge_plan": fields.function(_get_charge_plan,
73                                        type="integer",
74                                        string="Charge plannifiée"),
75     }
76
77     _defaults = {
78         "state": "cree",
79     }
80
81     def action_commencer(self, cr, uid, ids, context=None):
82         if type(ids) == list:
83             if len(ids) != 1:
84                 return # TODO: message d'avertissement
85             ids = ids[0]
86
87         evo = self.read(cr, uid, ids, ['state'], context)
88
89         if evo['state'] != 'cree':
90             return
91         self.write(
92             cr,
93             uid,
94             ids,
95             {'state': 'encours'},
96             context,
97         )
98         return self
99
100     def action_suspendre(self, cr, uid, ids, context=None):
101         if type(ids) == list:
102             if len(ids) != 1:
103                 return # TODO: message d'avertissement
104             ids = ids[0]
105
106         evo = self.read(cr, uid, ids, ['state'], context)
107         if evo['state'] != 'encours':
108             return
109         self.write(
110             cr,
111             uid,
112             ids,
113             {'state': 'suspendu'},
114             context,
115         )
116         return self
117
118     def action_terminer(self, cr, uid, ids, context=None):
119         if type(ids) == list:
120             if len(ids) != 1:
121                 return # TODO: message d'avertissement
122             ids = ids[0]
123
124         evo = self.read(cr, uid, ids, ['state'], context)
125         if evo['state'] != 'encours':
126             return
127         self.write(
128             cr,
129             uid,
130             ids,
131             {'state': 'termine'},
132             context,
133         )
134         return self
135
136     def action_abandonner(self, cr, uid, ids, context=None):
137         if type(ids) == list:
138             if len(ids) != 1:
139                 return # TODO: message d'avertissement
140             ids = ids[0]
141
142         evo = self.read(cr, uid, ids, ['state'], context)
143
144         if not ('encours', 'cree').__contains__(evo['state']):
145             return
146         self.write(
147             cr,
148             uid,
149             ids,
150             {'state': 'abandonne'},
151             context,
152         )
153         return self
154
155     def action_reprendre(self, cr, uid, ids, context=None):
156         if type(ids) == list:
157             if len(ids) != 1:
158                 return # TODO: message d'avertissement
159             ids = ids[0]
160
161         evo = self.read(cr, uid, ids, ['state'], context)
162
163         if evo['state'] != 'suspendu':
164             return
165         self.write(
166             cr,
167             uid,
168             ids,
169             {'state': 'encours'},
170             context,
171         )
172         return self
173
174
175 # =========================== EVOLUTION PHASE =============================== #
176 class Phase(osv.Model):
177     _name = "cmmi.evolution.phase"
178
179     _description = "Phase d'une evolution."
180
181     def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
182         if isinstance(ids, (int, long)):
183             ids = [ids]
184         return dict([(i, r.phase_id.name) for i, r in
185                 zip(ids, self.browse(cr, uid, ids, context=context))])
186
187
188     _columns = {
189         "name": fields.function(_get_name,
190                                 type='char',
191                                 store=True,
192                                 string="Nom de la phase"),
193         "description": fields.text(string="Description"),
194         "charge_init": fields.integer(string="Charge initiale"),
195         "charge_plan": fields.integer(string="Charge plannifiée"),
196         "phase_id": fields.many2one("cmmi.axes.palier.phase",
197                                     string="Phase"),
198         "evolution_id": fields.many2one("cmmi.evolution",
199                                         string="Evolution"),
200     }
201
202     def create(self, cr, uid, vals, context=None):
203         # TODO: gérer la création d'une phase d'évolution.
204         # Vérifier les valeurs contenues dans vals et les modifier / rajouter si nécessaire selon les cas suivants
205
206         # 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).
207         # Si commentaire est vide, alors par défaut, recopie du commentaire de ?
208         # Si version est vide, alors par dégaut, recopie de la version de ?
209 #        phase_model = self.pool.get("cmmi.axes.palier.phase")
210 #        evolution_model = self.pool.get("cmmi.evolution")
211 #
212 #        phase = phase_model.read(cr, vals["phase_id"], fields=None,context=None)
213 #        evolution = evolution_model.read(cr, vals["evolution_id"], fields=None,context=None)
214
215 #        if vals["description"] == "":
216 #            vals["description"] = "" + evolution["description"] + "\n" + phase["description"]
217
218 #        if vals["commentaire"] == "" # cmmi.evolution.phase n'a pas de commentaire
219 #            vals["commentaire"] = evolution["commentaire"]
220
221 #        if vals["version"] == "" # cmmi.evolution.phase n'a pas de version
222 #            vals["version"] = phase["version"]
223
224         return osv.Model.create(self, cr, uid, vals, context=context)
225
226     def commencer(self, cr, uid, ids, context=None):
227         if type(ids) == list:
228             if len(ids) != 1:
229                 return
230             ids = ids[0]
231
232         phase = self.read(cr, uid, ids, ['charge_plan'], context)
233
234         self.write(
235             cr,
236             uid,
237             ids, {
238                 'charge_init' : phase['charge_plan'],
239             },
240             context)
241         return self
242
243
244 # =========================== EVOLUTION CHARGE ============================== #
245 class Charge(osv.Model):
246     _name = "cmmi.evolution.charge"
247
248     _description = "Charge d'une evolution."
249
250     _columns = {
251         "name": fields.char(string="Title", size=64, required=True),
252         "description": fields.text(string="Description"),
253         "evolution_id": fields.many2one("cmmi.evolution",
254                                         string="Palier"),
255         "phase_id": fields.many2one("cmmi.evolution.phase",
256                                     string="Phase de l'évolution",
257                                     required=True),
258         "teammember_id": fields.many2one("res.partner", # TODO: Vers l'association teammember MO plutôt que MO.
259                                          string="Team Member",
260                                          required=True),
261     }