Merge branch 'master' of ssh://inspyration.org/~/OpenERP/cmmi
authorAlicia FLOREZ <alicflorez@gmail.com>
Thu, 23 May 2013 15:45:18 +0000 (17:45 +0200)
committerAlicia FLOREZ <alicflorez@gmail.com>
Thu, 23 May 2013 15:45:18 +0000 (17:45 +0200)
1  2 
projet.py

diff --combined projet.py
+++ b/projet.py
@@@ -9,25 -9,31 +9,31 @@@ class Projet(osv.Model)
  
      _name = "cmmi.projet"
  
-     _domains = {
-         'moe': [('role_mo_id.type_mo', '=', "MOE")],
-         'moa': [('role_mo_id.type_mo', '=', "MOA")],
-     }
+     def _get_main_domain(self, cr, uid, ids, field_name=None, arg=None, context=None):
+         if type(ids) in (int, float):
+             ids = [ids]
+         projects = self.browse(cr, uid, ids, context=context)
+         result = {}
+         for project in projects:
+             for domain in project.domains:
+                 if domain.main:
+                     result[project.id] = domain.name
+                     break
+             else:
+                 result[project.id] = "Any domain is selected as main domain yet"
+         return result
  
      _columns = {
          "name": fields.char(string="Title", size=64, required=True),
          "description": fields.text(string="Description"),
-         "domaines": fields.one2many("cmmi.projet.domaine",
+         "domains": fields.one2many("cmmi.projet.domaine",
                                      "project_id",
                                      string="Domaines"),
-         "structures": fields.many2many("cmmi.mo.structure",
-                                        string="Structures"),
-         "structures_moe": fields.many2many("cmmi.mo.structure",
-                                            string="Structures",
-                                            domain=_domains['moe']),
-         "structures_moa": fields.many2many("cmmi.mo.structure",
-                                            string="Structures",
-                                            domain=_domains['moa']),
          "team_members": fields.many2many("cmmi.partner.teammember",
                                           "cmmi_projet_teammember_rel",
                                           "projet_id",
          "evolutions": fields.one2many("cmmi.evolution",
                                        "projet_id",
                                        string="Evolutions"),
-         "moe_id": fields.many2one("cmmi.mo.moe", string="MoE", required=True),
-         "moa_id": fields.many2one("cmmi.mo.moa", string="MoA", required=True),
-         "main_domain": fields.many2one("cmmi.description.domaine",
+         "moe_ids": fields.one2many("cmmi.projet.moe",
+                                    "project_id",
+                                    string="MOEs"),
+         "moa_ids": fields.one2many("cmmi.projet.moa",
+                                    "project_id",
+                                    string="MOAs"),
+         "moe_id": fields.one2many("cmmi.projet.moe",
+                                   "project_id",
+                                   string="MOE principale",
+                                   domaine=[('main', '=', True)]),
+         "moa_id": fields.one2many("cmmi.projet.moa",
+                                   "project_id",
+                                   string="MOA principale",
+                                   domaine=[('main', '=', True)]),
+         "main_domain": fields.function(_get_main_domain,
+                                        type="string",
                                         string="Domaine principal"),
-         "main_structure": fields.many2one("cmmi.mo.structure",
-                                           string="Structure principale"),
      }
  
 +    def create(self, cr, uid, vals, context=None):
 +        project_id = osv.Model.create(self, cr, uid, vals, context=context)
 +
 +        # Récupération des ids de toutes les phases
 +        phase_model = self.pool.get("cmmi.phase")
 +        phases_ids = phase_model.search(cr, uid, [])
 +
 +        # Création des relations
 +        projet_phase_model = self.pool.get("cmmi.projet.phase")
 +        for phase_id in phases_ids:
 +            projet_phase_model.create(
 +                cr,
 +                uid,
 +                {
 +                    'projet_id': project_id,
 +                    'phase_id': phase_id,
 +                    'selectionne': False,
 +                }
 +            )
 +
 +        return project_id
 +
 +
      def action_add_domain(self, cr, uid, ids, context=None):
          pass
  
@@@ -161,16 -155,17 +178,19 @@@ class ProjetMoe(osv.Model)
                                  string="Nom de la MOE"),
          "main": fields.boolean(string="MOE principale ?"),
          "project_id": fields.many2one("cmmi.projet",
 -                                      string="Projet"),
 +                                      string="Projet",
 +                                      required=True),
          "moe_id": fields.many2one("cmmi.mo.moe",
 -                                      string="MOE"),
 +                                  string="MOE",
 +                                  required=True),
      }
  
+     def onchange_main(self, cr, uid, ids, project, moe, main, context=None):
+         pass
  
  class ProjetMoa(osv.Model):
-     _name = "cmmi.projet.moe"
+     _name = "cmmi.projet.moa"
  
      def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
          if isinstance(ids, (int, long)):
                                  string="Nom de la MOA"),
          "main": fields.boolean(string="MOA principale ?"),
          "project_id": fields.many2one("cmmi.projet",
 -                                      string="Projet"),
 +                                      string="Projet",
 +                                      required=True),
          "moa_id": fields.many2one("cmmi.mo.moa",
 -                                      string="MOA"),
 +                                  string="MOA",
 +                                  required=True),
      }
  
+     def onchange_main(self, cr, uid, ids, project, moa, main, context=None):
+         pass
  
  class ProjetPhase(osv.Model):
      _name = "cmmi.projet.phase"
                                  string="Nom de la phase"),
          "selectionne": fields.boolean(string="Phase sélectionnée ?"),
          "projet_id": fields.many2one("cmmi.projet",
 -                                     string="Projet"),
 +                                     string="Projet",
 +                                     required=True),
          "phase_id": fields.many2one("cmmi.phase",
 -                                    string="Phase"),
 +                                    string="Phase",
 +                                    required=True),
      }