Rajout de champs à la classe projet.evolution
[OpenERP/cmmi.git] / projet.py
1 #-*- coding: utf8 -*-
2 '''
3 '''
4
5 from openerp.osv import osv, fields
6 from gtk import TRUE
7
8 class Projet(osv.Model):
9     _name = "projet.projet"
10
11     _columns = {
12         "name": fields.char(string="Title", size=64, required=True),
13         "description": fields.text(string="Description"),
14         "domaines": fields.many2many("projet.domaine",
15                                      "projet_projet_domaine_rel",
16                                      "projets",
17                                      string="Domaines"),
18         "structures": fields.many2many("projet.structure",
19                                        "projet_projet_structure_rel",
20                                        "projets",
21                                        string="Structures"),
22         "team_members": fields.many2many("projet.teammember",
23                                          "projet_projet_teammember_rel",
24                                          "projets",
25                                          string="Team Members"),
26         "modules": fields.one2many("projet.module",
27                                    "projet_id",
28                                    string="Modules"),
29         "chantiers": fields.one2many("projet.chantier",
30                                      "projet_id",
31                                      string="Chantiers"),
32         "paliers": fields.one2many("projet.palier",
33                                    "projet_id",
34                                    string="Paliers"),
35         "phases": fields.one2many("projet.phase",
36                                    "projet_id",
37                                    string="Phases"),
38         "evolutions":fields.one2many("projet.evolution",
39                                      "projet_id",
40                                      string="Evolutions"),
41         "moe_id": fields.many2one("projet.moe", string="MoE", required=True),
42         "moa_id": fields.many2one("projet.moa", string="MoA", required=True),
43     }
44
45
46 class Evolution(osv.Model):
47     _name = "projet.evolution"
48
49     _priorites = [("incontournable", "Incontournable"),
50                   ("necessaire", "Nécéssaire"),
51                   ("utile", "Utile")]
52
53     _statuts = [("cree", "Crée"), ("encours", "En cours"),
54                 ("termine", "Terminé"), ("abandonne", "Abandonné"),
55                 ("suspendu", "Suspendu")]
56
57     _columns = {
58         "pid": fields.integer(string="PID"),
59         "name": fields.char(string="Title", size=64, required=True),
60         "description": fields.text(string="Description"),
61         "objectif": fields.text(string="Objectif"),
62         "commentaire": fields.text(string="Commentaire"),
63         "keywords": fields.text(string="Mots clés"),
64         "priorite": fields.selection(_priorites, string="Priorité"),
65         "statut": fields.selection(_statuts, string="Statut"),
66         "charges": fields.one2many("projet.charge",
67                                    "evolution_id",
68                                    string="Charges"),
69         "module_id": fields.many2one("projet.module",
70                                      string="Modules"),
71         "chantier_id": fields.many2one("projet.chantier",
72                                     string="Chantier"),
73         "palier_id": fields.many2one("projet.palier",
74                                      string="Palier"),
75         "phase_id": fields.many2one("projet.phase",
76                                     string="Phase"),
77         "projet_id": fields.many2one("projet.projet",
78                                      string="Projet")
79     }
80
81
82 class Structure(osv.Model):
83     _name = "projet.structure"
84
85     _statuts = [("actif", "Actif"), ("inactif", "Inactif")]
86
87     _columns = {
88         "name": fields.char(string="Title", size=64, required=True),
89         "code": fields.char(string="Code", size=8, required=True),
90         "description": fields.text(string="Description"),
91         "parent_id": fields.many2one("projet.structure", string="Parent_id"),
92         "statut": fields.selection(_statuts, string="Statut"),
93         "projets": fields.many2many("projet.projet",
94                                     "projet_projet_structure_rel",
95                                     "structures",
96                                     string="Projets"),
97     }
98
99
100 class Module(osv.Model):
101     _name = "projet.module"
102
103     _columns = {
104         "name": fields.char(string="Title", size=64, required=True),
105         "description": fields.text(string="Description"),
106         "projet_id": fields.many2one("projet.projet",
107                                      string="Projet",
108                                      required=True),
109         "evolutions": fields.one2many("projet.evolution",
110                                       "module_id",
111                                       string="Evolutions")
112     }
113
114
115 class Domaine(osv.Model):
116     _name = "projet.domaine"
117
118     _statuts = [("actif", "Actif"), ("inactif", "Inactif")]
119
120     _columns = {
121         "name": fields.char(string="Title", size=64, required=True),
122         "code": fields.char(string="Code", size=8),
123         "description": fields.text(string="Description"),
124         "ordre": fields.integer(string="Ordre"),
125         "parent_id": fields.many2one("projet.domaine", string="Parent_id"),
126         "statut": fields.selection(_statuts, string="Statut"),
127         "projets": fields.many2many("projet.projet",
128                                     "projet_projet_structure_rel",
129                                     "domaines",
130                                     string="Projets"),
131     }
132
133
134 class Teammember(osv.Model):
135     _name = "projet.teammember"
136
137     _inherit = "res.partner"
138
139     _columns = {
140         "projets": fields.many2many("projet.projet",
141                                     "projet_projet_teammember_rel",
142                                     "team_members",
143                                     string="Projets"),
144         "charges": fields.one2many("projet.projet",
145                                    "team_members",
146                                    string="Charges"),
147     }
148
149
150 class Phase(osv.Model):
151     _name = "projet.phase"
152
153     _statuts = [("actif", "Actif"), ("inactif", "Inactif")]
154
155
156     _columns = {
157         "name": fields.char(string="Title", size=64, required=True),
158         "description": fields.text(string="Description"),
159         "statut": fields.selection(_statuts, string="Statut"),
160         "projet_id": fields.many2one("projet.projet",
161                                      string="Projet",
162                                      required=True),
163         "charges": fields.one2many("projet.charge",
164                                    "phase_id",
165                                    string="Charges"),
166         "evolutions": fields.one2many("projet.evolution",
167                                       "phase_id",
168                                       string="Evolutions"),
169         "palier_id": fields.many2one("projet.palier",
170                                      string="Palier"),
171     }
172
173 #TODO trouver un nom a cette chose
174 class qqch(osv.Model):
175     _name = "projet.qqch"
176
177     _statuts = [("cree", "Crée"), ("encours", "En cours"),
178                 ("termine", "Terminé"), ("abandonne", "Abandonné"),
179                 ("suspendu", "Suspendu"), ("generique", "Générique")]
180
181     _columns = {
182         "name": fields.char(string="Title", size=64, required=True),
183         "description": fields.text(string="Description"),
184         "commentaire": fields.text(string="Commentaire"),
185         "statut": fields.selection(_statuts, string="Statut"),
186         "version": fields.char(string="Version", size=16),
187         "date_jalon": fields.date(sring="Jalon"),
188         "date_init_deb": fields.date(sring="Date initiale début"),
189         "date_init_fin": fields.date(sring="Date initiale de fin"),
190         "date_plan_deb": fields.date(string="Date plannifiée début"),
191         "date_plan_fin": fields.date(string="Date plannifiée de fin"),
192         "date_reel_deb": fields.date(string="Data réelle début"),
193         "date_reel_fin": fields.date(string="Data réelle fin"),
194     }
195
196     _sql_constraints = [
197         (
198             "date_init_deb_before_date_init_fin",
199             "CHECK(date_init_deb<> date_init_fin)",
200             "The date_init_deb should be previous date_init_fin",
201         ),
202         (
203             "date_plan_deb_before_date_plan_fin",
204             "CHECK(date_plan_deb <> date_plan_fin)",
205             "The date_plan_deb should be previous date_plan_fin",
206         ),
207         (
208             "date_reel_deb_before_date_reel_fin",
209             "CHECK(date_reel_deb<> date_reel_fin)",
210             "The date_reel_deb should be previous date_reel_fin",
211         ),
212     ]
213
214
215 class Chantier(osv.Model):
216     _name = "projet.chantier"
217
218     _inherit = "projet.qqch"
219
220     _columns = {
221         "projet_id": fields.many2one("projet.projet",
222                                      string="Projet",
223                                      required=True),
224         "evolutions": fields.one2many("projet.evolution",
225                                       "chantier_id",
226                                       string="Evolutions"),
227     }
228
229
230 class Palier(osv.Model):
231     _name = "projet.palier"
232
233     _types_palier = [("normal", "Normal"), ("exceptionnel", "Exceptionnel"), ("correctif", "Correctif"), ("autre", "Autre")]
234
235
236     _inherit = "projet.qqch"
237
238     _columns = {
239         "type_palier": fields.selection(_types_palier, string="Type"),
240         "projet_id": fields.many2one("projet.projet",
241                                      string="Projet",
242                                      required=True),
243         "evolutions": fields.one2many("projet.evolution",
244                                       "palier_id",
245                                       string="Evolutions"),
246         "phases": fields.one2many("projet.phase",
247                                   "palier_id",
248                                   string="Phases"),
249     }
250
251
252 class Charge(osv.Model):
253     _name = "projet.charge"
254
255     _columns = {
256         "name": fields.char(string="Title", size=64, required=True),
257         "description": fields.text(string="Description"),
258         "teammember_id": fields.many2one("projet.teammember",
259                                          string="Team Member",
260                                          required=True),
261         "phase_id": fields.many2one("projet.phase",
262                                     string="Phase",
263                                     required=True),
264         "evolution_id": fields.many2one("projet.evolution",
265                                     string="Evolution",
266                                     required=True),
267         "mo_id": fields.many2one("projet.mo",
268                                  string="Mo"),
269     }
270
271 class mo(osv.Model):
272     _name = "projet.mo"
273
274     _choses = [("primaire", "Primaire"),
275                ("secondaire", "Secondaire"),
276                ("generique", "Générique")]
277
278     _columns = {
279         "name": fields.char(string="Title"),
280         "description": fields.text(string="Description"),
281         "chose": fields.selection(_choses, string="Chose", required=True),
282         "charges": fields.one2many("projet.charge",
283                                    "mo_id",
284                                    string="Charges"),
285     }
286
287     _defaults = {
288         "chose": "generique"}
289
290
291 class moe(osv.Model):
292     _name = "projet.moe"
293     _inherit = "projet.mo"
294
295     _columns = {
296         "projets": fields.one2many("projet.projet",
297                                      "moe_id",
298                                      string="Projets"),
299     }
300
301
302 class moa(osv.Model):
303     _name= "projet.moa"
304     _inherit = "projet.mo"
305
306     _columns = {
307         "projets": fields.one2many("projet.projet",
308                                      "moa_id",
309                                      string="Projets"),
310     }