Liaison projet - domaine
authorSébastien CHAZALLET <s.chazallet@gmail.com>
Fri, 3 May 2013 11:54:00 +0000 (13:54 +0200)
committerSébastien CHAZALLET <s.chazallet@gmail.com>
Fri, 3 May 2013 11:54:00 +0000 (13:54 +0200)
projet.py
views/projet.xml

index 2b4d94a..7defaf7 100644 (file)
--- a/projet.py
+++ b/projet.py
@@ -17,8 +17,9 @@ class Projet(osv.Model):
     _columns = {
         "name": fields.char(string="Title", size=64, required=True),
         "description": fields.text(string="Description"),
-        "domaines": fields.many2many("cmmi.description.domaine",
-                                     string="Domaines"),
+        "domaines": fields.one2many("cmmi.projet.domaine",
+                                    "project_id",
+                                    string="Domaines"),
         "structures": fields.many2many("cmmi.mo.structure",
                                        string="Structures"),
         "structures_moe": fields.many2many("cmmi.mo.structure",
@@ -54,3 +55,31 @@ class Projet(osv.Model):
         "main_structure": fields.many2one("cmmi.mo.structure",
                                           string="Structure principale"),
     }
+
+
+class ProjetDomaine(osv.Model):
+
+    _name = "cmmi.projet.domaine"
+
+    def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
+        if isinstance(ids, (int, long)):
+            ids = [ids]
+        #return {i: r.domaine_id.name for i, r in
+        #        zip(ids, self.browse(cr, uid, ids, context=context))}
+        return dict([(i, r.domaine_id.name) for i, r in
+                zip(ids, self.browse(cr, uid, ids, context=context))])
+
+    def _set_name(self, cr, uid, _id, name, value, arg=None, context=None):
+        self.write(cr, uid, _id, {name: value}, context)
+
+    _columns = {
+        "name": fields.function(_get_name,
+                                type='char',
+                                store=True,
+                                string="Nom du domaine"),
+        "main": fields.boolean(string="Domaine principal ?"),
+        "project_id": fields.many2one("cmmi.projet",
+                                      string="Projet"),
+        "domaine_id": fields.many2one("cmmi.description.domaine",
+                                      string="Domaine"),
+    }
index 0aa0c20..b2d8144 100644 (file)
@@ -55,7 +55,7 @@
                                 <field name="domaines">
                                     <tree>
                                         <field name="name" />
-                                        <field name="description" />
+                                        <field name="main" />
                                     </tree>
                                 </field>
                             </page>